Compare commits

...

20 Commits

Author SHA1 Message Date
Carlos Satorres 5c2d7fff5b Merge branch 'dev' into 5633-accountShortToStandard
gitea/salix/pipeline/head This commit looks good Details
2023-11-15 10:37:37 +00:00
Carlos Satorres 4678c67625 Merge branch 'dev' into 5633-accountShortToStandard
gitea/salix/pipeline/head This commit looks good Details
2023-10-31 10:59:16 +00:00
Juan Ferrer beef33e402 Merge branch 'dev' into 5633-accountShortToStandard
gitea/salix/pipeline/head This commit looks good Details
2023-10-20 17:18:04 +00:00
Carlos Satorres c72a534d1c Merge branch '5633-accountShortToStandard' of https://gitea.verdnatura.es/verdnatura/salix into 5633-accountShortToStandard
gitea/salix/pipeline/head This commit looks good Details
2023-09-12 11:37:00 +02:00
Carlos Satorres 7c27fb6a2a refs #5633 quit $ 2023-09-12 11:36:57 +02:00
Carlos Satorres 7600e258d7 Merge branch 'dev' of https://gitea.verdnatura.es/verdnatura/salix into 5633-accountShortToStandard 2023-09-12 11:24:14 +02:00
Juan Ferrer 43d71ffdbf Merge branch 'dev' into 5633-accountShortToStandard
gitea/salix/pipeline/head This commit looks good Details
2023-09-11 09:28:56 +02:00
Carlos Satorres 6c5767ae7c refs #5633 arreglo e2e, selectors, seccion
gitea/salix/pipeline/head This commit looks good Details
2023-07-06 13:15:54 +02:00
Carlos Satorres f0bbeed889 Merge branch 'dev' of https://gitea.verdnatura.es/verdnatura/salix into 5633-accountShortToStandard
gitea/salix/pipeline/head This commit looks good Details
2023-07-06 10:32:17 +02:00
Carlos Satorres 27f806e607 refs #5633 fix test front
gitea/salix/pipeline/head This commit looks good Details
2023-07-06 10:31:17 +02:00
Carlos Satorres dba79e007f refs #5633 component fix remove html scss
gitea/salix/pipeline/head There was a failure building this commit Details
2023-07-06 09:21:31 +02:00
Carlos Satorres 56979788aa Merge branch 'dev' of https://gitea.verdnatura.es/verdnatura/salix into 5633-accountShortToStandard 2023-07-05 13:53:23 +02:00
Carlos Satorres 90d144d588 refs #5633 fix account-number component
gitea/salix/pipeline/head There was a failure building this commit Details
2023-07-05 13:52:56 +02:00
Carlos Satorres f6e27add6f refs #5633 move component
gitea/salix/pipeline/head This commit looks good Details
2023-07-05 11:33:30 +02:00
Carlos Satorres d832899258 Merge branch 'dev' of https://gitea.verdnatura.es/verdnatura/salix into 5633-accountShortToStandard 2023-07-05 09:01:34 +02:00
Alexandre Riera 27145ae083 Merge branch 'dev' into 5633-accountShortToStandard
gitea/salix/pipeline/head This commit looks good Details
2023-05-29 10:59:43 +00:00
Alexandre Riera 2a61fa2ff2 Merge branch 'dev' into 5633-accountShortToStandard
gitea/salix/pipeline/head This commit looks good Details
2023-05-23 12:19:39 +00:00
Alexandre Riera 6ccb308b6d Merge branch 'dev' into 5633-accountShortToStandard
gitea/salix/pipeline/head There was a failure building this commit Details
2023-05-18 12:27:15 +00:00
Alexandre Riera 04116642a4 refs #5633 minor fixes
gitea/salix/pipeline/head Build queued... Details
2023-05-18 14:26:58 +02:00
Alexandre Riera a27749758b refs #5633 vnAccountNumber new component
gitea/salix/pipeline/head This commit looks good Details
2023-05-18 14:21:42 +02:00
9 changed files with 91 additions and 19 deletions

View File

