From b6f31d7d4409d909854691ec0653a374bb7a5e2a Mon Sep 17 00:00:00 2001 From: carlosjr Date: Mon, 12 Apr 2021 12:43:17 +0200 Subject: [PATCH 01/13] invoiceIn descriptor implementation --- modules/entry/back/methods/entry/filter.js | 36 ++++++++------ .../back/methods/invoice-in/filter.js | 10 +++- modules/invoiceIn/back/models/invoice-in.json | 3 ++ modules/invoiceIn/front/card/index.js | 6 ++- modules/invoiceIn/front/descriptor/index.html | 49 +++++++++++++++++++ modules/invoiceIn/front/descriptor/index.js | 20 ++++++++ .../invoiceIn/front/descriptor/locale/es.yml | 3 ++ modules/invoiceIn/front/index/index.html | 22 +++++---- 8 files changed, 121 insertions(+), 28 deletions(-) create mode 100644 modules/invoiceIn/front/descriptor/locale/es.yml diff --git a/modules/entry/back/methods/entry/filter.js b/modules/entry/back/methods/entry/filter.js index 42dbe3078..0148d866d 100644 --- a/modules/entry/back/methods/entry/filter.js +++ b/modules/entry/back/methods/entry/filter.js @@ -10,76 +10,81 @@ module.exports = Self => { accepts: [ { arg: 'filter', - type: 'Object', + type: 'object', description: 'Filter defining where, order, offset, and limit - must be a JSON-encoded string', http: {source: 'query'} }, { arg: 'search', - type: 'String', + type: 'string', description: 'Searchs the entry by id', http: {source: 'query'} }, { arg: 'id', - type: 'Integer', + type: 'integer', description: 'The entry id', http: {source: 'query'} }, { arg: 'created', - type: 'Date', + type: 'date', description: 'The created date to filter', http: {source: 'query'} }, { arg: 'travelFk', - type: 'Number', + type: 'number', description: 'The travel id to filter', http: {source: 'query'} }, { arg: 'companyFk', - type: 'Number', + type: 'number', description: 'The company to filter', http: {source: 'query'} }, { arg: 'isBooked', - type: 'Boolean', + type: 'boolean', description: 'The isBokked filter', http: {source: 'query'} }, { arg: 'isConfirmed', - type: 'Boolean', + type: 'boolean', description: 'The isConfirmed filter', http: {source: 'query'} }, { arg: 'isOrdered', - type: 'Boolean', + type: 'boolean', description: 'The isOrdered filter', http: {source: 'query'} }, { arg: 'ref', - type: 'String', + type: 'string', description: 'The ref filter', http: {source: 'query'} }, { arg: 'supplierFk', - type: 'Number', + type: 'number', description: 'The supplier id to filter', http: {source: 'query'} + }, { + arg: 'invoiceInFk', + type: 'number', + description: 'The invoiceIn id to filter', + http: {source: 'query'} }, { arg: 'currencyFk', - type: 'Number', + type: 'number', description: 'The currency id to filter', http: {source: 'query'} }, { arg: 'from', - type: 'Date', + type: 'date', description: `The from date filter` }, { arg: 'to', - type: 'Date', + type: 'date', description: `The to date filter` } ], returns: { - type: ['Object'], + type: ['object'], root: true }, http: { @@ -116,6 +121,7 @@ module.exports = Self => { case 'travelFk': case 'currencyFk': case 'supplierFk': + case 'invoiceInFk': param = `e.${param}`; return {[param]: value}; } diff --git a/modules/invoiceIn/back/methods/invoice-in/filter.js b/modules/invoiceIn/back/methods/invoice-in/filter.js index 20680f153..0b9825752 100644 --- a/modules/invoiceIn/back/methods/invoice-in/filter.js +++ b/modules/invoiceIn/back/methods/invoice-in/filter.js @@ -17,7 +17,7 @@ module.exports = Self => { { arg: 'search', type: 'string', - description: 'Searchs the invoiceOut by id', + description: 'Searchs the invoiceIn by id', http: {source: 'query'} }, { @@ -25,6 +25,11 @@ module.exports = Self => { type: 'string', description: 'The supplier reference' }, + { + arg: 'supplierFk', + type: 'number', + description: 'The supplier id' + }, { arg: 'fi', type: 'string', @@ -108,6 +113,7 @@ module.exports = Self => { case 'fi': return {[`s.${param}`]: value}; case 'supplierRef': + case 'supplierFk': case 'serialNumber': case 'serial': case 'issued': @@ -132,7 +138,7 @@ module.exports = Self => { ii.isBooked, ii.supplierRef, ii.docFk AS dmsFk, - s.id AS supplierFk, + ii.supplierFk, s.name AS supplierName, s.account, SUM(iid.amount) AS amount, diff --git a/modules/invoiceIn/back/models/invoice-in.json b/modules/invoiceIn/back/models/invoice-in.json index 3310c4346..9bd37e569 100644 --- a/modules/invoiceIn/back/models/invoice-in.json +++ b/modules/invoiceIn/back/models/invoice-in.json @@ -18,6 +18,9 @@ "serial": { "type": "string" }, + "supplierRef": { + "type": "string" + }, "issued": { "type": "date" }, diff --git a/modules/invoiceIn/front/card/index.js b/modules/invoiceIn/front/card/index.js index 8c53ea8b8..99e96ae90 100644 --- a/modules/invoiceIn/front/card/index.js +++ b/modules/invoiceIn/front/card/index.js @@ -3,7 +3,11 @@ import ModuleCard from 'salix/components/module-card'; class Controller extends ModuleCard { reload() { - const filter = {}; + const filter = { + include: { + relation: 'supplier' + } + }; this.$http.get(`InvoiceIns/${this.$params.id}`, {filter}) .then(res => this.invoiceIn = res.data); diff --git a/modules/invoiceIn/front/descriptor/index.html b/modules/invoiceIn/front/descriptor/index.html index e69de29bb..42a946913 100644 --- a/modules/invoiceIn/front/descriptor/index.html +++ b/modules/invoiceIn/front/descriptor/index.html @@ -0,0 +1,49 @@ + + + + Delete Invoice + + + +
+ + + + + + + + + {{$ctrl.invoiceIn.supplier.nickname}} + + +
+ +
+
+ + + + diff --git a/modules/invoiceIn/front/descriptor/index.js b/modules/invoiceIn/front/descriptor/index.js index 6b22dd62b..be507e0d4 100644 --- a/modules/invoiceIn/front/descriptor/index.js +++ b/modules/invoiceIn/front/descriptor/index.js @@ -10,6 +10,26 @@ class Controller extends Descriptor { this.entity = value; } + get entryFilter() { + if (this.invoiceIn) + return JSON.stringify({invoiceInFk: this.invoiceIn.id}); + + return null; + } + + get invoiceInFilter() { + if (this.invoiceIn) + return JSON.stringify({supplierFk: this.invoiceIn.supplierFk}); + + return null; + } + + deleteInvoiceIn() { + return this.$http.delete(`InvoiceIns/${this.id}`) + .then(() => this.$state.go('invoiceIn.index')) + .then(() => this.vnApp.showSuccess(this.$t('InvoiceIn deleted'))); + } + loadData() { const filter = { include: [ diff --git a/modules/invoiceIn/front/descriptor/locale/es.yml b/modules/invoiceIn/front/descriptor/locale/es.yml new file mode 100644 index 000000000..4788ec8aa --- /dev/null +++ b/modules/invoiceIn/front/descriptor/locale/es.yml @@ -0,0 +1,3 @@ +Entries list: Listado de entradas +Invoice list: Listado de facturas +InvoiceIn deleted: Factura eliminada \ No newline at end of file diff --git a/modules/invoiceIn/front/index/index.html b/modules/invoiceIn/front/index/index.html index c554dfd5f..acac61907 100644 --- a/modules/invoiceIn/front/index/index.html +++ b/modules/invoiceIn/front/index/index.html @@ -22,26 +22,28 @@ - + {{::invoiceIn.id}} {{::invoiceIn.supplierName}} - + {{::invoiceIn.supplierRef | dashIfEmpty}} - {{::invoiceIn.serialNumber}} - {{::invoiceIn.serial}} - {{::invoiceIn.account}} + {{::invoiceIn.serialNumber}} + {{::invoiceIn.serial}} + {{::invoiceIn.account}} {{::invoiceIn.issued | date:'dd/MM/yyyy' | dashIfEmpty}} - + {{::invoiceIn.awbCode}} {{::invoiceIn.amount | currency:'EUR'}} @@ -68,7 +70,7 @@ invoice-in="$ctrl.selectedinvoiceIn"> - - + --> From 90a7c803fdc6e36bc7dd3b453312dea25907cdc4 Mon Sep 17 00:00:00 2001 From: carlosjr Date: Mon, 12 Apr 2021 16:32:13 +0200 Subject: [PATCH 02/13] descriptor invoiceIn amount --- modules/invoiceIn/back/model-config.json | 3 ++ .../back/models/invoice-in-due-day.json | 33 +++++++++++++++++++ modules/invoiceIn/back/models/invoice-in.json | 5 +++ modules/invoiceIn/front/card/index.js | 20 ++++++++--- .../invoiceIn/front/descriptor/locale/es.yml | 3 -- 5 files changed, 56 insertions(+), 8 deletions(-) create mode 100644 modules/invoiceIn/back/models/invoice-in-due-day.json delete mode 100644 modules/invoiceIn/front/descriptor/locale/es.yml diff --git a/modules/invoiceIn/back/model-config.json b/modules/invoiceIn/back/model-config.json index 7f95924a4..88d227ba3 100644 --- a/modules/invoiceIn/back/model-config.json +++ b/modules/invoiceIn/back/model-config.json @@ -1,5 +1,8 @@ { "InvoiceIn": { "dataSource": "vn" + }, + "InvoiceInDueDay": { + "dataSource": "vn" } } diff --git a/modules/invoiceIn/back/models/invoice-in-due-day.json b/modules/invoiceIn/back/models/invoice-in-due-day.json new file mode 100644 index 000000000..6c27dcd6c --- /dev/null +++ b/modules/invoiceIn/back/models/invoice-in-due-day.json @@ -0,0 +1,33 @@ +{ + "name": "InvoiceInDueDay", + "base": "VnModel", + "options": { + "mysql": { + "table": "invoiceInDueDay" + } + }, + "properties": { + "id": { + "id": true, + "type": "number", + "description": "Identifier" + }, + "invoiceInFk": { + "type": "number" + }, + "dueDated": { + "type": "date" + }, + "bankFk": { + "type": "number" + }, + "amount": { + "type": "number" + }, + "created": { + "type": "date" + } + } +} + + diff --git a/modules/invoiceIn/back/models/invoice-in.json b/modules/invoiceIn/back/models/invoice-in.json index 9bd37e569..af6490c8a 100644 --- a/modules/invoiceIn/back/models/invoice-in.json +++ b/modules/invoiceIn/back/models/invoice-in.json @@ -44,6 +44,11 @@ } }, "relations": { + "invoiceInDueDay": { + "type": "hasMany", + "model": "InvoiceInDueDay", + "foreignKey": "invoiceInFk" + }, "company": { "type": "belongsTo", "model": "Company", diff --git a/modules/invoiceIn/front/card/index.js b/modules/invoiceIn/front/card/index.js index 99e96ae90..84f415ce1 100644 --- a/modules/invoiceIn/front/card/index.js +++ b/modules/invoiceIn/front/card/index.js @@ -4,13 +4,23 @@ import ModuleCard from 'salix/components/module-card'; class Controller extends ModuleCard { reload() { const filter = { - include: { - relation: 'supplier' - } - }; + include: [ + { + relation: 'supplier' + }, + { + relation: 'invoiceInDueDay' + } + ]}; this.$http.get(`InvoiceIns/${this.$params.id}`, {filter}) - .then(res => this.invoiceIn = res.data); + .then(res => { + this.invoiceIn = res.data; + this.invoiceIn.amount = res.data.invoiceInDueDay.reduce( + (accumulator, currentValue) => { + return accumulator + (currentValue['amount'] || 0); + }, 0); + }); } } diff --git a/modules/invoiceIn/front/descriptor/locale/es.yml b/modules/invoiceIn/front/descriptor/locale/es.yml deleted file mode 100644 index 4788ec8aa..000000000 --- a/modules/invoiceIn/front/descriptor/locale/es.yml +++ /dev/null @@ -1,3 +0,0 @@ -Entries list: Listado de entradas -Invoice list: Listado de facturas -InvoiceIn deleted: Factura eliminada \ No newline at end of file From 6b8074e32f80a5e84382d5cb77c449ef7d4e7d9e Mon Sep 17 00:00:00 2001 From: joan Date: Tue, 13 Apr 2021 14:08:10 +0200 Subject: [PATCH 03/13] 2878 - Splitted method into activeWithRole and activeWithInheritedRole --- modules/claim/front/basic-data/index.html | 4 +-- modules/claim/front/development/index.html | 2 +- modules/claim/front/search-panel/index.html | 8 ++--- modules/client/back/models/client.js | 1 - modules/client/front/basic-data/index.html | 4 +-- .../front/consumption-search-panel/index.html | 4 +-- modules/client/front/create/index.html | 4 +-- modules/client/front/search-panel/index.html | 2 +- .../front/latest-buys-search-panel/index.html | 4 +-- .../front/fixed-price-search-panel/index.html | 2 +- .../front/request-search-panel/index.html | 4 +-- modules/item/front/search-panel/index.html | 4 +-- modules/order/front/search-panel/index.html | 4 +-- modules/route/front/basic-data/index.html | 2 +- modules/route/front/create/index.html | 2 +- modules/route/front/search-panel/index.html | 2 +- modules/supplier/front/basic-data/index.html | 2 +- .../front/consumption-search-panel/index.html | 4 +-- .../ticket/front/request/create/index.html | 2 +- modules/ticket/front/search-panel/index.html | 2 +- modules/ticket/front/tracking/edit/index.html | 2 +- .../back/methods/worker/active.js} | 31 ++---------------- .../methods/worker/activeWithInheritedRole.js | 32 +++++++++++++++++++ .../back/methods/worker/activeWithRole.js | 31 ++++++++++++++++++ modules/worker/back/models/worker.js | 3 ++ modules/worker/front/basic-data/index.html | 14 ++++---- 26 files changed, 108 insertions(+), 68 deletions(-) rename modules/{client/back/methods/client/activeWorkersWithRole.js => worker/back/methods/worker/active.js} (59%) create mode 100644 modules/worker/back/methods/worker/activeWithInheritedRole.js create mode 100644 modules/worker/back/methods/worker/activeWithRole.js diff --git a/modules/claim/front/basic-data/index.html b/modules/claim/front/basic-data/index.html index 064a9d4f5..a39ecc56e 100644 --- a/modules/claim/front/basic-data/index.html +++ b/modules/claim/front/basic-data/index.html @@ -28,10 +28,10 @@ {{firstName}} {{name}} {{firstName}} {{name}} diff --git a/modules/client/back/models/client.js b/modules/client/back/models/client.js index 035074210..842565c3f 100644 --- a/modules/client/back/models/client.js +++ b/modules/client/back/models/client.js @@ -8,7 +8,6 @@ const LoopBackContext = require('loopback-context'); module.exports = Self => { // Methods - require('../methods/client/activeWorkersWithRole')(Self); require('../methods/client/getCard')(Self); require('../methods/client/createWithUser')(Self); require('../methods/client/listWorkers')(Self); diff --git a/modules/client/front/basic-data/index.html b/modules/client/front/basic-data/index.html index 6235ec923..e4debac16 100644 --- a/modules/client/front/basic-data/index.html +++ b/modules/client/front/basic-data/index.html @@ -54,11 +54,11 @@ diff --git a/modules/client/front/consumption-search-panel/index.html b/modules/client/front/consumption-search-panel/index.html index fbcf24fad..28370537d 100644 --- a/modules/client/front/consumption-search-panel/index.html +++ b/modules/client/front/consumption-search-panel/index.html @@ -17,10 +17,10 @@ {{nickname}} diff --git a/modules/client/front/create/index.html b/modules/client/front/create/index.html index d9759e347..c5fa35658 100644 --- a/modules/client/front/create/index.html +++ b/modules/client/front/create/index.html @@ -18,10 +18,10 @@ + where="{role: 'salesPerson'}"> {{firstName}} {{lastName}} diff --git a/modules/client/front/search-panel/index.html b/modules/client/front/search-panel/index.html index 757767671..9caf4185b 100644 --- a/modules/client/front/search-panel/index.html +++ b/modules/client/front/search-panel/index.html @@ -17,7 +17,7 @@ diff --git a/modules/item/front/fixed-price-search-panel/index.html b/modules/item/front/fixed-price-search-panel/index.html index 5a1e7781e..773862bf1 100644 --- a/modules/item/front/fixed-price-search-panel/index.html +++ b/modules/item/front/fixed-price-search-panel/index.html @@ -44,7 +44,7 @@ {{nickname}} diff --git a/modules/item/front/search-panel/index.html b/modules/item/front/search-panel/index.html index f30442ec6..545cffda0 100644 --- a/modules/item/front/search-panel/index.html +++ b/modules/item/front/search-panel/index.html @@ -42,11 +42,11 @@ vn-one disabled="false" ng-model="filter.salesPersonFk" - url="Clients/activeWorkersWithRole" + url="Workers/activeWithRole" show-field="nickname" search-function="{firstName: $search}" value-field="id" - where="{role: 'employee'}" + where="{role: 'buyer'}" label="Buyer"> diff --git a/modules/order/front/search-panel/index.html b/modules/order/front/search-panel/index.html index f9b214578..c622dd152 100644 --- a/modules/order/front/search-panel/index.html +++ b/modules/order/front/search-panel/index.html @@ -28,11 +28,11 @@ diff --git a/modules/route/front/basic-data/index.html b/modules/route/front/basic-data/index.html index 0a1734ff2..d3ba25b11 100644 --- a/modules/route/front/basic-data/index.html +++ b/modules/route/front/basic-data/index.html @@ -11,7 +11,7 @@ diff --git a/modules/route/front/search-panel/index.html b/modules/route/front/search-panel/index.html index 4c9dd3110..6e3d30d30 100644 --- a/modules/route/front/search-panel/index.html +++ b/modules/route/front/search-panel/index.html @@ -13,7 +13,7 @@ {{nickname}} diff --git a/modules/ticket/front/request/create/index.html b/modules/ticket/front/request/create/index.html index 755e8cb51..f7280b2de 100644 --- a/modules/ticket/front/request/create/index.html +++ b/modules/ticket/front/request/create/index.html @@ -18,7 +18,7 @@ diff --git a/modules/ticket/front/search-panel/index.html b/modules/ticket/front/search-panel/index.html index 55611899b..d0b77b9de 100644 --- a/modules/ticket/front/search-panel/index.html +++ b/modules/ticket/front/search-panel/index.html @@ -60,7 +60,7 @@ { - Self.remoteMethod('activeWorkersWithRole', { - description: 'Returns actives workers with salesperson role', - accessType: 'READ', - accepts: [{ - arg: 'filter', - type: 'Object', - description: 'Filter defining where and paginated data', - required: true - }], - returns: { - type: 'Worker', - root: true - }, - http: { - path: `/activeWorkersWithRole`, - verb: 'get' - } - }); - - Self.activeWorkersWithRole = async filter => { + Self.activeWorkers = async(query, filter) => { let conn = Self.dataSource.connector; if (filter.where && filter.where.and && Array.isArray(filter.where.and)) { let where = {}; @@ -54,14 +35,8 @@ module.exports = Self => { myFilter = mergeFilters(myFilter, clientFilter); - let stmt = new ParameterizedSQL( - `SELECT DISTINCT w.id, w.firstName, w.lastName, u.name, u.nickname - FROM worker w - JOIN account.user u ON u.id = w.userFk - JOIN account.roleRole i ON i.role = u.role - JOIN account.role r ON r.id = i.inheritsFrom` - ); + let stmt = new ParameterizedSQL(query); stmt.merge(conn.makeSuffix(myFilter)); - return await conn.executeStmt(stmt); + return conn.executeStmt(stmt); }; }; diff --git a/modules/worker/back/methods/worker/activeWithInheritedRole.js b/modules/worker/back/methods/worker/activeWithInheritedRole.js new file mode 100644 index 000000000..9536b0f29 --- /dev/null +++ b/modules/worker/back/methods/worker/activeWithInheritedRole.js @@ -0,0 +1,32 @@ + +module.exports = Self => { + Self.remoteMethod('activeWithInheritedRole', { + description: 'Returns active workers with a role', + accessType: 'READ', + accepts: [{ + arg: 'filter', + type: 'Object', + description: 'Filter defining where and paginated data', + required: true + }], + returns: { + type: ['object'], + root: true + }, + http: { + path: `/activeWithInheritedRole`, + verb: 'GET' + } + }); + + Self.activeWithInheritedRole = async filter => { + const query = + `SELECT DISTINCT w.id, w.firstName, w.lastName, u.name, u.nickname + FROM worker w + JOIN account.user u ON u.id = w.userFk + JOIN account.roleRole i ON i.role = u.role + JOIN account.role r ON r.id = i.inheritsFrom`; + + return Self.activeWorkers(query, filter); + }; +}; diff --git a/modules/worker/back/methods/worker/activeWithRole.js b/modules/worker/back/methods/worker/activeWithRole.js new file mode 100644 index 000000000..392416458 --- /dev/null +++ b/modules/worker/back/methods/worker/activeWithRole.js @@ -0,0 +1,31 @@ + +module.exports = Self => { + Self.remoteMethod('activeWithRole', { + description: 'Returns active workers with an inherited role', + accessType: 'READ', + accepts: [{ + arg: 'filter', + type: 'Object', + description: 'Filter defining where and paginated data', + required: true + }], + returns: { + type: ['object'], + root: true + }, + http: { + path: `/activeWithRole`, + verb: 'GET' + } + }); + + Self.activeWithRole = async filter => { + const query = + `SELECT DISTINCT w.id, w.firstName, w.lastName, u.name, u.nickname + FROM worker w + JOIN account.user u ON u.id = w.id + JOIN account.role r ON r.id = u.role`; + + return Self.activeWorkers(query, filter); + }; +}; diff --git a/modules/worker/back/models/worker.js b/modules/worker/back/models/worker.js index 0d94c788e..9bfef5235 100644 --- a/modules/worker/back/models/worker.js +++ b/modules/worker/back/models/worker.js @@ -7,4 +7,7 @@ module.exports = Self => { require('../methods/worker/createAbsence')(Self); require('../methods/worker/deleteAbsence')(Self); require('../methods/worker/updateAbsence')(Self); + require('../methods/worker/active')(Self); + require('../methods/worker/activeWithRole')(Self); + require('../methods/worker/activeWithInheritedRole')(Self); }; diff --git a/modules/worker/front/basic-data/index.html b/modules/worker/front/basic-data/index.html index a767eccc4..228ae39d4 100644 --- a/modules/worker/front/basic-data/index.html +++ b/modules/worker/front/basic-data/index.html @@ -30,13 +30,13 @@ rule> + disabled="false" + ng-model="$ctrl.worker.bossFk" + url="Clients/activeWorkersWithInheritRole" + show-field="nickname" + search-function="{firstName: $search}" + where="{role: 'employee'}" + label="Boss"> From 78313bd9a7b32b9d9f45d2f07412983cc7d6a19c Mon Sep 17 00:00:00 2001 From: joan Date: Wed, 14 Apr 2021 08:15:03 +0200 Subject: [PATCH 04/13] Updated unit tests --- .../specs/activeWorkersWithRole.spec.js | 23 --------------- .../specs/activeWithInheritedRole.spec.js | 29 +++++++++++++++++++ .../worker/specs/activeWithRole.spec.js | 21 ++++++++++++++ 3 files changed, 50 insertions(+), 23 deletions(-) delete mode 100644 modules/client/back/methods/client/specs/activeWorkersWithRole.spec.js create mode 100644 modules/worker/back/methods/worker/specs/activeWithInheritedRole.spec.js create mode 100644 modules/worker/back/methods/worker/specs/activeWithRole.spec.js diff --git a/modules/client/back/methods/client/specs/activeWorkersWithRole.spec.js b/modules/client/back/methods/client/specs/activeWorkersWithRole.spec.js deleted file mode 100644 index fcf871d9b..000000000 --- a/modules/client/back/methods/client/specs/activeWorkersWithRole.spec.js +++ /dev/null @@ -1,23 +0,0 @@ -const app = require('vn-loopback/server/server'); - -describe('Client activeWorkersWithRole', () => { - it('should return the sales people as result', async() => { - let filter = {where: {role: 'salesPerson'}}; - let result = await app.models.Client.activeWorkersWithRole(filter); - - let isSalesPerson = await app.models.Account.hasRole(result[0].id, 'salesPerson'); - - expect(result.length).toEqual(19); - expect(isSalesPerson).toBeTruthy(); - }); - - it('should return the buyers as result', async() => { - let filter = {where: {role: 'buyer'}}; - let result = await app.models.Client.activeWorkersWithRole(filter); - - let isBuyer = await app.models.Account.hasRole(result[0].id, 'buyer'); - - expect(result.length).toEqual(17); - expect(isBuyer).toBeTruthy(); - }); -}); diff --git a/modules/worker/back/methods/worker/specs/activeWithInheritedRole.spec.js b/modules/worker/back/methods/worker/specs/activeWithInheritedRole.spec.js new file mode 100644 index 000000000..c44fb72f9 --- /dev/null +++ b/modules/worker/back/methods/worker/specs/activeWithInheritedRole.spec.js @@ -0,0 +1,29 @@ +const app = require('vn-loopback/server/server'); + +describe('Worker activeWithInheritedRole', () => { + it('should return the workers with an inherited role of salesPerson', async() => { + const filter = {where: {role: 'salesPerson'}}; + const result = await app.models.Worker.activeWithInheritedRole(filter); + + const randomIndex = Math.floor(Math.random() * result.length); + const worker = result[randomIndex]; + + const isSalesPerson = await app.models.Account.hasRole(worker.id, 'salesPerson'); + + expect(result.length).toEqual(19); + expect(isSalesPerson).toBe(true); + }); + + it('should return the workers with an inherited role of buyer', async() => { + const filter = {where: {role: 'buyer'}}; + const result = await app.models.Worker.activeWithInheritedRole(filter); + + const randomIndex = Math.floor(Math.random() * result.length); + const worker = result[randomIndex]; + + const isBuyer = await app.models.Account.hasRole(worker.id, 'buyer'); + + expect(result.length).toEqual(17); + expect(isBuyer).toBe(true); + }); +}); diff --git a/modules/worker/back/methods/worker/specs/activeWithRole.spec.js b/modules/worker/back/methods/worker/specs/activeWithRole.spec.js new file mode 100644 index 000000000..88a312e24 --- /dev/null +++ b/modules/worker/back/methods/worker/specs/activeWithRole.spec.js @@ -0,0 +1,21 @@ +const app = require('vn-loopback/server/server'); + +describe('Worker activeWithRole', () => { + it('should return the sales people as result', async() => { + const filter = {where: {role: 'salesPerson'}}; + const result = await app.models.Worker.activeWithRole(filter); + const firstWorker = result[0]; + + expect(result.length).toEqual(1); + expect(firstWorker.nickname).toEqual('salesPersonNick'); + }); + + it('should return the buyers as result', async() => { + const filter = {where: {role: 'buyer'}}; + const result = await app.models.Worker.activeWithRole(filter); + const firstWorker = result[0]; + + expect(result.length).toEqual(1); + expect(firstWorker.nickname).toEqual('buyerNick'); + }); +}); From 55b3a048e7bcc7cd3e61bdb3ddf308fb45371c18 Mon Sep 17 00:00:00 2001 From: joan Date: Wed, 14 Apr 2021 08:49:10 +0200 Subject: [PATCH 05/13] Updated E2E --- e2e/paths/02-client/01_create_client.spec.js | 2 +- e2e/paths/02-client/02_edit_basic_data.spec.js | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/e2e/paths/02-client/01_create_client.spec.js b/e2e/paths/02-client/01_create_client.spec.js index 4cb3c67ab..ae002b0ea 100644 --- a/e2e/paths/02-client/01_create_client.spec.js +++ b/e2e/paths/02-client/01_create_client.spec.js @@ -31,7 +31,7 @@ describe('Client create path', () => { await page.write(selectors.createClientView.taxNumber, '74451390E'); await page.write(selectors.createClientView.userName, 'CaptainMarvel'); await page.write(selectors.createClientView.email, 'CarolDanvers@verdnatura.es'); - await page.autocompleteSearch(selectors.createClientView.salesPerson, 'replenisher'); + await page.autocompleteSearch(selectors.createClientView.salesPerson, 'salesPerson'); await page.waitToClick(selectors.createClientView.createButton); const message = await page.waitForSnackbar(); diff --git a/e2e/paths/02-client/02_edit_basic_data.spec.js b/e2e/paths/02-client/02_edit_basic_data.spec.js index 6f331fb23..d770e7523 100644 --- a/e2e/paths/02-client/02_edit_basic_data.spec.js +++ b/e2e/paths/02-client/02_edit_basic_data.spec.js @@ -96,7 +96,7 @@ describe('Client Edit basicData path', () => { await page.write(selectors.clientBasicData.phone, '333333333'); await page.clearInput(selectors.clientBasicData.mobile); await page.write(selectors.clientBasicData.mobile, '444444444'); - await page.autocompleteSearch(selectors.clientBasicData.salesPerson, 'replenisherNick'); + await page.autocompleteSearch(selectors.clientBasicData.salesPerson, 'salesPerson'); await page.autocompleteSearch(selectors.clientBasicData.channel, 'Metropolis newspaper'); await page.waitToClick(selectors.clientBasicData.saveButton); const message = await page.waitForSnackbar(); @@ -143,7 +143,7 @@ describe('Client Edit basicData path', () => { const result = await page .waitToGetProperty(selectors.clientBasicData.salesPerson, 'value'); - expect(result).toEqual('replenisherNick'); + expect(result).toEqual('salesPersonNick'); }); it('should now confirm the channel have been selected', async() => { From 5931dd238c493243063650fd2edd802d24d1b89e Mon Sep 17 00:00:00 2001 From: carlosjr Date: Thu, 15 Apr 2021 10:43:28 +0200 Subject: [PATCH 06/13] Anomalous trigger disabled --- db/dump/structure.sql | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/db/dump/structure.sql b/db/dump/structure.sql index 7d79b45d3..8bc0aed8f 100644 --- a/db/dump/structure.sql +++ b/db/dump/structure.sql @@ -30193,7 +30193,7 @@ BEGIN NEW.currencyFk != OLD.currencyFk THEN - CALL vn2008.recibidaIvaDivisaUpdate(NEW.id); + -- CALL vn2008.recibidaIvaDivisaUpdate(NEW.id); END IF; From 8faa1531c62b05630db5af372e36218550b55e37 Mon Sep 17 00:00:00 2001 From: carlosjr Date: Thu, 15 Apr 2021 10:44:25 +0200 Subject: [PATCH 07/13] summary route + test --- .../methods/invoice-in/specs/summary.spec.js | 9 ++++ .../back/methods/invoice-in/summary.js | 42 +++++++++++++++++++ 2 files changed, 51 insertions(+) create mode 100644 modules/invoiceIn/back/methods/invoice-in/specs/summary.spec.js create mode 100644 modules/invoiceIn/back/methods/invoice-in/summary.js diff --git a/modules/invoiceIn/back/methods/invoice-in/specs/summary.spec.js b/modules/invoiceIn/back/methods/invoice-in/specs/summary.spec.js new file mode 100644 index 000000000..cf7ccdb1c --- /dev/null +++ b/modules/invoiceIn/back/methods/invoice-in/specs/summary.spec.js @@ -0,0 +1,9 @@ +const app = require('vn-loopback/server/server'); + +describe('invoiceIn summary()', () => { + it('should return a summary object containing data from one invoiceIn', async() => { + const summary = await app.models.InvoiceIn.summary(1); + + expect(summary.invoiceIn.supplierRef).toEqual('1234'); + }); +}); diff --git a/modules/invoiceIn/back/methods/invoice-in/summary.js b/modules/invoiceIn/back/methods/invoice-in/summary.js new file mode 100644 index 000000000..56a105f17 --- /dev/null +++ b/modules/invoiceIn/back/methods/invoice-in/summary.js @@ -0,0 +1,42 @@ +module.exports = Self => { + Self.remoteMethod('summary', { + description: 'The invoiceIn summary', + accessType: 'READ', + accepts: [{ + arg: 'id', + type: 'number', + required: true, + description: 'The invoiceIn id', + http: {source: 'path'} + }], + returns: { + type: 'object', + root: true + }, + http: { + path: `/:id/summary`, + verb: 'GET' + } + }); + + Self.summary = async id => { + const filter = { + include: [ + { + relation: 'company', + scope: { + fields: ['id', 'code'] + } + }, + { + relation: 'supplier', + scope: { + fields: ['id', 'name'] + } + } + ] + }; + + return Self.app.models.InvoiceIn.findById(id, filter); + }; +}; From ec378a17ae733a16e573dda19d0da1825241ad9b Mon Sep 17 00:00:00 2001 From: carlosjr Date: Thu, 15 Apr 2021 10:45:27 +0200 Subject: [PATCH 08/13] invoiceIn model updated a summary registered --- modules/invoiceIn/back/models/invoice-in.js | 1 + modules/invoiceIn/back/models/invoice-in.json | 9 +++++++++ 2 files changed, 10 insertions(+) diff --git a/modules/invoiceIn/back/models/invoice-in.js b/modules/invoiceIn/back/models/invoice-in.js index 278843428..7c5b16358 100644 --- a/modules/invoiceIn/back/models/invoice-in.js +++ b/modules/invoiceIn/back/models/invoice-in.js @@ -1,3 +1,4 @@ module.exports = Self => { require('../methods/invoice-in/filter')(Self); + require('../methods/invoice-in/summary')(Self); }; diff --git a/modules/invoiceIn/back/models/invoice-in.json b/modules/invoiceIn/back/models/invoice-in.json index af6490c8a..aa57f0eb9 100644 --- a/modules/invoiceIn/back/models/invoice-in.json +++ b/modules/invoiceIn/back/models/invoice-in.json @@ -30,12 +30,21 @@ "isBooked": { "type": "boolean" }, + "isVatDeductible": { + "type": "boolean" + }, + "withholdingSageFk": { + "type": "number" + }, "booked": { "type": "date" }, "operated": { "type": "date" }, + "bookEntried": { + "type": "date" + }, "dmsFk": { "type": "number", "mysql": { From 69069d5e2817295bfbcecc77f237119a63bce9bd Mon Sep 17 00:00:00 2001 From: carlosjr Date: Thu, 15 Apr 2021 10:46:23 +0200 Subject: [PATCH 09/13] invoiceIn summary frontend --- modules/invoiceIn/front/index.js | 2 + modules/invoiceIn/front/summary/index.html | 52 +++++++++++++++++++ modules/invoiceIn/front/summary/index.js | 28 ++++++++++ modules/invoiceIn/front/summary/index.spec.js | 29 +++++++++++ modules/invoiceIn/front/summary/locale/es.yml | 10 ++++ modules/invoiceIn/front/summary/style.scss | 5 ++ 6 files changed, 126 insertions(+) create mode 100644 modules/invoiceIn/front/summary/index.html create mode 100644 modules/invoiceIn/front/summary/index.js create mode 100644 modules/invoiceIn/front/summary/index.spec.js create mode 100644 modules/invoiceIn/front/summary/locale/es.yml create mode 100644 modules/invoiceIn/front/summary/style.scss diff --git a/modules/invoiceIn/front/index.js b/modules/invoiceIn/front/index.js index acb341c50..6c175d9a0 100644 --- a/modules/invoiceIn/front/index.js +++ b/modules/invoiceIn/front/index.js @@ -6,3 +6,5 @@ import './search-panel'; import './card'; import './descriptor'; import './descriptor-popover'; +import './summary'; +import './basic-data'; diff --git a/modules/invoiceIn/front/summary/index.html b/modules/invoiceIn/front/summary/index.html new file mode 100644 index 000000000..c097ec8cf --- /dev/null +++ b/modules/invoiceIn/front/summary/index.html @@ -0,0 +1,52 @@ + +
+ + + + {{$ctrl.summary.id}} - {{$ctrl.summary.supplier.name}} +
+ + +

Basic data

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+
+ + + \ No newline at end of file diff --git a/modules/invoiceIn/front/summary/index.js b/modules/invoiceIn/front/summary/index.js new file mode 100644 index 000000000..54b5bcd00 --- /dev/null +++ b/modules/invoiceIn/front/summary/index.js @@ -0,0 +1,28 @@ +import ngModule from '../module'; +import Summary from 'salix/components/summary'; +import './style.scss'; + +class Controller extends Summary { + set invoiceIn(value) { + this._invoiceIn = value; + if (value && value.id) + this.getSummary(); + } + + get invoiceIn() { + return this._invoiceIn; + } + + getSummary() { + return this.$http.get(`InvoiceIns/${this.invoiceIn.id}/summary`) + .then(res => this.summary = res.data); + } +} + +ngModule.vnComponent('vnInvoiceInSummary', { + template: require('./index.html'), + controller: Controller, + bindings: { + invoiceIn: '<' + } +}); diff --git a/modules/invoiceIn/front/summary/index.spec.js b/modules/invoiceIn/front/summary/index.spec.js new file mode 100644 index 000000000..56bfe9f4a --- /dev/null +++ b/modules/invoiceIn/front/summary/index.spec.js @@ -0,0 +1,29 @@ +import './index.js'; + +describe('InvoiceIn', () => { + describe('Component summary', () => { + let controller; + let $httpBackend; + let $scope; + + beforeEach(ngModule('invoiceIn')); + + beforeEach(inject(($componentController, _$httpBackend_, $rootScope) => { + $httpBackend = _$httpBackend_; + $scope = $rootScope.$new(); + const $element = angular.element(''); + controller = $componentController('vnInvoiceInSummary', {$element, $scope}); + controller.invoiceIn = {id: 1}; + })); + + describe('getSummary()', () => { + it('should perform a query to set summary', () => { + $httpBackend.when('GET', `InvoiceIns/1/summary`).respond(200, 'the data you are looking for'); + controller.getSummary(); + $httpBackend.flush(); + + expect(controller.summary).toEqual('the data you are looking for'); + }); + }); + }); +}); diff --git a/modules/invoiceIn/front/summary/locale/es.yml b/modules/invoiceIn/front/summary/locale/es.yml new file mode 100644 index 000000000..29bed3f9c --- /dev/null +++ b/modules/invoiceIn/front/summary/locale/es.yml @@ -0,0 +1,10 @@ +Go to the Invoice In: Ir a la factura recibida +Expedition date: Fecha expedición +Operation date: Fecha operación +Supplier ref: Ref. proveedor +Entry date: Fecha asiento +Booked date: Fecha contable +Accounted date: Fecha contable +Doc number: Numero documento +Sage withholding: Retención sage +Deductible: Deducible \ No newline at end of file diff --git a/modules/invoiceIn/front/summary/style.scss b/modules/invoiceIn/front/summary/style.scss new file mode 100644 index 000000000..f7ddb2cb7 --- /dev/null +++ b/modules/invoiceIn/front/summary/style.scss @@ -0,0 +1,5 @@ +@import "variables"; + +vn-invoice-in-summary .summary { + width: $width-lg; +} \ No newline at end of file From 38f43eca3bf356c68d8794f19eadf665d14c362a Mon Sep 17 00:00:00 2001 From: carlosjr Date: Thu, 15 Apr 2021 10:47:39 +0200 Subject: [PATCH 10/13] invoiceIn basicData + index preview of summary --- modules/invoiceIn/front/basic-data/index.html | 84 +++++++++++++++++++ modules/invoiceIn/front/basic-data/index.js | 10 +++ modules/invoiceIn/front/card/index.js | 3 + modules/invoiceIn/front/card/index.spec.js | 10 ++- modules/invoiceIn/front/index/index.html | 36 +------- modules/invoiceIn/front/index/index.js | 5 ++ modules/invoiceIn/front/routes.json | 19 ++++- 7 files changed, 129 insertions(+), 38 deletions(-) create mode 100644 modules/invoiceIn/front/basic-data/index.html create mode 100644 modules/invoiceIn/front/basic-data/index.js diff --git a/modules/invoiceIn/front/basic-data/index.html b/modules/invoiceIn/front/basic-data/index.html new file mode 100644 index 000000000..22bd6658a --- /dev/null +++ b/modules/invoiceIn/front/basic-data/index.html @@ -0,0 +1,84 @@ + + + +
+ + + + + + + + + + + {{::id}} - {{::nickname}} + + + + + + + + + + + + + + + + + + + + + + + + +
\ No newline at end of file diff --git a/modules/invoiceIn/front/basic-data/index.js b/modules/invoiceIn/front/basic-data/index.js new file mode 100644 index 000000000..6a39f35cd --- /dev/null +++ b/modules/invoiceIn/front/basic-data/index.js @@ -0,0 +1,10 @@ +import ngModule from '../module'; +import Section from 'salix/components/section'; + +ngModule.vnComponent('vnInvoiceInBasicData', { + template: require('./index.html'), + controller: Section, + bindings: { + invoiceIn: '<' + } +}); diff --git a/modules/invoiceIn/front/card/index.js b/modules/invoiceIn/front/card/index.js index 84f415ce1..c669e5f7f 100644 --- a/modules/invoiceIn/front/card/index.js +++ b/modules/invoiceIn/front/card/index.js @@ -10,6 +10,9 @@ class Controller extends ModuleCard { }, { relation: 'invoiceInDueDay' + }, + { + relation: 'company' } ]}; diff --git a/modules/invoiceIn/front/card/index.spec.js b/modules/invoiceIn/front/card/index.spec.js index 70f10f6b1..128f2334f 100644 --- a/modules/invoiceIn/front/card/index.spec.js +++ b/modules/invoiceIn/front/card/index.spec.js @@ -3,7 +3,12 @@ import './index.js'; describe('vnInvoiceIn', () => { let controller; let $httpBackend; - let data = {id: 1, name: 'fooName'}; + const expectedAmount = 99; + const data = { + id: 1, + name: 'fooName', + invoiceInDueDay: [{amount: expectedAmount}] + }; beforeEach(ngModule('invoiceIn')); @@ -21,7 +26,8 @@ describe('vnInvoiceIn', () => { controller.reload(); $httpBackend.flush(); - expect(controller.invoiceIn).toEqual(data); + expect(controller.invoiceIn).toBeDefined(); + expect(controller.invoiceIn.amount).toEqual(expectedAmount); }); }); diff --git a/modules/invoiceIn/front/index/index.html b/modules/invoiceIn/front/index/index.html index 49a2a5e63..3d9b787d9 100644 --- a/modules/invoiceIn/front/index/index.html +++ b/modules/invoiceIn/front/index/index.html @@ -69,38 +69,6 @@ + invoice-in="$ctrl.selectedInvoiceIn"> - - + \ No newline at end of file diff --git a/modules/invoiceIn/front/index/index.js b/modules/invoiceIn/front/index/index.js index 4bb0fd6a4..c6fc14c25 100644 --- a/modules/invoiceIn/front/index/index.js +++ b/modules/invoiceIn/front/index/index.js @@ -34,6 +34,11 @@ export default class Controller extends Section { return [minHour, maxHour]; } + + preview(invoiceIn) { + this.selectedInvoiceIn = invoiceIn; + this.$.summary.show(); + } } ngModule.vnComponent('vnInvoiceInIndex', { diff --git a/modules/invoiceIn/front/routes.json b/modules/invoiceIn/front/routes.json index 84f713c5c..05eff347b 100644 --- a/modules/invoiceIn/front/routes.json +++ b/modules/invoiceIn/front/routes.json @@ -7,6 +7,12 @@ "menus": { "main": [ {"state": "invoiceIn.index", "icon": "icon-invoiceIn"} + ], + "card": [ + { + "state": "invoiceIn.card.basicData", + "icon": "settings" + } ] }, "routes": [ @@ -36,9 +42,18 @@ "component": "vn-invoice-in-summary", "description": "Summary", "params": { - "invoice-In": "$ctrl.invoiceIn" + "invoice-in": "$ctrl.invoiceIn" }, - "acl": ["developer"] + "acl": ["administrative"] + }, + { + "url": "/basic-data", + "state": "invoiceIn.card.basicData", + "component": "vn-invoice-in-basic-data", + "description": "Basic data", + "params": { + "invoice-in": "$ctrl.invoiceIn" + } } ] } \ No newline at end of file From 41ab1bbe3555cb7b122d9bb357c29335c504ebd3 Mon Sep 17 00:00:00 2001 From: carlosjr Date: Thu, 15 Apr 2021 10:50:10 +0200 Subject: [PATCH 11/13] fixed a test where invoiceIn was nested into the summary --- modules/invoiceIn/back/methods/invoice-in/specs/summary.spec.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/invoiceIn/back/methods/invoice-in/specs/summary.spec.js b/modules/invoiceIn/back/methods/invoice-in/specs/summary.spec.js index cf7ccdb1c..ff7a39ef5 100644 --- a/modules/invoiceIn/back/methods/invoice-in/specs/summary.spec.js +++ b/modules/invoiceIn/back/methods/invoice-in/specs/summary.spec.js @@ -4,6 +4,6 @@ describe('invoiceIn summary()', () => { it('should return a summary object containing data from one invoiceIn', async() => { const summary = await app.models.InvoiceIn.summary(1); - expect(summary.invoiceIn.supplierRef).toEqual('1234'); + expect(summary.supplierRef).toEqual('1234'); }); }); From 2ebd812a1fec7376299a1042018b9097f4ccdf8e Mon Sep 17 00:00:00 2001 From: carlosjr Date: Thu, 15 Apr 2021 11:54:40 +0200 Subject: [PATCH 12/13] updated model + translations --- .../back/methods/invoice-in/summary.js | 6 +++++ modules/invoiceIn/back/models/invoice-in.json | 8 +++--- modules/invoiceIn/front/basic-data/index.html | 25 +++++++++++++------ modules/invoiceIn/front/locale/es.yml | 5 +++- modules/invoiceIn/front/summary/index.html | 2 +- 5 files changed, 33 insertions(+), 13 deletions(-) diff --git a/modules/invoiceIn/back/methods/invoice-in/summary.js b/modules/invoiceIn/back/methods/invoice-in/summary.js index 56a105f17..c4101e4dc 100644 --- a/modules/invoiceIn/back/methods/invoice-in/summary.js +++ b/modules/invoiceIn/back/methods/invoice-in/summary.js @@ -33,6 +33,12 @@ module.exports = Self => { scope: { fields: ['id', 'name'] } + }, + { + relation: 'sageWithholding', + scope: { + fields: ['withholding'] + } } ] }; diff --git a/modules/invoiceIn/back/models/invoice-in.json b/modules/invoiceIn/back/models/invoice-in.json index aa57f0eb9..ad14fb511 100644 --- a/modules/invoiceIn/back/models/invoice-in.json +++ b/modules/invoiceIn/back/models/invoice-in.json @@ -33,9 +33,6 @@ "isVatDeductible": { "type": "boolean" }, - "withholdingSageFk": { - "type": "number" - }, "booked": { "type": "date" }, @@ -58,6 +55,11 @@ "model": "InvoiceInDueDay", "foreignKey": "invoiceInFk" }, + "sageWithholding": { + "type": "belongsTo", + "model": "SageWithholding", + "foreignKey": "withholdingSageFk" + }, "company": { "type": "belongsTo", "model": "Company", diff --git a/modules/invoiceIn/front/basic-data/index.html b/modules/invoiceIn/front/basic-data/index.html index 22bd6658a..15052c5fe 100644 --- a/modules/invoiceIn/front/basic-data/index.html +++ b/modules/invoiceIn/front/basic-data/index.html @@ -11,12 +11,15 @@ + ng-model="$ctrl.invoiceIn.issued" + vn-focus + rule> + ng-model="$ctrl.invoiceIn.operated" + rule> @@ -29,26 +32,30 @@ value-field="id" order="nickname" label="Supplier" - required="true"> + required="true" + rule> {{::id}} - {{::nickname}} + ng-model="$ctrl.invoiceIn.supplierRef" + rule> + ng-model="$ctrl.invoiceIn.bookEntried" + rule> + ng-model="$ctrl.invoiceIn.booked" + rule> @@ -58,14 +65,16 @@ ng-model="$ctrl.invoiceIn.currencyFk" url="Currencies" show-field="name" - value-field="id"> + value-field="id" + rule> + ng-model="$ctrl.invoiceIn.companyFk" + rule> diff --git a/modules/invoiceIn/front/locale/es.yml b/modules/invoiceIn/front/locale/es.yml index 02501b14a..2d8dc02da 100644 --- a/modules/invoiceIn/front/locale/es.yml +++ b/modules/invoiceIn/front/locale/es.yml @@ -1,2 +1,5 @@ InvoiceIn: Facturas recibidas -Search invoices in by reference: Buscar facturas recibidas por referencia \ No newline at end of file +Search invoices in by reference: Buscar facturas recibidas por referencia +Entries list: Listado de entradas +Invoice list: Listado de entradas +InvoiceIn deleted: Factura eliminada \ No newline at end of file diff --git a/modules/invoiceIn/front/summary/index.html b/modules/invoiceIn/front/summary/index.html index c097ec8cf..360ef8014 100644 --- a/modules/invoiceIn/front/summary/index.html +++ b/modules/invoiceIn/front/summary/index.html @@ -32,7 +32,7 @@ - + From 56ec7b4729e7a8dca48d596589ad6e5c749976b0 Mon Sep 17 00:00:00 2001 From: carlosjr Date: Fri, 16 Apr 2021 10:17:59 +0200 Subject: [PATCH 13/13] input number made wider --- modules/order/front/prices-popover/style.scss | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/order/front/prices-popover/style.scss b/modules/order/front/prices-popover/style.scss index 0ab12ad02..deaeab044 100644 --- a/modules/order/front/prices-popover/style.scss +++ b/modules/order/front/prices-popover/style.scss @@ -8,7 +8,7 @@ font-size: .75rem } .vn-input-number { - width: 56px; + width: 80px; } } .footer {