forked from verdnatura/hedera-web
New longName/tags system, bigger images on zoom
This commit is contained in:
parent
1395532b6c
commit
acd0a0025e
|
@ -1,4 +1,4 @@
|
|||
hedera-web (1.406.13) stable; urgency=low
|
||||
hedera-web (1.406.14) stable; urgency=low
|
||||
|
||||
* Initial Release.
|
||||
|
||||
|
|
|
@ -15,11 +15,11 @@
|
|||
<htk-repeater form-id="iter" empty-message="_Enter a search term">
|
||||
<db-model property="model">
|
||||
<custom>
|
||||
SELECT Id_Article, Article, Medida, Categoria, Foto
|
||||
FROM vn2008.Articles
|
||||
WHERE Article LIKE CONCAT('%', #filter, '%')
|
||||
OR Id_Article = #filter
|
||||
ORDER BY Article LIMIT 50
|
||||
SELECT id, longName, size, category, image
|
||||
FROM vn.item
|
||||
WHERE longName LIKE CONCAT('%', #filter, '%')
|
||||
OR id = #filter
|
||||
ORDER BY longName LIMIT 50
|
||||
</custom>
|
||||
<sql-batch property="batch">
|
||||
<custom>
|
||||
|
@ -31,23 +31,23 @@
|
|||
<div class="row">
|
||||
<htk-image
|
||||
form="iter"
|
||||
column="Foto"
|
||||
column="image"
|
||||
class="photo"
|
||||
directory="catalog"
|
||||
subdir="200x200"
|
||||
full-dir="900x900"
|
||||
full-dir="1600x900"
|
||||
editable="true"
|
||||
conn="conn"/>
|
||||
<p class="concept">
|
||||
<htk-text form="iter" column="Article"/>
|
||||
<htk-text form="iter" column="Medida"/>
|
||||
<htk-text form="iter" column="Categoria"/>
|
||||
<htk-text form="iter" column="longName"/>
|
||||
<htk-text form="iter" column="size"/>
|
||||
<htk-text form="iter" column="category"/>
|
||||
</p>
|
||||
<p>
|
||||
<htk-text form="iter" column="Id_Article"/>
|
||||
<htk-text form="iter" column="id"/>
|
||||
</p>
|
||||
<p>
|
||||
<htk-text form="iter" column="Foto"/>
|
||||
<htk-text form="iter" column="image"/>
|
||||
</p>
|
||||
<div class="clear"/>
|
||||
</div>
|
||||
|
|
|
@ -29,11 +29,10 @@
|
|||
<div class="lines">
|
||||
<htk-repeater form-id="iter" renderer="repeaterFunc">
|
||||
<db-model id="items" property="model" updatable="true">
|
||||
SELECT bi.id, bi.amount, bi.price, i.name item, i.image,
|
||||
t.tag1, t.val1, t.tag2, t.val2, t.tag3, t.val3
|
||||
SELECT bi.id, bi.amount, bi.price, i.longName item, i.image,
|
||||
i.tag5, i.value5, i.tag6, i.value6, i.tag7, i.value7
|
||||
FROM myBasketItem bi
|
||||
JOIN vn.item i ON i.id = bi.itemFk
|
||||
LEFT JOIN vn.itemTagArranged t ON t.itemFk = i.id
|
||||
</db-model>
|
||||
<custom>
|
||||
<div class="line">
|
||||
|
@ -50,18 +49,18 @@
|
|||
class="photo"
|
||||
directory="catalog"
|
||||
subdir="200x200"
|
||||
full-dir="900x900"/>
|
||||
full-dir="1600x900"/>
|
||||
<div class="info">
|
||||
<h2>
|
||||
<htk-text form="iter" column="item"/>
|
||||
</h2>
|
||||
<p class="tags">
|
||||
<htk-text form="iter" column="tag1"/>
|
||||
<htk-text form="iter" column="val1"/>,
|
||||
<htk-text form="iter" column="tag2"/>
|
||||
<htk-text form="iter" column="val2"/>,
|
||||
<htk-text form="iter" column="tag3"/>
|
||||
<htk-text form="iter" column="val3"/>
|
||||
<htk-text form="iter" column="tag5"/>
|
||||
<htk-text form="iter" column="value5"/>,
|
||||
<htk-text form="iter" column="tag6"/>
|
||||
<htk-text form="iter" column="value6"/>,
|
||||
<htk-text form="iter" column="tag7"/>
|
||||
<htk-text form="iter" column="value7"/>
|
||||
</p>
|
||||
<p class="amount">
|
||||
<htk-text form="iter" column="amount"/> x
|
||||
|
|
|
@ -188,7 +188,7 @@
|
|||
white-space: nowrap;
|
||||
overflow: hidden;
|
||||
}
|
||||
.item-info .producer
|
||||
.item-info .sub-name
|
||||
{
|
||||
text-transform: uppercase;
|
||||
font-weight: bold;
|
||||
|
@ -201,95 +201,26 @@
|
|||
position: absolute;
|
||||
bottom: 0;
|
||||
}
|
||||
.catalog .item-info > .htk-button
|
||||
.item-info > .htk-button
|
||||
{
|
||||
margin: -0.3em;
|
||||
padding: .3em;
|
||||
}
|
||||
.catalog .item-info > .htk-button > img
|
||||
.item-info > .htk-button > img
|
||||
{
|
||||
vertical-align: middle;
|
||||
}
|
||||
|
||||
/* Card */
|
||||
|
||||
|
||||
.card-popup
|
||||
.tags
|
||||
{
|
||||
overflow: auto;
|
||||
}
|
||||
.item-card
|
||||
{
|
||||
font-size: .9em;
|
||||
width: 20em;
|
||||
}
|
||||
.item-card .top
|
||||
{
|
||||
padding: 1em;
|
||||
}
|
||||
.item-card .item-info
|
||||
{
|
||||
margin-left: 9em;
|
||||
height: 8em;
|
||||
}
|
||||
.item-card .htk-image
|
||||
{
|
||||
height: 8em;
|
||||
width: 8em;
|
||||
float: left;
|
||||
border-radius: .3em;
|
||||
}
|
||||
.item-card .desc
|
||||
{
|
||||
clear: both;
|
||||
font-size: .8em;
|
||||
display: table;
|
||||
color: #333;
|
||||
margin: 0;
|
||||
margin-top: 1em;
|
||||
font-size: .9em;
|
||||
width: auto;
|
||||
}
|
||||
.item-card .tags
|
||||
{
|
||||
font-size: .9em;
|
||||
color: #777;
|
||||
margin: 0;
|
||||
padding-top: .5em;
|
||||
}
|
||||
.item-card .tags p
|
||||
{
|
||||
margin: 0;
|
||||
}
|
||||
.item-card .lots-grid
|
||||
{
|
||||
border-top: 1px solid #DDD;
|
||||
}
|
||||
.item-card .lots-grid tr
|
||||
{
|
||||
height: 3em;
|
||||
}
|
||||
.item-card .footer
|
||||
{
|
||||
text-align: center;
|
||||
background-color: #009688;
|
||||
color: white;
|
||||
line-height: 2em;
|
||||
padding: .4em;
|
||||
}
|
||||
.item-card .footer > button
|
||||
{
|
||||
margin: 0;
|
||||
}
|
||||
.item-card .erase
|
||||
{
|
||||
float: left;
|
||||
}
|
||||
.item-card .confirm
|
||||
{
|
||||
float: right;
|
||||
}
|
||||
.item-card .erase > img,
|
||||
.item-card .confirm > img
|
||||
{
|
||||
display: block;
|
||||
height: 1em;
|
||||
.tags td:first-child {
|
||||
color: #999;
|
||||
padding-right: .6em;
|
||||
}
|
||||
|
||||
/* List view */
|
||||
|
@ -353,6 +284,10 @@
|
|||
{
|
||||
margin-right: 0;
|
||||
}
|
||||
.list-view .item-info .tags .extra
|
||||
{
|
||||
display: none;
|
||||
}
|
||||
|
||||
/* Grid view */
|
||||
|
||||
|
@ -404,6 +339,86 @@
|
|||
{
|
||||
float: right;
|
||||
}
|
||||
.grid-view .item-info .tags
|
||||
{
|
||||
position: absolute;
|
||||
top: 4em;
|
||||
}
|
||||
.grid-view .item-info .tags td {
|
||||
overflow: hidden;
|
||||
white-space: nowrap;
|
||||
text-overflow: ellipsis;
|
||||
max-width: 6em;
|
||||
width: 6em;
|
||||
}
|
||||
|
||||
/* Card */
|
||||
|
||||
.card-popup
|
||||
{
|
||||
overflow: auto;
|
||||
}
|
||||
.item-card
|
||||
{
|
||||
font-size: .9em;
|
||||
width: 20em;
|
||||
}
|
||||
.item-card .top
|
||||
{
|
||||
padding: 1em;
|
||||
}
|
||||
.item-card .item-info
|
||||
{
|
||||
margin-left: 9em;
|
||||
height: 8em;
|
||||
}
|
||||
.item-card .htk-image
|
||||
{
|
||||
height: 8em;
|
||||
width: 8em;
|
||||
float: left;
|
||||
border-radius: .3em;
|
||||
}
|
||||
.item-card .desc
|
||||
{
|
||||
clear: both;
|
||||
margin-top: 1em 0;
|
||||
font-size: .9em;
|
||||
}
|
||||
.item-card .lots-grid
|
||||
{
|
||||
border-top: 1px solid #DDD;
|
||||
}
|
||||
.item-card .lots-grid tr
|
||||
{
|
||||
height: 3em;
|
||||
}
|
||||
.item-card .footer
|
||||
{
|
||||
text-align: center;
|
||||
background-color: #009688;
|
||||
color: white;
|
||||
line-height: 2em;
|
||||
padding: .4em;
|
||||
}
|
||||
.item-card .footer > button
|
||||
{
|
||||
margin: 0;
|
||||
}
|
||||
.item-card .erase
|
||||
{
|
||||
float: left;
|
||||
}
|
||||
.item-card .confirm
|
||||
{
|
||||
float: right;
|
||||
}
|
||||
.item-card .erase > img,
|
||||
.item-card .confirm > img
|
||||
{
|
||||
display: block;
|
||||
height: 1em;
|
||||
}
|
||||
|
||||
/* Mobile */
|
||||
|
||||
|
|
|
@ -20,7 +20,7 @@
|
|||
<sql-value id="type-value"/>
|
||||
</sql-filter-item>
|
||||
<sql-filter-item type="LIKE" id="op-name">
|
||||
<sql-field target="i" name="name"/>
|
||||
<sql-field target="i" name="longName"/>
|
||||
<sql-search-tags param="search"/>
|
||||
</sql-filter-item>
|
||||
<sql-filter-item type="EQUAL" id="op-color">
|
||||
|
@ -60,16 +60,11 @@
|
|||
JOIN vn.itemType t ON t.id = i.typeFk
|
||||
WHERE #filter;
|
||||
CALL bionic_calc;
|
||||
SELECT i.id, i.description, i.image, i.name item, i.category, i.size,
|
||||
b.producer, b.available, b.price,
|
||||
IF(i.stems > 1, i.stems, NULL) stems, c.name color, o.name origin,
|
||||
t.tag1, t.val1, t.tag2, t.val2, t.tag3, t.val3
|
||||
SELECT i.id, i.description, i.image, i.longName item,
|
||||
i.subName, i.tag5, i.value5, i.tag6, i.value6, i.tag7, i.value7,
|
||||
b.available, b.price
|
||||
FROM tmp.bionic_item b
|
||||
JOIN vn.item i ON i.id = b.item_id
|
||||
LEFT JOIN vn.itemTagArranged t ON t.itemFk = i.id
|
||||
LEFT JOIN vn.producer p ON p.id = i.producerFk
|
||||
LEFT JOIN vn.inkL10n c ON c.id = i.inkFk
|
||||
LEFT JOIN vn.originL10n o ON o.id = i.originFk
|
||||
WHERE b.available > 0
|
||||
ORDER BY i.relevancy DESC, i.name, i.size
|
||||
LIMIT 400;
|
||||
|
@ -118,7 +113,7 @@
|
|||
subdir="200x200"
|
||||
form="item"
|
||||
column="image"
|
||||
full-dir="900x900"/>
|
||||
full-dir="1600x900"/>
|
||||
<div class="item-info">
|
||||
<htk-button
|
||||
form="item"
|
||||
|
@ -130,19 +125,23 @@
|
|||
<h2>
|
||||
<htk-text form="item" column="item"/>
|
||||
</h2>
|
||||
<p class="producer">
|
||||
<htk-text form="item" column="producer"/>
|
||||
</p>
|
||||
<p>
|
||||
<htk-text form="item" column="tag1"/> <htk-text form="item" column="val1"/>,
|
||||
<htk-text form="item" column="tag2"/> <htk-text form="item" column="val2"/>
|
||||
</p>
|
||||
<p class="color">
|
||||
<htk-text form="item" column="tag3"/> <htk-text form="item" column="val3"/>
|
||||
</p>
|
||||
<p class="color">
|
||||
<htk-text form="item" column="stems" format="_%.0d Units"/>
|
||||
<p class="sub-name">
|
||||
<htk-text form="item" column="subName"/>
|
||||
</p>
|
||||
<table class="tags">
|
||||
<tr>
|
||||
<td><htk-text form="item" column="tag5"/></td>
|
||||
<td><htk-text form="item" column="value5"/></td>
|
||||
</tr>
|
||||
<tr class="extra">
|
||||
<td><htk-text form="item" column="tag6"/></td>
|
||||
<td><htk-text form="item" column="value6"/></td>
|
||||
</tr>
|
||||
<tr class="extra">
|
||||
<td><htk-text form="item" column="tag7"/></td>
|
||||
<td><htk-text form="item" column="value7"/></td>
|
||||
</tr>
|
||||
</table>
|
||||
<div class="aval-price">
|
||||
<htk-text form="item" column="available"/>
|
||||
<span class="from">
|
||||
|
@ -386,15 +385,15 @@
|
|||
subdir="200x200"
|
||||
form="card"
|
||||
column="image"
|
||||
full-dir="900x900"
|
||||
full-dir="1600x900"
|
||||
conn="conn"
|
||||
editable="true"/>
|
||||
<div class="item-info">
|
||||
<h2>
|
||||
<htk-text form="card" column="item"/>
|
||||
</h2>
|
||||
<p class="producer">
|
||||
<htk-text form="card" column="producer"/>
|
||||
<p class="sub-name">
|
||||
<htk-text form="card" column="subName"/>
|
||||
</p>
|
||||
<p>
|
||||
@<htk-text form="card" column="id"/>
|
||||
|
@ -416,12 +415,14 @@
|
|||
JOIN vn.tag t ON t.id = it.tagFk
|
||||
JOIN vn.tagL10n l ON l.id = t.id
|
||||
WHERE it.itemFk = #item
|
||||
AND priority >= 0
|
||||
ORDER BY it.priority
|
||||
</db-model>
|
||||
<custom>
|
||||
<p>
|
||||
<htk-text form="tag" column="name"/> <htk-text form="tag" column="value"/>
|
||||
</p>
|
||||
<tr>
|
||||
<td><htk-text form="tag" column="name"/></td>
|
||||
<td><htk-text form="tag" column="value"/></td>
|
||||
</tr>
|
||||
</custom>
|
||||
</htk-repeater>
|
||||
</div>
|
||||
|
|
|
@ -78,18 +78,18 @@
|
|||
class="photo"
|
||||
directory="catalog"
|
||||
subdir="200x200"
|
||||
full-dir="900x900"/>
|
||||
full-dir="1600x900"/>
|
||||
<div class="info">
|
||||
<h2>
|
||||
<htk-text form="iter" column="concept"/>
|
||||
</h2>
|
||||
<p class="tags">
|
||||
<htk-text form="iter" column="tag1"/>
|
||||
<htk-text form="iter" column="val1"/>,
|
||||
<htk-text form="iter" column="tag2"/>
|
||||
<htk-text form="iter" column="val2"/>,
|
||||
<htk-text form="iter" column="tag3"/>
|
||||
<htk-text form="iter" column="val3"/>
|
||||
<htk-text form="iter" column="tag5"/>
|
||||
<htk-text form="iter" column="value5"/>,
|
||||
<htk-text form="iter" column="tag6"/>
|
||||
<htk-text form="iter" column="value6"/>,
|
||||
<htk-text form="iter" column="tag7"/>
|
||||
<htk-text form="iter" column="value7"/>
|
||||
</p>
|
||||
<p class="amount">
|
||||
<htk-text form="iter" column="quantity"/> x
|
||||
|
@ -118,7 +118,7 @@
|
|||
class="photo"
|
||||
directory="catalog"
|
||||
subdir="200x200"
|
||||
full-dir="900x900"/>
|
||||
full-dir="1600x900"/>
|
||||
<p class="subtotal">
|
||||
<htk-text form="iter" column="quantity"/>
|
||||
</p>
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
{
|
||||
"name": "hedera-web",
|
||||
"version": "1.406.13",
|
||||
"version": "1.406.14",
|
||||
"description": "Verdnatura web page",
|
||||
"license": "GPL-3.0",
|
||||
"repository": {
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
<?php
|
||||
|
||||
require_once(__DIR__.'/lib.php');
|
||||
require_once(__DIR__.'/image.php');
|
||||
|
||||
/**
|
||||
* Resizes all images allocated in a directory.
|
||||
|
@ -22,11 +22,8 @@ class Resize extends Vn\Lib\Method {
|
|||
,'symbolic'
|
||||
];
|
||||
|
||||
function run() {
|
||||
$options = getopt('', $params);
|
||||
|
||||
if (!$this->checkParams($options, self::PARAMS))
|
||||
$this->usage();
|
||||
function run($db) {
|
||||
$options = getopt('', self::PARAMS);
|
||||
|
||||
$srcDir = $options['srcDir'];
|
||||
$dstDir = $options['dstDir'];
|
||||
|
@ -35,6 +32,7 @@ class Resize extends Vn\Lib\Method {
|
|||
$rewrite = isset($options['rewrite']);
|
||||
$crop = isset($options['crop']);
|
||||
$symbolic = isset($options['symbolic']);
|
||||
$verbose = isset($options['verbose']);
|
||||
|
||||
set_time_limit(0);
|
||||
|
||||
|
@ -49,7 +47,12 @@ class Resize extends Vn\Lib\Method {
|
|||
|
||||
if (!file_exists($dstFile) || $rewrite)
|
||||
try {
|
||||
$symbolicSrc =($symbolic) ? $srcFile : NULL;
|
||||
$symbolicSrc = $symbolic ? $srcFile : NULL;
|
||||
|
||||
if ($verbose) {
|
||||
echo "SRC: $srcFile\n";
|
||||
echo "DST: $dstFile\n";
|
||||
}
|
||||
|
||||
$image = Image::create($srcFile);
|
||||
Image::resizeSave($image, $dstFile, $maxHeight, $maxWidth, $crop, $symbolicSrc);
|
||||
|
|
|
@ -31,7 +31,7 @@ class Sync extends Vn\Lib\Method {
|
|||
if ($dir)
|
||||
while ($schema = readdir($dir))
|
||||
if (!in_array($schema, ['.', '..'])) {
|
||||
$info = $this->loadInfo($schema);
|
||||
$info = $this->util->loadInfo($schema);
|
||||
$schemaPath = "{$this->dataDir}/$schema";
|
||||
|
||||
// Deletes unreferenced schemas.
|
||||
|
@ -105,7 +105,7 @@ class Sync extends Vn\Lib\Method {
|
|||
* @param string $file The file to move to the trash
|
||||
*/
|
||||
function moveTrash($file) {
|
||||
$trashBasedir = "{$this->dataDir}/.trash/". $this->$trashSubdir;
|
||||
$trashBasedir = "{$this->dataDir}/.trash/". $this->trashSubdir;
|
||||
$trashdir = "$trashBasedir/". dirname($file);
|
||||
|
||||
if (!is_dir($trashdir))
|
||||
|
|
Loading…
Reference in New Issue