@ -625,6 +625,7 @@ let actions = {
switch (tagName) { switch (tagName) {
case 'vn-textfield': case 'vn-textfield':
case 'vn-account-number':
case 'vn-datalist': case 'vn-datalist':
case 'vn-input-number': case 'vn-input-number':
await this.clearInput(selector); await this.clearInput(selector);
@ -667,6 +668,7 @@ let actions = {
switch (tagName) { switch (tagName) {
case 'vn-textfield': case 'vn-textfield':
case 'vn-account-number':
case 'vn-autocomplete': case 'vn-autocomplete':
case 'vn-worker-autocomplete': case 'vn-worker-autocomplete':
case 'vn-input-time': case 'vn-input-time':

View File

@ -37,6 +37,7 @@ describe('Supplier fiscal data path', () => {
const message = await page.sendForm(form, values); const message = await page.sendForm(form, values);
await page.reloadSection('supplier.card.fiscalData'); await page.reloadSection('supplier.card.fiscalData');
const formValues = await page.fetchForm(form, Object.keys(values)); const formValues = await page.fetchForm(form, Object.keys(values));
expect(errorMessage.text).toContain('Invalid Tax number'); expect(errorMessage.text).toContain('Invalid Tax number');

View File

@ -0,0 +1,22 @@
import Textfield from '../textfield/textfield';
import ngModule from '../../module';
export default class AccountNumber extends Textfield {
constructor($element, $) {
super($element, $);
super.insertable = true;
super.maxLength = 10;
this.element.addEventListener('change', () => this.accountShortToStandard());
}
accountShortToStandard() {
this.field = this.field.replace('.', '0'.repeat(11 - this.field.length));
this.$.$emit('accountShortToStandard', this.field);
}
}
AccountNumber.$inject = ['$element', '$scope'];
ngModule.vnComponent('vnAccountNumber', {
controller: AccountNumber,
});

View File

@ -0,0 +1,27 @@
describe('Component vnAccountNumber', () => {
let controller;
let $element;
beforeEach(ngModule('vnCore'));
beforeEach(inject(($compile, $rootScope) => {
$element = $compile(`<vn-account-number></vn-account-number>`)($rootScope);
controller = $element.controller('vnAccountNumber');
controller.$ = {$emit: jest.fn()};
}));
afterEach(() => {
$element.remove();
});
describe('accountShortToStandard', () => {
it('should replace dots and emit event with account number', () => {
controller.field = '41.1';
const expectedAccountNumber = '4100000001';
controller.accountShortToStandard();
expect(controller.$.$emit).toHaveBeenCalledWith('accountShortToStandard', expectedAccountNumber);
});
});
});

View File

@ -57,4 +57,5 @@ import './datalist';
import './contextmenu'; import './contextmenu';
import './rating'; import './rating';
import './smart-table'; import './smart-table';
import './account-number';
import './support-dialog'; import './support-dialog';

View File

@ -54,12 +54,12 @@
</vn-horizontal> </vn-horizontal>
<vn-vertical ng-show="$ctrl.bankSelection.accountingType.code == 'compensation'"> <vn-vertical ng-show="$ctrl.bankSelection.accountingType.code == 'compensation'">
<h6 translate>Compensation</h6> <h6 translate>Compensation</h6>
<vn-textfield <vn-account-number
ng-model="$ctrl.receipt.compensationAccount" vn-one
vn-name="compensationAccount"
label="Compensation Account" label="Compensation Account"
on-change="$ctrl.accountShortToStandard(value)"> vn-name="compensationAccount"
</vn-textfield> ng-model="$ctrl.receipt.compensationAccount">
</vn-account-number>
</vn-vertical> </vn-vertical>
<vn-horizontal> <vn-horizontal>
<vn-textfield <vn-textfield

View File

@ -127,9 +127,9 @@ class Controller extends Dialog {
this.receipt.bankFk = value; this.receipt.bankFk = value;
} }
accountShortToStandard(value) { getClientOrSupplierReference(value) {
if (value) { this.receipt.compensationAccount = value;
this.receipt.compensationAccount = value.replace('.', '0'.repeat(11 - value.length)); if (this.receipt.compensationAccount) {
const params = {bankAccount: this.receipt.compensationAccount}; const params = {bankAccount: this.receipt.compensationAccount};
this.$http.get(`Clients/getClientOrSupplierReference`, {params}) this.$http.get(`Clients/getClientOrSupplierReference`, {params})
.then(res => { .then(res => {

View File

@ -112,12 +112,34 @@ describe('Client', () => {
}); });
}); });
describe('accountShortToStandard()', () => { describe('getClientOrSupplierReference', () => {
it('should get de account in stardard format', () => { it('should update receipt description when compensation account is provided', async() => {
const shortAccount = '4.3'; jest.spyOn(controller, '$t');
controller.accountShortToStandard(shortAccount); const mockValue = '4100000001';
const mockResponse = {
clientId: '1',
clientName: 'Client mocked'
};
expect(controller.receipt.compensationAccount).toEqual('4000000003'); $httpBackend
.expectGET(`Clients/getClientOrSupplierReference?bankAccount=${mockValue}`)
.respond(mockResponse);
controller.getClientOrSupplierReference(mockValue);
$httpBackend.flush();
expect(controller.receipt.compensationAccount).toBe(mockValue);
expect(controller.receipt.description).toBe('Client Compensation Reference');
expect(controller.$t).toHaveBeenCalledWith('Client Compensation Reference', {
clientId: mockResponse.clientId,
clientName: mockResponse.clientName
});
});
it('should update receipt description to empty string if compensation account is not provided', async() => {
controller.getClientOrSupplierReference('');
expect(controller.receipt.compensationAccount).toBe('');
expect(controller.receipt.description).toBe('');
}); });
}); });

View File

@ -58,15 +58,12 @@
</vn-textfield> </vn-textfield>
</vn-horizontal> </vn-horizontal>
<vn-horizontal> <vn-horizontal>
<vn-textfield <vn-account-number
vn-one vn-one
label="Account" label="Account"
vn-name="account" vn-name="account"
ng-model="$ctrl.supplier.account" ng-model="$ctrl.supplier.account">
insertable="true" </vn-account-number>
max-length="10"
rule>
</vn-textfield>
<vn-autocomplete <vn-autocomplete
vn-one vn-one
label="Sage tax type" label="Sage tax type"