From 183d770483f073a8b4c3e11027cf3c6b1597d7d5 Mon Sep 17 00:00:00 2001 From: Joan Sanchez Date: Tue, 1 Oct 2019 15:09:55 +0200 Subject: [PATCH 01/10] first changes --- db/changes/10091-iberflora/00-department.sql | 73 +++++++++++++++ .../00-department_calcTree.sql | 37 ++++++++ .../00-department_calcTreeRec.sql | 75 ++++++++++++++++ .../10091-iberflora/00-department_doCalc.sql | 35 ++++++++ .../00-department_getLeaves.sql | 84 +++++++++++++++++ front/core/components/treeview/child.html | 13 +-- front/core/components/treeview/child.js | 12 ++- front/core/components/treeview/index.js | 15 +++- .../back/methods/department/getLeaves.js | 89 ++++++------------- modules/worker/front/department/index.html | 21 ++--- modules/worker/front/department/index.js | 1 - 11 files changed, 372 insertions(+), 83 deletions(-) create mode 100644 db/changes/10091-iberflora/00-department.sql create mode 100644 db/changes/10091-iberflora/00-department_calcTree.sql create mode 100644 db/changes/10091-iberflora/00-department_calcTreeRec.sql create mode 100644 db/changes/10091-iberflora/00-department_doCalc.sql create mode 100644 db/changes/10091-iberflora/00-department_getLeaves.sql diff --git a/db/changes/10091-iberflora/00-department.sql b/db/changes/10091-iberflora/00-department.sql new file mode 100644 index 000000000..f1d1776e9 --- /dev/null +++ b/db/changes/10091-iberflora/00-department.sql @@ -0,0 +1,73 @@ +ALTER TABLE `vn2008`.`department` +ADD COLUMN `parentFk` INT UNSIGNED NULL AFTER `sons`, +ADD COLUMN `path` VARCHAR(255) NULL AFTER `parentFk`, +CHANGE COLUMN `sons` `sons` DECIMAL(10,0) NOT NULL DEFAULT '0' ; + +USE `vn`; +CREATE + OR REPLACE ALGORITHM = UNDEFINED + DEFINER = `root`@`%` + SQL SECURITY DEFINER +VIEW `department` AS + SELECT + `b`.`department_id` AS `id`, + `b`.`name` AS `name`, + `b`.`production` AS `isProduction`, + `b`.`parentFk` AS `parentFk`, + `b`.`path` AS `path`, + `b`.`lft` AS `lft`, + `b`.`rgt` AS `rgt`, + `b`.`isSelected` AS `isSelected`, + `b`.`depth` AS `depth`, + `b`.`sons` AS `sons` + FROM + `vn2008`.`department` `b`; + +DROP TRIGGER IF EXISTS `vn2008`.`department_AFTER_DELETE`; + +DELIMITER $$ +USE `vn2008`$$ +CREATE DEFINER = CURRENT_USER TRIGGER `vn2008`.`department_AFTER_DELETE` + AFTER DELETE ON `department` FOR EACH ROW +BEGIN + UPDATE vn.department_recalc SET isChanged = TRUE; +END$$ +DELIMITER ; + +DROP TRIGGER IF EXISTS `vn2008`.`department_BEFORE_INSERT`; + +DELIMITER $$ +USE `vn2008`$$ +CREATE DEFINER = CURRENT_USER TRIGGER `vn2008`.`department_BEFORE_INSERT` + BEFORE INSERT ON `department` FOR EACH ROW +BEGIN + UPDATE vn.department_recalc SET isChanged = TRUE; +END$$ +DELIMITER ; + +DROP TRIGGER IF EXISTS `vn2008`.`department_AFTER_UPDATE`; + +DELIMITER $$ +USE `vn2008`$$ +CREATE DEFINER = CURRENT_USER TRIGGER `vn2008`.`department_AFTER_UPDATE` + AFTER UPDATE ON `department` FOR EACH ROW +BEGIN + IF !(OLD.parentFk <=> NEW.parentFk) THEN + UPDATE vn.department_recalc SET isChanged = TRUE; + END IF; +END$$ +DELIMITER ; + +CREATE TABLE `vn`.`department_recalc` ( + `id` INT UNSIGNED NOT NULL AUTO_INCREMENT, + `isChanged` TINYINT(4) NOT NULL, + PRIMARY KEY (`id`)); + +INSERT INTO `vn`.`department_recalc` (`id`, `isChanged`) VALUES ('1', '0'); + + +ALTER TABLE `vn2008`.`department` +CHANGE COLUMN `lft` `lft` INT(11) NULL , +CHANGE COLUMN `rgt` `rgt` INT(11) NULL ; + +UPDATE vn.department SET lft = NULL, rgt = NULL; diff --git a/db/changes/10091-iberflora/00-department_calcTree.sql b/db/changes/10091-iberflora/00-department_calcTree.sql new file mode 100644 index 000000000..5f518d2e2 --- /dev/null +++ b/db/changes/10091-iberflora/00-department_calcTree.sql @@ -0,0 +1,37 @@ +USE `vn`; +DROP procedure IF EXISTS `department_calcTree`; + +DELIMITER $$ +USE `vn`$$ +CREATE DEFINER=`root`@`%` PROCEDURE `department_calcTree`() +BEGIN +/** + * Calculates the #path, #lft, #rgt, #sons and #depth columns of + * the #department table. To build the tree, it uses the #parentFk + * column. + */ + DECLARE vIndex INT DEFAULT 0; + DECLARE vSons INT; + + DROP TEMPORARY TABLE IF EXISTS tNestedTree; + CREATE TEMPORARY TABLE tNestedTree + SELECT id, path, lft, rgt, depth, sons + FROM department LIMIT 0; + + SET max_sp_recursion_depth = 5; + CALL department_calcTreeRec(NULL, '/', 0, vIndex, vSons); + SET max_sp_recursion_depth = 0; + + UPDATE department z + JOIN tNestedTree t ON t.id = z.id + SET z.path = t.path, + z.lft = t.lft, + z.rgt = t.rgt, + z.depth = t.depth, + z.sons = t.sons; + + DROP TEMPORARY TABLE tNestedTree; +END$$ + +DELIMITER ; + diff --git a/db/changes/10091-iberflora/00-department_calcTreeRec.sql b/db/changes/10091-iberflora/00-department_calcTreeRec.sql new file mode 100644 index 000000000..1f24270e2 --- /dev/null +++ b/db/changes/10091-iberflora/00-department_calcTreeRec.sql @@ -0,0 +1,75 @@ +USE `vn`; +DROP procedure IF EXISTS `department_calcTreeRec`; + +DELIMITER $$ +USE `vn`$$ +CREATE DEFINER=`root`@`%` PROCEDURE `department_calcTreeRec`( + vSelf INT, + vPath VARCHAR(255), + vDepth INT, + INOUT vIndex INT, + OUT vSons INT +) +BEGIN +/** + * Calculates and sets the #path, #lft, #rgt, #sons and #depth + * columns for all children of the passed node. Once calculated + * the last node rgt index and the number of sons are returned. + * To update it's children, this procedure calls itself recursively + * for each one. + * + * @vSelf The node identifier + * @vPath The initial path + * @vDepth The initial depth + * @vIndex The initial lft index + * @vSons The number of direct sons + */ + DECLARE vChildFk INT; + DECLARE vLft INT; + DECLARE vMySons INT; + DECLARE vDone BOOL; + DECLARE vChildren CURSOR FOR + SELECT id FROM department + WHERE (vSelf IS NULL AND parentFk IS NULL) + OR (vSelf IS NOT NULL AND parentFk = vSelf); + + DECLARE CONTINUE HANDLER FOR NOT FOUND SET vDone = TRUE; + + SET vSons = 0; + + OPEN vChildren; + myLoop: LOOP + SET vDone = FALSE; + FETCH vChildren INTO vChildFk; + + IF vDone THEN + LEAVE myLoop; + END IF; + + SET vIndex = vIndex + 1; + SET vLft = vIndex; + SET vSons = vSons + 1; + + CALL department_calcTreeRec( + vChildFk, + CONCAT(vPath, vChildFk, '/'), + vDepth + 1, + vIndex, + vMySons + ); + + SET vIndex = vIndex + 1; + + INSERT INTO tNestedTree + SET id = vChildFk, + path = vPath, + lft = vLft, + rgt = vIndex, + depth = vDepth, + sons = vMySons; + END LOOP; + CLOSE vChildren; +END$$ + +DELIMITER ; + diff --git a/db/changes/10091-iberflora/00-department_doCalc.sql b/db/changes/10091-iberflora/00-department_doCalc.sql new file mode 100644 index 000000000..ba5c16c48 --- /dev/null +++ b/db/changes/10091-iberflora/00-department_doCalc.sql @@ -0,0 +1,35 @@ +USE `vn`; +DROP procedure IF EXISTS `department_doCalc`; + +DELIMITER $$ +USE `vn`$$ +CREATE DEFINER=`root`@`%` PROCEDURE `department_doCalc`() +proc: BEGIN +/** + * Recalculates the department tree. + */ + DECLARE vIsChanged BOOL; + + DECLARE CONTINUE HANDLER FOR SQLEXCEPTION + BEGIN + DO RELEASE_LOCK('vn.department_doCalc'); + RESIGNAL; + END; + + IF !GET_LOCK('vn.department_doCalc', 0) THEN + LEAVE proc; + END IF; + + SELECT isChanged INTO vIsChanged + FROM department_recalc; + + IF vIsChanged THEN + UPDATE department_recalc SET isChanged = FALSE; + CALL vn.department_calcTree; + END IF; + + DO RELEASE_LOCK('vn.department_doCalc'); +END$$ + +DELIMITER ; + diff --git a/db/changes/10091-iberflora/00-department_getLeaves.sql b/db/changes/10091-iberflora/00-department_getLeaves.sql new file mode 100644 index 000000000..436f67dbf --- /dev/null +++ b/db/changes/10091-iberflora/00-department_getLeaves.sql @@ -0,0 +1,84 @@ +USE `vn`; +DROP procedure IF EXISTS `department_getLeaves`; + +DELIMITER $$ +USE `vn`$$ +CREATE DEFINER=`root`@`%` PROCEDURE `department_getLeaves`( + vParentFk INT, + vSearch VARCHAR(255) +) +BEGIN + DECLARE vIsNumber BOOL; + DECLARE vIsSearch BOOL DEFAULT vSearch IS NOT NULL AND vSearch != ''; + + DROP TEMPORARY TABLE IF EXISTS tNodes; + CREATE TEMPORARY TABLE tNodes + (UNIQUE (id)) + ENGINE = MEMORY + SELECT id FROM department LIMIT 0; + + IF vIsSearch THEN + SET vIsNumber = vSearch REGEXP '^[0-9]+$'; + + INSERT INTO tNodes + SELECT id FROM department + WHERE (vIsNumber AND `name` = vSearch) + OR (!vIsNumber AND `name` LIKE CONCAT('%', vSearch, '%')) + LIMIT 1000; + END IF; + + IF vParentFk IS NULL THEN + DROP TEMPORARY TABLE IF EXISTS tChilds; + CREATE TEMPORARY TABLE tChilds + ENGINE = MEMORY + SELECT id FROM tNodes; + + DROP TEMPORARY TABLE IF EXISTS tParents; + CREATE TEMPORARY TABLE tParents + ENGINE = MEMORY + SELECT id FROM department LIMIT 0; + + myLoop: LOOP + DELETE FROM tParents; + INSERT INTO tParents + SELECT parentFk id + FROM department g + JOIN tChilds c ON c.id = g.id + WHERE g.parentFk IS NOT NULL; + + INSERT IGNORE INTO tNodes + SELECT id FROM tParents; + + IF ROW_COUNT() = 0 THEN + LEAVE myLoop; + END IF; + + DELETE FROM tChilds; + INSERT INTO tChilds + SELECT id FROM tParents; + END LOOP; + + DROP TEMPORARY TABLE + tChilds, + tParents; + END IF; + + IF !vIsSearch THEN + INSERT IGNORE INTO tNodes + SELECT id FROM department + WHERE parentFk <=> vParentFk; + END IF; + + SELECT d.id, + d.`name`, + d.parentFk, + d.sons + FROM department d + JOIN tNodes n ON n.id = d.id + ORDER BY depth, `name`; + + DROP TEMPORARY TABLE tNodes; +END$$ + +DELIMITER ; + diff --git a/front/core/components/treeview/child.html b/front/core/components/treeview/child.html index bb0bcb569..2cf930f3d 100644 --- a/front/core/components/treeview/child.html +++ b/front/core/components/treeview/child.html @@ -14,7 +14,8 @@ icon="keyboard_arrow_down" translate-attr="{title: 'Toggle'}"> - + - - + --> -
  • -
  • + --> \ No newline at end of file diff --git a/front/core/components/treeview/child.js b/front/core/components/treeview/child.js index 4441963f0..b1d377a83 100644 --- a/front/core/components/treeview/child.js +++ b/front/core/components/treeview/child.js @@ -2,9 +2,14 @@ import ngModule from '../../module'; import Component from '../../lib/component'; class Controller extends Component { - constructor($element, $scope) { + constructor($element, $scope, $transclude) { super($element, $scope); this.$scope = $scope; + this.$transclude = $transclude; + + $transclude($scope.$parent, tClone => { + this.element.querySelector('.tplItem').appendChild(tClone[0]); + }, null, 'tplItem'); } toggle(event, item) { @@ -35,6 +40,8 @@ class Controller extends Component { } } +Controller.$inject = ['$element', '$scope', '$transclude']; + ngModule.component('vnTreeviewChild', { template: require('./child.html'), controller: Controller, @@ -50,6 +57,9 @@ ngModule.component('vnTreeviewChild', { aclRole: ' { + this.element.querySelector('vn-treeview-child').appendChild(tClone[0]); + // Object.assign(scope, option); + // li.appendChild(clone[0]); + // this.scopes[i] = scope; + }, null, 'tplItem'); } $onInit() { @@ -76,7 +84,7 @@ export default class Treeview extends Component { } } -Treeview.$inject = ['$element', '$scope']; +Treeview.$inject = ['$element', '$scope', '$transclude']; ngModule.component('vnTreeview', { template: require('./index.html'), @@ -90,5 +98,8 @@ ngModule.component('vnTreeview', { draggable: ' { Self.remoteMethod('getLeaves', { - description: 'Returns the first shipped and landed possible for params', + description: 'Returns the nodes for a department', accepts: [{ arg: 'parentFk', type: 'Number', - default: 1, - required: false, - }, - { - arg: 'filter', - type: 'Object', - description: 'Filter defining where, order, offset, and limit - must be a JSON-encoded string', - http: {source: 'query'} + description: 'Get the children of the specified father', + }, { + arg: 'search', + type: 'String', + description: 'Filter nodes whose name starts with', }], returns: { type: ['object'], @@ -26,61 +20,30 @@ module.exports = Self => { } }); - Self.getLeaves = async(parentFk = 1, filter) => { - let conn = Self.dataSource.connector; - let stmt = new ParameterizedSQL( - `SELECT - child.id, - child.name, - child.lft, - child.rgt, - child.depth, - child.sons - FROM department parent - JOIN department child ON child.lft > parent.lft - AND child.rgt < parent.rgt - AND child.depth = parent.depth + 1 - WHERE parent.id = ?`, [parentFk]); + Self.getLeaves = async(parentFk = null, search) => { + let [res] = await Self.rawSql( + `CALL department_getLeaves(?, ?)`, + [parentFk, search] + ); - // Get nodes from depth greather than Origin - stmt.merge(conn.makeSuffix(filter)); - - const nodes = await Self.rawStmt(stmt); - - if (nodes.length == 0) - return nodes; - - // Get parent nodes - const minorDepth = nodes.reduce((a, b) => { - return b < a ? b : a; - }).depth; - - const parentNodes = nodes.filter(element => { - return element.depth === minorDepth; - }); - const leaves = Object.assign([], parentNodes); - - nestLeaves(leaves); - - function nestLeaves(elements) { - elements.forEach(element => { - let childs = Object.assign([], getLeaves(element)); - if (childs.length > 0) { - element.childs = childs; - nestLeaves(element.childs); - } - }); + let map = new Map(); + for (let node of res) { + if (!map.has(node.parentFk)) + map.set(node.parentFk, []); + map.get(node.parentFk).push(node); } - function getLeaves(parent) { - let elements = nodes.filter(element => { - return element.lft > parent.lft && element.rgt < parent.rgt - && element.depth === parent.depth + 1; - }); - - return elements; + function setLeaves(nodes) { + if (!nodes) return; + for (let node of nodes) { + node.childs = map.get(node.id); + setLeaves(node.childs); + } } - return leaves; + let leaves = map.get(parentFk); + setLeaves(leaves); + + return leaves || []; }; }; diff --git a/modules/worker/front/department/index.html b/modules/worker/front/department/index.html index 6cf2cd063..dfdb9bcfc 100644 --- a/modules/worker/front/department/index.html +++ b/modules/worker/front/department/index.html @@ -1,25 +1,26 @@ - -
    -
    +
    + + icons="$ctrl.icons"> + + test + -
    - - + + + + +
    Date: Wed, 2 Oct 2019 09:54:52 +0200 Subject: [PATCH 02/10] treeview refactor --- db/changes/10091-iberflora/00-department.sql | 10 +++ front/core/components/index.js | 1 - .../treeview/{child.html => childs.html} | 61 +++++++++-------- .../treeview/{child.js => childs.js} | 21 +++--- front/core/components/treeview/content.js | 23 +++++++ front/core/components/treeview/index.html | 10 +-- front/core/components/treeview/index.js | 18 ++--- front/core/components/treeview/style.scss | 68 +++++++++---------- modules/agency/front/location/index.html | 6 ++ modules/worker/front/department/index.html | 10 +-- 10 files changed, 133 insertions(+), 95 deletions(-) rename front/core/components/treeview/{child.html => childs.html} (58%) rename front/core/components/treeview/{child.js => childs.js} (77%) create mode 100644 front/core/components/treeview/content.js diff --git a/db/changes/10091-iberflora/00-department.sql b/db/changes/10091-iberflora/00-department.sql index f1d1776e9..5c2889985 100644 --- a/db/changes/10091-iberflora/00-department.sql +++ b/db/changes/10091-iberflora/00-department.sql @@ -70,4 +70,14 @@ ALTER TABLE `vn2008`.`department` CHANGE COLUMN `lft` `lft` INT(11) NULL , CHANGE COLUMN `rgt` `rgt` INT(11) NULL ; +ALTER TABLE `vn2008`.`department` +DROP INDEX `rgt_UNIQUE` , +DROP INDEX `lft_UNIQUE` ; +; + +ALTER TABLE `vn2008`.`department` +ADD INDEX `lft_rgt_depth_idx` (`lft` ASC, `rgt` ASC, `depth` ASC); +; + + UPDATE vn.department SET lft = NULL, rgt = NULL; diff --git a/front/core/components/index.js b/front/core/components/index.js index e8adb008e..50d0b5e94 100644 --- a/front/core/components/index.js +++ b/front/core/components/index.js @@ -43,4 +43,3 @@ import './input-file'; import './radio'; import './th'; import './treeview'; -import './treeview/child'; diff --git a/front/core/components/treeview/child.html b/front/core/components/treeview/childs.html similarity index 58% rename from front/core/components/treeview/child.html rename to front/core/components/treeview/childs.html index 2cf930f3d..cd0c59ec0 100644 --- a/front/core/components/treeview/child.html +++ b/front/core/components/treeview/childs.html @@ -1,11 +1,11 @@ +
      -
    • +
    • -
      - + +-->
      - -
    • - -
    \ No newline at end of file + + \ No newline at end of file diff --git a/front/core/components/treeview/child.js b/front/core/components/treeview/childs.js similarity index 77% rename from front/core/components/treeview/child.js rename to front/core/components/treeview/childs.js index b1d377a83..46bb776b8 100644 --- a/front/core/components/treeview/child.js +++ b/front/core/components/treeview/childs.js @@ -4,12 +4,15 @@ import Component from '../../lib/component'; class Controller extends Component { constructor($element, $scope, $transclude) { super($element, $scope); - this.$scope = $scope; this.$transclude = $transclude; + } - $transclude($scope.$parent, tClone => { - this.element.querySelector('.tplItem').appendChild(tClone[0]); - }, null, 'tplItem'); + $onInit() { + this.transcludeFunc((tClone, $scope) => { + $scope.item = this.item; + let content = this.element.querySelector('.content'); + angular.element(content).append(tClone); + }); } toggle(event, item) { @@ -42,8 +45,8 @@ class Controller extends Component { Controller.$inject = ['$element', '$scope', '$transclude']; -ngModule.component('vnTreeviewChild', { - template: require('./child.html'), +ngModule.component('vnTreeviewChilds', { + template: require('./childs.html'), controller: Controller, bindings: { items: '<', @@ -55,10 +58,8 @@ ngModule.component('vnTreeviewChild', { draggable: ' { + $scope.item = this.item; + this.$element.append(tClone); + }); + } +} +Controller.$inject = ['$element']; + +ngModule.component('vnTreeviewContent', { + controller: Controller, + bindings: { + item: '<', + transcludeFunc: '<' + } +}); diff --git a/front/core/components/treeview/index.html b/front/core/components/treeview/index.html index a200c913a..b33c90fcf 100644 --- a/front/core/components/treeview/index.html +++ b/front/core/components/treeview/index.html @@ -1,7 +1,6 @@ - - + vn-droppable="{{$ctrl.droppable}}" + transclude-func="$ctrl.$transclude"> + diff --git a/front/core/components/treeview/index.js b/front/core/components/treeview/index.js index 7c19b006b..2273288ac 100644 --- a/front/core/components/treeview/index.js +++ b/front/core/components/treeview/index.js @@ -2,6 +2,9 @@ import ngModule from '../../module'; import Component from '../../lib/component'; import './style.scss'; +import './childs'; +import './content'; + /** * Treeview * @@ -12,14 +15,7 @@ export default class Treeview extends Component { super($element, $scope); this.$scope = $scope; this.$transclude = $transclude; - this.data = []; - - $transclude($scope.$parent, tClone => { - this.element.querySelector('vn-treeview-child').appendChild(tClone[0]); - // Object.assign(scope, option); - // li.appendChild(clone[0]); - // this.scopes[i] = scope; - }, null, 'tplItem'); + this.items = []; } $onInit() { @@ -28,7 +24,7 @@ export default class Treeview extends Component { refresh() { this.model.refresh().then(() => { - this.data = this.model.data; + this.items = this.model.data; }); } @@ -99,7 +95,5 @@ ngModule.component('vnTreeview', { droppable: ' li { list-style: none; - - & > div > .arrow { - min-width: 24px; - margin-right: 10px; - transition: transform 200ms; - } - &.expanded > div > .arrow { - transform: rotate(180deg); - } - & > .node { - @extend %clickable; - display: flex; - padding: 5px; - align-items: center; - - & > vn-check:not(.indeterminate) { - color: $color-main; - - & > .check { - border-color: $color-main; - } - } - & > vn-check.checked { - color: $color-main; - } - } - ul { - padding-left: 2.2em; - } } } vn-icon-button { - padding: 0 + padding: 0; + } + & > ul > li > .node { + @extend %clickable; + display: flex; + padding: 5px; + align-items: center; + + & > .arrow { + min-width: 24px; + margin-right: 10px; + transition: transform 200ms; + } + &.expanded > .arrow { + transform: rotate(180deg); + } + & > vn-check:not(.indeterminate) { + color: $color-main; + + & > .check { + border-color: $color-main; + } + } + & > vn-check.checked { + color: $color-main; + } + } + ul { + padding-left: 2.2em; } } diff --git a/modules/agency/front/location/index.html b/modules/agency/front/location/index.html index b3025a8e0..3d00df006 100644 --- a/modules/agency/front/location/index.html +++ b/modules/agency/front/location/index.html @@ -18,6 +18,12 @@ acl-role="deliveryBoss" on-selection="$ctrl.onSelection(item, value)" selectable="true"> + + \ No newline at end of file diff --git a/modules/worker/front/department/index.html b/modules/worker/front/department/index.html index dfdb9bcfc..1eada1003 100644 --- a/modules/worker/front/department/index.html +++ b/modules/worker/front/department/index.html @@ -6,14 +6,14 @@
    - - - test - + icons="$ctrl.icons"> + {{item.name}} From 6a184496d65abe7af17f683053e91df2cffcd21b Mon Sep 17 00:00:00 2001 From: Joan Sanchez Date: Wed, 2 Oct 2019 14:12:17 +0200 Subject: [PATCH 03/10] treeview refactor 2 --- .../components/icon-button/icon-button.js | 31 +++++----- front/core/components/treeview/childs.html | 57 +++++-------------- front/core/components/treeview/childs.js | 19 +------ front/core/components/treeview/content.js | 8 ++- front/core/components/treeview/index.html | 20 +++---- front/core/components/treeview/index.js | 41 ++++++++++++- front/core/components/treeview/style.scss | 15 ++++- modules/worker/front/department/index.html | 7 +-- 8 files changed, 102 insertions(+), 96 deletions(-) diff --git a/front/core/components/icon-button/icon-button.js b/front/core/components/icon-button/icon-button.js index b4022ccec..ba3ccae3e 100644 --- a/front/core/components/icon-button/icon-button.js +++ b/front/core/components/icon-button/icon-button.js @@ -3,23 +3,28 @@ import './style.scss'; export default class IconButton { constructor($element) { - if ($element[0].getAttribute('tabindex') == null) - $element[0].tabIndex = 0; + this.element = $element[0]; - $element.on('keyup', event => this.onKeyDown(event, $element)); - let button = $element[0].querySelector('button'); - $element[0].addEventListener('click', event => { - if (this.disabled || button.disabled) - event.stopImmediatePropagation(); - }); + if (this.element.getAttribute('tabindex') == null) + this.element.tabIndex = 0; + + this.element.addEventListener('keyup', e => this.onKeyup(e)); + this.element.addEventListener('click', e => this.onClick(e)); } - onKeyDown(event, $element) { + onKeyup(event) { + if (event.code == 'Space') + this.onClick(event); + } + + onClick(event) { if (event.defaultPrevented) return; - if (event.keyCode == 13) { - event.preventDefault(); - $element.triggerHandler('click'); - } + event.preventDefault(); + + // FIXME: Don't use Event.stopPropagation() + let button = this.element.querySelector('button'); + if (this.disabled || button.disabled) + event.stopImmediatePropagation(); } } diff --git a/front/core/components/treeview/childs.html b/front/core/components/treeview/childs.html index cd0c59ec0..e185f44db 100644 --- a/front/core/components/treeview/childs.html +++ b/front/core/components/treeview/childs.html @@ -1,69 +1,42 @@ -
      +
      • + translate-attr="::{title: 'Toggle'}"> + item="::item"> + + + +
        + parent="::item">
      • -
      - - + ng-click="$ctrl.treeview.onCreate(item, item.childs)"> - diff --git a/front/core/components/treeview/index.html b/front/core/components/treeview/index.html index 0dc6f42d0..1970ddc43 100644 --- a/front/core/components/treeview/index.html +++ b/front/core/components/treeview/index.html @@ -1,4 +1,4 @@ -
      +
      diff --git a/front/core/components/treeview/index.js b/front/core/components/treeview/index.js index 0e1ace3b0..99d0a864f 100644 --- a/front/core/components/treeview/index.js +++ b/front/core/components/treeview/index.js @@ -27,51 +27,44 @@ export default class Treeview extends Component { }); } - /** - * Emits selection event - * @param {Object} item - Selected item - * @param {Boolean} value - Changed value - */ - onSelection(item, value) { - this.emit('selection', {item, value}); - } - - onCreate(parent) { - this.emit('create', {parent}); - } - onToggle(item) { if (item.active) - item.childs = undefined; - else { - this.model.applyFilter({}, {parentFk: item.id}).then(() => { - const newData = this.model.data; + this.fold(item); + else + this.unfold(item); + } - if (item.childs) { - let childs = item.childs; - childs.forEach(child => { - let index = newData.findIndex(newChild => { - return newChild.id == child.id; - }); - newData[index] = child; + fold(item) { + item.childs = undefined; + item.active = false; + } + + unfold(item) { + return this.model.applyFilter({}, {parentFk: item.id}).then(() => { + const newData = this.model.data; + + if (item.childs) { + let childs = item.childs; + childs.forEach(child => { + let index = newData.findIndex(newChild => { + return newChild.id == child.id; }); + newData[index] = child; + }); + } + + item.childs = newData.sort((a, b) => { + if (b.selected !== a.selected) { + if (a.selected == null) + return 1; + if (b.selected == null) + return -1; + return b.selected - a.selected; } - item.childs = newData.sort((a, b) => { - if (b.selected !== a.selected) { - if (a.selected == null) - return 1; - if (b.selected == null) - return -1; - return b.selected - a.selected; - } - - return a.name.localeCompare(b.name); - }); + return a.name.localeCompare(b.name); }); - } - - item.active = !item.active; + }).then(() => item.active = true); } onDrop(item, dragged, dropped) { @@ -80,7 +73,7 @@ export default class Treeview extends Component { onRemove(item, items, parent) { if (!this.removeFunc) return; - let res = this.removeFunc({$item: item}); + let res = this.removeFunc({$item: item, $parent: parent}); function remove() { let index = items.indexOf(item); @@ -94,25 +87,50 @@ export default class Treeview extends Component { remove(); } - onAdd(parent, childs) { - if (!this.addFunc) return; - let res = this.addFunc({$parent: parent}); + onCreate(parent, childs) { + if (!this.createFunc) return; + let res = this.createFunc({$parent: parent, $childs: childs}); - function add() { + function create() { if (!childs) childs = []; childs.push(res); - if (parent) { - parent.childs = childs; - parent.sons++; - parent.active = true; - } + if (parent) parent.sons++; } - if (res instanceof Object && res.then) - res.then(add); - else if (res) - add(); + if (res instanceof Object && res.then) { + if (parent && !parent.active) + this.unfold(parent).then(() => res.then(create)); + else res.then(create); + } else if (res) { + if (parent && !parent.active) + this.unfold(parent).then(() => create()); + else create(); + } else if (parent && !parent.active) + this.unfold(parent); } + + /* onCreate(parent, childs) { + if (!this.createFunc) return; + let res = this.createFunc({$parent: parent}); + + function create() { + if (!childs) childs = []; + + childs.push(res); + + if (parent) parent.sons++; + } + + if (res instanceof Object && res.then) { + if (!parent.active) + this.unfold(parent).then(() => res.then(create)); + else res.then(create); + } else if (res) { + if (!parent.active) + this.unfold(parent).then(() => create()); + else create(); + } + } */ } Treeview.$inject = ['$element', '$scope', '$transclude']; @@ -130,7 +148,7 @@ ngModule.component('vnTreeview', { droppable: ' { + Self.remoteMethod('createChild', { + description: 'Creates a new child department', + accessType: 'WRITE', + accepts: [{ + arg: 'parentId', + type: 'Number' + }, + { + arg: 'name', + type: 'String', + required: true, + }], + returns: { + type: 'object', + root: true + }, + http: { + path: `/createChild`, + verb: 'POST' + } + }); + + Self.createChild = async(parentId = null, name) => { + const models = Self.app.models; + const nameExists = await models.Department.count({name}); + + if (nameExists) + throw new UserError(`The department name can't be repeated`); + + const newDep = await models.Department.create({ + parentFk: parentId, + name: name + }); + + return newDep; + }; +}; diff --git a/modules/worker/back/methods/department/nodeAdd.js b/modules/worker/back/methods/department/nodeAdd.js deleted file mode 100644 index 93a6f81c0..000000000 --- a/modules/worker/back/methods/department/nodeAdd.js +++ /dev/null @@ -1,43 +0,0 @@ - -const ParameterizedSQL = require('loopback-connector').ParameterizedSQL; - -module.exports = Self => { - Self.remoteMethod('nodeAdd', { - description: 'Returns the first shipped and landed possible for params', - accessType: 'WRITE', - accepts: [{ - arg: 'parentFk', - type: 'Number', - required: false, - }, - { - arg: 'name', - type: 'String', - required: true, - }], - returns: { - type: 'object', - root: true - }, - http: { - path: `/nodeAdd`, - verb: 'POST' - } - }); - - Self.nodeAdd = async(parentFk = 1, name) => { - let stmts = []; - let conn = Self.dataSource.connector; - let nodeIndex = stmts.push(new ParameterizedSQL( - `CALL nst.nodeAdd('vn', 'department', ?, ?)`, [parentFk, name])) - 1; - - stmts.push(`CALL nst.nodeRecalc('vn', 'department')`); - - - let sql = ParameterizedSQL.join(stmts, ';'); - let result = await conn.executeStmt(sql); - let [node] = result[nodeIndex]; - - return node; - }; -}; diff --git a/modules/worker/back/methods/department/nodeDelete.js b/modules/worker/back/methods/department/nodeDelete.js deleted file mode 100644 index 92b354ee5..000000000 --- a/modules/worker/back/methods/department/nodeDelete.js +++ /dev/null @@ -1,29 +0,0 @@ - -const ParameterizedSQL = require('loopback-connector').ParameterizedSQL; - -module.exports = Self => { - Self.remoteMethod('nodeDelete', { - description: 'Returns the first shipped and landed possible for params', - accessType: 'WRITE', - accepts: [{ - arg: 'parentFk', - type: 'Number', - required: false, - }], - returns: { - type: ['object'], - root: true - }, - http: { - path: `/nodeDelete`, - verb: 'POST' - } - }); - - Self.nodeDelete = async parentFk => { - let stmt = new ParameterizedSQL( - `CALL nst.nodeDelete('vn', 'department', ?)`, [parentFk]); - - return await Self.rawStmt(stmt); - }; -}; diff --git a/modules/worker/back/methods/department/removeChild.js b/modules/worker/back/methods/department/removeChild.js new file mode 100644 index 000000000..2d3f40b36 --- /dev/null +++ b/modules/worker/back/methods/department/removeChild.js @@ -0,0 +1,27 @@ +module.exports = Self => { + Self.remoteMethod('removeChild', { + description: 'Returns the first shipped and landed possible for params', + accessType: 'WRITE', + accepts: [{ + arg: 'id', + type: 'Number', + description: 'The department id', + http: {source: 'path'} + }], + returns: { + type: 'Object', + root: true + }, + http: { + path: `/:id/removeChild`, + verb: 'POST' + } + }); + + Self.removeChild = async id => { + const models = Self.app.models; + const department = await models.Department.findById(id); + + return await department.destroy(); + }; +}; diff --git a/modules/worker/back/models/department.js b/modules/worker/back/models/department.js index 085c2bf9b..e6905d273 100644 --- a/modules/worker/back/models/department.js +++ b/modules/worker/back/models/department.js @@ -1,15 +1,5 @@ -const UserError = require('vn-loopback/util/user-error'); - module.exports = Self => { require('../methods/department/getLeaves')(Self); - require('../methods/department/nodeAdd')(Self); - require('../methods/department/nodeDelete')(Self); - - Self.rewriteDbError(function(err) { - if (err.code === 'ER_ROW_IS_REFERENCED_2') - return new UserError(`You cannot remove this department`); - if (err.code === 'ER_DUP_ENTRY') - return new UserError(`The department name can't be repeated`); - return err; - }); + require('../methods/department/createChild')(Self); + require('../methods/department/removeChild')(Self); }; diff --git a/modules/worker/back/models/department.json b/modules/worker/back/models/department.json index 0b978b56c..bb5d5e943 100644 --- a/modules/worker/back/models/department.json +++ b/modules/worker/back/models/department.json @@ -13,6 +13,9 @@ }, "name": { "type": "String" + }, + "parentFk": { + "type": "Number" } } } diff --git a/modules/worker/front/department/index.html b/modules/worker/front/department/index.html index 52303b0ad..16287b349 100644 --- a/modules/worker/front/department/index.html +++ b/modules/worker/front/department/index.html @@ -6,12 +6,9 @@
      - + {{::item.name}} @@ -37,7 +34,7 @@ + model="$ctrl.newChild.name"> diff --git a/modules/worker/front/department/index.js b/modules/worker/front/department/index.js index 0a62dd4b6..050bb215f 100644 --- a/modules/worker/front/department/index.js +++ b/modules/worker/front/department/index.js @@ -6,23 +6,6 @@ class Controller { this.$http = $http; this.vnApp = vnApp; this.$translate = $translate; - this.icons = [{icon: 'delete', tooltip: 'Delete', callback: this.onDelete}]; - this.newNode = { - name: '' - }; - } - - onCreate(parent) { - if (parent instanceof Object) - this.newNode.parentFk = parent.id; - - this.selectedNode = {parent}; - this.$scope.createNode.show(); - } - - onDelete(item, parent, index) { - this.selectedNode = {id: item.id, parent, index}; - this.$scope.deleteNode.show(); } onDrop(item, dragged, dropped) { @@ -39,25 +22,37 @@ class Controller { } } + onCreate(parent, childs) { + this.newChild = { + parent: parent, + childs: childs, + name: '' + }; + + this.$scope.createNode.show(); + } + onCreateDialogOpen() { - this.newNode.name = ''; + this.newChild.name = ''; } onCreateResponse(response) { if (response == 'ACCEPT') { try { - if (!this.newNode.name) + if (!this.newChild.name) throw new Error(`Name can't be empty`); - this.$http.post(`/worker/api/Departments/nodeAdd`, this.newNode).then(response => { - if (response.data) { - let parent = this.selectedNode.parent; - if ((parent instanceof Object) && !(parent instanceof Array)) { - const childs = parent.childs; - childs.push(response.data); - } else if ((parent instanceof Object) && (parent instanceof Array)) - parent.push(response.data); - } + const params = {name: this.newChild.name}; + const parent = this.newChild.parent; + const parentId = parent && parent.id || null; + let childs = this.newChild.childs; + + if (parent) params.parentId = parentId; + + const query = `/api/departments/createChild`; + this.$http.post(query, params).then(response => { + if (!childs) childs = []; + childs.push(response.data); }); } catch (e) { this.vnApp.showError(this.$translate.instant(e.message)); @@ -67,17 +62,24 @@ class Controller { return true; } + onRemove(item) { + this.removedChild = item; + this.$scope.deleteNode.show(); + } + onRemoveResponse(response) { if (response === 'ACCEPT') { - const path = `/worker/api/Departments/nodeDelete`; - this.$http.post(path, {parentFk: this.selectedNode.id}).then(() => { - let parent = this.selectedNode.parent; + const childId = this.removedChild.id; + const path = `/api/departments/${childId}/removeChild`; + this.$http.post(path).then(() => { + items.splice(index, 1); + /* let parent = this.selectedNode.parent; if ((parent instanceof Object) && !(parent instanceof Array)) { const childs = parent.childs; childs.splice(this.selectedNode.index, 1); } else if ((parent instanceof Object) && (parent instanceof Array)) - parent.splice(this.selectedNode.index, 1); + parent.splice(this.selectedNode.index, 1); */ }); } } From 8e80f53d30b7a2c1db0542a275466670bf0e684e Mon Sep 17 00:00:00 2001 From: Joan Sanchez Date: Fri, 4 Oct 2019 11:01:47 +0200 Subject: [PATCH 05/10] show buttons on hover --- front/core/components/treeview/childs.html | 18 ++++++++++-------- front/core/components/treeview/style.scss | 10 ++++++++++ 2 files changed, 20 insertions(+), 8 deletions(-) diff --git a/front/core/components/treeview/childs.html b/front/core/components/treeview/childs.html index 54e408b00..7dd242380 100644 --- a/front/core/components/treeview/childs.html +++ b/front/core/components/treeview/childs.html @@ -25,14 +25,16 @@ label="{{::item.name}}"> --> - - - - +
      + + + + +
      .buttons { + display: none + } + + .node:hover > .buttons { + display: block + } + & > ul > li > .node { @extend %clickable; display: flex; From 366d1123d494467087fafaa45560867bab0969c3 Mon Sep 17 00:00:00 2001 From: Joan Sanchez Date: Fri, 4 Oct 2019 12:20:49 +0200 Subject: [PATCH 06/10] Destroy transclude scopes --- front/core/components/treeview/childs.html | 2 +- front/core/components/treeview/childs.js | 26 +--------------------- front/core/components/treeview/content.js | 10 +++++++-- 3 files changed, 10 insertions(+), 28 deletions(-) diff --git a/front/core/components/treeview/childs.html b/front/core/components/treeview/childs.html index 7dd242380..5573dbbd9 100644 --- a/front/core/components/treeview/childs.html +++ b/front/core/components/treeview/childs.html @@ -3,7 +3,7 @@
    • { + this.treeview.$transclude(($clone, $scope) => { + this.$contentScope = $scope; $scope.item = this.item; - this.$element.append(tClone); + this.$element.append($clone); }); } + + $onDestroy() { + if (this.$contentScope) + this.$contentScope.$destroy(); + } } Controller.$inject = ['$element']; From b32cf4a386eb35706499a22c60ce223f3b98ba01 Mon Sep 17 00:00:00 2001 From: Joan Sanchez Date: Tue, 8 Oct 2019 07:22:38 +0200 Subject: [PATCH 07/10] last refactor --- front/core/components/treeview/childs.html | 26 +-- front/core/components/treeview/content.js | 20 +- front/core/components/treeview/index.html | 8 - front/core/components/treeview/index.js | 173 +++++++++--------- front/core/components/treeview/style.scss | 3 + .../methods/zone-included/toggleIsIncluded.js | 35 ---- modules/agency/back/methods/zone/getLeaves.js | 9 +- .../back/methods/zone/toggleIsIncluded.js | 41 +++++ modules/agency/back/models/zone-included.js | 3 - modules/agency/back/models/zone.js | 1 + modules/agency/front/location/index.html | 16 +- modules/agency/front/location/index.js | 37 +++- modules/worker/front/department/index.html | 6 +- modules/worker/front/department/index.js | 54 +++--- 14 files changed, 225 insertions(+), 207 deletions(-) delete mode 100644 modules/agency/back/methods/zone-included/toggleIsIncluded.js create mode 100644 modules/agency/back/methods/zone/toggleIsIncluded.js delete mode 100644 modules/agency/back/models/zone-included.js diff --git a/front/core/components/treeview/childs.html b/front/core/components/treeview/childs.html index 5573dbbd9..2dd7e77ef 100644 --- a/front/core/components/treeview/childs.html +++ b/front/core/components/treeview/childs.html @@ -14,25 +14,15 @@ - -
      - - - + + ng-click="$ctrl.treeview.onRemove(item)" + ng-if="item.parent"> + +
      diff --git a/front/core/components/treeview/content.js b/front/core/components/treeview/content.js index 62caf5674..506117d4f 100644 --- a/front/core/components/treeview/content.js +++ b/front/core/components/treeview/content.js @@ -1,16 +1,24 @@ import ngModule from '../../module'; class Controller { - constructor($element) { + constructor($element, $scope, $compile) { this.$element = $element; + this.$scope = $scope; + this.$compile = $compile; } $onInit() { - this.treeview.$transclude(($clone, $scope) => { - this.$contentScope = $scope; - $scope.item = this.item; + if (this.item.parent) { + this.treeview.$transclude(($clone, $scope) => { + this.$contentScope = $scope; + $scope.item = this.item; + this.$element.append($clone); + }); + } else { + let template = `{{$ctrl.treeview.rootLabel}}`; + let $clone = this.$compile(template)(this.$scope); this.$element.append($clone); - }); + } } $onDestroy() { @@ -18,7 +26,7 @@ class Controller { this.$contentScope.$destroy(); } } -Controller.$inject = ['$element']; +Controller.$inject = ['$element', '$scope', '$compile']; ngModule.component('vnTreeviewContent', { controller: Controller, diff --git a/front/core/components/treeview/index.html b/front/core/components/treeview/index.html index 1970ddc43..31e6a88a9 100644 --- a/front/core/components/treeview/index.html +++ b/front/core/components/treeview/index.html @@ -1,11 +1,3 @@ -
      - - - - Create new one - -
      diff --git a/front/core/components/treeview/index.js b/front/core/components/treeview/index.js index 99d0a864f..d9da39215 100644 --- a/front/core/components/treeview/index.js +++ b/front/core/components/treeview/index.js @@ -7,23 +7,45 @@ import './content'; /** * Treeview - * - * @property {String} position The relative position to the parent */ export default class Treeview extends Component { constructor($element, $scope, $transclude) { super($element, $scope); this.$transclude = $transclude; - this.items = []; + this.readOnly = true; } - $onInit() { - this.refresh(); + get data() { + return this._data; } - refresh() { - this.model.refresh().then(() => { - this.items = this.model.data; + set data(value) { + this._data = value; + + const sons = value.length; + const rootElement = [{ + childs: value, + active: true, + sons: sons + }]; + + this.setParent(rootElement[0], value); + + this.items = rootElement; + } + + fetch() { + return this.fetchFunc().then(res => + this.data = res + ); + } + + setParent(parent, childs) { + childs.forEach(child => { + child.parent = parent; + + if (child.childs) + this.setParent(parent, child.childs); }); } @@ -40,11 +62,11 @@ export default class Treeview extends Component { } unfold(item) { - return this.model.applyFilter({}, {parentFk: item.id}).then(() => { - const newData = this.model.data; + return this.fetchFunc({$item: item}).then(newData => { + this.setParent(item, newData); - if (item.childs) { - let childs = item.childs; + const childs = item.childs; + if (childs) { childs.forEach(child => { let index = newData.findIndex(newChild => { return newChild.id == child.id; @@ -53,84 +75,54 @@ export default class Treeview extends Component { }); } - item.childs = newData.sort((a, b) => { - if (b.selected !== a.selected) { - if (a.selected == null) - return 1; - if (b.selected == null) - return -1; - return b.selected - a.selected; - } - - return a.name.localeCompare(b.name); - }); + if (this.sortFunc) { + item.childs = newData.sort((a, b) => + this.sortFunc({$a: a, $b: b}) + ); + } }).then(() => item.active = true); } + onRemove(item) { + if (this.removeFunc) + this.removeFunc({$item: item}); + } + + remove(item) { + const parent = item.parent; + let childs = parent.childs; + + if (!childs) childs = []; + + let index = childs.indexOf(item); + childs.splice(index, 1); + if (parent) parent.sons--; + } + + onCreate(parent) { + if (this.createFunc) + this.createFunc({$parent: parent}); + } + + create(item) { + const parent = item.parent; + let childs = parent.childs; + if (!childs) childs = []; + + childs.push(item); + + if (this.sortFunc) { + childs = childs.sort((a, b) => + this.sortFunc({$a: a, $b: b}) + ); + } + + if (parent) parent.sons++; + } + onDrop(item, dragged, dropped) { this.emit('drop', {item, dragged, dropped}); } - - onRemove(item, items, parent) { - if (!this.removeFunc) return; - let res = this.removeFunc({$item: item, $parent: parent}); - - function remove() { - let index = items.indexOf(item); - items.splice(index, 1); - if (parent) parent.sons--; - } - - if (res instanceof Object && res.then) - res.then(remove); - else if (res) - remove(); - } - - onCreate(parent, childs) { - if (!this.createFunc) return; - let res = this.createFunc({$parent: parent, $childs: childs}); - - function create() { - if (!childs) childs = []; - childs.push(res); - if (parent) parent.sons++; - } - - if (res instanceof Object && res.then) { - if (parent && !parent.active) - this.unfold(parent).then(() => res.then(create)); - else res.then(create); - } else if (res) { - if (parent && !parent.active) - this.unfold(parent).then(() => create()); - else create(); - } else if (parent && !parent.active) - this.unfold(parent); - } - - /* onCreate(parent, childs) { - if (!this.createFunc) return; - let res = this.createFunc({$parent: parent}); - - function create() { - if (!childs) childs = []; - - childs.push(res); - - if (parent) parent.sons++; - } - - if (res instanceof Object && res.then) { - if (!parent.active) - this.unfold(parent).then(() => res.then(create)); - else res.then(create); - } else if (res) { - if (!parent.active) - this.unfold(parent).then(() => create()); - else create(); - } - } */ } Treeview.$inject = ['$element', '$scope', '$transclude']; @@ -139,16 +131,15 @@ ngModule.component('vnTreeview', { template: require('./index.html'), controller: Treeview, bindings: { - model: '<', - icons: ' { - Self.remoteMethod('toggleIsIncluded', { - description: 'Toggle include to delivery', - accepts: [{ - arg: 'zoneFk', - type: 'Number', - required: true, - }, - { - arg: 'item', - type: 'Object', - required: true, - }], - returns: { - type: 'object', - root: true - }, - http: { - path: `/toggleIsIncluded`, - verb: 'POST' - } - }); - - Self.toggleIsIncluded = async(zoneFk, item) => { - if (item.isIncluded === null) - return Self.destroyAll({zoneFk, geoFk: item.id}); - else { - return Self.upsert({ - zoneFk: zoneFk, - geoFk: item.id, - isIncluded: item.isIncluded - }); - } - }; -}; diff --git a/modules/agency/back/methods/zone/getLeaves.js b/modules/agency/back/methods/zone/getLeaves.js index 50ee54345..c45136d4f 100644 --- a/modules/agency/back/methods/zone/getLeaves.js +++ b/modules/agency/back/methods/zone/getLeaves.js @@ -6,10 +6,11 @@ module.exports = Self => { { arg: 'id', type: 'Number', + description: 'The zone id', http: {source: 'path'}, required: true }, { - arg: 'parentFk', + arg: 'parentId', type: 'Number', description: 'Get the children of the specified father', }, { @@ -28,10 +29,10 @@ module.exports = Self => { } }); - Self.getLeaves = async(id, parentFk = null, search) => { + Self.getLeaves = async(id, parentId = null, search) => { let [res] = await Self.rawSql( `CALL zone_getLeaves(?, ?, ?)`, - [id, parentFk, search] + [id, parentId, search] ); let map = new Map(); @@ -49,7 +50,7 @@ module.exports = Self => { } } - let leaves = map.get(parentFk); + let leaves = map.get(parentId); setLeaves(leaves); return leaves || []; diff --git a/modules/agency/back/methods/zone/toggleIsIncluded.js b/modules/agency/back/methods/zone/toggleIsIncluded.js new file mode 100644 index 000000000..ae8f7c571 --- /dev/null +++ b/modules/agency/back/methods/zone/toggleIsIncluded.js @@ -0,0 +1,41 @@ +module.exports = Self => { + Self.remoteMethod('toggleIsIncluded', { + description: 'Toggle include to delivery', + accepts: [{ + arg: 'id', + type: 'Number', + description: 'The zone id', + http: {source: 'path'}, + required: true + }, { + arg: 'geoId', + type: 'Number', + required: true + }, { + arg: 'isIncluded', + type: 'Boolean' + }], + returns: { + type: 'object', + root: true + }, + http: { + path: `/:id/toggleIsIncluded`, + verb: 'POST' + } + }); + + Self.toggleIsIncluded = async(id, geoId, isIncluded) => { + const models = Self.app.models; + + if (isIncluded === undefined) + return models.ZoneIncluded.destroyAll({zoneFk: id, geoFk: geoId}); + else { + return models.ZoneIncluded.upsert({ + zoneFk: id, + geoFk: geoId, + isIncluded: isIncluded + }); + } + }; +}; diff --git a/modules/agency/back/models/zone-included.js b/modules/agency/back/models/zone-included.js deleted file mode 100644 index 6cf1192aa..000000000 --- a/modules/agency/back/models/zone-included.js +++ /dev/null @@ -1,3 +0,0 @@ -module.exports = Self => { - require('../methods/zone-included/toggleIsIncluded')(Self); -}; diff --git a/modules/agency/back/models/zone.js b/modules/agency/back/models/zone.js index a6695bd02..1f8b0a675 100644 --- a/modules/agency/back/models/zone.js +++ b/modules/agency/back/models/zone.js @@ -3,6 +3,7 @@ module.exports = Self => { require('../methods/zone/editPrices')(Self); require('../methods/zone/getLeaves')(Self); require('../methods/zone/getEvents')(Self); + require('../methods/zone/toggleIsIncluded')(Self); Self.validatesPresenceOf('agencyModeFk', { message: `Agency cannot be blank` diff --git a/modules/agency/front/location/index.html b/modules/agency/front/location/index.html index 3d00df006..5d16329dc 100644 --- a/modules/agency/front/location/index.html +++ b/modules/agency/front/location/index.html @@ -1,26 +1,22 @@ + filter="::$ctrl.filter">
      - - + diff --git a/modules/agency/front/location/index.js b/modules/agency/front/location/index.js index 3e3decf23..860e73fcf 100644 --- a/modules/agency/front/location/index.js +++ b/modules/agency/front/location/index.js @@ -8,8 +8,29 @@ class Controller { } onSearch(params) { - this.$.model.applyFilter(null, params); - this.$.$applyAsync(() => this.$.treeview.refresh()); + this.$.model.applyFilter({}, params).then(() => { + const data = this.$.model.data; + this.$.treeview.data = data; + }); + } + + onFetch(item) { + const params = item ? {parentId: item.id} : null; + return this.$.model.applyFilter({}, params).then(() => { + return this.$.model.data; + }); + } + + onSort(a, b) { + if (b.selected !== a.selected) { + if (a.selected == null) + return 1; + if (b.selected == null) + return -1; + return b.selected - a.selected; + } + + return a.name.localeCompare(b.name); } exprBuilder(param, value) { @@ -19,13 +40,11 @@ class Controller { } } - onSelection(item, isIncluded) { - let node = Object.assign({}, item); - node.isIncluded = isIncluded; - node.childs = []; // Data too large - - const path = '/agency/api/ZoneIncludeds/toggleIsIncluded'; - const params = {zoneFk: this.zone.id, item: node}; + onSelection(value, item) { + if (value == null) + value = undefined; + const params = {geoId: item.id, isIncluded: value}; + const path = `/api/zones/${this.zone.id}/toggleIsIncluded`; this.$http.post(path, params); } } diff --git a/modules/worker/front/department/index.html b/modules/worker/front/department/index.html index 16287b349..5da6dafe0 100644 --- a/modules/worker/front/department/index.html +++ b/modules/worker/front/department/index.html @@ -6,9 +6,11 @@
      - + create-func="$ctrl.onCreate($parent)" + sort-func="$ctrl.onSort($a, $b)"> {{::item.name}} diff --git a/modules/worker/front/department/index.js b/modules/worker/front/department/index.js index 050bb215f..0023dcca9 100644 --- a/modules/worker/front/department/index.js +++ b/modules/worker/front/department/index.js @@ -2,13 +2,28 @@ import ngModule from '../module'; class Controller { constructor($scope, $http, vnApp, $translate) { - this.$scope = $scope; + this.$ = $scope; this.$http = $http; this.vnApp = vnApp; this.$translate = $translate; } - onDrop(item, dragged, dropped) { + $postLink() { + this.$.treeview.fetch(); + } + + onFetch(item) { + const params = item ? {parentFk: item.id} : null; + return this.$.model.applyFilter({}, params).then(() => { + return this.$.model.data; + }); + } + + onSort(a, b) { + return a.name.localeCompare(b.name); + } + + /* onDrop(item, dragged, dropped) { if (dropped.scope.item) { const droppedItem = dropped.scope.item; const draggedItem = dragged.scope.item; @@ -20,16 +35,15 @@ class Controller { this.$scope.$apply(); } - } + } */ - onCreate(parent, childs) { + onCreate(parent) { this.newChild = { parent: parent, - childs: childs, name: '' }; - this.$scope.createNode.show(); + this.$.createNode.show(); } onCreateDialogOpen() { @@ -44,15 +58,20 @@ class Controller { const params = {name: this.newChild.name}; const parent = this.newChild.parent; - const parentId = parent && parent.id || null; - let childs = this.newChild.childs; - if (parent) params.parentId = parentId; + if (parent && parent.id) + params.parentId = parent.id; + + if (!parent.active) + this.$.treeview.unfold(parent); const query = `/api/departments/createChild`; - this.$http.post(query, params).then(response => { - if (!childs) childs = []; - childs.push(response.data); + this.$http.post(query, params).then(res => { + const parent = this.newChild.parent; + const item = res.data; + item.parent = parent; + + this.$.treeview.create(item); }); } catch (e) { this.vnApp.showError(this.$translate.instant(e.message)); @@ -64,7 +83,7 @@ class Controller { onRemove(item) { this.removedChild = item; - this.$scope.deleteNode.show(); + this.$.deleteNode.show(); } onRemoveResponse(response) { @@ -72,14 +91,7 @@ class Controller { const childId = this.removedChild.id; const path = `/api/departments/${childId}/removeChild`; this.$http.post(path).then(() => { - items.splice(index, 1); - /* let parent = this.selectedNode.parent; - - if ((parent instanceof Object) && !(parent instanceof Array)) { - const childs = parent.childs; - childs.splice(this.selectedNode.index, 1); - } else if ((parent instanceof Object) && (parent instanceof Array)) - parent.splice(this.selectedNode.index, 1); */ + this.$.treeview.remove(this.removedChild); }); } } From eb655215f4c017b5738554032d82886a5cc45221 Mon Sep 17 00:00:00 2001 From: Joan Sanchez Date: Tue, 8 Oct 2019 09:23:29 +0200 Subject: [PATCH 08/10] merge pull changes --- db/changes/10081-agency/00-zone.sql | 7 +- e2e/helpers/selectors.js | 14 +- .../02-client-module/01_create_client.spec.js | 16 +- front/core/components/calendar/index.js | 24 +- front/core/components/calendar/index.spec.js | 11 +- front/core/components/check/index.html | 2 +- front/core/components/check/index.js | 47 +--- front/core/components/check/style.scss | 45 +--- .../core/components/crud-model/crud-model.js | 12 +- front/core/components/data-viewer/index.html | 31 +++ front/core/components/data-viewer/index.js | 33 +++ front/core/components/data-viewer/style.scss | 14 ++ front/core/components/field/index.html | 36 +++ front/core/components/field/index.js | 178 ++++++++++++++ front/core/components/field/style.scss | 227 ++++++++++++++++++ front/core/components/index.js | 7 +- .../components/model-proxy/model-proxy.js | 22 +- .../components/pagination/pagination.html | 9 +- front/core/components/pagination/style.scss | 3 +- front/core/components/paging/paging.html | 11 - front/core/components/paging/paging.js | 58 ----- front/core/components/paging/paging.spec.js | 65 ----- front/core/components/paging/style.scss | 40 --- front/core/components/popover/popover.js | 5 +- front/core/components/radio/index.js | 69 ++---- front/core/components/radio/index.spec.js | 47 +--- front/core/components/radio/style.scss | 41 +--- front/core/components/table/index.html | 11 +- front/core/components/table/index.js | 16 +- front/core/components/table/style.scss | 9 +- .../components/{radio => toggle}/index.html | 2 +- front/core/components/toggle/index.js | 62 +++++ front/core/components/toggle/style.scss | 50 ++++ front/core/components/treeview/style.scss | 54 ++--- front/core/lib/index.js | 1 - front/core/lib/interpolate.js | 189 --------------- front/core/lib/section.js | 34 +++ front/core/lib/template.js | 8 - front/core/locale/es.yml | 3 + front/core/styles/index.js | 1 - front/core/styles/md-override.scss | 11 - front/core/vendor.js | 5 - front/salix/components/left-menu/left-menu.js | 12 +- .../components/left-menu/left-menu.spec.js | 4 +- front/salix/locale/es.yml | 2 - front/salix/styles/index.js | 1 + front/salix/styles/list.scss | 2 +- front/salix/styles/misc.scss | 12 +- front/salix/styles/photo-list.scss | 2 + front/salix/styles/responsive.scss | 7 + front/salix/styles/variables.scss | 21 +- front/salix/styles/width.scss | 26 ++ modules/agency/front/basic-data/index.html | 16 +- modules/agency/front/calendar/index.html | 2 + modules/agency/front/calendar/index.js | 16 +- modules/agency/front/card/index.html | 2 +- modules/agency/front/events/index.html | 38 ++- modules/agency/front/events/index.js | 35 +-- modules/agency/front/exclusions/index.html | 59 ++--- modules/agency/front/exclusions/index.js | 50 ++-- modules/agency/front/index/index.html | 35 +-- modules/agency/front/location/index.html | 2 +- modules/agency/front/location/index.js | 12 +- modules/agency/front/location/style.scss | 14 ++ modules/agency/front/warehouses/index.html | 17 +- modules/agency/front/warehouses/index.js | 13 +- modules/claim/front/dms/index/index.html | 8 +- modules/claim/front/dms/index/style.scss | 19 +- modules/claim/front/dms/locale/es.yml | 2 +- modules/claim/front/index/index.html | 35 +-- modules/client/back/models/client.js | 2 +- modules/client/front/address/index/index.html | 137 +++++------ modules/client/front/address/index/index.js | 3 +- modules/client/front/balance/index/index.html | 140 +++++------ .../front/credit-insurance/index/index.html | 123 +++++----- .../front/credit-insurance/index/index.js | 2 +- .../front/credit-insurance/index/style.scss | 5 + modules/client/front/credit/index/index.html | 54 +++-- .../client/front/credit/index/locale/es.yml | 3 +- modules/client/front/dms/index/index.html | 187 ++++++++------- modules/client/front/greuge/index/index.html | 39 +-- modules/client/front/index/index.html | 117 ++++----- modules/client/front/mandate/index.html | 55 ++--- modules/client/front/mandate/index.js | 11 +- modules/client/front/note/index/index.html | 18 +- modules/client/front/note/index/index.js | 1 + modules/client/front/note/index/style.scss | 5 + .../client/front/recovery/index/index.html | 80 +++--- .../client/front/recovery/index/locale/es.yml | 1 - modules/client/front/sample/index/index.html | 76 +++--- modules/client/front/summary/locale/es.yml | 2 +- modules/client/front/web-payment/index.html | 95 ++++---- .../client/front/web-payment/locale/es.yml | 1 - modules/invoiceOut/front/index/index.html | 22 +- modules/invoiceOut/front/summary/style.scss | 2 +- modules/item/back/methods/item/filter.js | 23 +- modules/item/front/index/index.html | 62 ++--- modules/item/front/locale/es.yml | 2 - modules/order/front/catalog/index.js | 2 +- modules/order/front/index/index.html | 35 ++- modules/order/front/locale/es.yml | 2 - modules/order/front/summary/style.scss | 3 +- modules/route/front/index/index.html | 49 ++-- modules/route/front/index/style.scss | 2 +- modules/route/front/summary/style.scss | 2 +- modules/route/front/tickets/style.scss | 2 +- .../ticket/specs/transferSales.spec.js | 53 ++-- .../front/basic-data/step-one/index.html | 3 +- .../ticket/front/basic-data/step-one/index.js | 56 ++--- .../front/basic-data/step-one/index.spec.js | 157 +++++++++++- .../ticket/front/descriptor/addStowaway.html | 2 +- modules/ticket/front/index/index.html | 63 ++--- modules/ticket/front/index/style.scss | 1 - modules/ticket/front/summary/index.html | 6 +- modules/ticket/front/summary/style.scss | 19 +- modules/travel/front/index/index.html | 33 +-- modules/worker/front/index/index.html | 120 +++++---- modules/worker/front/log/index.html | 177 +++++++------- modules/worker/front/time-control/index.html | 2 +- modules/worker/front/time-control/index.js | 11 +- package-lock.json | 127 +++++----- 121 files changed, 2282 insertions(+), 1907 deletions(-) create mode 100644 front/core/components/data-viewer/index.html create mode 100644 front/core/components/data-viewer/index.js create mode 100644 front/core/components/data-viewer/style.scss create mode 100644 front/core/components/field/index.html create mode 100644 front/core/components/field/index.js create mode 100644 front/core/components/field/style.scss delete mode 100644 front/core/components/paging/paging.html delete mode 100644 front/core/components/paging/paging.js delete mode 100644 front/core/components/paging/paging.spec.js delete mode 100644 front/core/components/paging/style.scss rename front/core/components/{radio => toggle}/index.html (78%) create mode 100644 front/core/components/toggle/index.js create mode 100644 front/core/components/toggle/style.scss delete mode 100644 front/core/lib/interpolate.js create mode 100644 front/core/lib/section.js delete mode 100644 front/core/styles/md-override.scss create mode 100644 front/salix/styles/width.scss create mode 100644 modules/agency/front/location/style.scss create mode 100644 modules/client/front/credit-insurance/index/style.scss create mode 100644 modules/client/front/note/index/style.scss diff --git a/db/changes/10081-agency/00-zone.sql b/db/changes/10081-agency/00-zone.sql index 6abab582e..d01008a32 100644 --- a/db/changes/10081-agency/00-zone.sql +++ b/db/changes/10081-agency/00-zone.sql @@ -1,5 +1,6 @@ +USE `vn`; -CREATE TABLE vn.`zoneWarehouse` ( +CREATE TABLE `vn`.`zoneWarehouse` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `zoneFk` int(11) NOT NULL, `warehouseFk` smallint(6) unsigned NOT NULL, @@ -10,7 +11,7 @@ CREATE TABLE vn.`zoneWarehouse` ( CONSTRAINT `zoneWarehouse_ibfk_2` FOREIGN KEY (`warehouseFk`) REFERENCES `vn2008`.`warehouse` (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8; -CREATE TABLE vn.`zoneEvent` ( +CREATE TABLE `vn`.`zoneEvent` ( `id` int(11) NOT NULL AUTO_INCREMENT, `zoneFk` int(11) NOT NULL, `from` date DEFAULT NULL, @@ -25,7 +26,7 @@ CREATE TABLE vn.`zoneEvent` ( CONSTRAINT `zoneEvent_ibfk_1` FOREIGN KEY (`zoneFk`) REFERENCES `zone` (`id`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB AUTO_INCREMENT=31 DEFAULT CHARSET=utf8; -CREATE TABLE vn.`zoneExclusion` ( +CREATE TABLE `vn`.`zoneExclusion` ( `id` int(11) NOT NULL AUTO_INCREMENT, `zoneFk` int(11) NOT NULL, `day` date NOT NULL, diff --git a/e2e/helpers/selectors.js b/e2e/helpers/selectors.js index d8a1cda62..351053a02 100644 --- a/e2e/helpers/selectors.js +++ b/e2e/helpers/selectors.js @@ -175,8 +175,8 @@ export default { firstPaymentConfirmed: 'vn-client-web-payment vn-tr:nth-child(1) vn-icon[icon="check"]' }, dms: { - deleteFileButton: 'vn-client-dms-index vn-table vn-tr:nth-child(1) vn-icon-button[icon="delete"]', - firstDocWorker: 'vn-client-dms-index vn-table > div > vn-tbody > vn-tr > vn-td:nth-child(8) > span', + deleteFileButton: 'vn-client-dms-index vn-tr:nth-child(1) vn-icon-button[icon="delete"]', + firstDocWorker: 'vn-client-dms-index vn-td:nth-child(8) > span', firstDocWorkerDescriptor: '.vn-popover.shown vn-worker-descriptor', acceptDeleteButton: 'vn-client-dms-index > vn-confirm button[response="ACCEPT"]' }, @@ -190,8 +190,8 @@ export default { searchItemInput: 'vn-searchbar vn-textfield input', searchButton: 'vn-searchbar vn-icon[icon="search"]', closeItemSummaryPreview: 'vn-item-index [vn-id="preview"] button.close', - fieldsToShowButton: 'vn-item-index vn-table > div.ng-scope > div > vn-icon-button[icon="menu"]', - fieldsToShowForm: 'vn-item-index > div > vn-card > div > vn-table > div.ng-scope > div > vn-dialog > div > form', + fieldsToShowButton: 'vn-item-index vn-table > div > div > vn-icon-button[icon="menu"]', + fieldsToShowForm: 'vn-item-index vn-table > div > div > vn-dialog > div > form', firstItemImage: 'vn-item-index vn-tbody > a:nth-child(1) > vn-td:nth-child(1)', firstItemId: 'vn-item-index vn-tbody > a:nth-child(1) > vn-td:nth-child(2)', idCheckbox: 'vn-item-index vn-dialog form vn-horizontal:nth-child(2) > vn-check', @@ -494,9 +494,9 @@ export default { }, ticketLog: { logButton: 'vn-left-menu a[ui-sref="ticket.card.log"]', - changedBy: 'vn-ticket-log > vn-log > vn-vertical > vn-card > div > vn-vertical > vn-table > div > vn-tbody > vn-tr:nth-child(1) > vn-td:nth-child(2) > span', - actionTaken: 'vn-ticket-log > vn-log > vn-vertical > vn-card > div > vn-vertical > vn-table > div > vn-tbody > vn-tr > vn-td:nth-child(1) > div > div:nth-child(3) > span.value.ng-scope.ng-binding', - id: 'vn-ticket-log > vn-log > vn-vertical > vn-card > div > vn-vertical > vn-table > div > vn-tbody > vn-tr > vn-td.before > vn-one:nth-child(1) > div > span.value.ng-scope.ng-binding' + changedBy: 'vn-ticket-log > vn-log vn-tr:nth-child(1) > vn-td:nth-child(2) > span', + actionTaken: 'vn-ticket-log > vn-log vn-td:nth-child(1) > div > div:nth-child(3) > span.value', + id: 'vn-ticket-log > vn-log vn-td.before > vn-one:nth-child(1) > div > span.value' }, ticketService: { addServiceButton: 'vn-ticket-service vn-icon-button[vn-tooltip="Add service"] > button', diff --git a/e2e/paths/02-client-module/01_create_client.spec.js b/e2e/paths/02-client-module/01_create_client.spec.js index b67a89e68..f2fe30464 100644 --- a/e2e/paths/02-client-module/01_create_client.spec.js +++ b/e2e/paths/02-client-module/01_create_client.spec.js @@ -65,6 +65,18 @@ describe('Client create path', () => { expect(result).toEqual('Some fields are invalid'); }); + it(`should attempt to create a new user with all it's data but wrong postal code`, async() => { + const result = await nightmare + .clearInput(selectors.createClientView.email) + .write(selectors.createClientView.email, 'CarolDanvers@verdnatura.es') + .clearInput(selectors.createClientView.postcode) + .write(selectors.createClientView.postcode, '479999') + .waitToClick(selectors.createClientView.createButton) + .waitForLastSnackbar(); + + expect(result).toEqual(`The postcode doesn't exists. Ensure you put the correct format`); + }); + it(`should check for autocompleted city, province and country`, async() => { const clientCity = await nightmare .waitToGetProperty(`${selectors.createClientView.city}`, 'value'); @@ -82,8 +94,8 @@ describe('Client create path', () => { it(`should create a new user with all correct data`, async() => { const result = await nightmare - .clearInput(selectors.createClientView.email) - .write(selectors.createClientView.email, 'caroldanvers@verdnatura.es') + .clearInput(selectors.createClientView.postcode) + .write(selectors.createClientView.postcode, '46000') .waitToClick(selectors.createClientView.createButton) .waitForLastSnackbar(); diff --git a/front/core/components/calendar/index.js b/front/core/components/calendar/index.js index d473b60d5..3778d64d2 100644 --- a/front/core/components/calendar/index.js +++ b/front/core/components/calendar/index.js @@ -262,10 +262,12 @@ export default class Calendar extends Component { */ select(index) { if (this.disabled) return; - let day = this.days[index]; - day.index = index; + let day = this.days[index].dated; - this.emit('selection', {values: [day]}); + this.emit('selection', { + $days: [day], + $type: 'day' + }); } /** @@ -276,15 +278,17 @@ export default class Calendar extends Component { selectAll(weekday) { if (this.disabled) return; - let selected = []; + let days = []; for (let i in this.days) { - const day = this.days[i]; - const date = day.dated; - day.index = i; - if (date.getDay() === weekday && date.getMonth() == this.defaultDate.getMonth()) - selected.push(day); + const day = this.days[i].dated; + if (day.getDay() === weekday && day.getMonth() == this.defaultDate.getMonth()) + days.push(day); } - this.emit('selection', {values: selected}); + this.emit('selection', { + $days: days, + $type: 'weekday', + $weekday: weekday + }); } renderStyle(style) { diff --git a/front/core/components/calendar/index.spec.js b/front/core/components/calendar/index.spec.js index 174bc7997..21915eed4 100644 --- a/front/core/components/calendar/index.spec.js +++ b/front/core/components/calendar/index.spec.js @@ -60,12 +60,17 @@ describe('Component vnCalendar', () => { describe('select()', () => { it(`should return the selected element, then emit a 'selection' event`, () => { spyOn(controller, 'emit'); - const days = [{dated: new Date()}]; + const dated = new Date(); + const days = [{dated}]; controller.days = days; - controller.select(0); - expect(controller.emit).toHaveBeenCalledWith('selection', {values: days}); + let res = { + $days: [dated], + $type: 'day' + }; + + expect(controller.emit).toHaveBeenCalledWith('selection', res); }); }); diff --git a/front/core/components/check/index.html b/front/core/components/check/index.html index dd0a5d012..8c8171410 100644 --- a/front/core/components/check/index.html +++ b/front/core/components/check/index.html @@ -1,4 +1,4 @@ -
      +
      diff --git a/front/core/components/check/index.js b/front/core/components/check/index.js index 471be638a..35ff07e8a 100644 --- a/front/core/components/check/index.js +++ b/front/core/components/check/index.js @@ -1,29 +1,16 @@ import ngModule from '../../module'; -import Component from '../../lib/component'; +import Toggle from '../toggle'; import './style.scss'; /** * Basic element for user input. You can use this to supply a way for the user * to toggle an option. * - * @property {String} label Label to display along the component - * @property {any} field The value with which the element is linked - * @property {Boolean} checked Whether the checkbox is checked - * @property {Boolean} disabled Put component in disabled mode * @property {Boolean} tripleState Switch between three states when clicked * @property {Boolean} indeterminate Sets the element into indeterminate state * @property {String} info Shows a text information tooltip to the user */ -export default class Controller extends Component { - constructor($element, $, $attrs) { - super($element, $); - - let element = this.element; - element.addEventListener('click', e => this.onClick(e)); - element.addEventListener('keydown', e => this.onKeydown(e)); - element.tabIndex = 0; - } - +export default class Check extends Toggle { set field(value) { this._field = value; this.element.classList.toggle('checked', Boolean(value)); @@ -34,14 +21,12 @@ export default class Controller extends Component { return this._field; } - set disabled(value) { - this.element.tabIndex = !value ? 0 : -1; - this.element.classList.toggle('disabled', Boolean(value)); - this._disabled = value; + set checked(value) { + this.field = Boolean(value); } - get disabled() { - return this._disabled; + get checked() { + return Boolean(this.field); } set indeterminate(value) { @@ -63,9 +48,7 @@ export default class Controller extends Component { } onClick(event) { - event.preventDefault(); - - if (this.disabled) return; + if (super.onClick(event)) return; if (this.tripleState) { if (this.field == null) @@ -77,28 +60,18 @@ export default class Controller extends Component { } else this.field = !this.field; - this.$.$applyAsync(); - this.element.dispatchEvent(new Event('change')); - this.emit('change', {value: this.field}); - } - - onKeydown(event) { - if (event.code == 'Space') - this.onClick(event); + this.changed(); } } -Controller.$inject = ['$element', '$scope', '$attrs']; - ngModule.component('vnCheck', { template: require('./index.html'), - controller: Controller, - + controller: Check, bindings: { label: '@?', field: '=?', - checked: ' .check { - position: relative; - box-sizing: border-box; - display: inline-block; - vertical-align: middle; + & > .btn { border-radius: 2px; - width: 20px; - height: 20px; transition: background 250ms; - border: 2px solid #666; - margin: 6px 0; - margin-right: .4em; & > .mark { box-sizing: border-box; @@ -29,13 +12,10 @@ vn-check { border-width: 0; } } - &.checked > .check { - background-color: $color-main; + &.checked > .btn { border-color: $color-main; + background-color: $color-main; - & > .focus-mark { - background-color: rgba($color-main, .15); - } & > .mark { top: 0; left: 4px; @@ -47,7 +27,7 @@ vn-check { border-left: 0; } } - &.indeterminate > .check > .mark { + &.indeterminate > .btn > .mark { top: 50%; left: 50%; transform: translate(-50%, -50%); @@ -55,23 +35,6 @@ vn-check { height: 2px; border-bottom: 2px solid #666; } - & > .check > .focus-mark { - position: absolute; - top: 50%; - left: 50%; - height: 38px; - width: 38px; - margin-top: -19px; - margin-left: -19px; - border-radius: 50%; - transform: scale3d(0, 0, 0); - transition: background 250ms; - transition: transform 250ms; - background-color: rgba(0, 0, 0, .1); - } - &:focus:not(.disabled) > .check > .focus-mark { - transform: scale3d(1, 1, 1); - } & > vn-icon { margin-left: 5px; color: $color-font-secondary; diff --git a/front/core/components/crud-model/crud-model.js b/front/core/components/crud-model/crud-model.js index 4f3058305..0839881ab 100644 --- a/front/core/components/crud-model/crud-model.js +++ b/front/core/components/crud-model/crud-model.js @@ -207,8 +207,8 @@ export default class CrudModel extends ModelProxy { sendRequest(filter, append) { this.cancelRequest(); this.canceler = this.$q.defer(); - this.isRefreshing = !append; this.isPaging = append; + if (!append) this.status = 'loading'; let params = Object.assign( {filter}, @@ -221,9 +221,8 @@ export default class CrudModel extends ModelProxy { return this.$http.get(this._url, options).then( json => this.onRemoteDone(json, filter, append), - json => this.onRemoteError(json) + json => this.onRemoteError(json, append) ).finally(() => { - this.isRefreshing = false; this.isPaging = false; }); } @@ -243,7 +242,12 @@ export default class CrudModel extends ModelProxy { this.onRequestEnd(); } - onRemoteError(err) { + onRemoteError(err, append) { + if (!append) { + this.clear(); + this.status = 'error'; + } + this.onRequestEnd(); throw err; } diff --git a/front/core/components/data-viewer/index.html b/front/core/components/data-viewer/index.html new file mode 100644 index 000000000..dd696fda3 --- /dev/null +++ b/front/core/components/data-viewer/index.html @@ -0,0 +1,31 @@ +
      +
      + + +
      +
      + + + + Enter a new search + + + Ups! It seems there was an error + + + No results + +
      \ No newline at end of file diff --git a/front/core/components/data-viewer/index.js b/front/core/components/data-viewer/index.js new file mode 100644 index 000000000..1f967d94b --- /dev/null +++ b/front/core/components/data-viewer/index.js @@ -0,0 +1,33 @@ +import ngModule from '../../module'; +import './style.scss'; + +export default class DataViewer { + get isReady() { + return this.status == 'ready'; + } + + get status() { + if (this.model) + return this.model.status; + + if (this.isLoading) + return 'loading'; + if (!this.data) + return 'clear'; + if (this.data.length) + return 'ready'; + else + return 'empty'; + } +} + +ngModule.component('vnDataViewer', { + template: require('./index.html'), + transclude: true, + controller: DataViewer, + bindings: { + model: ' .empty-rows { + display: block; + text-align: center; + padding: 1.5em; + box-sizing: border-box; + color: $color-font-secondary; + font-size: 1.4em; + } +} \ No newline at end of file diff --git a/front/core/components/field/index.html b/front/core/components/field/index.html new file mode 100644 index 000000000..a2401ee4f --- /dev/null +++ b/front/core/components/field/index.html @@ -0,0 +1,36 @@ +
      +
      +
      +
      +
      +
      + +
      +
      + +
      +
      + + + + +
      +
      +
      +
      +
      +
      +
      diff --git a/front/core/components/field/index.js b/front/core/components/field/index.js new file mode 100644 index 000000000..5d78f0d66 --- /dev/null +++ b/front/core/components/field/index.js @@ -0,0 +1,178 @@ +import ngModule from '../../module'; +import Component from '../../lib/component'; +import './style.scss'; + +export default class Field extends Component { + constructor($element, $scope) { + super($element, $scope); + this._value = undefined; + this.prefix = null; + this.suffix = null; + + this.input = this.element.querySelector('input'); + this.classList = this.element.classList; + this.classList.add('vn-field'); + + this.element.addEventListener('focusin', + () => this.onFocus(true)); + this.element.addEventListener('focusout', + () => this.onFocus(false)); + this.element.addEventListener('click', + () => this.onClick()); + } + + $onInit() { + if (this.info) this.classList.add('has-icons'); + } + + set field(value) { + this._field = value; + this.classList.toggle('not-empty', value != null && value !== ''); + } + + get field() { + return this._field; + } + + set type(value) { + this.input.type = value; + } + + get type() { + return this.input.type; + } + + set disabled(value) { + this._disabled = boolTag(value); + this.input.disabled = this._disabled; + this.classList.toggle('disabled', this._disabled); + } + + get disabled() { + return this._disabled; + } + + set readonly(value) { + this._readonly = boolTag(value); + this.input.readOnly = this._readonly; + this.classList.toggle('readonly', this._readonly); + } + + get readonly() { + return this._readonly; + } + + set required(value) { + this._required = boolTag(value); + let required = this.element.querySelector('.required'); + display(required, this._required); + } + + get required() { + return this._required; + } + + set prefix(value) { + this._prefix = value; + this.refreshFix('.prefix', value); + } + + get prefix() { + return this._prefix; + } + + set suffix(value) { + this._suffix = value; + this.refreshFix('.suffix', value); + } + + get suffix() { + return this._suffix; + } + + set hint(value) { + this._hint = value; + this.refreshHint(); + } + + get hint() { + return this._hint; + } + + set error(value) { + this._error = value; + this.refreshHint(); + this.classList.toggle('invalid', Boolean(value)); + } + + get error() { + return this._error; + } + + refreshHint() { + let hint = this.error || this.hint || ''; + let hintEl = this.element.querySelector('.hint'); + hintEl.innerText = hint; + hintEl.classList.toggle('filled', Boolean(hint)); + } + + refreshFix(selector, text) { + let fix = this.element.querySelector(selector); + display(fix, text); + fix.innerText = text || ''; + } + + onClick() { + if (this.input !== document.activeElement) + this.input.focus(); + } + + onFocus(hasFocus) { + this.classList.toggle('focused', hasFocus); + } + + onClear() { + this.input.value = ''; + this.input.dispatchEvent(new Event('change')); + } + + focus() { + this.input.focus(); + } + + select() { + this.input.select(); + } +} +Field.$inject = ['$element', '$scope']; + +ngModule.component('vnField', { + template: require('./index.html'), + transclude: { + prepend: '?prepend', + append: '?append' + }, + controller: Field, + bindings: { + field: '=?', + label: '@?', + name: '@?', + type: '@?', + info: '@?', + disabled: '@?', + readonly: '@?', + required: '@?', + prefix: '@?', + suffix: '@?', + hint: '@?', + error: ' .container { + display: flex; + align-items: stretch; + position: relative; + height: 56px; + + & > .infix { + position: relative; + display: flex; + flex: auto; + width: 100%; + min-width: 0; + + & > label { + position: absolute; + left: 0; + top: 18px; + line-height: 20px; + pointer-events: none; + color: $color-font-secondary; + transition-property: top, color, font-size; + transition-duration: 400ms; + transition-timing-function: cubic-bezier(.4, 0, .2, 1); + + & > .required { + display: none; + color: $color-alert + } + } + & > .fix { + padding-top: 24px; + line-height: 24px; + font-size: $input-font-size; + opacity: 0; + transition: opacity 200ms ease-in-out; + + &.prefix { + padding-right: 5px; + } + &.suffix { + padding-left: 5px; + } + } + & > .control { + height: 100%; + flex: auto; + } + & > .control > input { + padding-top: 24px; + padding-bottom: 8px; + height: inherit; + outline: none; + border: none; + font-family: Arial, sans-serif; + display: block; + font-size: $input-font-size; + width: 100%; + background: 0; + color: inherit; + box-sizing: border-box; + + &[type=time], + &[type=date] { + clip-path: inset(0 20px 0 0); + } + &[type=number] { + -moz-appearance: textfield; + + &::-webkit-outer-spin-button, + &::-webkit-inner-spin-button { + -webkit-appearance: none; + margin: 0; + } + } + &:invalid { + box-shadow: none; + } + } + } + & > .prepend, + & > .append, + & > .icons { + display: flex; + align-items: center; + color: $color-font-secondary; + } + & > .prepend > prepend, + & > .append > append, + & > .icons { + display: flex; + + & > vn-icon { + font-size: 24px; + } + } + & > .prepend > prepend { + padding-right: 12px; + } + & > .append > append { + padding-left: 12px; + } + & > .icons > vn-icon[icon=clear] { + display: none; + cursor: pointer; + } + & > .underline { + position: absolute; + bottom: 0; + content: ' '; + pointer-events: none; + width: 100%; + + &.blur { + border-bottom: 1px solid $color-input-underline; + transition: border-color 200ms ease-in-out; + } + &.focus { + height: 2px; + background-color: $color-main; + left: 50%; + width: 0; + transition-property: width, left, background-color; + transition-duration: 300ms; + transition-timing-function: cubic-bezier(.4, 0, .2, 1); + } + } + } + &.not-empty > .container, + &.focused > .container { + & > .infix { + & > .fix { + opacity: 1; + } + & > label { + top: 5px; + color: $color-main; + padding: 0; + font-size: 12px; + } + } + } + &.has-icons, + &.not-empty:hover, + &.not-empty.focused { + & > .container > .append > append { + padding-left: 0; + } + & > .container > .icons { + padding-left: 12px; + } + } + &:not(.disabled):not(.readonly) { + &.focused > .container > .underline.focus { + left: 0; + width: 100%; + } + & > .container:hover > .underline.blur { + border-color: $color-input-underline-hover; + } + &.not-empty:hover, + &.not-empty.focused { + & > .container > .icons > vn-icon[icon=clear] { + display: initial; + } + } + } + &:not(.not-empty):not(.focused) > .container > .infix > .control > input { + &[type=time], + &[type=date] { + opacity: 0; + } + } + &.readonly > .container { + & > .infix > .control > input { + caret-color: transparent; + } + & > .underline.blur { + border-bottom-style: dashed; + } + } + & > .hint { + z-index: -1; + padding-top: 8px; + height: 20px; + color: rgba(0, 0, 0, .4); + font-size: 12px; + transform: translateY(-28px); + transition-property: opacity, transform, color; + transition-duration: 200ms; + transition-timing-function: ease-in-out; + opacity: 0; + + &.filled { + z-index: 0; + opacity: 1; + transform: translateY(0); + } + } + &.invalid { + & > .container { + & > .infix > label { + color: $color-alert; + } + & > .underline.focus { + background-color: $color-alert; + } + & > .underline.blur { + border-bottom-color: $color-alert; + opacity: 1; + } + } + & > .hint { + color: $color-alert; + } + } +} +vn-table { + .vn-field { + margin: 0; + } +} diff --git a/front/core/components/index.js b/front/core/components/index.js index 50d0b5e94..0dec50778 100644 --- a/front/core/components/index.js +++ b/front/core/components/index.js @@ -26,20 +26,21 @@ import './card/card'; import './float-button/float-button'; import './step-control/step-control'; import './label-value/label-value'; -import './paging/paging'; import './pagination/pagination'; import './searchbar/searchbar'; import './scroll-up/scroll-up'; -import './table'; -import './td-editable'; import './input-range'; import './calendar'; import './check'; import './chip'; import './color-legend'; +import './data-viewer'; +import './field'; import './input-number'; import './input-time'; import './input-file'; import './radio'; +import './table'; +import './td-editable'; import './th'; import './treeview'; diff --git a/front/core/components/model-proxy/model-proxy.js b/front/core/components/model-proxy/model-proxy.js index 342841bda..1eaf749d5 100644 --- a/front/core/components/model-proxy/model-proxy.js +++ b/front/core/components/model-proxy/model-proxy.js @@ -57,6 +57,7 @@ export default class ModelProxy extends DataModel { constructor($element, $scope) { super($element, $scope); this.resetChanges(); + this.status = 'clear'; } get orgData() { @@ -90,6 +91,14 @@ export default class ModelProxy extends DataModel { set data(value) { this._data = value; + + if (value == null) + this.status = 'clear'; + else if (value.length) + this.status = 'ready'; + else + this.status = 'empty'; + this.emit('dataChange'); this.emit('dataUpdate'); } @@ -109,8 +118,12 @@ export default class ModelProxy extends DataModel { this.removed.push(item); this.isChanged = true; + if (!this.data.length) + this.status = 'empty'; + this.emit('rowRemove', index); this.emit('dataUpdate'); + if (this.autoSave) this.save(); } @@ -131,8 +144,11 @@ export default class ModelProxy extends DataModel { this.data.push(newRow); this.isChanged = true; + this.status = 'ready'; + this.emit('rowInsert', index); this.emit('dataUpdate'); + return index; } @@ -322,10 +338,10 @@ export class Paginable { } /** - * @type {Boolean} Whether the model is refreshing. + * @type {ready|loading|clear|empty|error} The current model status. */ - get isRefreshing() { - return false; + get status() { + return null; } /** diff --git a/front/core/components/pagination/pagination.html b/front/core/components/pagination/pagination.html index 9da15c002..5bc1b67f6 100644 --- a/front/core/components/pagination/pagination.html +++ b/front/core/components/pagination/pagination.html @@ -1,13 +1,12 @@ -
      +
      + ng-if="$ctrl.model.isPaging" + enable="::true">
      \ No newline at end of file diff --git a/front/core/components/pagination/style.scss b/front/core/components/pagination/style.scss index 0cacb53e3..2610bc502 100644 --- a/front/core/components/pagination/style.scss +++ b/front/core/components/pagination/style.scss @@ -3,7 +3,8 @@ vn-pagination { display: block; text-align: center; - & > div > vn-icon-button { + & > div > vn-icon-button { font-size: 2em; + padding: 0; } } \ No newline at end of file diff --git a/front/core/components/paging/paging.html b/front/core/components/paging/paging.html deleted file mode 100644 index 6e71f321d..000000000 --- a/front/core/components/paging/paging.html +++ /dev/null @@ -1,11 +0,0 @@ - - \ No newline at end of file diff --git a/front/core/components/paging/paging.js b/front/core/components/paging/paging.js deleted file mode 100644 index 850b9c722..000000000 --- a/front/core/components/paging/paging.js +++ /dev/null @@ -1,58 +0,0 @@ -import ngModule from '../../module'; -import './style.scss'; - -export default class Paging { - get numPages() { - return Math.ceil(this.numItems / this.numPerPage); - } - - constructor($http, $scope) { - this.$http = $http; - this.$scope = $scope; - this.where = this.filter; - this.numPerPage = null; - this.numItems = 0; - $scope.$watch('$ctrl.index.model.length', () => this.onModelUpdated()); - } - - $onChanges(changes) { - if (!this.index) return; - this.numPerPage = this.index.filter.size; - this.currentPage = this.index.filter.page; - if (changes.total) - this.numItems = changes.total.currentValue; - } - - onModelUpdated() { - let index = this.index; - let filter = index.filter; - - if (filter.page >= this.numPages && index.model.length >= this.numPerPage) - this.numItems = filter.page * filter.size + 1; - } - - onPageChange(page) { - this.index.filter.page = page; - if (typeof this.pageChange === 'undefined') { - this.index.accept(); - } else { - this.pageChange(); - } - } - $doCheck() { - if (this.index && this.index.filter && this.index.filter.page && this.index.filter.page != this.currentPage) { - this.currentPage = this.index.filter.page; - } - } -} -Paging.$inject = ['$http', '$scope']; - -ngModule.component('vnPaging', { - template: require('./paging.html'), - bindings: { - index: '<', - pageChange: '&?', - total: '<' - }, - controller: Paging -}); diff --git a/front/core/components/paging/paging.spec.js b/front/core/components/paging/paging.spec.js deleted file mode 100644 index 9f6023ff6..000000000 --- a/front/core/components/paging/paging.spec.js +++ /dev/null @@ -1,65 +0,0 @@ -import './paging.js'; - -describe('Component vnPaging', () => { - let $scope; - let controller; - - beforeEach(angular.mock.module('vnCore', $translateProvider => { - $translateProvider.translations('en', {}); - })); - - beforeEach(angular.mock.inject(($componentController, $rootScope) => { - $scope = $rootScope.$new(); - controller = $componentController('vnPaging', {$scope}); - })); - - describe('$onChanges()', () => { - it(`should define numberPage and currentPage based on index.filter properties`, () => { - controller.index = {filter: {size: 'something', page: 'something else'}}; - controller.$onChanges({index: 'simpleChange', currentValue: 'current value', previousValue: 'previous value'}); - - expect(controller.numPerPage).toBe(controller.index.filter.size); - expect(controller.currentPage).toEqual(controller.index.filter.page); - }); - - it(`should define numItems based on changes.total.currentValue`, () => { - controller.index = {filter: {size: 'something', page: 'something else'}}; - controller.$onChanges({total: {currentValue: 'current value'}}); - - expect(controller.numItems).toEqual('current value'); - }); - }); - - describe('onModelUpdated()', () => { - it(`should define controllers numItems as the result of page times size plus one`, () => { - controller.numPerPage = 2; - controller.index = { - filter: {size: 10, page: 10}, - model: ['one mother..', 'another model..', 'last model..'] - }; - controller.onModelUpdated(); - - expect(controller.numItems).toBe(101); - }); - }); - - describe('onPageChange()', () => { - it(`should call accept() since pageChange property is undefined`, () => { - controller.index = {accept: () => {}, filter: {page: 0}}; - spyOn(controller.index, 'accept'); - controller.onPageChange(100); - - expect(controller.index.accept).toHaveBeenCalledWith(); - }); - - it(`should call pageChange() since pageChange property isn't undefined`, () => { - controller.index = {accept: () => {}, filter: {page: 0}}; - controller.pageChange = true; - spyOn(controller, 'pageChange'); - controller.onPageChange(100); - - expect(controller.pageChange).toHaveBeenCalledWith(); - }); - }); -}); - diff --git a/front/core/components/paging/style.scss b/front/core/components/paging/style.scss deleted file mode 100644 index e88202e49..000000000 --- a/front/core/components/paging/style.scss +++ /dev/null @@ -1,40 +0,0 @@ -@import "variables"; - -vn-paging { - display: block; - text-align: center; - - ul { - box-shadow: 0 0 .4em $color-shadow; - background-color: #fff; - display: inline-block; - margin: 20px 0; - border-radius: .1em; - padding: 0; - } - li { - display: inline; - - &:first-child > a, - &:first-child > span { - margin-left: 0; - } - &.active > a { - background: $color-active; - color: #fff; - } - & > a, - & > span { - position: relative; - float: left; - padding: 6px 12px; - margin-left: -1px; - line-height: 1.42857143; - color: inherit; - text-decoration: none; - } - &:not(.active) > a:hover { - background-color: #ddd; - } - } -} diff --git a/front/core/components/popover/popover.js b/front/core/components/popover/popover.js index 8babe867d..be6546246 100644 --- a/front/core/components/popover/popover.js +++ b/front/core/components/popover/popover.js @@ -180,11 +180,8 @@ export default class Popover extends Component { onDocKeyDown(event) { if (event.defaultPrevented) return; - - if (event.keyCode == 27) { // Esc - event.preventDefault(); + if (event.code == 'Escape') this.hide(); - } } onMouseDown(event) { diff --git a/front/core/components/radio/index.js b/front/core/components/radio/index.js index a8475c256..e965196c8 100644 --- a/front/core/components/radio/index.js +++ b/front/core/components/radio/index.js @@ -1,29 +1,14 @@ import ngModule from '../../module'; -import Component from '../../lib/component'; +import Toggle from '../toggle'; import './style.scss'; /** * Basic element for user input. You can use this to supply a way for the user * to pick an option from multiple choices. * - * @property {String} label Label to display along the component - * @property {any} field The value with which the element is linked - * @property {Boolean} checked Whether the radio is checked * @property {String} val The actual value of the option - * @property {Boolean} disabled Put component in disabled mode */ -export default class Controller extends Component { - constructor($element, $, $attrs) { - super($element, $); - this.hasInfo = Boolean($attrs.info); - this.info = $attrs.info || null; - - let element = this.element; - element.addEventListener('click', e => this.onClick(e)); - element.addEventListener('keydown', e => this.onKeydown(e)); - element.tabIndex = 0; - } - +export default class Radio extends Toggle { set field(value) { this._field = value; this.element.classList.toggle('checked', @@ -34,6 +19,14 @@ export default class Controller extends Component { return this._field; } + set checked(value) { + this.field = value ? this.val : null; + } + + get checked() { + return this.field == this.val; + } + set val(value) { this._val = value; this.field = this.field; @@ -43,51 +36,21 @@ export default class Controller extends Component { return this._val; } - set checked(value) { - this.field = value ? this.val : null; - this.$.$applyAsync(); - } - - get checked() { - return this.field == this.val; - } - - set disabled(value) { - this.element.tabIndex = !value ? 0 : -1; - this.element.classList.toggle('disabled', Boolean(value)); - this._disabled = value; - } - - get disabled() { - return this._disabled; - } - onClick(event) { - if (this.disabled) return; - event.preventDefault(); - + if (super.onClick(event)) return; this.field = this.val; - this.$.$applyAsync(); - this.element.dispatchEvent(new Event('change')); - } - - onKeydown(event) { - if (event.code == 'Space') - this.onClick(event); + this.changed(); } } -Controller.$inject = ['$element', '$scope', '$attrs']; - ngModule.component('vnRadio', { - template: require('./index.html'), - controller: Controller, - + template: require('../toggle/index.html'), + controller: Radio, bindings: { label: '@?', field: '=?', + disabled: ' { +describe('Component vnRadio', () => { let $element; let $ctrl; let element; @@ -8,8 +8,8 @@ describe('Component vnCheck', () => { })); beforeEach(inject(($compile, $rootScope) => { - $element = $compile(` { }); describe('field() setter', () => { - it(`should set model value`, () => { - $ctrl.field = true; - - expect($ctrl.field).toEqual(true); - }); - - it(`should uncheck value and change to true when clicked`, () => { - $ctrl.field = false; + it(`should change field value when clicked`, () => { element.click(); - expect($ctrl.field).toEqual(true); - }); - - it(`should check value and change to false when clicked`, () => { - $ctrl.field = true; - element.click(); - - expect($ctrl.field).toEqual(false); - }); - - it(`should uncheck value and change to null when clicked`, () => { - $ctrl.field = false; - $ctrl.tripleState = true; - element.click(); - - expect($ctrl.field).toEqual(null); - }); - - it(`should set value to null and change to true when clicked`, () => { - $ctrl.field = null; - $ctrl.tripleState = true; - element.click(); - - expect($ctrl.field).toEqual(true); - }); - - it(`should cast value to boolean when clicked`, () => { - $ctrl.field = 0; - element.click(); - - expect($ctrl.field).toEqual(true); + expect($ctrl.field).toEqual('myVal'); }); }); }); diff --git a/front/core/components/radio/style.scss b/front/core/components/radio/style.scss index de49286b4..dd1555b7f 100644 --- a/front/core/components/radio/style.scss +++ b/front/core/components/radio/style.scss @@ -1,31 +1,14 @@ @import "variables"; vn-radio { - position: relative; - cursor: pointer; - display: inline-block; - outline: none; - - &.disabled { - cursor: initial; - } - & > .radio { - position: relative; - box-sizing: border-box; - display: inline-block; - vertical-align: middle; + & > .btn { border-radius: 50%; - width: 20px; - height: 20px; - border: 2px solid #666; - margin: 6px 0; - margin-right: .4em; & > .mark { transition: background 250ms; } } - &.checked > .radio { + &.checked > .btn { border-color: $color-main; & > .mark { @@ -38,25 +21,5 @@ vn-radio { height: 10px; background-color: $color-main; } - & > .focus-mark { - background-color: rgba($color-main, .15); - } - } - & > .radio > .focus-mark { - position: absolute; - top: 50%; - left: 50%; - height: 38px; - width: 38px; - margin-top: -19px; - margin-left: -19px; - border-radius: 50%; - transform: scale3d(0, 0, 0); - transition: background 250ms; - transition: transform 250ms; - background-color: rgba(0, 0, 0, .1); - } - &:focus:not(.disabled) > .radio > .focus-mark { - transform: scale3d(1, 1, 1); } } diff --git a/front/core/components/table/index.html b/front/core/components/table/index.html index a5abd1c66..e7ae44886 100644 --- a/front/core/components/table/index.html +++ b/front/core/components/table/index.html @@ -1,11 +1,2 @@ -
      - - - - - Enter a new search - - - No results - +
      \ No newline at end of file diff --git a/front/core/components/table/index.js b/front/core/components/table/index.js index d091e8345..0b9236c84 100644 --- a/front/core/components/table/index.js +++ b/front/core/components/table/index.js @@ -8,18 +8,6 @@ export default class Table { this.field = null; this.order = null; this.autoLoad = true; - - $transclude($scope.$parent, clone => { - angular.element($element[0].querySelector('.table')).append(clone); - }); - } - - get isRefreshing() { - return (this.model && this.model.isRefreshing); - } - - get isPaging() { - return (this.model && this.model.isPaging); } setOrder(field, order) { @@ -37,7 +25,9 @@ export default class Table { } $onChanges() { - if (this.model && this.autoLoad) + // FIXME: The autoload property should be removed from vnTable + // because it's already implemented at vnModel + if (this.autoLoad && this.model && !this.model.data) this.applyOrder(); } diff --git a/front/core/components/table/style.scss b/front/core/components/table/style.scss index 29b163950..9c14e3e03 100644 --- a/front/core/components/table/style.scss +++ b/front/core/components/table/style.scss @@ -51,14 +51,15 @@ vn-table { } & > * > vn-tr, & > * > a.vn-tr { - display: table-row + display: table-row; + height: 3em; } vn-thead, vn-tbody, vn-tfoot { & > * { display: table-row; & > vn-th { - font-weight: bold; + color: $color-font-light; padding-top: 1em; padding-bottom: .8em; } @@ -97,10 +98,10 @@ vn-table { } } & > :last-child { - padding-right: 1em; + padding-right: 1.4em; } & > :first-child { - padding-left: 1em; + padding-left: 1.4em; } } & > a.vn-tr { diff --git a/front/core/components/radio/index.html b/front/core/components/toggle/index.html similarity index 78% rename from front/core/components/radio/index.html rename to front/core/components/toggle/index.html index 8a8e12b8f..3ec11242e 100644 --- a/front/core/components/radio/index.html +++ b/front/core/components/toggle/index.html @@ -1,4 +1,4 @@ -
      +
      diff --git a/front/core/components/toggle/index.js b/front/core/components/toggle/index.js new file mode 100644 index 000000000..7642c8973 --- /dev/null +++ b/front/core/components/toggle/index.js @@ -0,0 +1,62 @@ +import ngModule from '../../module'; +import Component from '../../lib/component'; +import './style.scss'; + +/** + * Base component with common logic and styles for checkbox and radio button. + * + * @property {String} label Label to display along the component + * @property {any} field The value with which the element is linked + * @property {Boolean} checked Whether the checkbox is checked + * @property {Boolean} disabled Put component in disabled mode + */ +export default class Toggle extends Component { + constructor($element, $) { + super($element, $); + + let element = this.element; + element.tabIndex = 0; + element.addEventListener('click', e => this.onClick(e)); + element.addEventListener('keydown', e => this.onKeydown(e)); + element.classList.add('vn-toggle'); + } + + set disabled(value) { + this.element.tabIndex = !value ? 0 : -1; + this.element.classList.toggle('disabled', Boolean(value)); + this._disabled = value; + } + + get disabled() { + return this._disabled; + } + + onKeydown(event) { + if (event.code == 'Space') + this.onClick(event); + } + + onClick(event) { + if (this.disabled || event.defaultPrevented) + return true; + + event.preventDefault(); + } + + changed() { + this.$.$applyAsync(); + this.element.dispatchEvent(new Event('change')); + this.emit('change', {value: this.field}); + } +} +Toggle.$inject = ['$element', '$scope']; + +ngModule.component('vnToggle', { + controller: Toggle, + bindings: { + label: '@?', + field: '=?', + disabled: ' span { + font-size: $input-font-size; + } + & > .btn { + position: relative; + box-sizing: border-box; + display: inline-block; + vertical-align: middle; + width: 20px; + height: 20px; + margin: 6px 0; + margin-right: .4em; + border: 2px solid #666; + } + &.checked > .btn { + border-color: $color-main; + + & > .focus-mark { + background-color: rgba($color-main, .15); + } + } + & > .btn > .focus-mark { + position: absolute; + top: 50%; + left: 50%; + height: 38px; + width: 38px; + margin-top: -19px; + margin-left: -19px; + border-radius: 50%; + transform: scale3d(0, 0, 0); + transition: background 250ms; + transition: transform 250ms; + background-color: rgba(0, 0, 0, .1); + } + &:focus:not(.disabled) > .btn > .focus-mark { + transform: scale3d(1, 1, 1); + } +} diff --git a/front/core/components/treeview/style.scss b/front/core/components/treeview/style.scss index 0beee8e7c..c3a7e3cab 100644 --- a/front/core/components/treeview/style.scss +++ b/front/core/components/treeview/style.scss @@ -1,11 +1,5 @@ @import "effects"; -vn-treeview { - & > .add-item { - @extend %clickable; - } -} - vn-treeview-childs { display: block; @@ -13,9 +7,26 @@ vn-treeview-childs { padding: 0; margin: 0; - & > li { + li { list-style: none; + & > .node { + @extend %clickable; + display: flex; + padding: 5px; + align-items: center; + } + + & > div > .arrow { + min-width: 24px; + margin-right: 10px; + transition: transform 200ms; + } + + & > div.expanded > .arrow { + transform: rotate(180deg); + } + ul { padding-left: 2.2em; } @@ -35,33 +46,8 @@ vn-treeview-childs { .node:hover > .buttons { display: block } - - & > ul > li > .node { - @extend %clickable; - display: flex; - padding: 5px; - align-items: center; - - & > .arrow { - min-width: 24px; - margin-right: 10px; - transition: transform 200ms; - } - &.expanded > .arrow { - transform: rotate(180deg); - } - & > vn-check:not(.indeterminate) { - color: $color-main; - - & > .check { - border-color: $color-main; - } - } - & > vn-check.checked { - color: $color-main; - } - } } + vn-treeview-content { - flex-grow: 1; + flex-grow: 1 } \ No newline at end of file diff --git a/front/core/lib/index.js b/front/core/lib/index.js index d6e47b118..dac8e460d 100644 --- a/front/core/lib/index.js +++ b/front/core/lib/index.js @@ -2,7 +2,6 @@ import './module-loader'; import './crud'; import './acl-service'; import './template'; -import './interpolate'; import './copy'; import './equals'; import './modified'; diff --git a/front/core/lib/interpolate.js b/front/core/lib/interpolate.js deleted file mode 100644 index 0db22b312..000000000 --- a/front/core/lib/interpolate.js +++ /dev/null @@ -1,189 +0,0 @@ -import ngModule from '../module'; -import {ng} from '../vendor'; - -function stringify(value) { - if (value === null) { // null || undefined - return ''; - } - switch (typeof value) { - case 'string': - break; - case 'number': - value = String(value); - break; - default: - value = angular.toJson(value); - } - - return value; -} - -var $interpolateMinErr = ng.$interpolateMinErr = ng.$$minErr('$interpolate'); - -$interpolateMinErr.throwNoconcat = function(text) { - throw $interpolateMinErr('noconcat', - 'Error while interpolating: {0}\nStrict Contextual Escaping disallows ' + - 'interpolations that concatenate multiple expressions when a trusted value is ' + - 'required. See http://docs.angularjs.org/api/ng.$sce', text); -}; - -$interpolateMinErr.interr = function(text, err) { - return $interpolateMinErr('interr', 'Can\'t interpolate: {0}\n{1}', text, err.toString()); -}; - -function $get($parse, $exceptionHandler, $sce) { - let startSymbolLength = this._startSymbol.length; - let endSymbolLength = this._endSymbol.length; - let escapedStartRegexp = new RegExp(this._startSymbol.replace(/./g, escape), 'g'); - let escapedEndRegexp = new RegExp(this._endSymbol.replace(/./g, escape), 'g'); - let self = this; - - function escape(ch) { - return '\\\\\\' + ch; - } - - function unescapeText(text) { - return text.replace(escapedStartRegexp, self._startSymbol) - .replace(escapedEndRegexp, self._endSymbol); - } - - // TODO: this is the same as the constantWatchDelegate in parse.js - function constantWatchDelegate(scope, listener, objectEquality, constantInterp) { - var unwatch = scope.$watch(function constantInterpolateWatch(scope) { - unwatch(); - return constantInterp(scope); - }, listener, objectEquality); - return unwatch; - } - - function $interpolate(text, mustHaveExpression, trustedContext, allOrNothing) { - // Provide a quick exit and simplified result function for text with no interpolation - if (!text.length || text.indexOf(self._startSymbol) === -1) { - var constantInterp; - if (!mustHaveExpression) { - var unescapedText = unescapeText(text); - constantInterp = valueFn(unescapedText); - constantInterp.exp = text; - constantInterp.expressions = []; - constantInterp.$$watchDelegate = constantWatchDelegate; - } - return constantInterp; - } - - allOrNothing = Boolean(allOrNothing); - let startIndex; - let endIndex; - let index = 0; - let expressions = []; - let parseFns = []; - let textLength = text.length; - let exp; - let concat = []; - let expressionPositions = []; - - while (index < textLength) { - if (((startIndex = text.indexOf(self._startSymbol, index)) !== -1) && - ((endIndex = text.indexOf(self._endSymbol, startIndex + startSymbolLength)) !== -1)) { - if (index !== startIndex) - concat.push(unescapeText(text.substring(index, startIndex))); - exp = text.substring(startIndex + startSymbolLength, endIndex); - expressions.push(exp); - parseFns.push($parse(exp, parseStringifyInterceptor)); - index = endIndex + endSymbolLength; - expressionPositions.push(concat.length); - concat.push(''); - } else { - // we did not find an interpolation, so we have to add the remainder to the separators array - if (index !== textLength) - concat.push(unescapeText(text.substring(index))); - break; - } - } - - if (trustedContext && concat.length > 1) { - $interpolateMinErr.throwNoconcat(text); - } - - var getValue = function(value) { - return trustedContext ? - $sce.getTrusted(trustedContext, value) : - $sce.valueOf(value); - }; - - if (!mustHaveExpression || expressions.length) { - var compute = function(values) { - for (var i = 0, ii = expressions.length; i < ii; i++) { - if (allOrNothing && isUndefined(values[i])) return; - concat[expressionPositions[i]] = values[i]; - } - return concat.join(''); - }; - - return angular.extend(function interpolationFn(context) { - var i = 0; - var ii = expressions.length; - var values = new Array(ii); - - try { - for (; i < ii; i++) { - values[i] = parseFns[i](context); - } - - return compute(values); - } catch (err) { - $exceptionHandler($interpolateMinErr.interr(text, err)); - } - }, { - // all of these properties are undocumented for now - exp: text, // just for compatibility with regular watchers created via $watch - expressions: expressions - }); - } - - function parseStringifyInterceptor(value) { - try { - value = getValue(value); - return allOrNothing && !isDefined(value) ? value : stringify(value); - } catch (err) { - $exceptionHandler($interpolateMinErr.interr(text, err)); - } - } - } - - $interpolate.startSymbol = function() { - return startSymbol; - }; - - $interpolate.endSymbol = function() { - return endSymbol; - }; - - return $interpolate; -} - -$get.$inject = ['$parse', '$exceptionHandler', '$sce']; - -export class Interpolate { - constructor() { - this._startSymbol = '*['; - this._endSymbol = ']*'; - } - set startSymbol(value) { - if (value) { - this._startSymbol = value; - return this; - } - return this._startSymbol; - } - set endSymbol(value) { - if (value) { - this._endSymbol = value; - return this; - } - return this._endSymbol; - } -} - -Interpolate.prototype.$get = $get; -var interpolate = new Interpolate(); -ngModule.provider('vnInterpolate', () => interpolate); diff --git a/front/core/lib/section.js b/front/core/lib/section.js new file mode 100644 index 000000000..7e59bb8b3 --- /dev/null +++ b/front/core/lib/section.js @@ -0,0 +1,34 @@ +import Component from './component'; + +/** + * Class with commonly injected services assigned as properties. It also has + * abbreviations for commonly used methods like tranlation. + * + * @property {Object} $translate Angular tranlation service + * @property {Object} $http Angular HTTP service + * @property {Object} $state Router state service + * @property {Object} $stateParams Router state parameters + */ +export default class Section extends Component { + constructor($element, $scope, $translate, $http, $state) { + super($element, $scope); + Object.assign(this, { + $translate, + $http, + $state, + $stateParams: $state.params + }); + } + + /** + * Translates an string. + * + * @param {String} string String to translate + * @param {Array} params Translate parameters + * @return {String} The translated string + */ + _(string, params) { + return this.$translate.instant(string, params, ); + } +} +Section.$inject = ['$element', '$scope', '$translate', '$http', '$state']; diff --git a/front/core/lib/template.js b/front/core/lib/template.js index 6be5677dd..ae2f1b188 100644 --- a/front/core/lib/template.js +++ b/front/core/lib/template.js @@ -1,13 +1,6 @@ import ngModule from '../module'; export default class Template { - constructor(vnInterpolate) { - this.vnInterpolate = vnInterpolate; - } - get(template, $attrs, defaults) { - let scope = Object.assign({}, defaults, $attrs); - return template && this.vnInterpolate(template)(scope); - } getNormalized(template, $attrs, defaults) { this.normalizeInputAttrs($attrs); return this.get(template, $attrs, defaults); @@ -43,6 +36,5 @@ export default class Template { $attrs.focus = 'vn-focus'; } } -Template.$inject = ['vnInterpolate']; ngModule.service('vnTemplate', Template); diff --git a/front/core/locale/es.yml b/front/core/locale/es.yml index 01a17aa48..1fcd12b98 100644 --- a/front/core/locale/es.yml +++ b/front/core/locale/es.yml @@ -24,6 +24,9 @@ Value should be %s characters long: El valor debe ser de %s carácteres de longi Value should have a length between %s and %s: El valor debe tener una longitud de entre %s y %s Value should have at least %s characters: El valor debe tener al menos %s carácteres Value should have at most %s characters: El valor debe tener un máximo de %s carácteres +Enter a new search: Introduce una nueva búsqueda +No results: Sin resultados +Ups! It seems there was an error: ¡Vaya! Parece que ha habido un error General search: Busqueda general January: Enero February: Febrero diff --git a/front/core/styles/index.js b/front/core/styles/index.js index c3503f3d5..0912fcd20 100644 --- a/front/core/styles/index.js +++ b/front/core/styles/index.js @@ -1,4 +1,3 @@ -import './md-override.scss'; import './mdl-override.scss'; import './mdi-override.css'; import './zoom-image.scss'; diff --git a/front/core/styles/md-override.scss b/front/core/styles/md-override.scss deleted file mode 100644 index ba71a9a77..000000000 --- a/front/core/styles/md-override.scss +++ /dev/null @@ -1,11 +0,0 @@ - -html { - background-color: initial; -} - -// Disable ng-repeat effects - -.ng-enter, -.ng-leave { - transition: none !important; -} diff --git a/front/core/vendor.js b/front/core/vendor.js index 44d041ebe..ac4364feb 100644 --- a/front/core/vendor.js +++ b/front/core/vendor.js @@ -7,10 +7,6 @@ import 'angular-translate-loader-partial'; import '@uirouter/angularjs'; import 'mg-crud'; import 'oclazyload'; -/* -import 'angular-material'; -import 'angular-material/modules/scss/angular-material.scss'; -*/ import 'angular-moment'; export const ngDeps = [ @@ -18,7 +14,6 @@ export const ngDeps = [ 'ui.router', 'mgCrud', 'oc.lazyLoad', - // 'ngMaterial', 'angularMoment' ]; diff --git a/front/salix/components/left-menu/left-menu.js b/front/salix/components/left-menu/left-menu.js index 1df67f6d3..576dcc2df 100644 --- a/front/salix/components/left-menu/left-menu.js +++ b/front/salix/components/left-menu/left-menu.js @@ -2,7 +2,9 @@ import ngModule from '../../module'; import './style.scss'; export default class LeftMenu { - constructor($state, $transitions, aclService) { + constructor($state, $transitions, aclService, $timeout, $element) { + this.$element = $element; + this.$timeout = $timeout; this.$state = $state; this.deregisterCallback = $transitions.onSuccess({}, () => this.activateItem()); @@ -89,13 +91,19 @@ export default class LeftMenu { setActive(item) { if (item.state) return; item.active = !item.active; + + this.$timeout(() => { + let element = this.$element[0].querySelector('a[class="expanded"]'); + if (element) + element.scrollIntoView(); + }); } $onDestroy() { this.deregisterCallback(); } } -LeftMenu.$inject = ['$state', '$transitions', 'aclService']; +LeftMenu.$inject = ['$state', '$transitions', 'aclService', '$timeout', '$element']; ngModule.component('vnLeftMenu', { template: require('./left-menu.html'), diff --git a/front/salix/components/left-menu/left-menu.spec.js b/front/salix/components/left-menu/left-menu.spec.js index 73ce5f7de..76a6d10f8 100644 --- a/front/salix/components/left-menu/left-menu.spec.js +++ b/front/salix/components/left-menu/left-menu.spec.js @@ -2,16 +2,18 @@ import './left-menu.js'; describe('Component vnLeftMenu', () => { let controller; + let $element; beforeEach(angular.mock.module('salix', $translateProvider => { $translateProvider.translations('en', {}); })); beforeEach(angular.mock.inject(($componentController, $state, $window) => { + $element = angular.element('
      '); $state.current.name = 'client.card.summary'; $state.current.data = {moduleIndex: 0}; $window.routes = [{menu: []}]; - controller = $componentController('vnLeftMenu', {$state, $window}); + controller = $componentController('vnLeftMenu', {$state, $window, $element}); controller.items = [ {description: 'Client', state: 'client', icon: null, childs: []}, {description: 'Client', state: 'client.card', icon: null, childs: []}, diff --git a/front/salix/locale/es.yml b/front/salix/locale/es.yml index 2056210e4..898728363 100644 --- a/front/salix/locale/es.yml +++ b/front/salix/locale/es.yml @@ -14,8 +14,6 @@ Push on applications menu: Para abrir un módulo pulsa en el menú de aplicacion Return to module index: Volver a la página principal del módulo What is new: Novedades de la versión Settings: Ajustes -Enter a new search: Introduce una nueva búsqueda -No results: Sin resultados # Actions diff --git a/front/salix/styles/index.js b/front/salix/styles/index.js index 969793a32..d4c026f9f 100644 --- a/front/salix/styles/index.js +++ b/front/salix/styles/index.js @@ -15,3 +15,4 @@ import './descriptor.scss'; import './list.scss'; import './modal-form.scss'; import './photo-list.scss'; +import './width.scss'; diff --git a/front/salix/styles/list.scss b/front/salix/styles/list.scss index c483feca1..3a6d0d6d9 100644 --- a/front/salix/styles/list.scss +++ b/front/salix/styles/list.scss @@ -1,7 +1,7 @@ @import "./effects"; .vn-list { - max-width: 36em; + max-width: $width-sm; margin: 0 auto; a.vn-list-item { diff --git a/front/salix/styles/misc.scss b/front/salix/styles/misc.scss index 1eef5af2b..4ecd4fbd6 100644 --- a/front/salix/styles/misc.scss +++ b/front/salix/styles/misc.scss @@ -47,7 +47,6 @@ vn-bg-title { justify-content: center; align-items: center; padding: 18px; - margin-bottom: 10px; max-width: 12em; } .form { @@ -99,11 +98,6 @@ html [pointer], .pointer{ html [noDrop], .noDrop{ cursor: no-drop; } -html [compact], .compact{ - max-width: $width-compact; - margin-left: auto; - margin-right: auto; -} button { @extend %clickable; } @@ -147,6 +141,12 @@ fieldset[disabled] .mdl-textfield .mdl-textfield__label, font-size: 0.7em } } +[compact], .compact { + margin-left: auto; + margin-right: auto; + max-width: $width-md; +} + .vn-grid { border-collapse: collapse; width: 100%; diff --git a/front/salix/styles/photo-list.scss b/front/salix/styles/photo-list.scss index c573d06a2..b4e6ec698 100644 --- a/front/salix/styles/photo-list.scss +++ b/front/salix/styles/photo-list.scss @@ -17,6 +17,8 @@ box-shadow: 0 2px 2px 0 rgba(0,0,0,.14), 0 3px 1px -2px rgba(0,0,0,.2), 0 1px 5px 0 rgba(0,0,0,.12); + background: no-repeat center center fixed; + background-size: cover !important; overflow: hidden; cursor: zoom-in; height: 100%; diff --git a/front/salix/styles/responsive.scss b/front/salix/styles/responsive.scss index fc47180ba..9cc58dd12 100644 --- a/front/salix/styles/responsive.scss +++ b/front/salix/styles/responsive.scss @@ -1,3 +1,4 @@ +@import "variables"; /* Desktop - Laptop 1360x768 */ @media (max-resolution: 119dpi) and (min-device-width: 1340px) and (max-device-width: 1899px) @@ -46,3 +47,9 @@ { body { font-size: 11pt; } } + +.vn-hide-narrow { + @media (max-width: $mobile-width) { + display: none; + } +} diff --git a/front/salix/styles/variables.scss b/front/salix/styles/variables.scss index 5eccf0418..5b96973f2 100644 --- a/front/salix/styles/variables.scss +++ b/front/salix/styles/variables.scss @@ -2,12 +2,15 @@ $menu-width: 16em; $topbar-height: 4em; $mobile-width: 800px; +$input-font-size: 16px; // Width -$width-small: 36em; -$width-compact: 60em; -$width-large: 80em; +$width-xs: 25em; +$width-sm: 34em; +$width-md: 50em; +$width-lg: 80em; +$width-xl: 100em; // Padding @@ -29,7 +32,8 @@ $margin-huge: 100px; $color-header: #3d3d3d; $color-bg: #e5e5e5; $color-bg-dark: #3d3d3d; -$color-font: #222222; +$color-font: #222; +$color-font-light: #555; $color-font-secondary: #9b9b9b; $color-font-dark: white; $color-font-bg: rgba(0, 0, 0, .7); @@ -46,8 +50,9 @@ $color-alert: #f42121; $color-spacer: rgba(0, 0, 0, .3); $color-spacer-light: rgba(0, 0, 0, .12); $color-input-underline: rgba(0, 0, 0, .12); +$color-input-underline-hover: rgba(0, 0, 0, .6); $color-shadow: rgba(0, 0, 0, .2); -$color-hightlight: rgba(0, 0, 0, .15); +$color-hightlight: rgba(0, 0, 0, .05); $color-hover-cd: rgba(0, 0, 0, .1); $color-hover-dc: .7; $color-disabled: .6; @@ -70,6 +75,7 @@ $color-header: #3d3d3d; $color-bg: #222; $color-bg-dark: #222; $color-font: white; +$color-font-light: #aaa; $color-font-secondary: #777; $color-font-dark: white; $color-font-bg: rgba(0, 0, 0, .8); @@ -82,6 +88,7 @@ $color-secondary: #ccc; $color-success: #a3d131; $color-notice: #32b1ce; $color-alert: #f42121; + $color-spacer: rgba(255, 255, 255, .3); $color-spacer-light: rgba(255, 255, 255, .12); $color-input-underline: rgba(255, 255, 255, .12); @@ -104,5 +111,5 @@ $color-alert-light: darken($color-alert, 35%); // Border -$border-thin: .1em solid $color-spacer; -$border-thin-light: .1em solid $color-spacer-light; +$border-thin: .05em solid $color-spacer; +$border-thin-light: .05em solid $color-spacer-light; diff --git a/front/salix/styles/width.scss b/front/salix/styles/width.scss new file mode 100644 index 000000000..e017de3ea --- /dev/null +++ b/front/salix/styles/width.scss @@ -0,0 +1,26 @@ +@import "./variables"; + +%margin-auto { + margin-left: auto; + margin-right: auto; +} +.vn-w-xs { + @extend %margin-auto; + max-width: $width-xs; +} +.vn-w-sm { + @extend %margin-auto; + max-width: $width-sm; +} +.vn-w-md { + @extend %margin-auto; + max-width: $width-md; +} +.vn-w-lg { + @extend %margin-auto; + max-width: $width-lg; +} +.vn-w-xl { + @extend %margin-auto; + max-width: $width-xl; +} diff --git a/modules/agency/front/basic-data/index.html b/modules/agency/front/basic-data/index.html index 8749494e1..8e3067877 100644 --- a/modules/agency/front/basic-data/index.html +++ b/modules/agency/front/basic-data/index.html @@ -5,7 +5,10 @@ form="form" save="patch"> - + - - + + + + diff --git a/modules/agency/front/calendar/index.html b/modules/agency/front/calendar/index.html index 9172ec4a3..6cf521065 100644 --- a/modules/agency/front/calendar/index.html +++ b/modules/agency/front/calendar/index.html @@ -3,6 +3,7 @@ skip="2" has-events="$ctrl.hasEvents($day)" get-class="$ctrl.getClass($day)" + on-selection="$ctrl.onSelection($days, $type, $weekday)" on-move-next="ndMonth.moveNext(2)" on-move-previous="ndMonth.movePrevious(2)" vn-acl="deliveryBoss" @@ -13,6 +14,7 @@ skip="2" has-events="$ctrl.hasEvents($day)" get-class="$ctrl.getClass($day)" + on-selection="$ctrl.onSelection($days, $type, $weekday)" default-date="$ctrl.ndMonthDate" vn-acl="deliveryBoss" display-controls="false" diff --git a/modules/agency/front/calendar/index.js b/modules/agency/front/calendar/index.js index 5b99264c7..74588d9ef 100644 --- a/modules/agency/front/calendar/index.js +++ b/modules/agency/front/calendar/index.js @@ -1,12 +1,10 @@ import ngModule from '../module'; +import Section from 'core/lib/section'; import './style.scss'; -class Controller { - constructor($, $stateParams) { - Object.assign(this, { - $, - $stateParams - }); +class Controller extends Section { + constructor($el, $, $t, $http, $state) { + super($el, $, $t, $http, $state); this.excls = {}; this.resetEvents(); @@ -14,6 +12,10 @@ class Controller { this.ndMonthDate.setMonth(this.ndMonthDate.getMonth() + 1); } + onSelection($days, $type, $weekday) { + this.emit('selection', {$days, $type, $weekday}); + } + resetEvents() { this.wdays = []; this.days = {}; @@ -96,8 +98,6 @@ class Controller { } } -Controller.$inject = ['$scope', '$stateParams']; - ngModule.component('vnZoneCalendar', { template: require('./index.html'), controller: Controller, diff --git a/modules/agency/front/card/index.html b/modules/agency/front/card/index.html index 1a1763916..1fd22809a 100644 --- a/modules/agency/front/card/index.html +++ b/modules/agency/front/card/index.html @@ -2,4 +2,4 @@ -
      +
      diff --git a/modules/agency/front/events/index.html b/modules/agency/front/events/index.html index fa114b9bc..b54ee8f0b 100644 --- a/modules/agency/front/events/index.html +++ b/modules/agency/front/events/index.html @@ -1,6 +1,10 @@
      -
      - + + +
      +
      -
      - - - - - No records found - +
      + exclusions="exclusions" + on-selection="$ctrl.onCreate($days, $type, $weekday)"> - - - + + label="Indefinitely" + val="indefinitely"> + label="Range of dates" + val="range">
      this.$.exclusions = res.data); - this.path = `/api/Zones/${$stateParams.id}/events`; + this.path = `/api/Zones/${this.$stateParams.id}/events`; this.refresh(); } @@ -62,7 +59,7 @@ class Controller { return abrWdays.length < 7 ? abrWdays.join(', ') - : this._.instant('Everyday'); + : this._('Everyday'); } onEdit(row, event) { @@ -89,10 +86,19 @@ class Controller { this.$.dialog.show(); } - onCreate() { + onCreate($day, $type, $weekday) { this.isNew = true; - this.eventType = 'day'; - this.selected = {}; + this.eventType = $type == 'day' ? 'day' : 'indefinitely'; + + if ($type == 'weekday') { + let wdays = []; + let index = $weekday - 1; + if (index < 0) index = 7 - index; + wdays[this.wdays[index].code] = true; + this.selected = {wdays}; + } else + this.selected = {from: $day[0]}; + this.$.dialog.show(); } @@ -153,7 +159,6 @@ class Controller { }); } } -Controller.$inject = ['$scope', '$translate', '$http', '$stateParams']; ngModule.component('vnZoneEvents', { template: require('./index.html'), diff --git a/modules/agency/front/exclusions/index.html b/modules/agency/front/exclusions/index.html index 47d2cba4c..57418e71e 100644 --- a/modules/agency/front/exclusions/index.html +++ b/modules/agency/front/exclusions/index.html @@ -1,50 +1,33 @@ - - - +
      + + + + {{::row.day | dateTime:'dd/MM/yyyy'}} + ng-click="$ctrl.onDelete(row.id)"> - - - - - - - - No records found - - - - - - - - - - - - - - - + + + + +
      + + + + this.$.events = res.data); + + this.path = `/api/Zones/${this.$stateParams.id}/exclusions`; this.refresh(); } @@ -16,43 +17,26 @@ class Controller { .then(res => this.$.data = res.data); } - onCreate() { - this.isNew = true; - this.selected = {}; - this.$.dialog.show(); + onCreate($days) { + this.$http.post(this.path, {day: $days[0]}) + .then(() => this.refresh()); } - onSave(response) { - if (response != 'ACCEPT') return; - - this.$http.post(this.path, this.selected) - .then(() => { - this.selected = null; - this.isNew = null; - this.$.dialog.hide(); - this.refresh(); - }); - - return false; - } - - onDelete(index) { + onDelete(id) { this.$.confirm.show(); - this.deleteIndex = index; + this.deleteId = id; } delete(response) { if (response != 'ACCEPT') return; - let id = this.$.data[this.deleteIndex].id; - if (!id) return; - this.$http.delete(`${this.path}/${id}`) + if (!this.deleteId) return; + this.$http.delete(`${this.path}/${this.deleteId}`) .then(() => { - this.$.data.splice(this.deleteIndex, 1); - this.deleteIndex = null; + this.refresh(); + this.deleteId = null; }); } } -Controller.$inject = ['$scope', '$http', '$stateParams']; ngModule.component('vnZoneExclusions', { template: require('./index.html'), diff --git a/modules/agency/front/index/index.html b/modules/agency/front/index/index.html index 079200b33..67a8fffcf 100644 --- a/modules/agency/front/index/index.html +++ b/modules/agency/front/index/index.html @@ -4,21 +4,24 @@ filter="::$ctrl.filter" limit="20" data="zones" - auto-load="false"> + auto-load="true"> -
      -
      - - - - -
      - +
      + + + + + + @@ -59,8 +62,8 @@ - - + +
      -
      +
      { const data = this.$.model.data; @@ -49,8 +45,6 @@ class Controller { } } -Controller.$inject = ['$scope', '$http', '$stateParams']; - ngModule.component('vnZoneLocation', { template: require('./index.html'), controller: Controller, diff --git a/modules/agency/front/location/style.scss b/modules/agency/front/location/style.scss new file mode 100644 index 000000000..a3b237b13 --- /dev/null +++ b/modules/agency/front/location/style.scss @@ -0,0 +1,14 @@ +@import "variables"; + +vn-treeview-content { + & > vn-check:not(.indeterminate) { + color: $color-main; + + & > .btn { + border-color: $color-main; + } + } + & > vn-check.checked { + color: $color-main; + } +} \ No newline at end of file diff --git a/modules/agency/front/warehouses/index.html b/modules/agency/front/warehouses/index.html index 71baa9b3c..d40e1139c 100644 --- a/modules/agency/front/warehouses/index.html +++ b/modules/agency/front/warehouses/index.html @@ -1,6 +1,8 @@ - + + @@ -15,13 +17,8 @@ - - - - - - No records found - + + - + +
      +
      +
      Drag & Drop files here...
      +
      + +
      + order="claimStateFk ASC, created DESC" + auto-load="true">
      -
      - - - - -
      - + + + + + + @@ -62,10 +65,12 @@ - - + +
      - + + diff --git a/modules/client/back/models/client.js b/modules/client/back/models/client.js index 2522e1413..58aac9ccd 100644 --- a/modules/client/back/models/client.js +++ b/modules/client/back/models/client.js @@ -168,7 +168,7 @@ module.exports = Self => { } function isAlpha(value) { - const regexp = new RegExp(/^[ñça-zA-Z0-9\s]*$/); + const regexp = new RegExp(/^[ñça-zA-Z0-9\s]*$/i); return regexp.test(value); } diff --git a/modules/client/front/address/index/index.html b/modules/client/front/address/index/index.html index 2a601ade1..4c0527136 100644 --- a/modules/client/front/address/index/index.html +++ b/modules/client/front/address/index/index.html @@ -6,75 +6,70 @@ data="$ctrl.addresses" auto-load="true"> - + + + + diff --git a/modules/client/front/address/index/index.js b/modules/client/front/address/index/index.js index 96859a0c0..8dc9b4394 100644 --- a/modules/client/front/address/index/index.js +++ b/modules/client/front/address/index/index.js @@ -56,8 +56,7 @@ class Controller { } isDefaultAddress(address) { - if (this.client) - return this.client.defaultAddressFk === address.id; + return this.client && this.client.defaultAddressFk === address.id; } /** diff --git a/modules/client/front/balance/index/index.html b/modules/client/front/balance/index/index.html index 045eb1f80..55ad2f615 100644 --- a/modules/client/front/balance/index/index.html +++ b/modules/client/front/balance/index/index.html @@ -3,7 +3,8 @@ url="/client/api/receipts/filter" params="$ctrl.params" limit="20" - data="$ctrl.balances"> + data="$ctrl.balances" + auto-load="true"> - - - +
      + + + label="Company"> @@ -38,68 +40,68 @@
      - - - - - Date - Creation date - Employee - Reference - Bank - Debit - Havings - Balance - Conciliated - - - - - - {{::balance.payed | dateTime:'dd/MM/yyyy'}} - {{::balance.created | dateTime:'dd/MM/yyyy HH:mm'}} - - - {{::balance.userNickname}} - - - - {{balance.isInvoice ? 'BILL' : balance.ref | translate: {ref: balance.ref} }} - - - {{::balance.bankFk}} - {{::balance.debit | currency: 'EUR':2}} - {{::balance.credit | currency: 'EUR':2}} - {{balance.balance | currency: 'EUR':2}} - - - - - - - - - - - - - - -
      -
      - + + + + + + Date + Creation date + Employee + Reference + Bank + Debit + Havings + Balance + Conciliated + + + + + + {{::balance.payed | dateTime:'dd/MM/yyyy'}} + {{::balance.created | dateTime:'dd/MM/yyyy HH:mm'}} + + + {{::balance.userNickname}} + + + + {{balance.isInvoice ? 'BILL' : balance.ref | translate: {ref: balance.ref} }} + + + {{::balance.bankFk}} + {{::balance.debit | currency: 'EUR':2}} + {{::balance.credit | currency: 'EUR':2}} + {{balance.balance | currency: 'EUR':2}} + + + + + + + + + + + + + + + +
      - - + - - diff --git a/modules/client/front/credit-insurance/index/index.html b/modules/client/front/credit-insurance/index/index.html index 37840d0b9..dc7f546aa 100644 --- a/modules/client/front/credit-insurance/index/index.html +++ b/modules/client/front/credit-insurance/index/index.html @@ -1,67 +1,64 @@ -
      - - - - - - - - - -
      Since {{::classification.started | dateTime:'dd/MM/yyyy'}}
      -
      To {{classification.finished | dateTime:'dd/MM/yyyy'}}
      -
      - - - - - - - - - - - - - - - - - - - -
      -
      -
      - - - No results - - + + + + + + + + + + +
      Since {{::classification.started | dateTime:'dd/MM/yyyy'}}
      +
      To {{classification.finished | dateTime:'dd/MM/yyyy'}}
      +
      + + + + + + + + + + + + + + + + + + + +
      +
      +
      - - -
      + + + + data="credits" + order="created DESC" + auto-load="true"> - - - - - - - Credit - Since - Employee - - - - - {{::credit.amount | number:2}} € - {{::credit.created | dateTime:'dd/MM/yyyy HH:mm'}} - {{::credit.worker.user.nickname}} - - - - - + + + + + + Since + Employee + Credit + + + + + {{::credit.created | dateTime:'dd/MM/yyyy HH:mm'}} + {{::credit.worker.user.nickname}} + {{::credit.amount | currency:'EUR':2}} + + + - - - + + vn-bind="+" + fixed-bottom-right> diff --git a/modules/client/front/credit/index/locale/es.yml b/modules/client/front/credit/index/locale/es.yml index b4b5940cf..a15a1085f 100644 --- a/modules/client/front/credit/index/locale/es.yml +++ b/modules/client/front/credit/index/locale/es.yml @@ -1,3 +1,2 @@ Since : Desde -Employee : Empleado -No results: Sin resultados \ No newline at end of file +Employee : Empleado \ No newline at end of file diff --git a/modules/client/front/dms/index/index.html b/modules/client/front/dms/index/index.html index c147a74e0..aaeac7b64 100644 --- a/modules/client/front/dms/index/index.html +++ b/modules/client/front/dms/index/index.html @@ -4,101 +4,102 @@ link="{clientFk: $ctrl.$stateParams.id}" filter="::$ctrl.filter" limit="20" - data="$ctrl.clientDms"> + data="$ctrl.clientDms" + order="dmsFk DESC" + auto-load="true"> - - - - - - - Id - Type - Order - Reference - Description - Original - File - Employee - Created - - - - - - - - {{::document.dmsFk}} - - - {{::document.dms.dmsType.name}} - - - - - {{::document.dms.hardCopyNumber}} - - - - - {{::document.dms.reference}} - - - - - {{::document.dms.description}} - - - - - - - - {{::document.dms.file}} - - - - - {{::document.dms.worker.user.nickname | dashIfEmpty}} - - - {{::document.dms.created | dateTime:'dd/MM/yyyy HH:mm'}} - - - - - - - - - - - - - - - - - - - - + + + + + + Id + Type + Order + Reference + Description + Original + File + Employee + Created + + + + + + + + {{::document.dmsFk}} + + + {{::document.dms.dmsType.name}} + + + + + {{::document.dms.hardCopyNumber}} + + + + + {{::document.dms.reference}} + + + + + {{::document.dms.description}} + + + + + + + + {{::document.dms.file}} + + + + + {{::document.dms.worker.user.nickname | dashIfEmpty}} + + + {{::document.dms.created | dateTime:'dd/MM/yyyy HH:mm'}} + + + + + + + + + + + + + + + + + + - + diff --git a/modules/client/front/greuge/index/index.html b/modules/client/front/greuge/index/index.html index 537e67602..9ce76491c 100644 --- a/modules/client/front/greuge/index/index.html +++ b/modules/client/front/greuge/index/index.html @@ -4,49 +4,54 @@ filter="::$ctrl.filter" link="{clientFk: $ctrl.$stateParams.id}" limit="20" - data="greuges" auto-load="true"> + data="greuges" + auto-load="true"> - - - -
      - - -
      -
      + + + + + + Date Comment - Amount Type + Amount {{::greuge.shipped | dateTime:'dd/MM/yyyy HH:mm' }} {{::greuge.description}} - {{::greuge.amount | currency: 'EUR': 2}} {{::greuge.greugeType.name}} + {{::greuge.amount | currency: 'EUR': 2}} - -
      - - + + vn-bind="+" + fixed-bottom-right> diff --git a/modules/client/front/index/index.html b/modules/client/front/index/index.html index 8321f99d1..ec09a936d 100644 --- a/modules/client/front/index/index.html +++ b/modules/client/front/index/index.html @@ -3,73 +3,74 @@ url="/item/api/Clients" order="id DESC" limit="8" - data="clients" - auto-load="false"> + data="clients"> -
      - - + - + + \ No newline at end of file diff --git a/modules/client/front/mandate/index.html b/modules/client/front/mandate/index.html index ad6345dd9..c5bfb058a 100644 --- a/modules/client/front/mandate/index.html +++ b/modules/client/front/mandate/index.html @@ -4,32 +4,33 @@ filter="::$ctrl.filter" link="{clientFk: $ctrl.$stateParams.id}" limit="20" - data="mandates" auto-load="false"> + data="mandates" + order="created DESC" + auto-load="true"> - - - - - - - Id - Company - Type - Register date - End date - - - - - {{::mandate.id}} - {{::mandate.company.code}} - {{::mandate.mandateType.name}} - {{::mandate.created | dateTime:'dd/MM/yyyy HH:mm' }} - {{::mandate.finished | dateTime:'dd/MM/yyyy HH:mm' || '-'}} - - - - - + + + + + + Id + Company + Type + Register date + End date + + + + + {{::mandate.id}} + {{::mandate.company.code}} + {{::mandate.mandateType.name}} + {{::mandate.created | dateTime:'dd/MM/yyyy HH:mm' }} + {{::mandate.finished | dateTime:'dd/MM/yyyy HH:mm' || '-'}} + + + - \ No newline at end of file + \ No newline at end of file diff --git a/modules/client/front/mandate/index.js b/modules/client/front/mandate/index.js index a406fcab3..607bb335b 100644 --- a/modules/client/front/mandate/index.js +++ b/modules/client/front/mandate/index.js @@ -6,15 +6,14 @@ class Controller { this.filter = { include: [ { - relation: "mandateType", + relation: 'mandateType', scope: { - fields: ["id", "name"] + fields: ['id', 'name'] } - }, - { - relation: "company", + }, { + relation: 'company', scope: { - fields: ["id", "code"] + fields: ['id', 'code'] } } ] diff --git a/modules/client/front/note/index/index.html b/modules/client/front/note/index/index.html index 179a0d9a7..a653ef9da 100644 --- a/modules/client/front/note/index/index.html +++ b/modules/client/front/note/index/index.html @@ -6,9 +6,11 @@ data="notes" auto-load="true"> - - - + +
      {{::note.text}} - - - - No results - - +
      -
      - + + data="recoveries" + order="started DESC" + auto-load="true"> - - - - - - - - Since - To - Amount - Period - - - - - - - - - {{::recovery.started | dateTime:'dd/MM/yyyy' }} - {{recovery.finished | dateTime:'dd/MM/yyyy' }} - {{::recovery.amount | currency: 'EUR': 0}} - {{::recovery.period}} - - - - - + + + + + + + Since + To + Amount + Period + + + + + + + + + {{::recovery.started | dateTime:'dd/MM/yyyy' }} + {{recovery.finished | dateTime:'dd/MM/yyyy' }} + {{::recovery.amount | currency: 'EUR': 0}} + {{::recovery.period}} + + + - - - + - \ No newline at end of file + diff --git a/modules/client/front/recovery/index/locale/es.yml b/modules/client/front/recovery/index/locale/es.yml index 5b21429f4..0cb5b3ed6 100644 --- a/modules/client/front/recovery/index/locale/es.yml +++ b/modules/client/front/recovery/index/locale/es.yml @@ -1,5 +1,4 @@ Since: Desde Employee: Empleado -No results: Sin resultados To: Hasta Finish that recovery period: Terminar el recobro \ No newline at end of file diff --git a/modules/client/front/sample/index/index.html b/modules/client/front/sample/index/index.html index 48543d135..2d7f63ba7 100644 --- a/modules/client/front/sample/index/index.html +++ b/modules/client/front/sample/index/index.html @@ -4,49 +4,51 @@ filter="::$ctrl.filter" link="{clientFk: $ctrl.$stateParams.id}" limit="20" - data="samples" auto-load="false"> + data="samples" + order="created DESC" + auto-load="true"> - - - - - - - - - Sent - Description - Worker - Company - - - - - {{::sample.created | dateTime:'dd/MM/yyyy HH:mm' }} - - {{::sample.type.description}} - - - - {{::sample.worker.user.nickname}} - - - {{::sample.company.code}} - - - - - + + + + + + Sent + Description + Worker + Company + + + + + {{::sample.created | dateTime:'dd/MM/yyyy HH:mm' }} + + {{::sample.type.description}} + + + + {{::sample.worker.user.nickname}} + + + {{::sample.company.code}} + + + - + - + \ No newline at end of file diff --git a/modules/client/front/summary/locale/es.yml b/modules/client/front/summary/locale/es.yml index a21be4523..24068e4ad 100644 --- a/modules/client/front/summary/locale/es.yml +++ b/modules/client/front/summary/locale/es.yml @@ -1,4 +1,4 @@ -Default address: Consignatario pred. +Default address: Consignatario predeterminado Total greuge: Greuge total Financial information: Datos financieros Mana: Maná diff --git a/modules/client/front/web-payment/index.html b/modules/client/front/web-payment/index.html index e9c45dc53..326945c21 100644 --- a/modules/client/front/web-payment/index.html +++ b/modules/client/front/web-payment/index.html @@ -3,52 +3,53 @@ url="/client/api/clients/getTransactions" link="{clientFk: $ctrl.$stateParams.id}" limit="20" - data="transactions" auto-load="false"> + data="transactions" + order="created DESC" + auto-load="true"> - - - - - - - State - Id - Amount - Payed - Confirm - - - - - - - - - - - {{::transaction.id}} - {{::transaction.amount | currency: 'EUR':2}} - {{::transaction.created | dateTime:'dd/MM/yyyy HH:mm'}} - - - - - - - - - + + + + + + State + Id + Date + Amount + + + + + + + + + + + + {{::transaction.id}} + {{::transaction.created | dateTime:'dd/MM/yyyy HH:mm'}} + {{::transaction.amount | currency: 'EUR':2}} + + + + + + + - \ No newline at end of file + \ No newline at end of file diff --git a/modules/client/front/web-payment/locale/es.yml b/modules/client/front/web-payment/locale/es.yml index 099ca359c..8e988857c 100644 --- a/modules/client/front/web-payment/locale/es.yml +++ b/modules/client/front/web-payment/locale/es.yml @@ -1,6 +1,5 @@ Web Payment: Pago Web Confirmed: Confirmado -Payed: Pagado Confirm transaction: Confirmar transacción Confirm: Confirmar State: Estado \ No newline at end of file diff --git a/modules/invoiceOut/front/index/index.html b/modules/invoiceOut/front/index/index.html index 744b52fad..ef7bd988f 100644 --- a/modules/invoiceOut/front/index/index.html +++ b/modules/invoiceOut/front/index/index.html @@ -7,7 +7,7 @@
      - +
      - - + + + Reference @@ -67,15 +71,19 @@ - - + +
      - + + - + + \ No newline at end of file diff --git a/modules/invoiceOut/front/summary/style.scss b/modules/invoiceOut/front/summary/style.scss index f2cf53381..dcad44362 100644 --- a/modules/invoiceOut/front/summary/style.scss +++ b/modules/invoiceOut/front/summary/style.scss @@ -2,7 +2,7 @@ vn-invoice-out-summary .summary { - max-width: $width-large; + max-width: $width-lg; vn-icon[icon=insert_drive_file]{ color: $color-font-secondary; diff --git a/modules/item/back/methods/item/filter.js b/modules/item/back/methods/item/filter.js index 4e390227b..ad7edfa8c 100644 --- a/modules/item/back/methods/item/filter.js +++ b/modules/item/back/methods/item/filter.js @@ -62,13 +62,26 @@ module.exports = Self => { Self.filter = async(ctx, filter) => { let conn = Self.dataSource.connector; + let codeWhere; + + if (ctx.args.search) { + let items = await Self.app.models.ItemBarcode.find({ + where: {code: ctx.args.search}, + fields: ['itemFk'] + }); + let itemIds = []; + for (const item of items) + itemIds.push(item.itemFk); + + codeWhere = {'i.id': {inq: itemIds}}; + } let where = buildFilter(ctx.args, (param, value) => { switch (param) { case 'search': return /^\d+$/.test(value) - ? {or: [{'i.id': value}, {'ib.code': value}]} - : {or: [{'i.name': {like: `%${value}%`}}, {'ib.code': value}]}; + ? {or: [{'i.id': value}, codeWhere]} + : {or: [{'i.name': {like: `%${value}%`}}, codeWhere]}; case 'id': return {'i.id': value}; case 'description': @@ -83,8 +96,8 @@ module.exports = Self => { return {'i.isActive': value}; } }); - filter = mergeFilters(filter, {where}); + let stmts = []; let stmt; @@ -123,8 +136,7 @@ module.exports = Self => { LEFT JOIN origin ori ON ori.id = i.originFk LEFT JOIN cache.last_buy lb ON lb.item_id = i.id AND lb.warehouse_id = t.warehouseFk LEFT JOIN vn.buy b ON b.id = lb.buy_id - LEFT JOIN itemPlacement itn ON itn.itemFk = i.id AND itn.warehouseFk = t.warehouseFk - LEFT JOIN itemBarcode ib ON ib.itemFk = i.id` + LEFT JOIN itemPlacement itn ON itn.itemFk = i.id AND itn.warehouseFk = t.warehouseFk` ); if (ctx.args.tags) { @@ -150,7 +162,6 @@ module.exports = Self => { } stmt.merge(conn.makeWhere(filter.where)); - stmt.merge(`GROUP BY i.id`); stmt.merge(conn.makePagination(filter)); let itemsIndex = stmts.push(stmt) - 1; diff --git a/modules/item/front/index/index.html b/modules/item/front/index/index.html index 40d816bb5..d692d61f6 100644 --- a/modules/item/front/index/index.html +++ b/modules/item/front/index/index.html @@ -3,35 +3,39 @@ url="/item/api/Items/filter" limit="12" order="isActive DESC, name, id" - data="items" - auto-load="false"> + data="items">
      -
      - - - - - - - - -
      - - + + + + + + + + + + + @@ -124,8 +128,8 @@ - - + +
      diff --git a/modules/item/front/locale/es.yml b/modules/item/front/locale/es.yml index c922656c4..c071d2c69 100644 --- a/modules/item/front/locale/es.yml +++ b/modules/item/front/locale/es.yml @@ -33,8 +33,6 @@ Remove niche: Quitar nicho Add barcode: Añadir código de barras Remove barcode: Quitar código de barras Buyer: Comprador -No results: Sin resultados -Enter a new search: Introduce una nueva búsqueda Tag: Etiqueta Worker: Trabajador Available: Disponible diff --git a/modules/order/front/catalog/index.js b/modules/order/front/catalog/index.js index a5d7ee968..758c56f0e 100644 --- a/modules/order/front/catalog/index.js +++ b/modules/order/front/catalog/index.js @@ -131,7 +131,7 @@ class Controller { } get isRefreshing() { - return this.$scope.model && this.$scope.model.isRefreshing; + return this.$scope.model && this.$scope.model.status == 'loading'; } } diff --git a/modules/order/front/index/index.html b/modules/order/front/index/index.html index 62094941e..a22e7501a 100644 --- a/modules/order/front/index/index.html +++ b/modules/order/front/index/index.html @@ -3,24 +3,23 @@ url="/api/Orders/filter" limit="20" data="orders" - order="landed DESC, clientFk" - auto-load="false"> + order="landed DESC, clientFk">
      -
      - - - - -
      - - + + + + + + + Id @@ -71,8 +70,8 @@ - - + +
      diff --git a/modules/order/front/locale/es.yml b/modules/order/front/locale/es.yml index 943606a47..0ada37bfd 100644 --- a/modules/order/front/locale/es.yml +++ b/modules/order/front/locale/es.yml @@ -3,8 +3,6 @@ Catalog: Catálogo from: desde results: resultados More than: Más de -No results: Sin resultados -Enter a new search: Introduce una nueva búsqueda Plant: Planta Flower: Flor Handmade: Confección diff --git a/modules/order/front/summary/style.scss b/modules/order/front/summary/style.scss index bc8017a0c..c225b4b49 100644 --- a/modules/order/front/summary/style.scss +++ b/modules/order/front/summary/style.scss @@ -1,7 +1,8 @@ @import "./variables"; vn-order-summary .summary{ - max-width: $width-large; + max-width: $width-lg; + & > div > vn-horizontal > vn-one { min-width: 10em !important; diff --git a/modules/route/front/index/index.html b/modules/route/front/index/index.html index 969c5f380..3cb4e13eb 100644 --- a/modules/route/front/index/index.html +++ b/modules/route/front/index/index.html @@ -3,32 +3,36 @@ url="/api/Routes/filter" limit="20" data="routes" - order="created DESC"> + order="created DESC" + auto-load="true"> - + + - + \ No newline at end of file diff --git a/modules/route/front/index/style.scss b/modules/route/front/index/style.scss index bbf7d6fa8..d8c24a482 100644 --- a/modules/route/front/index/style.scss +++ b/modules/route/front/index/style.scss @@ -1,5 +1,5 @@ @import "./variables"; vn-route-index .index { - max-width: $width-large; + max-width: $width-lg; } \ No newline at end of file diff --git a/modules/route/front/summary/style.scss b/modules/route/front/summary/style.scss index aef44fbf9..b41512f32 100644 --- a/modules/route/front/summary/style.scss +++ b/modules/route/front/summary/style.scss @@ -2,7 +2,7 @@ vn-route-summary .summary { - max-width: $width-large; + max-width: $width-lg; vn-icon[icon=insert_drive_file]{ color: $color-font-secondary; diff --git a/modules/route/front/tickets/style.scss b/modules/route/front/tickets/style.scss index 55a57fd24..2c287ed9d 100644 --- a/modules/route/front/tickets/style.scss +++ b/modules/route/front/tickets/style.scss @@ -2,5 +2,5 @@ vn-route-tickets form{ margin: 0 auto; - max-width: $width-large; + max-width: $width-lg; } \ No newline at end of file diff --git a/modules/ticket/back/methods/ticket/specs/transferSales.spec.js b/modules/ticket/back/methods/ticket/specs/transferSales.spec.js index 8894c92d8..75823f00a 100644 --- a/modules/ticket/back/methods/ticket/specs/transferSales.spec.js +++ b/modules/ticket/back/methods/ticket/specs/transferSales.spec.js @@ -135,44 +135,45 @@ describe('sale transferSales()', () => { expect(error).toBeDefined(); }); - xit('should partially transfer the sales from one ticket to a new one', async() => { + it('should transfer two sales to a new ticket but one shall be partial', async() => { const ctx = {req: {accessToken: {userId: 101}}}; - let currentTicket = await app.models.Ticket.findById(11); - let currentTicketSales = []; - let saleToRestore = await app.models.Sale.findById(7); - currentTicketSales.push(saleToRestore); - - expect(currentTicketSales[0].quantity).toEqual(15); - - const currentTicketId = currentTicket.id; + const originalTicketId = 11; const receiverTicketId = undefined; - const originalQuantity = currentTicketSales[0].quantity; + let currentTicketSales = await app.models.Ticket.getSales(originalTicketId); + + const originalPartialSaleId = currentTicketSales[0].id; + const originalCompleteSaleId = currentTicketSales[1].id; + let originalQuantity = currentTicketSales[0].quantity; currentTicketSales[0].quantity = 1; - let salesToPartiallyTransfer = [currentTicketSales[0]]; - const saleIdToRestore = currentTicketSales[0].id; let createdTicket = await app.models.Ticket.transferSales( - ctx, currentTicketId, receiverTicketId, salesToPartiallyTransfer); + ctx, originalTicketId, receiverTicketId, currentTicketSales); createdTicketId = createdTicket.id; createdTicketsIds.push(createdTicket.id); - currentTicketSales = await app.models.Ticket.getSales(currentTicket.id); - receiverTicketSales = await app.models.Ticket.getSales(createdTicket.id); + currentTicketSales = await app.models.Ticket.getSales(originalTicketId); + receiverTicketSales = await app.models.Ticket.getSales(createdTicketId); + + const [createdPartialSale] = receiverTicketSales.filter(sale => { + return sale.id != originalCompleteSaleId; + }); + + expect(currentTicketSales.length).toEqual(1); + expect(currentTicketSales[0].quantity).toEqual(originalQuantity -= 1); + expect(receiverTicketSales.length).toEqual(2); + expect(createdPartialSale.quantity).toEqual(1); + + let saleToRestore = await app.models.Sale.findById(originalPartialSaleId); + await saleToRestore.updateAttribute('quantity', originalQuantity); + + let saleToReturnToTicket = await app.models.Sale.findById(originalCompleteSaleId); + await saleToReturnToTicket.updateAttribute('ticketFk', originalTicketId); + + currentTicketSales = await app.models.Ticket.getSales(originalTicketId); expect(currentTicketSales.length).toEqual(2); - expect(currentTicketSales[0].quantity).toEqual(14); - expect(receiverTicketSales.length).toEqual(1); - expect(receiverTicketSales[0].quantity).toEqual(1); - - saleToRestore.updateAttribute('quantity', originalQuantity); - - currentTicketSales = await app.models.Ticket.getSales(currentTicket.id); - - - expect(currentTicketSales[0].quantity).toEqual(15); - expect(currentTicketSales[0].id).toEqual(saleIdToRestore); }); }); }); diff --git a/modules/ticket/front/basic-data/step-one/index.html b/modules/ticket/front/basic-data/step-one/index.html index 3d79b9b68..4e3cf361a 100644 --- a/modules/ticket/front/basic-data/step-one/index.html +++ b/modules/ticket/front/basic-data/step-one/index.html @@ -14,6 +14,7 @@ label="Client" show-field="name" value-field="id" + search-function="{or: [{id: $search}, {name: {like: '%'+ $search +'%'}}]}" field="$ctrl.clientId" initial-data="$ctrl.clientId" order="id"> @@ -23,7 +24,7 @@ label="Address" show-field="nickname" value-field="id" - field="$ctrl.ticket.addressFk" + field="$ctrl.addressId" order="isActive DESC"> {{::isActive ? '' : 'INACTIVE'}} {{::nickname}} diff --git a/modules/ticket/front/basic-data/step-one/index.js b/modules/ticket/front/basic-data/step-one/index.js index 862a7a315..09632ba5a 100644 --- a/modules/ticket/front/basic-data/step-one/index.js +++ b/modules/ticket/front/basic-data/step-one/index.js @@ -26,10 +26,7 @@ class Controller { } get clientId() { - if (this.ticket) - return this.ticket.clientFk; - - return null; + return this.ticket && this.ticket.clientFk; } set clientId(value) { @@ -39,11 +36,24 @@ class Controller { this.onChangeClient(value); } - get warehouseId() { - if (this.ticket) - return this.ticket.warehouseFk; + get addressId() { + return this.ticket && this.ticket.addressFk; + } - return null; + set addressId(value) { + if (value != this.ticket.addressFk) { + this.ticket.addressFk = value; + this.getShipped({ + landed: this.ticket.landed, + addressFk: value, + agencyModeFk: this.ticket.agencyModeFk, + warehouseFk: this.ticket.warehouseFk + }); + } + } + + get warehouseId() { + return this.ticket && this.ticket.warehouseFk; } set warehouseId(value) { @@ -60,10 +70,7 @@ class Controller { get shipped() { - if (this.ticket) - return this.ticket.shipped; - - return null; + return this.ticket && this.ticket.shipped; } set shipped(value) { @@ -77,10 +84,7 @@ class Controller { } get landed() { - if (this.ticket) - return this.ticket.landed; - - return null; + return this.ticket && this.ticket.landed; } set landed(value) { @@ -94,17 +98,14 @@ class Controller { } get agencyModeId() { - if (this.ticket) - return this.ticket.agencyModeFk; - - return null; + return this.ticket && this.ticket.agencyModeFk; } set agencyModeId(value) { if (value != this.ticket.agencyModeFk) { this.ticket.agencyModeFk = value; - this.getShipped({ - landed: this.ticket.landed, + this.getLanded({ + shipped: this.ticket.shipped, addressFk: this.ticket.addressFk, agencyModeFk: value, warehouseFk: this.ticket.warehouseFk @@ -113,10 +114,7 @@ class Controller { } get zoneId() { - if (this.ticket) - return this.ticket.zoneFk; - - return null; + return this.ticket && this.ticket.zoneFk; } set zoneId(value) { @@ -206,9 +204,10 @@ class Controller { this.$http.get(query, {params}).then(res => { if (res.data) { this.ticket.zoneFk = res.data.zoneFk; - this.ticket.landed = res.data.landed; this.ticket.agencyModeFk = res.data.agencyModeFk; this.ticket.warehouseFk = res.data.warehouseFk; + this.ticket.landed = res.data.landed; + this.ticket.shipped = params.shipped; } else { return this.vnApp.showError( this.$translate.instant(`No delivery zone available for this landing date`) @@ -226,9 +225,10 @@ class Controller { this.$http.get(query, {params}).then(res => { if (res.data) { this.ticket.zoneFk = res.data.zoneFk; - this.ticket.shipped = res.data.shipped; this.ticket.agencyModeFk = res.data.agencyModeFk; this.ticket.warehouseFk = res.data.warehouseFk; + this.ticket.landed = params.landed; + this.ticket.shipped = res.data.shipped; } else { return this.vnApp.showError( this.$translate.instant(`No delivery zone available for this landing date`) diff --git a/modules/ticket/front/basic-data/step-one/index.spec.js b/modules/ticket/front/basic-data/step-one/index.spec.js index c743ca911..89ca7f171 100644 --- a/modules/ticket/front/basic-data/step-one/index.spec.js +++ b/modules/ticket/front/basic-data/step-one/index.spec.js @@ -5,14 +5,16 @@ describe('Ticket', () => { let $state; let controller; let $httpBackend; + let $httpParamSerializer; beforeEach(angular.mock.module('ticket', $translateProvider => { $translateProvider.translations('en', {}); })); - beforeEach(angular.mock.inject(($componentController, _$state_, _$httpBackend_) => { + beforeEach(angular.mock.inject(($componentController, _$state_, _$httpBackend_, _$httpParamSerializer_) => { $state = _$state_; $httpBackend = _$httpBackend_; + $httpParamSerializer = _$httpParamSerializer_; controller = $componentController('vnTicketBasicDataStepOne', {$state}); controller.ticket = { addressFk: 121, @@ -37,6 +39,14 @@ describe('Ticket', () => { }); }); + describe('clientId() getter', () => { + it('should return the clientFk property', () => { + controller.ticket = {id: 1, clientFk: 102}; + + expect(controller.clientId).toEqual(102); + }); + }); + describe('clientId() setter', () => { it('should set clientId property and call onChangeClient() method ', () => { spyOn(controller, 'onChangeClient'); @@ -47,6 +57,69 @@ describe('Ticket', () => { }); }); + describe('adressId() getter', () => { + it('should return the addressFk property', () => { + controller.ticket = {id: 1, addressFk: 99}; + + expect(controller.addressId).toEqual(99); + }); + }); + + describe('addressId() setter', () => { + it('should set addressId property and call getShipped() method ', () => { + spyOn(controller, 'getShipped'); + controller.ticket.addressFk = 99; + controller.addressId = 100; + const landed = new Date(); + const spectedResult = { + landed: landed, + addressFk: 100, + agencyModeFk: 7, + warehouseFk: 1 + }; + controller.landed = landed; + + expect(controller.getShipped).toHaveBeenCalledWith(spectedResult); + expect(controller.ticket.addressFk).toEqual(100); + }); + }); + + describe('warehouseId() getter', () => { + it('should return the warehouseId property', () => { + controller.ticket.warehouseFk = 2; + + expect(controller.warehouseId).toEqual(2); + }); + }); + + describe('warehouseId() setter', () => { + it('should set warehouseId property and call getShipped() method ', () => { + spyOn(controller, 'getShipped'); + controller.ticket.warehouseId = 1; + controller.warehouseId = 2; + const landed = new Date(); + const spectedResult = { + landed: landed, + addressFk: 121, + agencyModeFk: 7, + warehouseFk: 2 + }; + controller.landed = landed; + + expect(controller.getShipped).toHaveBeenCalledWith(spectedResult); + expect(controller.ticket.warehouseFk).toEqual(2); + }); + }); + + describe('shipped() getter', () => { + it('should return the shipped property', () => { + const shipped = new Date(); + controller.ticket.shipped = shipped; + + expect(controller.shipped).toEqual(shipped); + }); + }); + describe('shipped() setter', () => { it('should set shipped property and call getLanded() method ', () => { spyOn(controller, 'getLanded'); @@ -59,11 +132,19 @@ describe('Ticket', () => { }; controller.shipped = shipped; - expect(controller.getLanded).toHaveBeenCalledWith(spectedResult); }); }); + describe('landed() getter', () => { + it('should return the landed property', () => { + const landed = new Date(); + controller.ticket.landed = landed; + + expect(controller.landed).toEqual(landed); + }); + }); + describe('landed() setter', () => { it('should set shipped property and call getShipped() method ', () => { spyOn(controller, 'getShipped'); @@ -81,21 +162,29 @@ describe('Ticket', () => { }); }); + describe('agencyModeId() getter', () => { + it('should return the agencyModeFk property', () => { + controller.ticket.agencyModeFk = 66; + + expect(controller.agencyModeId).toEqual(66); + }); + }); + describe('agencyModeId() setter', () => { - it('should set agencyModeId property and call onChangeAgencyMode() method', () => { - spyOn(controller, 'getShipped'); - const landed = new Date(); + it('should set agencyModeId property and call getLanded() method', () => { + spyOn(controller, 'getLanded'); + const shipped = new Date(); const agencyModeId = 8; const spectedResult = { - landed: landed, + shipped: shipped, addressFk: 121, agencyModeFk: agencyModeId, warehouseFk: 1 }; - controller.ticket.landed = landed; + controller.ticket.shipped = shipped; controller.agencyModeId = 8; - expect(controller.getShipped).toHaveBeenCalledWith(spectedResult); + expect(controller.getLanded).toHaveBeenCalledWith(spectedResult); }); it('should do nothing if attempting to set the same agencyMode id', () => { @@ -115,6 +204,14 @@ describe('Ticket', () => { }); }); + describe('zoneId() getter', () => { + it('should return the zoneFk property', () => { + controller.ticket.zoneFk = 10; + + expect(controller.zoneId).toEqual(10); + }); + }); + describe('zoneId() setter', () => { it('should set zoneId property and call onChangeZone() method ', () => { const zoneId = 5; @@ -223,5 +320,49 @@ describe('Ticket', () => { $httpBackend.flush(); }); }); + + describe('getLanded()', () => { + it('should return an available landed date', async() => { + const shipped = new Date(); + const expectedResult = {landed: new Date()}; + const params = { + shipped: shipped, + addressFk: 121, + agencyModeFk: 7, + warehouseFk: 1 + }; + const serializedParams = $httpParamSerializer(params); + + $httpBackend.when('GET', `/api/Agencies/getLanded?${serializedParams}`).respond(200, expectedResult); + $httpBackend.expect('GET', `/api/Agencies/getLanded?${serializedParams}`); + controller.getLanded(params); + $httpBackend.flush(); + + expect(controller.shipped).toEqual(shipped); + expect(controller.landed).toEqual(expectedResult.landed); + }); + }); + + describe('getShipped()', () => { + it('should return an available shipped date', async() => { + const landed = new Date(); + const expectedResult = {shipped: new Date()}; + const params = { + landed: landed, + addressFk: 121, + agencyModeFk: 7, + warehouseFk: 1 + }; + const serializedParams = $httpParamSerializer(params); + + $httpBackend.when('GET', `/api/Agencies/getShipped?${serializedParams}`).respond(200, expectedResult); + $httpBackend.expect('GET', `/api/Agencies/getShipped?${serializedParams}`); + controller.getShipped(params); + $httpBackend.flush(); + + expect(controller.shipped).toEqual(expectedResult.shipped); + expect(controller.landed).toEqual(landed); + }); + }); }); }); diff --git a/modules/ticket/front/descriptor/addStowaway.html b/modules/ticket/front/descriptor/addStowaway.html index 74554d2be..3efaedc8d 100644 --- a/modules/ticket/front/descriptor/addStowaway.html +++ b/modules/ticket/front/descriptor/addStowaway.html @@ -12,7 +12,7 @@
      Stowaways to add
      - + Ticket id diff --git a/modules/ticket/front/index/index.html b/modules/ticket/front/index/index.html index 8b2060e42..0f70dea40 100644 --- a/modules/ticket/front/index/index.html +++ b/modules/ticket/front/index/index.html @@ -4,34 +4,35 @@ limit="20" params="::$ctrl.params" data="tickets" - order="shipped DESC, zoneHour ASC, zoneMinute ASC, clientFk" - auto-load="false"> + order="shipped DESC, zoneHour ASC, zoneMinute ASC, clientFk">
      -
      - - - - - - - - -
      - - + + + + + + + + + + + @@ -42,7 +43,7 @@ Id Salesperson - Date + Date Hour Alias Province @@ -122,8 +123,8 @@ {{::ticket.warehouse}} {{::ticket.refFk | dashIfEmpty}} {{::ticket.zoneLanding | dateTime: 'HH:mm'}} - - + + {{::ticket.total | currency: 'EUR': 2}} @@ -142,8 +143,8 @@ - - + +
      diff --git a/modules/ticket/front/index/style.scss b/modules/ticket/front/index/style.scss index 6a935c7f6..ccf913ff5 100644 --- a/modules/ticket/front/index/style.scss +++ b/modules/ticket/front/index/style.scss @@ -10,7 +10,6 @@ vn-ticket-index { color: initial; } } - vn-searchbar { width: 100% } diff --git a/modules/ticket/front/summary/index.html b/modules/ticket/front/summary/index.html index 383d02ec9..d97c3125a 100644 --- a/modules/ticket/front/summary/index.html +++ b/modules/ticket/front/summary/index.html @@ -1,5 +1,9 @@ -
      Ticket #{{$ctrl.summary.id}} - {{$ctrl.summary.client.name}} ({{$ctrl.summary.client.id}}) - {{$ctrl.summary.nickname}} +
      + + Ticket #{{$ctrl.summary.id}} - {{$ctrl.summary.client.name}} + ({{$ctrl.summary.client.id}}) - {{$ctrl.summary.nickname}} + + data="travels">
      -
      - - - - -
      - - + + + + + + + Id @@ -50,6 +51,6 @@ - +
      \ No newline at end of file diff --git a/modules/worker/front/index/index.html b/modules/worker/front/index/index.html index 3c254e7f7..ce1a438b5 100644 --- a/modules/worker/front/index/index.html +++ b/modules/worker/front/index/index.html @@ -5,72 +5,70 @@ order="id" data="workers"> -
      -
      - + - + + \ No newline at end of file diff --git a/modules/worker/front/log/index.html b/modules/worker/front/log/index.html index 1a4ac0a5f..4f170ac35 100644 --- a/modules/worker/front/log/index.html +++ b/modules/worker/front/log/index.html @@ -7,98 +7,97 @@ limit="20" auto-load="true"> - - - - History - - - - Date - Changed by - Model - Action - Name - Before - After - - - - - - {{::log.creationDate | dateTime:'dd/MM/yyyy HH:mm'}} -
      -
      - Changed by: - {{::log.user.name | dashIfEmpty}} - -
      -
      - Model: - {{::log.changedModel | dashIfEmpty}} -
      -
      - Action: - {{::$ctrl.actionsText[log.action] | dashIfEmpty}} -
      -
      - Name: - {{::log.changedModelValue | dashIfEmpty}} -
      + + + + + + Date + Changed by + Model + Action + Name + Before + After + + + + + + {{::log.creationDate | dateTime:'dd/MM/yyyy HH:mm'}} +
      +
      + Changed by: + {{::log.user.name | dashIfEmpty}} +
      - - - {{::log.user.name | dashIfEmpty}} - - - - {{::log.changedModel}} - - - {{::$ctrl.actionsText[log.action]}} - - - {{::log.changedModelValue}} - - - -
      - {{::old.key}}: - {{::old.value}} -
      -
      -
      - - -
      - {{::new.key}}: - {{::new.value}} -
      -
      - -
      - {{log.description}} -
      -
      -
      - - - - +
      + Model: + {{::log.changedModel | dashIfEmpty}} +
      +
      + Action: + {{::$ctrl.actionsText[log.action] | dashIfEmpty}} +
      +
      + Name: + {{::log.changedModelValue | dashIfEmpty}} +
      +
      +
      + + {{::log.user.name | dashIfEmpty}} + + + + {{::log.changedModel}} + + + {{::$ctrl.actionsText[log.action]}} + + + {{::log.changedModelValue}} + + + +
      + {{::old.key}}: + {{::old.value}} +
      +
      +
      + + +
      + {{::new.key}}: + {{::new.value}} +
      +
      + +
      + {{log.description}} +
      +
      +
      +
      +
      +
      - +
      diff --git a/modules/worker/front/time-control/index.html b/modules/worker/front/time-control/index.html index 1aeb70304..f8915542b 100644 --- a/modules/worker/front/time-control/index.html +++ b/modules/worker/front/time-control/index.html @@ -63,7 +63,7 @@ diff --git a/modules/worker/front/time-control/index.js b/modules/worker/front/time-control/index.js index a82fdc63d..a13a1d384 100644 --- a/modules/worker/front/time-control/index.js +++ b/modules/worker/front/time-control/index.js @@ -208,12 +208,9 @@ class Controller { this.refresh(); } - onSelection(value) { - const selected = value[0].dated; - - this.defaultDate.setMonth(selected.getMonth()); - this.defaultDate.setDate(selected.getDate()); - + onSelection($days) { + this.defaultDate.setMonth($days[0].getMonth()); + this.defaultDate.setDate($days[0].getDate()); this.refresh(); } @@ -221,9 +218,9 @@ class Controller { const timed = new Date(weekday.dated); const now = new Date(); - now.setHours(now.getHours(), now.getMinutes(), 0, 0); now.setMonth(timed.getMonth()); now.setDate(timed.getDate()); + now.setHours(0, 0, 0, 0); this.newTime = now; this.selectedWeekday = weekday; diff --git a/package-lock.json b/package-lock.json index 535c5229d..7b4445337 100644 --- a/package-lock.json +++ b/package-lock.json @@ -2166,7 +2166,7 @@ }, "util": { "version": "0.10.3", - "resolved": "https://registry.npmjs.org/util/-/util-0.10.3.tgz", + "resolved": "http://registry.npmjs.org/util/-/util-0.10.3.tgz", "integrity": "sha1-evsa/lCAUkZInj23/g7TeTNqwPk=", "dev": true, "requires": { @@ -2960,7 +2960,7 @@ "base": { "version": "0.11.2", "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", - "integrity": "sha1-e95c7RRbbVUakNuH+DxVi060io8=", + "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", "dev": true, "requires": { "cache-base": "^1.0.1", @@ -3293,7 +3293,7 @@ }, "browserify-rsa": { "version": "4.0.1", - "resolved": "https://registry.npmjs.org/browserify-rsa/-/browserify-rsa-4.0.1.tgz", + "resolved": "http://registry.npmjs.org/browserify-rsa/-/browserify-rsa-4.0.1.tgz", "integrity": "sha1-IeCr+vbyApzy+vsTNWenAdQTVSQ=", "dev": true, "requires": { @@ -3352,7 +3352,7 @@ }, "buffer": { "version": "4.9.1", - "resolved": "https://registry.npmjs.org/buffer/-/buffer-4.9.1.tgz", + "resolved": "http://registry.npmjs.org/buffer/-/buffer-4.9.1.tgz", "integrity": "sha1-bRu2AbB6TvztlwlBMgkwJ8lbwpg=", "requires": { "base64-js": "^1.0.2", @@ -3490,7 +3490,7 @@ "cache-base": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", - "integrity": "sha1-Cn9GQWgxyLZi7jb+TnxZ129marI=", + "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", "dev": true, "requires": { "collection-visit": "^1.0.0", @@ -3528,7 +3528,7 @@ }, "camelcase-keys": { "version": "2.1.0", - "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-2.1.0.tgz", + "resolved": "http://registry.npmjs.org/camelcase-keys/-/camelcase-keys-2.1.0.tgz", "integrity": "sha1-MIvur/3ygRkFHvodkyITyRuPkuc=", "dev": true, "requires": { @@ -3667,7 +3667,7 @@ "class-utils": { "version": "0.3.6", "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", - "integrity": "sha1-+TNprouafOAv1B+q0MqDAzGQxGM=", + "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==", "dev": true, "requires": { "arr-union": "^3.1.0", @@ -4769,7 +4769,7 @@ "dot-prop": { "version": "4.2.0", "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-4.2.0.tgz", - "integrity": "sha1-HxngwuGqDjJ5fEl5nyg3rGr2nFc=", + "integrity": "sha512-tUMXrxlExSW6U2EXiiKGSBVdYgtV8qlHL+C10TsW4PURY/ic+eaysnSkwB4kA/mBlCyy/IKDJ+Lc3wbWeaXtuQ==", "requires": { "is-obj": "^1.0.0" } @@ -4801,7 +4801,7 @@ }, "readable-stream": { "version": "1.1.14", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", + "resolved": "http://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", "dev": true, "requires": { @@ -4924,7 +4924,7 @@ "dependencies": { "fs-extra": { "version": "0.30.0", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-0.30.0.tgz", + "resolved": "http://registry.npmjs.org/fs-extra/-/fs-extra-0.30.0.tgz", "integrity": "sha1-8jP/zAjU2n1DLapEl3aYnbHfk/A=", "dev": true, "requires": { @@ -4937,7 +4937,7 @@ }, "jsonfile": { "version": "2.4.0", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-2.4.0.tgz", + "resolved": "http://registry.npmjs.org/jsonfile/-/jsonfile-2.4.0.tgz", "integrity": "sha1-NzaitCi4e72gzIO1P6PWM6NcKug=", "dev": true, "requires": { @@ -5840,7 +5840,7 @@ }, "file-loader": { "version": "1.1.11", - "resolved": "https://registry.npmjs.org/file-loader/-/file-loader-1.1.11.tgz", + "resolved": "http://registry.npmjs.org/file-loader/-/file-loader-1.1.11.tgz", "integrity": "sha512-TGR4HU7HUsGg6GCOPJnFk06RhWgEWFLAGWiT6rcD+GRC2keU3s9RGJ+b3Z6/U73jwwNb2gKLJ7YCrp+jvU4ALg==", "dev": true, "requires": { @@ -6204,7 +6204,8 @@ "ansi-regex": { "version": "2.1.1", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "aproba": { "version": "1.2.0", @@ -6225,12 +6226,14 @@ "balanced-match": { "version": "1.0.0", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "brace-expansion": { "version": "1.1.11", "bundled": true, "dev": true, + "optional": true, "requires": { "balanced-match": "^1.0.0", "concat-map": "0.0.1" @@ -6245,17 +6248,20 @@ "code-point-at": { "version": "1.1.0", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "concat-map": { "version": "0.0.1", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "console-control-strings": { "version": "1.1.0", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "core-util-is": { "version": "1.0.2", @@ -6372,7 +6378,8 @@ "inherits": { "version": "2.0.3", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "ini": { "version": "1.3.5", @@ -6384,6 +6391,7 @@ "version": "1.0.0", "bundled": true, "dev": true, + "optional": true, "requires": { "number-is-nan": "^1.0.0" } @@ -6398,6 +6406,7 @@ "version": "3.0.4", "bundled": true, "dev": true, + "optional": true, "requires": { "brace-expansion": "^1.1.7" } @@ -6405,12 +6414,14 @@ "minimist": { "version": "0.0.8", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "minipass": { "version": "2.3.5", "bundled": true, "dev": true, + "optional": true, "requires": { "safe-buffer": "^5.1.2", "yallist": "^3.0.0" @@ -6429,6 +6440,7 @@ "version": "0.5.1", "bundled": true, "dev": true, + "optional": true, "requires": { "minimist": "0.0.8" } @@ -6509,7 +6521,8 @@ "number-is-nan": { "version": "1.0.1", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "object-assign": { "version": "4.1.1", @@ -6521,6 +6534,7 @@ "version": "1.4.0", "bundled": true, "dev": true, + "optional": true, "requires": { "wrappy": "1" } @@ -6606,7 +6620,8 @@ "safe-buffer": { "version": "5.1.2", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "safer-buffer": { "version": "2.1.2", @@ -6642,6 +6657,7 @@ "version": "1.0.2", "bundled": true, "dev": true, + "optional": true, "requires": { "code-point-at": "^1.0.0", "is-fullwidth-code-point": "^1.0.0", @@ -6661,6 +6677,7 @@ "version": "3.0.1", "bundled": true, "dev": true, + "optional": true, "requires": { "ansi-regex": "^2.0.0" } @@ -6704,12 +6721,14 @@ "wrappy": { "version": "1.0.2", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "yallist": { "version": "3.0.3", "bundled": true, - "dev": true + "dev": true, + "optional": true } } }, @@ -6992,7 +7011,7 @@ "global-modules": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/global-modules/-/global-modules-1.0.0.tgz", - "integrity": "sha1-bXcPDrUjrHgWTXK15xqIdyZcw+o=", + "integrity": "sha512-sKzpEkf11GpOFuw0Zzjzmt4B4UZwjOcG757PPvrfhxcLFbq0wpsgpOqxpxtxFiCG4DtG93M6XRVbF2oGdev7bg==", "dev": true, "requires": { "global-prefix": "^1.0.1", @@ -7029,7 +7048,7 @@ }, "globby": { "version": "5.0.0", - "resolved": "https://registry.npmjs.org/globby/-/globby-5.0.0.tgz", + "resolved": "http://registry.npmjs.org/globby/-/globby-5.0.0.tgz", "integrity": "sha1-69hGZ8oNuzMLmbz8aOrCvFQ3Dg0=", "dev": true, "requires": { @@ -7133,7 +7152,7 @@ }, "got": { "version": "6.7.1", - "resolved": "https://registry.npmjs.org/got/-/got-6.7.1.tgz", + "resolved": "http://registry.npmjs.org/got/-/got-6.7.1.tgz", "integrity": "sha1-JAzQV4WpoY5WHcG0S0HHY+8ejbA=", "dev": true, "requires": { @@ -7466,7 +7485,7 @@ }, "kind-of": { "version": "1.1.0", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-1.1.0.tgz", + "resolved": "http://registry.npmjs.org/kind-of/-/kind-of-1.1.0.tgz", "integrity": "sha1-FAo9LUGjbS78+pN3tiwk+ElaXEQ=", "dev": true }, @@ -7686,7 +7705,7 @@ "dependencies": { "es6-promise": { "version": "3.3.1", - "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-3.3.1.tgz", + "resolved": "http://registry.npmjs.org/es6-promise/-/es6-promise-3.3.1.tgz", "integrity": "sha1-oIzd6EzNvzTQJ6FFG8kdS80ophM=", "dev": true }, @@ -8720,7 +8739,7 @@ }, "is-obj": { "version": "1.0.1", - "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", + "resolved": "http://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=" }, "is-path-cwd": { @@ -8750,7 +8769,7 @@ "is-plain-object": { "version": "2.0.4", "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", - "integrity": "sha1-LBY7P6+xtgbZ0Xko8FwqHDjgdnc=", + "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", "dev": true, "requires": { "isobject": "^3.0.1" @@ -9101,7 +9120,7 @@ }, "jasmine-core": { "version": "2.99.1", - "resolved": "https://registry.npmjs.org/jasmine-core/-/jasmine-core-2.99.1.tgz", + "resolved": "http://registry.npmjs.org/jasmine-core/-/jasmine-core-2.99.1.tgz", "integrity": "sha1-5kAN8ea1bhMLYcS80JPap/boyhU=", "dev": true }, @@ -10224,7 +10243,7 @@ }, "load-json-file": { "version": "1.1.0", - "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-1.1.0.tgz", + "resolved": "http://registry.npmjs.org/load-json-file/-/load-json-file-1.1.0.tgz", "integrity": "sha1-lWkFcI1YtLq0wiYbBPWfMcmTdMA=", "dev": true, "requires": { @@ -11013,7 +11032,7 @@ }, "media-typer": { "version": "0.3.0", - "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", + "resolved": "http://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" }, "mem": { @@ -11038,7 +11057,7 @@ }, "meow": { "version": "3.7.0", - "resolved": "https://registry.npmjs.org/meow/-/meow-3.7.0.tgz", + "resolved": "http://registry.npmjs.org/meow/-/meow-3.7.0.tgz", "integrity": "sha1-cstmi0JSKCkKu/qFaJJYcwioAfs=", "dev": true, "requires": { @@ -11161,7 +11180,7 @@ }, "minimist": { "version": "1.2.0", - "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", + "resolved": "http://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=" }, "minstache": { @@ -11273,7 +11292,7 @@ }, "mkdirp": { "version": "0.5.1", - "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", + "resolved": "http://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", "requires": { "minimist": "0.0.8" @@ -11281,7 +11300,7 @@ "dependencies": { "minimist": { "version": "0.0.8", - "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", + "resolved": "http://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" } } @@ -11482,7 +11501,7 @@ }, "multipipe": { "version": "0.1.2", - "resolved": "https://registry.npmjs.org/multipipe/-/multipipe-0.1.2.tgz", + "resolved": "http://registry.npmjs.org/multipipe/-/multipipe-0.1.2.tgz", "integrity": "sha1-Ko8t33Du1WTf8tV/HhoTfZ8FB4s=", "dev": true, "requires": { @@ -11688,7 +11707,7 @@ }, "jsesc": { "version": "0.5.0", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", + "resolved": "http://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=", "dev": true }, @@ -12330,7 +12349,7 @@ "dependencies": { "minimist": { "version": "0.0.10", - "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.10.tgz", + "resolved": "http://registry.npmjs.org/minimist/-/minimist-0.0.10.tgz", "integrity": "sha1-3j+YVD2/lggr5IrRoMfNqDYwHc8=", "dev": true }, @@ -12392,7 +12411,7 @@ }, "os-homedir": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", + "resolved": "http://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", "dev": true }, @@ -12408,7 +12427,7 @@ }, "os-tmpdir": { "version": "1.0.2", - "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", + "resolved": "http://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", "dev": true }, @@ -12931,7 +12950,7 @@ }, "pretty-bytes": { "version": "1.0.4", - "resolved": "https://registry.npmjs.org/pretty-bytes/-/pretty-bytes-1.0.4.tgz", + "resolved": "http://registry.npmjs.org/pretty-bytes/-/pretty-bytes-1.0.4.tgz", "integrity": "sha1-CiLoIQYJrTVUL4yNXSFZr/B1HIQ=", "dev": true, "requires": { @@ -13022,7 +13041,7 @@ }, "readable-stream": { "version": "1.1.14", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", + "resolved": "http://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", "dev": true, "requires": { @@ -13040,7 +13059,7 @@ }, "through2": { "version": "0.2.3", - "resolved": "https://registry.npmjs.org/through2/-/through2-0.2.3.tgz", + "resolved": "http://registry.npmjs.org/through2/-/through2-0.2.3.tgz", "integrity": "sha1-6zKE2k6jEbbMis42U3SKUqvyWj8=", "dev": true, "requires": { @@ -13859,7 +13878,7 @@ }, "safe-regex": { "version": "1.1.0", - "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", + "resolved": "http://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", "dev": true, "requires": { @@ -13984,7 +14003,7 @@ "dependencies": { "source-map": { "version": "0.4.4", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", + "resolved": "http://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", "dev": true, "requires": { @@ -14404,7 +14423,7 @@ "snapdragon-node": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz", - "integrity": "sha1-bBdfhv8UvbByRWPo88GwIaKGhTs=", + "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==", "dev": true, "requires": { "define-property": "^1.0.0", @@ -14455,7 +14474,7 @@ "snapdragon-util": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", - "integrity": "sha1-+VZHlIbyrNeXAGk/b3uAXkWrVuI=", + "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", "dev": true, "requires": { "kind-of": "^3.2.0" @@ -14736,7 +14755,7 @@ "split-string": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", - "integrity": "sha1-fLCd2jqGWFcFxks5pkZgOGguj+I=", + "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", "dev": true, "requires": { "extend-shallow": "^3.0.0" @@ -14745,7 +14764,7 @@ "split2": { "version": "2.2.0", "resolved": "https://registry.npmjs.org/split2/-/split2-2.2.0.tgz", - "integrity": "sha1-GGsldbz4PoW30YRldWI47k7kJJM=", + "integrity": "sha512-RAb22TG39LhI31MbreBgIuKiIKhVsawfTgEGqKHTK87aG+ul/PB8Sqoi3I7kVdRWiCfrKxK3uo4/YUkpNvhPbw==", "dev": true, "requires": { "through2": "^2.0.2" @@ -15671,7 +15690,7 @@ }, "through": { "version": "2.3.8", - "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", + "resolved": "http://registry.npmjs.org/through/-/through-2.3.8.tgz", "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=" }, "through2": { @@ -15866,7 +15885,7 @@ "touch": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", - "integrity": "sha1-/jZfX3XsntTlaCXgu3bSSrdK+Ds=", + "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", "dev": true, "requires": { "nopt": "~1.0.10" @@ -15964,7 +15983,7 @@ }, "tty-browserify": { "version": "0.0.0", - "resolved": "https://registry.npmjs.org/tty-browserify/-/tty-browserify-0.0.0.tgz", + "resolved": "http://registry.npmjs.org/tty-browserify/-/tty-browserify-0.0.0.tgz", "integrity": "sha1-oVe6QC2iTpv5V/mqadUk7tQpAaY=", "dev": true }, From 4025c624b3f1518b429630d5437f1ce4dbef5777 Mon Sep 17 00:00:00 2001 From: Joan Sanchez Date: Tue, 8 Oct 2019 12:48:12 +0200 Subject: [PATCH 09/10] #15 WIP fixed requested changes --- loopback/locale/es.json | 2 +- modules/worker/back/methods/department/getLeaves.js | 8 ++++---- modules/worker/back/methods/department/removeChild.js | 2 +- modules/worker/front/department/index.js | 2 +- 4 files changed, 7 insertions(+), 7 deletions(-) diff --git a/loopback/locale/es.json b/loopback/locale/es.json index 9daf90d63..07c95af32 100644 --- a/loopback/locale/es.json +++ b/loopback/locale/es.json @@ -108,5 +108,5 @@ "This postal code is not valid": "This postal code is not valid", "is invalid": "is invalid", "The postcode doesn't exists. Ensure you put the correct format": "El código postal no existe. Asegúrate de ponerlo con el formato correcto", - "The department name can't be repeated": "The department name can't be repeated" + "The department name can't be repeated": "El nombre del departamento no puede repetirse" } \ No newline at end of file diff --git a/modules/worker/back/methods/department/getLeaves.js b/modules/worker/back/methods/department/getLeaves.js index bb6fd8d7e..614f3388e 100644 --- a/modules/worker/back/methods/department/getLeaves.js +++ b/modules/worker/back/methods/department/getLeaves.js @@ -2,7 +2,7 @@ module.exports = Self => { Self.remoteMethod('getLeaves', { description: 'Returns the nodes for a department', accepts: [{ - arg: 'parentFk', + arg: 'parentId', type: 'Number', description: 'Get the children of the specified father', }, { @@ -20,10 +20,10 @@ module.exports = Self => { } }); - Self.getLeaves = async(parentFk = null, search) => { + Self.getLeaves = async(parentId = null, search) => { let [res] = await Self.rawSql( `CALL department_getLeaves(?, ?)`, - [parentFk, search] + [parentId, search] ); let map = new Map(); @@ -41,7 +41,7 @@ module.exports = Self => { } } - let leaves = map.get(parentFk); + let leaves = map.get(parentId); setLeaves(leaves); return leaves || []; diff --git a/modules/worker/back/methods/department/removeChild.js b/modules/worker/back/methods/department/removeChild.js index 2d3f40b36..00115ec34 100644 --- a/modules/worker/back/methods/department/removeChild.js +++ b/modules/worker/back/methods/department/removeChild.js @@ -1,6 +1,6 @@ module.exports = Self => { Self.remoteMethod('removeChild', { - description: 'Returns the first shipped and landed possible for params', + description: 'Removes a child department', accessType: 'WRITE', accepts: [{ arg: 'id', diff --git a/modules/worker/front/department/index.js b/modules/worker/front/department/index.js index 0023dcca9..1a72681bc 100644 --- a/modules/worker/front/department/index.js +++ b/modules/worker/front/department/index.js @@ -13,7 +13,7 @@ class Controller { } onFetch(item) { - const params = item ? {parentFk: item.id} : null; + const params = item ? {parentId: item.id} : null; return this.$.model.applyFilter({}, params).then(() => { return this.$.model.data; }); From 935860247107819ad4e91680d20677876b3b9fc4 Mon Sep 17 00:00:00 2001 From: Joan Sanchez Date: Tue, 8 Oct 2019 13:03:19 +0200 Subject: [PATCH 10/10] #15 Updated changes width dev --- back/models/account.js | 24 +- .../core/components/crud-model/crud-model.js | 4 +- front/core/components/data-viewer/index.html | 2 +- front/core/components/date-picker/style.scss | 2 +- front/core/components/index.js | 1 + front/core/components/label-value/style.scss | 3 - front/core/components/list/index.js | 1 + .../components/list/style.scss} | 2 +- front/core/components/searchbar/style.scss | 2 +- front/core/components/step-control/style.scss | 9 - front/core/components/subtitle/subtitle.html | 2 +- front/core/components/title/title.html | 2 +- front/core/directives/uvc.html | 4 +- front/core/directives/zoom-image.js | 8 +- .../{styles => directives}/zoom-image.scss | 6 +- front/{salix => core}/styles/background.scss | 2 +- front/core/styles/border.scss | 23 ++ front/{salix => core}/styles/effects.scss | 1 - front/{salix => core}/styles/font-family.scss | 6 + .../styles/fonts/Roboto-Bold.ttf | Bin .../styles/fonts/Roboto-Medium.ttf | Bin .../styles/fonts/Roboto-Regular.ttf | Bin .../{ => icons}/Material-Design-Icons.woff2 | Bin front/core/styles/{ => icons}/salixfont.css | 0 front/core/styles/{ => icons}/salixfont.svg | 0 front/core/styles/{ => icons}/salixfont.ttf | Bin front/core/styles/{ => icons}/salixfont.woff | Bin front/core/styles/index.js | 13 +- front/{salix => core}/styles/layout.scss | 5 - front/core/styles/mdi-override.css | 6 - front/core/styles/mdl-override.scss | 67 ++-- front/{salix => core}/styles/responsive.scss | 0 front/core/styles/spacing.scss | 355 ++++++++++++++++++ front/core/styles/text.scss | 72 ++++ front/{salix => core}/styles/variables.scss | 22 +- front/{salix => core}/styles/width.scss | 0 front/salix/components/app/style.scss | 6 +- front/salix/components/descriptor/index.js | 1 + .../descriptor/style.scss} | 10 +- front/salix/components/index.js | 2 + .../salix/components/left-menu/left-menu.html | 2 +- .../salix/components/main-menu/main-menu.html | 4 +- front/salix/components/main-menu/main-menu.js | 9 +- .../components/main-menu/main-menu.spec.js | 4 +- front/salix/components/summary/index.js | 1 + .../summary/style.scss} | 8 +- .../user-configuration-popover/index.html | 18 +- .../user-configuration-popover/locale/es.yml | 1 + .../user-configuration-popover/style.scss | 27 +- front/salix/styles/border.scss | 23 -- front/salix/styles/display.scss | 35 -- front/salix/styles/font-style.scss | 16 - front/salix/styles/index.js | 16 +- front/salix/styles/margin.scss | 138 ------- front/salix/styles/misc.scss | 71 ++-- front/salix/styles/modal-form.scss | 27 +- front/salix/styles/order-product.scss | 10 +- front/salix/styles/padding.scss | 85 ----- front/salix/styles/photo-list.scss | 4 +- front/salix/styles/title.scss | 28 -- loopback/locale/en.json | 3 +- modules/agency/front/basic-data/index.html | 2 +- modules/agency/front/calendar/index.html | 4 +- modules/agency/front/create/index.html | 2 +- modules/agency/front/delivery-days/index.html | 4 +- modules/agency/front/edit/index.html | 2 +- modules/agency/front/events/index.html | 6 +- modules/agency/front/events/style.scss | 4 +- modules/agency/front/index/index.html | 6 +- .../front/location-search-panel/index.html | 2 +- modules/agency/front/location/index.html | 4 +- modules/agency/front/main/style.scss | 2 +- modules/agency/front/search-panel/index.html | 2 +- modules/agency/front/summary/index.html | 2 +- modules/claim/front/action/index.html | 6 +- modules/claim/front/basic-data/index.html | 6 +- modules/claim/front/detail/index.html | 10 +- modules/claim/front/development/index.html | 6 +- modules/claim/front/dms/index/style.scss | 4 +- modules/claim/front/index/index.html | 5 +- modules/claim/front/search-panel/index.html | 2 +- .../client/front/address/create/index.html | 12 +- modules/client/front/address/edit/index.html | 12 +- modules/client/front/address/index/index.html | 15 +- modules/client/front/address/index/style.scss | 2 +- .../client/front/balance/create/index.html | 4 +- modules/client/front/balance/index/index.html | 2 +- modules/client/front/basic-data/index.html | 2 +- modules/client/front/billing-data/index.html | 10 +- modules/client/front/contact/index.html | 4 +- modules/client/front/create/index.html | 16 +- .../front/credit-insurance/create/index.html | 2 +- .../front/credit-insurance/index/index.html | 13 +- .../insurance/create/index.html | 2 +- .../insurance/index/index.html | 2 +- modules/client/front/credit/create/index.html | 2 +- modules/client/front/dms/create/index.html | 8 +- modules/client/front/dms/edit/index.html | 8 +- modules/client/front/fiscal-data/index.html | 10 +- modules/client/front/greuge/create/index.html | 2 +- modules/client/front/greuge/index/index.html | 2 +- modules/client/front/index/index.html | 4 +- modules/client/front/note/create/index.html | 2 +- modules/client/front/note/index/index.html | 11 +- modules/client/front/postcode/index.html | 2 +- .../client/front/recovery/create/index.html | 2 +- modules/client/front/sample/create/index.html | 2 +- modules/client/front/search-panel/index.html | 2 +- modules/client/front/sms/index.html | 2 +- modules/client/front/web-access/index.html | 4 +- modules/invoiceOut/front/index/index.html | 5 +- .../invoiceOut/front/search-panel/index.html | 2 +- modules/item/front/barcode/index.html | 2 +- modules/item/front/basic-data/index.html | 2 +- modules/item/front/botanical/index.html | 2 +- modules/item/front/create/index.html | 2 +- modules/item/front/diary/index.html | 2 +- modules/item/front/index/index.html | 5 +- modules/item/front/last-entries/index.html | 2 +- modules/item/front/last-entries/style.scss | 2 +- modules/item/front/niche/index.html | 2 +- .../front/request-search-panel/index.html | 4 +- modules/item/front/request/index.html | 10 +- modules/item/front/search-panel/index.html | 4 +- modules/item/front/tags/index.html | 2 +- modules/item/front/tax/index.html | 2 +- modules/order/front/basic-data/index.html | 2 +- .../front/catalog-search-panel/index.html | 4 +- modules/order/front/catalog/index.html | 6 +- modules/order/front/catalog/style.scss | 6 +- modules/order/front/create/index.html | 2 +- modules/order/front/filter/style.scss | 12 +- modules/order/front/index/index.html | 5 +- modules/order/front/line/index.html | 2 +- modules/order/front/prices-popover/index.html | 2 +- modules/order/front/search-panel/index.html | 2 +- modules/order/front/summary/index.html | 6 +- modules/order/front/volume/index.html | 2 +- modules/route/front/basic-data/index.html | 2 +- modules/route/front/create/index.html | 2 +- modules/route/front/index/index.html | 6 +- modules/route/front/search-panel/index.html | 2 +- modules/route/front/tickets/index.html | 4 +- .../front/basic-data/step-one/index.html | 2 +- .../front/basic-data/step-three/index.html | 2 +- .../front/basic-data/step-two/index.html | 2 +- modules/ticket/front/component/index.html | 2 +- modules/ticket/front/create/index.html | 2 +- .../ticket/front/descriptor/addStowaway.html | 51 +-- modules/ticket/front/descriptor/index.html | 2 +- .../front/descriptor/removeStowaway.html | 4 +- modules/ticket/front/dms/create/index.html | 8 +- modules/ticket/front/dms/edit/index.html | 8 +- modules/ticket/front/dms/index/index.html | 2 +- modules/ticket/front/expedition/index.html | 4 +- modules/ticket/front/index/index.html | 17 +- modules/ticket/front/index/style.scss | 6 + modules/ticket/front/note/index.html | 8 +- modules/ticket/front/package/index.html | 4 +- modules/ticket/front/picture/index.html | 2 +- .../ticket/front/request/create/index.html | 4 +- modules/ticket/front/request/index/index.html | 2 +- modules/ticket/front/sale-checked/index.html | 2 +- modules/ticket/front/sale-tracking/index.html | 2 +- modules/ticket/front/sale/editDiscount.html | 4 +- modules/ticket/front/sale/index.html | 14 +- modules/ticket/front/search-panel/index.html | 2 +- modules/ticket/front/services/index.html | 10 +- modules/ticket/front/tracking/edit/index.html | 2 +- .../ticket/front/tracking/index/index.html | 2 +- modules/ticket/front/volume/index.html | 2 +- modules/ticket/front/weekly/create/index.html | 2 +- modules/ticket/front/weekly/index/index.html | 6 +- modules/travel/front/index/index.html | 5 +- modules/travel/front/search-panel/index.html | 2 +- modules/worker/front/account/index.html | 33 ++ modules/worker/front/basic-data/index.html | 2 +- modules/worker/front/calendar/index.html | 4 +- modules/worker/front/calendar/style.scss | 2 +- modules/worker/front/department/index.html | 4 +- modules/worker/front/index/index.html | 4 +- modules/worker/front/pbx/index.html | 2 +- modules/worker/front/search-panel/index.html | 2 +- modules/worker/front/summary/index.html | 2 +- modules/worker/front/time-control/index.html | 8 +- webpack.config.js | 2 +- 186 files changed, 1003 insertions(+), 801 deletions(-) create mode 100644 front/core/components/list/index.js rename front/{salix/styles/list.scss => core/components/list/style.scss} (96%) rename front/core/{styles => directives}/zoom-image.scss (100%) rename front/{salix => core}/styles/background.scss (98%) create mode 100644 front/core/styles/border.scss rename front/{salix => core}/styles/effects.scss (99%) rename front/{salix => core}/styles/font-family.scss (58%) rename front/{salix => core}/styles/fonts/Roboto-Bold.ttf (100%) rename front/{salix => core}/styles/fonts/Roboto-Medium.ttf (100%) rename front/{salix => core}/styles/fonts/Roboto-Regular.ttf (100%) rename front/core/styles/{ => icons}/Material-Design-Icons.woff2 (100%) rename front/core/styles/{ => icons}/salixfont.css (100%) rename front/core/styles/{ => icons}/salixfont.svg (100%) rename front/core/styles/{ => icons}/salixfont.ttf (100%) rename front/core/styles/{ => icons}/salixfont.woff (100%) rename front/{salix => core}/styles/layout.scss (89%) delete mode 100644 front/core/styles/mdi-override.css rename front/{salix => core}/styles/responsive.scss (100%) create mode 100644 front/core/styles/spacing.scss create mode 100644 front/core/styles/text.scss rename front/{salix => core}/styles/variables.scss (92%) rename front/{salix => core}/styles/width.scss (100%) create mode 100644 front/salix/components/descriptor/index.js rename front/salix/{styles/descriptor.scss => components/descriptor/style.scss} (90%) create mode 100644 front/salix/components/summary/index.js rename front/salix/{styles/summary.scss => components/summary/style.scss} (91%) delete mode 100644 front/salix/styles/border.scss delete mode 100644 front/salix/styles/display.scss delete mode 100644 front/salix/styles/font-style.scss delete mode 100644 front/salix/styles/margin.scss delete mode 100644 front/salix/styles/padding.scss delete mode 100644 front/salix/styles/title.scss create mode 100644 modules/worker/front/account/index.html diff --git a/back/models/account.js b/back/models/account.js index 40b7e9c12..9e6ecba45 100644 --- a/back/models/account.js +++ b/back/models/account.js @@ -23,15 +23,13 @@ module.exports = Self => { description: 'Gets the current user data', accepts: [ { - arg: 'context', - type: 'object', - http: function(ctx) { - return ctx; - } + arg: 'ctx', + type: 'Object', + http: {source: 'context'} } ], returns: { - type: 'object', + type: 'Object', root: true }, http: { @@ -41,12 +39,18 @@ module.exports = Self => { }); Self.getCurrentUserData = async function(ctx) { - let filter = {fields: ['name']}; let userId = ctx.req.accessToken.userId; - let account = await Self.findById(userId, filter); - let worker = await Self.app.models.Worker.findOne({where: {userFk: userId}, fields: ['id']}); - return {accountName: account.name, workerId: worker.id}; + let account = await Self.findById(userId, { + fields: ['id', 'name', 'nickname'] + }); + + let worker = await Self.app.models.Worker.findOne({ + fields: ['id'], + where: {userFk: userId} + }); + + return Object.assign(account, {workerId: worker.id}); }; /** diff --git a/front/core/components/crud-model/crud-model.js b/front/core/components/crud-model/crud-model.js index 0839881ab..41b5390a7 100644 --- a/front/core/components/crud-model/crud-model.js +++ b/front/core/components/crud-model/crud-model.js @@ -208,7 +208,9 @@ export default class CrudModel extends ModelProxy { this.cancelRequest(); this.canceler = this.$q.defer(); this.isPaging = append; - if (!append) this.status = 'loading'; + + if (!append && this.status != 'ready') + this.status = 'loading'; let params = Object.assign( {filter}, diff --git a/front/core/components/data-viewer/index.html b/front/core/components/data-viewer/index.html index dd696fda3..8c843d869 100644 --- a/front/core/components/data-viewer/index.html +++ b/front/core/components/data-viewer/index.html @@ -2,7 +2,7 @@
      + class="vn-pt-md">
      section { content: ':'; } } - & > span { - color: $color-font; - } & > vn-icon { vertical-align: middle; color: $color-font-secondary; diff --git a/front/core/components/list/index.js b/front/core/components/list/index.js new file mode 100644 index 000000000..423b033ce --- /dev/null +++ b/front/core/components/list/index.js @@ -0,0 +1 @@ +import './style.scss'; diff --git a/front/salix/styles/list.scss b/front/core/components/list/style.scss similarity index 96% rename from front/salix/styles/list.scss rename to front/core/components/list/style.scss index 3a6d0d6d9..7560d3288 100644 --- a/front/salix/styles/list.scss +++ b/front/core/components/list/style.scss @@ -14,7 +14,7 @@ color: inherit; & > vn-horizontal { - padding: $pad-medium; + padding: $spacing-md; & > vn-one { overflow: hidden; diff --git a/front/core/components/searchbar/style.scss b/front/core/components/searchbar/style.scss index e663f7cb9..3915c2089 100644 --- a/front/core/components/searchbar/style.scss +++ b/front/core/components/searchbar/style.scss @@ -13,6 +13,6 @@ vn-searchbar { max-height: 48em; & > form { - padding: $pad-large; + padding: $spacing-lg; } } \ No newline at end of file diff --git a/front/core/components/step-control/style.scss b/front/core/components/step-control/style.scss index f020a31f6..e1c29c9a2 100644 --- a/front/core/components/step-control/style.scss +++ b/front/core/components/step-control/style.scss @@ -12,31 +12,25 @@ vn-step-control { display: flex; flex-direction: row } - & > .steps > .step { justify-content: center; min-width: 125px; display: flex; flex: auto } - & > .steps > .step .circle { border: 2px solid $color-main; background-color: white; align-content: center; margin-top: -9.5px; - -moz-border-radius: 50%; - -webkit-border-radius: 50%; border-radius: 50%; cursor: pointer; height: 15px; width: 15px } - & > .steps > .step .circle.active { background-color: $color-main; } - & > .buttons { display: flex; flex: auto; @@ -44,11 +38,9 @@ vn-step-control { justify-content: space-between; margin-top: 10px } - & > .buttons > .step { display: flex } - & > .buttons > .step > .mdl-button { line-height: 32px; font-size: 12px; @@ -56,5 +48,4 @@ vn-step-control { height: 32px } } - } \ No newline at end of file diff --git a/front/core/components/subtitle/subtitle.html b/front/core/components/subtitle/subtitle.html index ac00ac0c2..40c244006 100644 --- a/front/core/components/subtitle/subtitle.html +++ b/front/core/components/subtitle/subtitle.html @@ -1,2 +1,2 @@ -
      +
      \ No newline at end of file diff --git a/front/core/components/title/title.html b/front/core/components/title/title.html index 773b40040..cfdad746f 100644 --- a/front/core/components/title/title.html +++ b/front/core/components/title/title.html @@ -1,3 +1,3 @@ -

      +

      \ No newline at end of file diff --git a/front/core/directives/uvc.html b/front/core/directives/uvc.html index 0248aefc1..907ea6f2a 100644 --- a/front/core/directives/uvc.html +++ b/front/core/directives/uvc.html @@ -8,10 +8,10 @@ class="modal-form" vn-id="uvc"> - +
      Fields to show
      -
      +
      .body { - padding: $pad-small; + padding: $spacing-sm; & > * { - padding: $pad-small; + padding: $spacing-sm; } & > .attributes > h5 { - padding-bottom: $pad-small; + padding-bottom: $spacing-sm; text-overflow: ellipsis; white-space: nowrap; overflow: hidden; @@ -45,7 +45,7 @@ padding: 0; & > vn-icon { - padding: $pad-small; + padding: $spacing-sm; color: $color-secondary; font-size: 1.5em; @@ -62,7 +62,7 @@ padding: 0; & > a { - padding: $pad-small; + padding: $spacing-sm; & > vn-icon { font-size: 1.8em; diff --git a/front/salix/components/index.js b/front/salix/components/index.js index a5ce18e4c..a61b037b0 100644 --- a/front/salix/components/index.js +++ b/front/salix/components/index.js @@ -7,3 +7,5 @@ import './side-menu/side-menu'; import './left-menu/left-menu'; import './topbar/topbar'; import './user-configuration-popover'; +import './descriptor'; +import './summary'; diff --git a/front/salix/components/left-menu/left-menu.html b/front/salix/components/left-menu/left-menu.html index 31dcb7903..12cea49a3 100644 --- a/front/salix/components/left-menu/left-menu.html +++ b/front/salix/components/left-menu/left-menu.html @@ -1,4 +1,4 @@ -
      -
    • - +
    diff --git a/modules/order/front/catalog/style.scss b/modules/order/front/catalog/style.scss index 8061cabc4..18dc51bb0 100644 --- a/modules/order/front/catalog/style.scss +++ b/modules/order/front/catalog/style.scss @@ -3,7 +3,7 @@ vn-order-catalog { .catalog-header { border-bottom: $border-thin; - padding: $pad-medium; + padding: $spacing-md; align-items: center; & > vn-one { @@ -20,12 +20,12 @@ vn-order-catalog { overflow: hidden; & > * { - padding-left: $pad-medium; + padding-left: $spacing-md; } } } .catalog-list { - padding-top: $pad-small; + padding-top: $spacing-sm; } } diff --git a/modules/order/front/create/index.html b/modules/order/front/create/index.html index 0f52e18ac..d557bd21a 100644 --- a/modules/order/front/create/index.html +++ b/modules/order/front/create/index.html @@ -1,6 +1,6 @@
    - + diff --git a/modules/order/front/filter/style.scss b/modules/order/front/filter/style.scss index 07a7b1dbd..52125ace6 100644 --- a/modules/order/front/filter/style.scss +++ b/modules/order/front/filter/style.scss @@ -3,25 +3,25 @@ vn-catalog-filter > div { & > .input { - padding-left: $pad-medium; - padding-right: $pad-medium; + padding-left: $spacing-md; + padding-right: $spacing-md; border-color: $color-spacer; border-bottom: $border-thin; } .item-category { - padding: $pad-small; + padding: $spacing-sm; justify-content: flex-start; align-items: flex-start; flex-wrap: wrap; & > vn-one { - padding: $pad-small; + padding: $spacing-sm; min-width: 33.33%; text-align: center; box-sizing: border-box; & > vn-icon { - padding: $pad-small; + padding: $spacing-sm; background-color: $color-font-secondary; border-radius: 50%; cursor: pointer; @@ -40,7 +40,7 @@ vn-catalog-filter > div { } .chips { flex-wrap: wrap; - padding: $pad-medium; + padding: $spacing-md; } vn-autocomplete[vn-id="type"] .list { diff --git a/modules/order/front/index/index.html b/modules/order/front/index/index.html index a22e7501a..ca7e6ac4e 100644 --- a/modules/order/front/index/index.html +++ b/modules/order/front/index/index.html @@ -6,7 +6,7 @@ order="landed DESC, clientFk"> -
    +
    {{$ctrl.item.id}}
    diff --git a/modules/order/front/search-panel/index.html b/modules/order/front/search-panel/index.html index 953524625..3b8ca238b 100644 --- a/modules/order/front/search-panel/index.html +++ b/modules/order/front/search-panel/index.html @@ -80,7 +80,7 @@ field="filter.isConfirmed"> - + diff --git a/modules/order/front/summary/index.html b/modules/order/front/summary/index.html index e3022493d..4f3aee712 100644 --- a/modules/order/front/summary/index.html +++ b/modules/order/front/summary/index.html @@ -8,9 +8,6 @@ - - @@ -27,6 +24,9 @@ + + - +
    diff --git a/modules/route/front/basic-data/index.html b/modules/route/front/basic-data/index.html index 5bdcfc1e5..0292d89dc 100644 --- a/modules/route/front/basic-data/index.html +++ b/modules/route/front/basic-data/index.html @@ -6,7 +6,7 @@ save="patch">
    - +
    - +
    - + + class="vn-w-lg vn-my-md vn-mb-xl"> diff --git a/modules/route/front/search-panel/index.html b/modules/route/front/search-panel/index.html index f19f88ee6..1b495c640 100644 --- a/modules/route/front/search-panel/index.html +++ b/modules/route/front/search-panel/index.html @@ -69,7 +69,7 @@ model="filter.description"> - + diff --git a/modules/route/front/tickets/index.html b/modules/route/front/tickets/index.html index 6019ebfa2..560a34cc8 100644 --- a/modules/route/front/tickets/index.html +++ b/modules/route/front/tickets/index.html @@ -6,8 +6,8 @@ auto-load="true">
    - - + + - + - + - + diff --git a/modules/ticket/front/component/index.html b/modules/ticket/front/component/index.html index 228a0270c..d79bd524f 100644 --- a/modules/ticket/front/component/index.html +++ b/modules/ticket/front/component/index.html @@ -7,7 +7,7 @@ auto-load="true"> - +
    diff --git a/modules/ticket/front/create/index.html b/modules/ticket/front/create/index.html index 81c04a7b1..97980d08a 100644 --- a/modules/ticket/front/create/index.html +++ b/modules/ticket/front/create/index.html @@ -1,6 +1,6 @@
    - + diff --git a/modules/ticket/front/descriptor/addStowaway.html b/modules/ticket/front/descriptor/addStowaway.html index 3efaedc8d..c51d9d0d3 100644 --- a/modules/ticket/front/descriptor/addStowaway.html +++ b/modules/ticket/front/descriptor/addStowaway.html @@ -1,37 +1,38 @@ - + on-open="model.refresh()"> - +
    Stowaways to add
    - - - - - Ticket id - Shipped - Agency - Warehouse - State - - - - - {{ticket.id}} - {{ticket.landed | dateTime: 'dd/MM/yyyy'}} - {{ticket.agencyMode.name}} - {{ticket.warehouse.name}} - {{ticket.state.state.name}} - - - + + + + + + Ticket id + Shipped + Agency + Warehouse + State + + + + + {{ticket.id}} + {{ticket.landed | dateTime: 'dd/MM/yyyy'}} + {{ticket.agencyMode.name}} + {{ticket.warehouse.name}} + {{ticket.state.state.name}} + + + +
    \ No newline at end of file diff --git a/modules/ticket/front/descriptor/index.html b/modules/ticket/front/descriptor/index.html index c377a23b1..88d510e06 100644 --- a/modules/ticket/front/descriptor/index.html +++ b/modules/ticket/front/descriptor/index.html @@ -119,7 +119,7 @@
    In which day you want to add the ticket?
    - + diff --git a/modules/ticket/front/descriptor/removeStowaway.html b/modules/ticket/front/descriptor/removeStowaway.html index 515d6b2cc..78ac5cf3f 100644 --- a/modules/ticket/front/descriptor/removeStowaway.html +++ b/modules/ticket/front/descriptor/removeStowaway.html @@ -2,10 +2,10 @@ class="modal-form" vn-id="dialog"> - +
    Stowaways of the ticket {{$ctrl.ticket.id}}
    - + diff --git a/modules/ticket/front/dms/create/index.html b/modules/ticket/front/dms/create/index.html index 2ab817c75..a3eae3b4d 100644 --- a/modules/ticket/front/dms/create/index.html +++ b/modules/ticket/front/dms/create/index.html @@ -2,9 +2,13 @@ vn-id="watcher" data="$ctrl.dms"> - +
    - + - +
    - + - + diff --git a/modules/ticket/front/expedition/index.html b/modules/ticket/front/expedition/index.html index eafd318a2..a39c2f9c2 100644 --- a/modules/ticket/front/expedition/index.html +++ b/modules/ticket/front/expedition/index.html @@ -7,7 +7,7 @@ data="expeditions"> - + @@ -26,7 +26,7 @@ - + diff --git a/modules/ticket/front/index/index.html b/modules/ticket/front/index/index.html index 0f70dea40..169e6802e 100644 --- a/modules/ticket/front/index/index.html +++ b/modules/ticket/front/index/index.html @@ -7,7 +7,7 @@ order="shipped DESC, zoneHour ASC, zoneMinute ASC, clientFk">
    - + + class="vn-my-md vn-mb-xl"> @@ -42,15 +41,15 @@ Id - Salesperson + Salesperson Date Hour Alias - Province + Province State Agency Warehouse - Invoice + Invoice Closure Total @@ -93,7 +92,7 @@ {{::ticket.id}} - + @@ -113,7 +112,7 @@ {{::ticket.nickname}} - {{::ticket.province}} + {{::ticket.province}} {{::ticket.state}} @@ -121,7 +120,7 @@ {{::ticket.agencyMode}} {{::ticket.warehouse}} - {{::ticket.refFk | dashIfEmpty}} + {{::ticket.refFk | dashIfEmpty}} {{::ticket.zoneLanding | dateTime: 'HH:mm'}} diff --git a/modules/ticket/front/index/style.scss b/modules/ticket/front/index/style.scss index ccf913ff5..7fed21006 100644 --- a/modules/ticket/front/index/style.scss +++ b/modules/ticket/front/index/style.scss @@ -13,4 +13,10 @@ vn-ticket-index { vn-searchbar { width: 100% } + + @media screen and (max-width: 1440px) { + .expendable { + display: none; + } + } } \ No newline at end of file diff --git a/modules/ticket/front/note/index.html b/modules/ticket/front/note/index.html index bc808ce8e..765cee481 100644 --- a/modules/ticket/front/note/index.html +++ b/modules/ticket/front/note/index.html @@ -17,8 +17,8 @@ form="form"> - - + + - + - + - + + class="vn-pa-md"> No results diff --git a/modules/ticket/front/request/create/index.html b/modules/ticket/front/request/create/index.html index b03e87f6a..3ff2dc82e 100644 --- a/modules/ticket/front/request/create/index.html +++ b/modules/ticket/front/request/create/index.html @@ -5,9 +5,9 @@ form="form" save="post"> - +
    - + - + diff --git a/modules/ticket/front/sale-checked/index.html b/modules/ticket/front/sale-checked/index.html index cc4db0aaf..e55441a02 100644 --- a/modules/ticket/front/sale-checked/index.html +++ b/modules/ticket/front/sale-checked/index.html @@ -7,7 +7,7 @@ data="sales"> - + diff --git a/modules/ticket/front/sale-tracking/index.html b/modules/ticket/front/sale-tracking/index.html index c3c918c09..175efbf66 100644 --- a/modules/ticket/front/sale-tracking/index.html +++ b/modules/ticket/front/sale-tracking/index.html @@ -6,7 +6,7 @@ data="sales"> - + diff --git a/modules/ticket/front/sale/editDiscount.html b/modules/ticket/front/sale/editDiscount.html index e4c7cf9cd..ce90f9d99 100644 --- a/modules/ticket/front/sale/editDiscount.html +++ b/modules/ticket/front/sale/editDiscount.html @@ -1,7 +1,7 @@ - +
    MANÁ: {{$ctrl.mana | currency: 'EUR':0}}
    -
    +
    - + - +
    - +
    MANÁ: {{$ctrl.mana | currency: 'EUR':0}}
    -
    +
    -
    +

    Sales to transfer

    @@ -332,7 +332,7 @@
    - + - + diff --git a/modules/ticket/front/search-panel/index.html b/modules/ticket/front/search-panel/index.html index 70fa24e63..da6aac8e3 100644 --- a/modules/ticket/front/search-panel/index.html +++ b/modules/ticket/front/search-panel/index.html @@ -109,7 +109,7 @@ url="/api/Provinces">
    - + diff --git a/modules/ticket/front/services/index.html b/modules/ticket/front/services/index.html index dc7f5b92c..5b6b2dbef 100644 --- a/modules/ticket/front/services/index.html +++ b/modules/ticket/front/services/index.html @@ -10,7 +10,7 @@ data="$ctrl.services">
    - + - - + -
    New service type
    +
    New service type
    - + - + Tracking diff --git a/modules/ticket/front/volume/index.html b/modules/ticket/front/volume/index.html index ef21d8f50..faeb758b6 100644 --- a/modules/ticket/front/volume/index.html +++ b/modules/ticket/front/volume/index.html @@ -12,7 +12,7 @@ - +
    - +
    - +
    -
    - +
    + diff --git a/modules/travel/front/index/index.html b/modules/travel/front/index/index.html index faa21144c..9641f26ca 100644 --- a/modules/travel/front/index/index.html +++ b/modules/travel/front/index/index.html @@ -6,7 +6,7 @@ data="travels">
    - + + class="vn-w-lg vn-my-md"> diff --git a/modules/travel/front/search-panel/index.html b/modules/travel/front/search-panel/index.html index 2a763767e..3c36c419a 100644 --- a/modules/travel/front/search-panel/index.html +++ b/modules/travel/front/search-panel/index.html @@ -63,7 +63,7 @@ value-field="id"> - + diff --git a/modules/worker/front/account/index.html b/modules/worker/front/account/index.html new file mode 100644 index 000000000..8535025d9 --- /dev/null +++ b/modules/worker/front/account/index.html @@ -0,0 +1,33 @@ + + + + +
    + + + + + + + + + + + + + +
    diff --git a/modules/worker/front/basic-data/index.html b/modules/worker/front/basic-data/index.html index 5c2f4d6cd..1908aab66 100644 --- a/modules/worker/front/basic-data/index.html +++ b/modules/worker/front/basic-data/index.html @@ -7,7 +7,7 @@ save="post">
    - +
    - +
    - +
    Holidays
    diff --git a/modules/worker/front/calendar/style.scss b/modules/worker/front/calendar/style.scss index 04c1ba305..cb93174af 100644 --- a/modules/worker/front/calendar/style.scss +++ b/modules/worker/front/calendar/style.scss @@ -12,7 +12,7 @@ .calendar { box-sizing: border-box; - padding: $pad-medium; + padding: $spacing-md; overflow: hidden; min-width: 18em; width: 25%; diff --git a/modules/worker/front/department/index.html b/modules/worker/front/department/index.html index 5da6dafe0..39abb8250 100644 --- a/modules/worker/front/department/index.html +++ b/modules/worker/front/department/index.html @@ -5,7 +5,7 @@