taxtank-core 0.29.10 → 0.29.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/taxtank-core.umd.js +151 -164
- package/bundles/taxtank-core.umd.js.map +1 -1
- package/esm2015/lib/db/Models/sole/sole-invoice-template.js +1 -1
- package/esm2015/lib/forms/phone/phone.form.js +9 -7
- package/esm2015/lib/forms/sole/sole-contact.form.js +2 -4
- package/esm2015/lib/forms/sole/sole-invoice-template.form.js +1 -2
- package/esm2015/lib/models/property/property-document.js +2 -2
- package/esm2015/lib/models/sole/sole-invoice-template.js +2 -13
- package/esm2015/lib/models/sole/sole-invoice.js +5 -10
- package/fesm2015/taxtank-core.js +117 -129
- package/fesm2015/taxtank-core.js.map +1 -1
- package/lib/db/Models/sole/sole-invoice-template.d.ts +0 -2
- package/lib/models/sole/sole-invoice-template.d.ts +2 -7
- package/lib/models/sole/sole-invoice.d.ts +3 -5
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import { AbstractModel } from '../abstract-model';
|
|
2
2
|
export class SoleInvoiceTemplate extends AbstractModel {
|
|
3
3
|
}
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29sZS1pbnZvaWNlLXRlbXBsYXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHQtY29yZS9zcmMvbGliL2RiL01vZGVscy9zb2xlL3NvbGUtaW52b2ljZS10ZW1wbGF0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFHbEQsTUFBTSxPQUFPLG1CQUFvQixTQUFRLGFBQWE7Q0FPckQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTb2xlQnVzaW5lc3MgfSBmcm9tICcuL3NvbGUtYnVzaW5lc3MnO1xuaW1wb3J0IHsgQmFua0FjY291bnQgfSBmcm9tICcuLi9iYW5rL2JhbmstYWNjb3VudCc7XG5pbXBvcnQgeyBBYnN0cmFjdE1vZGVsIH0gZnJvbSAnLi4vYWJzdHJhY3QtbW9kZWwnO1xuaW1wb3J0IHsgU29sZUludm9pY2VUZW1wbGF0ZVRheFR5cGVFbnVtIH0gZnJvbSAnLi4vLi4vRW51bXMvc29sZS1pbnZvaWNlLXRlbXBsYXRlLXRheC10eXBlLmVudW0nO1xuXG5leHBvcnQgY2xhc3MgU29sZUludm9pY2VUZW1wbGF0ZSBleHRlbmRzIEFic3RyYWN0TW9kZWwge1xuICBuYW1lPzogc3RyaW5nO1xuICB0YXhUeXBlPzogU29sZUludm9pY2VUZW1wbGF0ZVRheFR5cGVFbnVtO1xuICB0ZXJtPzogbnVtYmVyO1xuICBpZD86IG51bWJlcjtcbiAgYnVzaW5lc3M/OiBTb2xlQnVzaW5lc3M7XG4gIGJhbmtBY2NvdW50PzogQmFua0FjY291bnQ7XG59XG4iXX0=
|
|
@@ -1,15 +1,17 @@
|
|
|
1
1
|
import { AbstractForm } from '../abstract.form';
|
|
2
|
-
import { Phone } from '../../models/phone/phone';
|
|
3
|
-
import { plainToClass } from 'class-transformer';
|
|
4
2
|
import { FormControl, Validators } from '@angular/forms';
|
|
5
3
|
import { phoneNumberValidator } from '../../validators/phone-number.validator';
|
|
4
|
+
import { PhoneTypeEnum } from '../../db/Enums/phone-type.enum';
|
|
5
|
+
import { Country } from '../../models';
|
|
6
6
|
export class PhoneForm extends AbstractForm {
|
|
7
|
-
constructor(
|
|
7
|
+
constructor(
|
|
8
|
+
// no default value because this form is always built-in, so phone passed from parent form
|
|
9
|
+
phone) {
|
|
8
10
|
super({
|
|
9
|
-
type: new FormControl(phone.type, Validators.required),
|
|
10
|
-
country: new FormControl(phone.country, Validators.required),
|
|
11
|
-
number: new FormControl(phone.number, [Validators.required, phoneNumberValidator()])
|
|
11
|
+
type: new FormControl((phone === null || phone === void 0 ? void 0 : phone.type) || PhoneTypeEnum.MOBILE, Validators.required),
|
|
12
|
+
country: new FormControl((phone === null || phone === void 0 ? void 0 : phone.country) || Country.australia, Validators.required),
|
|
13
|
+
number: new FormControl((phone === null || phone === void 0 ? void 0 : phone.number) || null, [Validators.required, phoneNumberValidator()])
|
|
12
14
|
}, phone);
|
|
13
15
|
}
|
|
14
16
|
}
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGhvbmUuZm9ybS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3R0LWNvcmUvc3JjL2xpYi9mb3Jtcy9waG9uZS9waG9uZS5mb3JtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUVoRCxPQUFPLEVBQUUsV0FBVyxFQUFFLFVBQVUsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQy9FLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUMvRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRXZDLE1BQU0sT0FBTyxTQUFVLFNBQVEsWUFBbUI7SUFDaEQ7SUFDRSwwRkFBMEY7SUFDMUYsS0FBYTtRQUViLEtBQUssQ0FBQztZQUNKLElBQUksRUFBRSxJQUFJLFdBQVcsQ0FBQyxDQUFBLEtBQUssYUFBTCxLQUFLLHVCQUFMLEtBQUssQ0FBRSxJQUFJLEtBQUksYUFBYSxDQUFDLE1BQU0sRUFBRSxVQUFVLENBQUMsUUFBUSxDQUFDO1lBQy9FLE9BQU8sRUFBRSxJQUFJLFdBQVcsQ0FBQyxDQUFBLEtBQUssYUFBTCxLQUFLLHVCQUFMLEtBQUssQ0FBRSxPQUFPLEtBQUksT0FBTyxDQUFDLFNBQVMsRUFBRSxVQUFVLENBQUMsUUFBUSxDQUFDO1lBQ2xGLE1BQU0sRUFBRSxJQUFJLFdBQVcsQ0FBQyxDQUFBLEtBQUssYUFBTCxLQUFLLHVCQUFMLEtBQUssQ0FBRSxNQUFNLEtBQUksSUFBSSxFQUFFLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRSxvQkFBb0IsRUFBRSxDQUFDLENBQUM7U0FDOUYsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUNaLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFic3RyYWN0Rm9ybSB9IGZyb20gJy4uL2Fic3RyYWN0LmZvcm0nO1xuaW1wb3J0IHsgUGhvbmUgfSBmcm9tICcuLi8uLi9tb2RlbHMvcGhvbmUvcGhvbmUnO1xuaW1wb3J0IHsgRm9ybUNvbnRyb2wsIFZhbGlkYXRvcnMgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBwaG9uZU51bWJlclZhbGlkYXRvciB9IGZyb20gJy4uLy4uL3ZhbGlkYXRvcnMvcGhvbmUtbnVtYmVyLnZhbGlkYXRvcic7XG5pbXBvcnQgeyBQaG9uZVR5cGVFbnVtIH0gZnJvbSAnLi4vLi4vZGIvRW51bXMvcGhvbmUtdHlwZS5lbnVtJztcbmltcG9ydCB7IENvdW50cnkgfSBmcm9tICcuLi8uLi9tb2RlbHMnO1xuXG5leHBvcnQgY2xhc3MgUGhvbmVGb3JtIGV4dGVuZHMgQWJzdHJhY3RGb3JtPFBob25lPiB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIC8vIG5vIGRlZmF1bHQgdmFsdWUgYmVjYXVzZSB0aGlzIGZvcm0gaXMgYWx3YXlzIGJ1aWx0LWluLCBzbyBwaG9uZSBwYXNzZWQgZnJvbSBwYXJlbnQgZm9ybVxuICAgIHBob25lPzogUGhvbmVcbiAgKSB7XG4gICAgc3VwZXIoe1xuICAgICAgdHlwZTogbmV3IEZvcm1Db250cm9sKHBob25lPy50eXBlIHx8IFBob25lVHlwZUVudW0uTU9CSUxFLCBWYWxpZGF0b3JzLnJlcXVpcmVkKSxcbiAgICAgIGNvdW50cnk6IG5ldyBGb3JtQ29udHJvbChwaG9uZT8uY291bnRyeSB8fCBDb3VudHJ5LmF1c3RyYWxpYSwgVmFsaWRhdG9ycy5yZXF1aXJlZCksXG4gICAgICBudW1iZXI6IG5ldyBGb3JtQ29udHJvbChwaG9uZT8ubnVtYmVyIHx8IG51bGwsIFtWYWxpZGF0b3JzLnJlcXVpcmVkLCBwaG9uZU51bWJlclZhbGlkYXRvcigpXSlcbiAgICB9LCBwaG9uZSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -3,8 +3,6 @@ import { SoleContact } from '../../models';
|
|
|
3
3
|
import { plainToClass } from 'class-transformer';
|
|
4
4
|
import { FormControl, Validators } from '@angular/forms';
|
|
5
5
|
import { AddressForm } from '../address';
|
|
6
|
-
import { PhoneForm } from '../phone';
|
|
7
|
-
import { Phone } from '../../models/phone/phone';
|
|
8
6
|
import { Address } from '../../models/address/address';
|
|
9
7
|
export class SoleContactForm extends AbstractForm {
|
|
10
8
|
constructor(contact = plainToClass(SoleContact, {})) {
|
|
@@ -14,9 +12,9 @@ export class SoleContactForm extends AbstractForm {
|
|
|
14
12
|
firstName: new FormControl(contact.firstName, Validators.required),
|
|
15
13
|
lastName: new FormControl(contact.lastName, Validators.required),
|
|
16
14
|
email: new FormControl(contact.email, [Validators.required, Validators.email]),
|
|
17
|
-
phone: new
|
|
15
|
+
phone: new FormControl(contact.phone),
|
|
18
16
|
address: new AddressForm(contact.address || plainToClass(Address, {}))
|
|
19
17
|
}, contact);
|
|
20
18
|
}
|
|
21
19
|
}
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29sZS1jb250YWN0LmZvcm0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvZm9ybXMvc29sZS9zb2xlLWNvbnRhY3QuZm9ybS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDaEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUMzQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDakQsT0FBTyxFQUFFLFdBQVcsRUFBRSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUV2RCxNQUFNLE9BQU8sZUFBZ0IsU0FBUSxZQUF5QjtJQUM1RCxZQUNFLFVBQXVCLFlBQVksQ0FBQyxXQUFXLEVBQUUsRUFBRSxDQUFDO1FBRXBELEtBQUssQ0FBQztZQUNKLElBQUksRUFBRSxJQUFJLFdBQVcsQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLFVBQVUsQ0FBQyxRQUFRLENBQUM7WUFDeEQsR0FBRyxFQUFFLElBQUksV0FBVyxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxFQUFFLFVBQVUsQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztZQUN2RixTQUFTLEVBQUUsSUFBSSxXQUFXLENBQUMsT0FBTyxDQUFDLFNBQVMsRUFBRSxVQUFVLENBQUMsUUFBUSxDQUFDO1lBQ2xFLFFBQVEsRUFBRSxJQUFJLFdBQVcsQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxRQUFRLENBQUM7WUFDaEUsS0FBSyxFQUFFLElBQUksV0FBVyxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUM5RSxLQUFLLEVBQUUsSUFBSSxXQUFXLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQztZQUNyQyxPQUFPLEVBQUUsSUFBSSxXQUFXLENBQUMsT0FBTyxDQUFDLE9BQU8sSUFBSSxZQUFZLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1NBQ3ZFLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDZCxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYnN0cmFjdEZvcm0gfSBmcm9tICcuLi9hYnN0cmFjdC5mb3JtJztcbmltcG9ydCB7IFNvbGVDb250YWN0IH0gZnJvbSAnLi4vLi4vbW9kZWxzJztcbmltcG9ydCB7IHBsYWluVG9DbGFzcyB9IGZyb20gJ2NsYXNzLXRyYW5zZm9ybWVyJztcbmltcG9ydCB7IEZvcm1Db250cm9sLCBWYWxpZGF0b3JzIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQWRkcmVzc0Zvcm0gfSBmcm9tICcuLi9hZGRyZXNzJztcbmltcG9ydCB7IEFkZHJlc3MgfSBmcm9tICcuLi8uLi9tb2RlbHMvYWRkcmVzcy9hZGRyZXNzJztcblxuZXhwb3J0IGNsYXNzIFNvbGVDb250YWN0Rm9ybSBleHRlbmRzIEFic3RyYWN0Rm9ybTxTb2xlQ29udGFjdD4ge1xuICBjb25zdHJ1Y3RvcihcbiAgICBjb250YWN0OiBTb2xlQ29udGFjdCA9IHBsYWluVG9DbGFzcyhTb2xlQ29udGFjdCwge30pXG4gICkge1xuICAgIHN1cGVyKHtcbiAgICAgIG5hbWU6IG5ldyBGb3JtQ29udHJvbChjb250YWN0Lm5hbWUsIFZhbGlkYXRvcnMucmVxdWlyZWQpLFxuICAgICAgYWJuOiBuZXcgRm9ybUNvbnRyb2woY29udGFjdC5hYm4sIFtWYWxpZGF0b3JzLm1pbkxlbmd0aCgxMSksIFZhbGlkYXRvcnMubWF4TGVuZ3RoKDExKV0pLFxuICAgICAgZmlyc3ROYW1lOiBuZXcgRm9ybUNvbnRyb2woY29udGFjdC5maXJzdE5hbWUsIFZhbGlkYXRvcnMucmVxdWlyZWQpLFxuICAgICAgbGFzdE5hbWU6IG5ldyBGb3JtQ29udHJvbChjb250YWN0Lmxhc3ROYW1lLCBWYWxpZGF0b3JzLnJlcXVpcmVkKSxcbiAgICAgIGVtYWlsOiBuZXcgRm9ybUNvbnRyb2woY29udGFjdC5lbWFpbCwgW1ZhbGlkYXRvcnMucmVxdWlyZWQsIFZhbGlkYXRvcnMuZW1haWxdKSxcbiAgICAgIHBob25lOiBuZXcgRm9ybUNvbnRyb2woY29udGFjdC5waG9uZSksXG4gICAgICBhZGRyZXNzOiBuZXcgQWRkcmVzc0Zvcm0oY29udGFjdC5hZGRyZXNzIHx8IHBsYWluVG9DbGFzcyhBZGRyZXNzLCB7fSkpXG4gICAgfSwgY29udGFjdCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -9,8 +9,7 @@ export class SoleInvoiceTemplateForm extends AbstractForm {
|
|
|
9
9
|
// 32767 - max value because we have small int data type in database for this field, but we don't have actual max validation for term
|
|
10
10
|
term: new FormControl(invoiceTemplate.term, [Validators.required, Validators.min(0), Validators.max(32767)]),
|
|
11
11
|
bankAccount: new FormControl(invoiceTemplate.bankAccount, [Validators.required]),
|
|
12
|
-
file: new FormControl(invoiceTemplate.file)
|
|
13
12
|
}, invoiceTemplate);
|
|
14
13
|
}
|
|
15
14
|
}
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29sZS1pbnZvaWNlLXRlbXBsYXRlLmZvcm0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvZm9ybXMvc29sZS9zb2xlLWludm9pY2UtdGVtcGxhdGUuZm9ybS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFaEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUV6RCxNQUFNLE9BQU8sdUJBQXdCLFNBQVEsWUFBaUM7SUFDNUUsWUFDRSxlQUFvQztRQUVwQyxLQUFLLENBQUM7WUFDSixJQUFJLEVBQUUsSUFBSSxXQUFXLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSxVQUFVLENBQUMsUUFBUSxDQUFDO1lBQ2hFLDhEQUE4RDtZQUM5RCxPQUFPLEVBQUUsSUFBSSxXQUFXLENBQUMsZUFBZSxDQUFDLE9BQU8sRUFBRSxVQUFVLENBQUMsUUFBUSxDQUFDO1lBQ3RFLHFJQUFxSTtZQUNySSxJQUFJLEVBQUUsSUFBSSxXQUFXLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSxDQUFDLFVBQVUsQ0FBQyxRQUFRLEVBQUUsVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxVQUFVLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7WUFDNUcsV0FBVyxFQUFFLElBQUksV0FBVyxDQUFDLGVBQWUsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUM7U0FDakYsRUFBRSxlQUFlLENBQUMsQ0FBQztJQUN0QixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYnN0cmFjdEZvcm0gfSBmcm9tICcuLi9hYnN0cmFjdC5mb3JtJztcbmltcG9ydCB7IFNvbGVJbnZvaWNlVGVtcGxhdGUgfSBmcm9tICcuLi8uLi9tb2RlbHMnO1xuaW1wb3J0IHsgRm9ybUNvbnRyb2wsIFZhbGlkYXRvcnMgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmV4cG9ydCBjbGFzcyBTb2xlSW52b2ljZVRlbXBsYXRlRm9ybSBleHRlbmRzIEFic3RyYWN0Rm9ybTxTb2xlSW52b2ljZVRlbXBsYXRlPiB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIGludm9pY2VUZW1wbGF0ZTogU29sZUludm9pY2VUZW1wbGF0ZVxuICApIHtcbiAgICBzdXBlcih7XG4gICAgICBuYW1lOiBuZXcgRm9ybUNvbnRyb2woaW52b2ljZVRlbXBsYXRlLm5hbWUsIFZhbGlkYXRvcnMucmVxdWlyZWQpLFxuICAgICAgLy8gdGF4VHlwZSBpcyBhbHdheXMgJ05vIFRheCcgd2hlbiBzb2xlRGV0YWlscy5pc0dTVCA9PT0gZmFsc2VcbiAgICAgIHRheFR5cGU6IG5ldyBGb3JtQ29udHJvbChpbnZvaWNlVGVtcGxhdGUudGF4VHlwZSwgVmFsaWRhdG9ycy5yZXF1aXJlZCksXG4gICAgICAvLyAzMjc2NyAtIG1heCB2YWx1ZSBiZWNhdXNlIHdlIGhhdmUgc21hbGwgaW50IGRhdGEgdHlwZSBpbiBkYXRhYmFzZSBmb3IgdGhpcyBmaWVsZCwgYnV0IHdlIGRvbid0IGhhdmUgYWN0dWFsIG1heCB2YWxpZGF0aW9uIGZvciB0ZXJtXG4gICAgICB0ZXJtOiBuZXcgRm9ybUNvbnRyb2woaW52b2ljZVRlbXBsYXRlLnRlcm0sIFtWYWxpZGF0b3JzLnJlcXVpcmVkLCBWYWxpZGF0b3JzLm1pbigwKSwgVmFsaWRhdG9ycy5tYXgoMzI3NjcpXSksXG4gICAgICBiYW5rQWNjb3VudDogbmV3IEZvcm1Db250cm9sKGludm9pY2VUZW1wbGF0ZS5iYW5rQWNjb3VudCwgW1ZhbGlkYXRvcnMucmVxdWlyZWRdKSxcbiAgICB9LCBpbnZvaWNlVGVtcGxhdGUpO1xuICB9XG59XG4iXX0=
|
|
@@ -4,7 +4,7 @@ import { AssetEntityTypeEnum } from '../../interfaces/asset-entity-type.enum';
|
|
|
4
4
|
export class PropertyDocument extends PropertyDocumentBase {
|
|
5
5
|
constructor() {
|
|
6
6
|
super(...arguments);
|
|
7
|
-
this.type = AssetTypeEnum.
|
|
7
|
+
this.type = AssetTypeEnum.PROPERTY;
|
|
8
8
|
this.entityType = AssetEntityTypeEnum.PROPERTIES;
|
|
9
9
|
}
|
|
10
10
|
getApiUrlPrefix() {
|
|
@@ -14,4 +14,4 @@ export class PropertyDocument extends PropertyDocumentBase {
|
|
|
14
14
|
return this.property;
|
|
15
15
|
}
|
|
16
16
|
}
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvcGVydHktZG9jdW1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dC1jb3JlL3NyYy9saWIvbW9kZWxzL3Byb3BlcnR5L3Byb3BlcnR5LWRvY3VtZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsSUFBSSxvQkFBb0IsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBR3RHLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUk5RSxNQUFNLE9BQU8sZ0JBQWlCLFNBQVEsb0JBQW9CO0lBQTFEOztRQUNFLFNBQUksR0FBa0IsYUFBYSxDQUFDLFFBQVEsQ0FBQztRQUM3QyxlQUFVLEdBQXdCLG1CQUFtQixDQUFDLFVBQVUsQ0FBQztJQVVuRSxDQUFDO0lBUEMsZUFBZTtRQUNiLE9BQU8sRUFBRSxDQUFDO0lBQ1osQ0FBQztJQUVELFNBQVM7UUFDUCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDdkIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUHJvcGVydHlEb2N1bWVudCBhcyBQcm9wZXJ0eURvY3VtZW50QmFzZSB9IGZyb20gJy4uLy4uL2RiL01vZGVscy9kb2N1bWVudC9wcm9wZXJ0eS1kb2N1bWVudCc7XG5pbXBvcnQgeyBJQXNzZXQgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzL2Fzc2V0LmludGVyZmFjZSc7XG5pbXBvcnQgeyBJRG9jdW1lbnQgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzL2RvY3VtZW50LmludGVyZmFjZSc7XG5pbXBvcnQgeyBBc3NldFR5cGVFbnVtIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9hc3NldC10eXBlLmVudW0nO1xuaW1wb3J0IHsgQXNzZXRFbnRpdHlUeXBlRW51bSB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvYXNzZXQtZW50aXR5LXR5cGUuZW51bSc7XG5pbXBvcnQgeyBEb2N1bWVudGFibGUgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzL2RvY3VtZW50YWJsZS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgUHJvcGVydHkgfSBmcm9tICcuL3Byb3BlcnR5JztcblxuZXhwb3J0IGNsYXNzIFByb3BlcnR5RG9jdW1lbnQgZXh0ZW5kcyBQcm9wZXJ0eURvY3VtZW50QmFzZSBpbXBsZW1lbnRzIElBc3NldCwgSURvY3VtZW50IHtcbiAgdHlwZTogQXNzZXRUeXBlRW51bSA9IEFzc2V0VHlwZUVudW0uUFJPUEVSVFk7XG4gIGVudGl0eVR5cGU6IEFzc2V0RW50aXR5VHlwZUVudW0gPSBBc3NldEVudGl0eVR5cGVFbnVtLlBST1BFUlRJRVM7XG4gIHByb3BlcnR5OiBQcm9wZXJ0eTtcblxuICBnZXRBcGlVcmxQcmVmaXgoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gJyc7XG4gIH1cblxuICBnZXRFbnRpdHkoKTogRG9jdW1lbnRhYmxlIHtcbiAgICByZXR1cm4gdGhpcy5wcm9wZXJ0eTtcbiAgfVxufVxuIl19
|
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
2
|
import { SoleBusiness } from './sole-business';
|
|
3
|
-
import { BankAccount } from '../bank
|
|
3
|
+
import { BankAccount } from '../bank';
|
|
4
4
|
import { SoleInvoiceTemplate as SoleInvoiceTemplateBase } from '../../db/Models/sole/sole-invoice-template';
|
|
5
5
|
import { Type } from 'class-transformer';
|
|
6
6
|
import { SoleInvoiceTemplateTaxTypeEnum } from '../../db/Enums/sole-invoice-template-tax-type.enum';
|
|
7
|
-
import { AppFile } from '../file';
|
|
8
7
|
export class SoleInvoiceTemplate extends SoleInvoiceTemplateBase {
|
|
9
8
|
constructor() {
|
|
10
9
|
super(...arguments);
|
|
@@ -22,13 +21,6 @@ export class SoleInvoiceTemplate extends SoleInvoiceTemplateBase {
|
|
|
22
21
|
get termTime() {
|
|
23
22
|
return this.term * 24 * 3600 * 1000;
|
|
24
23
|
}
|
|
25
|
-
getPhoto() {
|
|
26
|
-
var _a;
|
|
27
|
-
return ((_a = this.file) === null || _a === void 0 ? void 0 : _a.publicUrl) || null;
|
|
28
|
-
}
|
|
29
|
-
getPhotoPlaceholder() {
|
|
30
|
-
return `${this.name[0].toUpperCase()}${this.name[1].toUpperCase()}`;
|
|
31
|
-
}
|
|
32
24
|
}
|
|
33
25
|
__decorate([
|
|
34
26
|
Type(() => SoleBusiness)
|
|
@@ -36,7 +28,4 @@ __decorate([
|
|
|
36
28
|
__decorate([
|
|
37
29
|
Type(() => BankAccount)
|
|
38
30
|
], SoleInvoiceTemplate.prototype, "bankAccount", void 0);
|
|
39
|
-
|
|
40
|
-
Type(() => AppFile)
|
|
41
|
-
], SoleInvoiceTemplate.prototype, "file", void 0);
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29sZS1pbnZvaWNlLXRlbXBsYXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHQtY29yZS9zcmMvbGliL21vZGVscy9zb2xlL3NvbGUtaW52b2ljZS10ZW1wbGF0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNuRCxPQUFPLEVBQUUsbUJBQW1CLElBQUksdUJBQXVCLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUM1RyxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDekMsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sb0RBQW9ELENBQUM7QUFDcEcsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUdsQyxNQUFNLE9BQU8sbUJBQW9CLFNBQVEsdUJBQXVCO0lBQWhFOztRQVVFOzs7OztXQUtHO1FBQ0gsWUFBTyxHQUFtQyw4QkFBOEIsQ0FBQyxNQUFNLENBQUM7SUFnQmxGLENBQUM7SUFkQzs7T0FFRztJQUNILElBQUksUUFBUTtRQUNWLE9BQU8sSUFBSSxDQUFDLElBQUksR0FBRyxFQUFFLEdBQUcsSUFBSSxHQUFHLElBQUksQ0FBQztJQUN0QyxDQUFDO0lBRUQsUUFBUTs7UUFDTixPQUFPLENBQUEsTUFBQSxJQUFJLENBQUMsSUFBSSwwQ0FBRSxTQUFTLEtBQUksSUFBSSxDQUFDO0lBQ3RDLENBQUM7SUFFRCxtQkFBbUI7UUFDakIsT0FBTyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxFQUFFLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsRUFBRSxDQUFDO0lBQ3RFLENBQUM7Q0FDRjtBQTlCQztJQURDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxZQUFZLENBQUM7cURBQ0Y7QUFHdkI7SUFEQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsV0FBVyxDQUFDO3dEQUNDO0FBR3pCO0lBREMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQztpREFDUCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNvbGVCdXNpbmVzcyB9IGZyb20gJy4vc29sZS1idXNpbmVzcyc7XG5pbXBvcnQgeyBCYW5rQWNjb3VudCB9IGZyb20gJy4uL2JhbmsvYmFuay1hY2NvdW50JztcbmltcG9ydCB7IFNvbGVJbnZvaWNlVGVtcGxhdGUgYXMgU29sZUludm9pY2VUZW1wbGF0ZUJhc2UgfSBmcm9tICcuLi8uLi9kYi9Nb2RlbHMvc29sZS9zb2xlLWludm9pY2UtdGVtcGxhdGUnO1xuaW1wb3J0IHsgVHlwZSB9IGZyb20gJ2NsYXNzLXRyYW5zZm9ybWVyJztcbmltcG9ydCB7IFNvbGVJbnZvaWNlVGVtcGxhdGVUYXhUeXBlRW51bSB9IGZyb20gJy4uLy4uL2RiL0VudW1zL3NvbGUtaW52b2ljZS10ZW1wbGF0ZS10YXgtdHlwZS5lbnVtJztcbmltcG9ydCB7IEFwcEZpbGUgfSBmcm9tICcuLi9maWxlJztcbmltcG9ydCB7IFBob3RvYWJsZSB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xuXG5leHBvcnQgY2xhc3MgU29sZUludm9pY2VUZW1wbGF0ZSBleHRlbmRzIFNvbGVJbnZvaWNlVGVtcGxhdGVCYXNlIGltcGxlbWVudHMgUGhvdG9hYmxlIHtcbiAgQFR5cGUoKCkgPT4gU29sZUJ1c2luZXNzKVxuICBidXNpbmVzczogU29sZUJ1c2luZXNzO1xuXG4gIEBUeXBlKCgpID0+IEJhbmtBY2NvdW50KVxuICBiYW5rQWNjb3VudDogQmFua0FjY291bnQ7XG5cbiAgQFR5cGUoKCkgPT4gQXBwRmlsZSlcbiAgZmlsZTogQXBwRmlsZVxuXG4gIC8qKlxuICAgKiBBZmZlY3RzIHRvIFNvbGVJbnZvaWNlSXRlbS5pc0dTVCBmbGFnIGF2YWlsYWJpbGl0eS5cbiAgICogV2hlbiBOT05FOiBpc0dTVCBpcyB1bmF2YWlsYWJsZVxuICAgKiBXaGVuIEVYQ0xVU0lWRTogR1NUIGFtb3VudCBhZGRlZCBhZGRpdGlvbmFseSB0byBpbnZvaWNlIHRvdGFsIHByaWNlXG4gICAqIFdoZW4gSU5DTFVTSVZFOiBHU1QgYW1vdW50IGlzIGFscmVhZHkgaW5jbHVkZWQgdG8gaW52b2ljZSB0b3RhbCBwcmljZVxuICAgKi9cbiAgdGF4VHlwZTogU29sZUludm9pY2VUZW1wbGF0ZVRheFR5cGVFbnVtID0gU29sZUludm9pY2VUZW1wbGF0ZVRheFR5cGVFbnVtLk5PX1RBWDtcblxuICAvKipcbiAgICogR2V0IHRlcm0gZHVyYXRpb24gaW4gbWlsbGlzZWNvbmRzXG4gICAqL1xuICBnZXQgdGVybVRpbWUoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gdGhpcy50ZXJtICogMjQgKiAzNjAwICogMTAwMDtcbiAgfVxuXG4gIGdldFBob3RvKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuZmlsZT8ucHVibGljVXJsIHx8IG51bGw7XG4gIH1cblxuICBnZXRQaG90b1BsYWNlaG9sZGVyKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGAke3RoaXMubmFtZVswXS50b1VwcGVyQ2FzZSgpfSR7dGhpcy5uYW1lWzFdLnRvVXBwZXJDYXNlKCl9YDtcbiAgfVxufVxuIl19
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29sZS1pbnZvaWNlLXRlbXBsYXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHQtY29yZS9zcmMvbGliL21vZGVscy9zb2xlL3NvbGUtaW52b2ljZS10ZW1wbGF0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDdEMsT0FBTyxFQUFFLG1CQUFtQixJQUFJLHVCQUF1QixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDNUcsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3pDLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLG9EQUFvRCxDQUFDO0FBR3BHLE1BQU0sT0FBTyxtQkFBb0IsU0FBUSx1QkFBdUI7SUFBaEU7O1FBT0U7Ozs7O1dBS0c7UUFDSCxZQUFPLEdBQW1DLDhCQUE4QixDQUFDLE1BQU0sQ0FBQztJQVFsRixDQUFDO0lBTkM7O09BRUc7SUFDSCxJQUFJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxJQUFJLEdBQUcsRUFBRSxHQUFHLElBQUksR0FBRyxJQUFJLENBQUM7SUFDdEMsQ0FBQztDQUNGO0FBbkJDO0lBREMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLFlBQVksQ0FBQztxREFDRjtBQUd2QjtJQURDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxXQUFXLENBQUM7d0RBQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTb2xlQnVzaW5lc3MgfSBmcm9tICcuL3NvbGUtYnVzaW5lc3MnO1xuaW1wb3J0IHsgQmFua0FjY291bnQgfSBmcm9tICcuLi9iYW5rJztcbmltcG9ydCB7IFNvbGVJbnZvaWNlVGVtcGxhdGUgYXMgU29sZUludm9pY2VUZW1wbGF0ZUJhc2UgfSBmcm9tICcuLi8uLi9kYi9Nb2RlbHMvc29sZS9zb2xlLWludm9pY2UtdGVtcGxhdGUnO1xuaW1wb3J0IHsgVHlwZSB9IGZyb20gJ2NsYXNzLXRyYW5zZm9ybWVyJztcbmltcG9ydCB7IFNvbGVJbnZvaWNlVGVtcGxhdGVUYXhUeXBlRW51bSB9IGZyb20gJy4uLy4uL2RiL0VudW1zL3NvbGUtaW52b2ljZS10ZW1wbGF0ZS10YXgtdHlwZS5lbnVtJztcbmltcG9ydCB7IFBob3RvYWJsZSB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xuXG5leHBvcnQgY2xhc3MgU29sZUludm9pY2VUZW1wbGF0ZSBleHRlbmRzIFNvbGVJbnZvaWNlVGVtcGxhdGVCYXNlIHtcbiAgQFR5cGUoKCkgPT4gU29sZUJ1c2luZXNzKVxuICBidXNpbmVzczogU29sZUJ1c2luZXNzO1xuXG4gIEBUeXBlKCgpID0+IEJhbmtBY2NvdW50KVxuICBiYW5rQWNjb3VudDogQmFua0FjY291bnQ7XG5cbiAgLyoqXG4gICAqIEFmZmVjdHMgdG8gU29sZUludm9pY2VJdGVtLmlzR1NUIGZsYWcgYXZhaWxhYmlsaXR5LlxuICAgKiBXaGVuIE5PTkU6IGlzR1NUIGlzIHVuYXZhaWxhYmxlXG4gICAqIFdoZW4gRVhDTFVTSVZFOiBHU1QgYW1vdW50IGFkZGVkIGFkZGl0aW9uYWx5IHRvIGludm9pY2UgdG90YWwgcHJpY2VcbiAgICogV2hlbiBJTkNMVVNJVkU6IEdTVCBhbW91bnQgaXMgYWxyZWFkeSBpbmNsdWRlZCB0byBpbnZvaWNlIHRvdGFsIHByaWNlXG4gICAqL1xuICB0YXhUeXBlOiBTb2xlSW52b2ljZVRlbXBsYXRlVGF4VHlwZUVudW0gPSBTb2xlSW52b2ljZVRlbXBsYXRlVGF4VHlwZUVudW0uTk9fVEFYO1xuXG4gIC8qKlxuICAgKiBHZXQgdGVybSBkdXJhdGlvbiBpbiBtaWxsaXNlY29uZHNcbiAgICovXG4gIGdldCB0ZXJtVGltZSgpOiBudW1iZXIge1xuICAgIHJldHVybiB0aGlzLnRlcm0gKiAyNCAqIDM2MDAgKiAxMDAwO1xuICB9XG59XG4iXX0=
|
|
@@ -1,17 +1,15 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
2
|
import { SoleInvoice as SoleInvoiceBase } from '../../db/Models/sole/sole-invoice';
|
|
3
|
-
import { User } from '../user
|
|
3
|
+
import { User } from '../user';
|
|
4
4
|
import { SoleBusiness } from './sole-business';
|
|
5
5
|
import { SoleInvoiceItem } from './sole-invoice-item';
|
|
6
6
|
import { SoleContact } from './sole-contact';
|
|
7
|
-
import { SoleInvoiceTemplate } from './sole-invoice-template';
|
|
8
7
|
import { Type } from 'class-transformer';
|
|
9
8
|
import { SoleInvoiceStatusesEnum } from '../../db/Enums/sole-invoice-statuses.enum';
|
|
10
|
-
import { BankAccount } from '../bank
|
|
9
|
+
import { BankAccount } from '../bank';
|
|
11
10
|
import { SoleInvoiceTaxTypeEnum } from '../../db/Enums/sole-invoice-tax-type.enum';
|
|
12
|
-
import { SoleInvoiceItemCollection } from '../../collections
|
|
13
|
-
import { ChartAccounts } from '../chart-accounts
|
|
14
|
-
import { Collection } from '../../collections/collection';
|
|
11
|
+
import { SoleInvoiceItemCollection, Collection } from '../../collections';
|
|
12
|
+
import { ChartAccounts } from '../chart-accounts';
|
|
15
13
|
export class SoleInvoice extends SoleInvoiceBase {
|
|
16
14
|
constructor() {
|
|
17
15
|
super(...arguments);
|
|
@@ -141,10 +139,7 @@ __decorate([
|
|
|
141
139
|
__decorate([
|
|
142
140
|
Type(() => SoleContact)
|
|
143
141
|
], SoleInvoice.prototype, "payer", void 0);
|
|
144
|
-
__decorate([
|
|
145
|
-
Type(() => SoleInvoiceTemplate)
|
|
146
|
-
], SoleInvoice.prototype, "template", void 0);
|
|
147
142
|
__decorate([
|
|
148
143
|
Type(() => BankAccount)
|
|
149
144
|
], SoleInvoice.prototype, "bankAccount", void 0);
|
|
150
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sole-invoice.js","sourceRoot":"","sources":["../../../../../../projects/tt-core/src/lib/models/sole/sole-invoice.ts"],"names":[],"mappings":"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","sourcesContent":["import { SoleInvoice as SoleInvoiceBase } from '../../db/Models/sole/sole-invoice';\nimport { User } from '../user/user';\nimport { SoleBusiness } from './sole-business';\nimport { SoleInvoiceItem } from './sole-invoice-item';\nimport { SoleContact } from './sole-contact';\nimport { SoleInvoiceTemplate } from './sole-invoice-template';\nimport { Type } from 'class-transformer';\nimport { SoleInvoiceStatusesEnum } from '../../db/Enums/sole-invoice-statuses.enum';\nimport { BankAccount } from '../bank/bank-account';\nimport { SoleInvoiceTaxTypeEnum } from '../../db/Enums/sole-invoice-tax-type.enum';\nimport { SoleInvoiceItemCollection } from '../../collections/sole/sole-invoice-item.collection';\nimport { ChartAccounts } from '../chart-accounts/chart-accounts';\nimport { Collection } from '../../collections/collection';\n\nexport class SoleInvoice extends SoleInvoiceBase {\n  static NUMBER_LENGTH = 4;\n\n  @Type(() => Date)\n  dateFrom: Date;\n\n  @Type(() => Date)\n  dateTo: Date;\n\n  @Type(() => User)\n  user: User;\n\n  @Type(() => SoleBusiness)\n  business: SoleBusiness;\n\n  @Type(() => SoleInvoiceItem)\n  items: SoleInvoiceItem[];\n\n  @Type(() => SoleContact)\n  payer: SoleContact;\n\n  @Type(() => SoleInvoiceTemplate)\n  template: SoleInvoiceTemplate;\n\n  @Type(() => BankAccount)\n  bankAccount: BankAccount;\n\n  status: SoleInvoiceStatusesEnum = SoleInvoiceStatusesEnum.DRAFT;\n  taxType: SoleInvoiceTaxTypeEnum = SoleInvoiceTaxTypeEnum.NO_TAX;\n\n  /**\n   * Get items array as collection\n   */\n  get itemsCollection(): SoleInvoiceItemCollection {\n    return new SoleInvoiceItemCollection(this.items);\n  }\n\n  /**\n   * Total price of all items\n   */\n  private get price(): number {\n    return this.itemsCollection.sumBy('totalPrice');\n  }\n\n  /**\n   * Total invoice price without GST\n   */\n  get netPrice(): number {\n    if (this.isTaxInclusive()) {\n      return this.price - this.GSTAmount;\n    }\n\n    return this.price;\n  }\n\n  /**\n   * Total final price (net + GST)\n   */\n  get grossPrice(): number {\n    if (this.isTaxExclusive()) {\n      return this.price + this.GSTAmount;\n    }\n\n    return this.price;\n  }\n\n  /**\n   * Total GST amount\n   */\n  get GSTAmount(): number {\n    switch (this.taxType) {\n      case SoleInvoiceTaxTypeEnum.TAX_INCLUSIVE:\n        return this.inclusiveGSTAmount;\n      case SoleInvoiceTaxTypeEnum.TAX_EXCLUSIVE:\n        return this.exclusiveGSTAmount;\n      case SoleInvoiceTaxTypeEnum.NO_TAX:\n        return 0;\n    }\n  }\n\n  /**\n   * When tax inclusive, GST amount is included to total price\n   */\n  private get inclusiveGSTAmount(): number {\n    const gstPrice = this.itemsCollection.gstPrice;\n\n    return +(gstPrice - (gstPrice / (1 + ChartAccounts.GSTRatio))).toFixed(2);\n  }\n\n  /**\n   * When tax exclusive, GST amount should be added additionally to total price\n   */\n  private get exclusiveGSTAmount(): number {\n    return +(this.itemsCollection.gstPrice * ChartAccounts.GSTRatio).toFixed(2)\n  }\n\n  isDraft(): boolean {\n    return this.status === SoleInvoiceStatusesEnum.DRAFT;\n  }\n\n  isCancelled(): boolean {\n    return this.status === SoleInvoiceStatusesEnum.CANCELED;\n  }\n\n  isPending(): boolean {\n    return this.status === SoleInvoiceStatusesEnum.PENDING;\n  }\n\n  isPaid(): boolean {\n    return this.status === SoleInvoiceStatusesEnum.PAID;\n  }\n\n  isOverdue(): boolean {\n    return this.isPending() && this.dateTo < new Date();\n  }\n\n  isUnpaid(): boolean {\n    return this.isPending() && this.dateTo >= new Date();\n  }\n\n  /**\n   * GST is not available for invoices without taxes\n   */\n  isNoTax(): boolean {\n    return this.taxType === SoleInvoiceTaxTypeEnum.NO_TAX;\n  }\n\n  /**\n   * GST amount is not included in items prices for invoices with tax exclusive,\n   * we should add GST amount additionaly to subtotal price to get total price\n   */\n  isTaxExclusive(): boolean {\n    return this.taxType === SoleInvoiceTaxTypeEnum.TAX_EXCLUSIVE;\n  }\n\n  /**\n   * GST amount already included in items prices for invoices with tax inclusive,\n   * we should subtract GST amount from total price to get subtotal price\n   */\n  isTaxInclusive(): boolean {\n    return this.taxType === SoleInvoiceTaxTypeEnum.TAX_INCLUSIVE;\n  }\n\n  getNumber(): string {\n    return String(this.number).padStart(SoleInvoice.NUMBER_LENGTH, '0');\n  }\n\n  get name(): string {\n    return `invoice-${this.getNumber()}.pdf`;\n  }\n\n  getTransactionsIds(): number[] {\n    return new Collection(this.items).mapBy('transaction.id');\n  }\n}\n"]}
|
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sole-invoice.js","sourceRoot":"","sources":["../../../../../../projects/tt-core/src/lib/models/sole/sole-invoice.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,WAAW,IAAI,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACnF,OAAO,EAAE,IAAI,EAAE,MAAM,SAAS,CAAC;AAC/B,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,IAAI,EAAE,MAAM,mBAAmB,CAAC;AACzC,OAAO,EAAE,uBAAuB,EAAE,MAAM,2CAA2C,CAAC;AACpF,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AACtC,OAAO,EAAE,sBAAsB,EAAE,MAAM,2CAA2C,CAAC;AACnF,OAAO,EAAE,yBAAyB,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC1E,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,MAAM,OAAO,WAAY,SAAQ,eAAe;IAAhD;;QAwBE,WAAM,GAA4B,uBAAuB,CAAC,KAAK,CAAC;QAChE,YAAO,GAA2B,sBAAsB,CAAC,MAAM,CAAC;IA8HlE,CAAC;IA5HC;;OAEG;IACH,IAAI,eAAe;QACjB,OAAO,IAAI,yBAAyB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC;IAED;;OAEG;IACH,IAAY,KAAK;QACf,OAAO,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;IAClD,CAAC;IAED;;OAEG;IACH,IAAI,QAAQ;QACV,IAAI,IAAI,CAAC,cAAc,EAAE,EAAE;YACzB,OAAO,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC;SACpC;QAED,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED;;OAEG;IACH,IAAI,UAAU;QACZ,IAAI,IAAI,CAAC,cAAc,EAAE,EAAE;YACzB,OAAO,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC;SACpC;QAED,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED;;OAEG;IACH,IAAI,SAAS;QACX,QAAQ,IAAI,CAAC,OAAO,EAAE;YACpB,KAAK,sBAAsB,CAAC,aAAa;gBACvC,OAAO,IAAI,CAAC,kBAAkB,CAAC;YACjC,KAAK,sBAAsB,CAAC,aAAa;gBACvC,OAAO,IAAI,CAAC,kBAAkB,CAAC;YACjC,KAAK,sBAAsB,CAAC,MAAM;gBAChC,OAAO,CAAC,CAAC;SACZ;IACH,CAAC;IAED;;OAEG;IACH,IAAY,kBAAkB;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC;QAE/C,OAAO,CAAC,CAAC,QAAQ,GAAG,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC5E,CAAC;IAED;;OAEG;IACH,IAAY,kBAAkB;QAC5B,OAAO,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,QAAQ,GAAG,aAAa,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;IAC7E,CAAC;IAED,OAAO;QACL,OAAO,IAAI,CAAC,MAAM,KAAK,uBAAuB,CAAC,KAAK,CAAC;IACvD,CAAC;IAED,WAAW;QACT,OAAO,IAAI,CAAC,MAAM,KAAK,uBAAuB,CAAC,QAAQ,CAAC;IAC1D,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,KAAK,uBAAuB,CAAC,OAAO,CAAC;IACzD,CAAC;IAED,MAAM;QACJ,OAAO,IAAI,CAAC,MAAM,KAAK,uBAAuB,CAAC,IAAI,CAAC;IACtD,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;IACtD,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,IAAI,EAAE,CAAC;IACvD,CAAC;IAED;;OAEG;IACH,OAAO;QACL,OAAO,IAAI,CAAC,OAAO,KAAK,sBAAsB,CAAC,MAAM,CAAC;IACxD,CAAC;IAED;;;OAGG;IACH,cAAc;QACZ,OAAO,IAAI,CAAC,OAAO,KAAK,sBAAsB,CAAC,aAAa,CAAC;IAC/D,CAAC;IAED;;;OAGG;IACH,cAAc;QACZ,OAAO,IAAI,CAAC,OAAO,KAAK,sBAAsB,CAAC,aAAa,CAAC;IAC/D,CAAC;IAED,SAAS;QACP,OAAO,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,WAAW,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC;IACtE,CAAC;IAED,IAAI,IAAI;QACN,OAAO,WAAW,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3C,CAAC;IAED,kBAAkB;QAChB,OAAO,IAAI,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;IAC5D,CAAC;;AArJM,yBAAa,GAAG,CAAC,CAAC;AAGzB;IADC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;6CACF;AAGf;IADC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;2CACJ;AAGb;IADC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;yCACN;AAGX;IADC,IAAI,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC;6CACF;AAGvB;IADC,IAAI,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC;0CACH;AAGzB;IADC,IAAI,CAAC,GAAG,EAAE,CAAC,WAAW,CAAC;0CACL;AAGnB;IADC,IAAI,CAAC,GAAG,EAAE,CAAC,WAAW,CAAC;gDACC","sourcesContent":["import { SoleInvoice as SoleInvoiceBase } from '../../db/Models/sole/sole-invoice';\nimport { User } from '../user';\nimport { SoleBusiness } from './sole-business';\nimport { SoleInvoiceItem } from './sole-invoice-item';\nimport { SoleContact } from './sole-contact';\nimport { Type } from 'class-transformer';\nimport { SoleInvoiceStatusesEnum } from '../../db/Enums/sole-invoice-statuses.enum';\nimport { BankAccount } from '../bank';\nimport { SoleInvoiceTaxTypeEnum } from '../../db/Enums/sole-invoice-tax-type.enum';\nimport { SoleInvoiceItemCollection, Collection } from '../../collections';\nimport { ChartAccounts } from '../chart-accounts';\n\nexport class SoleInvoice extends SoleInvoiceBase {\n  static NUMBER_LENGTH = 4;\n\n  @Type(() => Date)\n  dateFrom: Date;\n\n  @Type(() => Date)\n  dateTo: Date;\n\n  @Type(() => User)\n  user: User;\n\n  @Type(() => SoleBusiness)\n  business: SoleBusiness;\n\n  @Type(() => SoleInvoiceItem)\n  items: SoleInvoiceItem[];\n\n  @Type(() => SoleContact)\n  payer: SoleContact;\n\n  @Type(() => BankAccount)\n  bankAccount: BankAccount;\n\n  status: SoleInvoiceStatusesEnum = SoleInvoiceStatusesEnum.DRAFT;\n  taxType: SoleInvoiceTaxTypeEnum = SoleInvoiceTaxTypeEnum.NO_TAX;\n\n  /**\n   * Get items array as collection\n   */\n  get itemsCollection(): SoleInvoiceItemCollection {\n    return new SoleInvoiceItemCollection(this.items);\n  }\n\n  /**\n   * Total price of all items\n   */\n  private get price(): number {\n    return this.itemsCollection.sumBy('totalPrice');\n  }\n\n  /**\n   * Total invoice price without GST\n   */\n  get netPrice(): number {\n    if (this.isTaxInclusive()) {\n      return this.price - this.GSTAmount;\n    }\n\n    return this.price;\n  }\n\n  /**\n   * Total final price (net + GST)\n   */\n  get grossPrice(): number {\n    if (this.isTaxExclusive()) {\n      return this.price + this.GSTAmount;\n    }\n\n    return this.price;\n  }\n\n  /**\n   * Total GST amount\n   */\n  get GSTAmount(): number {\n    switch (this.taxType) {\n      case SoleInvoiceTaxTypeEnum.TAX_INCLUSIVE:\n        return this.inclusiveGSTAmount;\n      case SoleInvoiceTaxTypeEnum.TAX_EXCLUSIVE:\n        return this.exclusiveGSTAmount;\n      case SoleInvoiceTaxTypeEnum.NO_TAX:\n        return 0;\n    }\n  }\n\n  /**\n   * When tax inclusive, GST amount is included to total price\n   */\n  private get inclusiveGSTAmount(): number {\n    const gstPrice = this.itemsCollection.gstPrice;\n\n    return +(gstPrice - (gstPrice / (1 + ChartAccounts.GSTRatio))).toFixed(2);\n  }\n\n  /**\n   * When tax exclusive, GST amount should be added additionally to total price\n   */\n  private get exclusiveGSTAmount(): number {\n    return +(this.itemsCollection.gstPrice * ChartAccounts.GSTRatio).toFixed(2)\n  }\n\n  isDraft(): boolean {\n    return this.status === SoleInvoiceStatusesEnum.DRAFT;\n  }\n\n  isCancelled(): boolean {\n    return this.status === SoleInvoiceStatusesEnum.CANCELED;\n  }\n\n  isPending(): boolean {\n    return this.status === SoleInvoiceStatusesEnum.PENDING;\n  }\n\n  isPaid(): boolean {\n    return this.status === SoleInvoiceStatusesEnum.PAID;\n  }\n\n  isOverdue(): boolean {\n    return this.isPending() && this.dateTo < new Date();\n  }\n\n  isUnpaid(): boolean {\n    return this.isPending() && this.dateTo >= new Date();\n  }\n\n  /**\n   * GST is not available for invoices without taxes\n   */\n  isNoTax(): boolean {\n    return this.taxType === SoleInvoiceTaxTypeEnum.NO_TAX;\n  }\n\n  /**\n   * GST amount is not included in items prices for invoices with tax exclusive,\n   * we should add GST amount additionaly to subtotal price to get total price\n   */\n  isTaxExclusive(): boolean {\n    return this.taxType === SoleInvoiceTaxTypeEnum.TAX_EXCLUSIVE;\n  }\n\n  /**\n   * GST amount already included in items prices for invoices with tax inclusive,\n   * we should subtract GST amount from total price to get subtotal price\n   */\n  isTaxInclusive(): boolean {\n    return this.taxType === SoleInvoiceTaxTypeEnum.TAX_INCLUSIVE;\n  }\n\n  getNumber(): string {\n    return String(this.number).padStart(SoleInvoice.NUMBER_LENGTH, '0');\n  }\n\n  get name(): string {\n    return `invoice-${this.getNumber()}.pdf`;\n  }\n\n  getTransactionsIds(): number[] {\n    return new Collection(this.items).mapBy('transaction.id');\n  }\n}\n"]}
|
package/fesm2015/taxtank-core.js
CHANGED
|
@@ -2468,6 +2468,53 @@ __decorate([
|
|
|
2468
2468
|
Type(() => SoleBusinessLossOffsetRule)
|
|
2469
2469
|
], SoleBusinessLoss.prototype, "offsetRule", void 0);
|
|
2470
2470
|
|
|
2471
|
+
var MyAccountHistoryInitiatedByEnum;
|
|
2472
|
+
(function (MyAccountHistoryInitiatedByEnum) {
|
|
2473
|
+
MyAccountHistoryInitiatedByEnum[MyAccountHistoryInitiatedByEnum["OWNER"] = 0] = "OWNER";
|
|
2474
|
+
MyAccountHistoryInitiatedByEnum[MyAccountHistoryInitiatedByEnum["ACCOUNTANT"] = 1] = "ACCOUNTANT";
|
|
2475
|
+
})(MyAccountHistoryInitiatedByEnum || (MyAccountHistoryInitiatedByEnum = {}));
|
|
2476
|
+
|
|
2477
|
+
var MyAccountHistoryStatusEnum;
|
|
2478
|
+
(function (MyAccountHistoryStatusEnum) {
|
|
2479
|
+
MyAccountHistoryStatusEnum[MyAccountHistoryStatusEnum["SUCCESS"] = 0] = "SUCCESS";
|
|
2480
|
+
MyAccountHistoryStatusEnum[MyAccountHistoryStatusEnum["ERROR"] = 1] = "ERROR";
|
|
2481
|
+
})(MyAccountHistoryStatusEnum || (MyAccountHistoryStatusEnum = {}));
|
|
2482
|
+
|
|
2483
|
+
var MyAccountHistoryTypeEnum;
|
|
2484
|
+
(function (MyAccountHistoryTypeEnum) {
|
|
2485
|
+
MyAccountHistoryTypeEnum[MyAccountHistoryTypeEnum["REVIEW"] = 0] = "REVIEW";
|
|
2486
|
+
MyAccountHistoryTypeEnum[MyAccountHistoryTypeEnum["UPGRADE_PLAN"] = 1] = "UPGRADE_PLAN";
|
|
2487
|
+
MyAccountHistoryTypeEnum[MyAccountHistoryTypeEnum["UPLOAD_DOCUMENT"] = 2] = "UPLOAD_DOCUMENT";
|
|
2488
|
+
})(MyAccountHistoryTypeEnum || (MyAccountHistoryTypeEnum = {}));
|
|
2489
|
+
|
|
2490
|
+
class MyAccountHistory {
|
|
2491
|
+
}
|
|
2492
|
+
|
|
2493
|
+
class Occupation extends Occupation$1 {
|
|
2494
|
+
}
|
|
2495
|
+
|
|
2496
|
+
/**
|
|
2497
|
+
* role hierarchy
|
|
2498
|
+
*/
|
|
2499
|
+
const USER_ROLES = {
|
|
2500
|
+
ROLE_FIRM_OWNER: [UserRolesEnum.FIRM_OWNER, UserRolesEnum.FIRM_MANAGER, UserRolesEnum.ACCOUNTANT, UserRolesEnum.ADVISOR],
|
|
2501
|
+
ROLE_FIRM_MANAGER: [UserRolesEnum.FIRM_MANAGER, UserRolesEnum.ACCOUNTANT, UserRolesEnum.ADVISOR],
|
|
2502
|
+
ROLE_EMPLOYEE: [UserRolesEnum.ACCOUNTANT, UserRolesEnum.ADVISOR],
|
|
2503
|
+
ROLE_ACCOUNTANT: [UserRolesEnum.ACCOUNTANT],
|
|
2504
|
+
ROLE_ADVISOR: [UserRolesEnum.ADVISOR],
|
|
2505
|
+
ROLE_CLIENT: [UserRolesEnum.CLIENT],
|
|
2506
|
+
ROLE_USER_SUBSCRIPTION: [UserRolesEnum.SUBSCRIPTION],
|
|
2507
|
+
ROLE_USER_WORK: [UserRolesEnum.WORK_TANK],
|
|
2508
|
+
ROLE_USER_PROPERTY: [UserRolesEnum.PROPERTY_TANK],
|
|
2509
|
+
ROLE_USER_SOLE: [UserRolesEnum.SOLE_TANK],
|
|
2510
|
+
};
|
|
2511
|
+
|
|
2512
|
+
/**
|
|
2513
|
+
* Class with basic information about registering user
|
|
2514
|
+
*/
|
|
2515
|
+
class UserToRegister {
|
|
2516
|
+
}
|
|
2517
|
+
|
|
2471
2518
|
class ChartAccountsHeading extends ChartAccountsHeading$1 {
|
|
2472
2519
|
}
|
|
2473
2520
|
|
|
@@ -3976,55 +4023,6 @@ __decorate([
|
|
|
3976
4023
|
Type(() => SoleInvoice)
|
|
3977
4024
|
], SoleContact.prototype, "invoices", void 0);
|
|
3978
4025
|
|
|
3979
|
-
var SoleInvoiceTemplateTaxTypeEnum;
|
|
3980
|
-
(function (SoleInvoiceTemplateTaxTypeEnum) {
|
|
3981
|
-
SoleInvoiceTemplateTaxTypeEnum[SoleInvoiceTemplateTaxTypeEnum["TAX_EXCLUSIVE"] = 0] = "TAX_EXCLUSIVE";
|
|
3982
|
-
SoleInvoiceTemplateTaxTypeEnum[SoleInvoiceTemplateTaxTypeEnum["TAX_INCLUSIVE"] = 1] = "TAX_INCLUSIVE";
|
|
3983
|
-
SoleInvoiceTemplateTaxTypeEnum[SoleInvoiceTemplateTaxTypeEnum["NO_TAX"] = 2] = "NO_TAX";
|
|
3984
|
-
})(SoleInvoiceTemplateTaxTypeEnum || (SoleInvoiceTemplateTaxTypeEnum = {}));
|
|
3985
|
-
|
|
3986
|
-
/**
|
|
3987
|
-
* The model renamed for more comfortable work because File already exist in JS
|
|
3988
|
-
* @TODO Alex: consider a better name like document
|
|
3989
|
-
*/
|
|
3990
|
-
class AppFile extends File$1 {
|
|
3991
|
-
}
|
|
3992
|
-
|
|
3993
|
-
class SoleInvoiceTemplate extends SoleInvoiceTemplate$1 {
|
|
3994
|
-
constructor() {
|
|
3995
|
-
super(...arguments);
|
|
3996
|
-
/**
|
|
3997
|
-
* Affects to SoleInvoiceItem.isGST flag availability.
|
|
3998
|
-
* When NONE: isGST is unavailable
|
|
3999
|
-
* When EXCLUSIVE: GST amount added additionaly to invoice total price
|
|
4000
|
-
* When INCLUSIVE: GST amount is already included to invoice total price
|
|
4001
|
-
*/
|
|
4002
|
-
this.taxType = SoleInvoiceTemplateTaxTypeEnum.NO_TAX;
|
|
4003
|
-
}
|
|
4004
|
-
/**
|
|
4005
|
-
* Get term duration in milliseconds
|
|
4006
|
-
*/
|
|
4007
|
-
get termTime() {
|
|
4008
|
-
return this.term * 24 * 3600 * 1000;
|
|
4009
|
-
}
|
|
4010
|
-
getPhoto() {
|
|
4011
|
-
var _a;
|
|
4012
|
-
return ((_a = this.file) === null || _a === void 0 ? void 0 : _a.publicUrl) || null;
|
|
4013
|
-
}
|
|
4014
|
-
getPhotoPlaceholder() {
|
|
4015
|
-
return `${this.name[0].toUpperCase()}${this.name[1].toUpperCase()}`;
|
|
4016
|
-
}
|
|
4017
|
-
}
|
|
4018
|
-
__decorate([
|
|
4019
|
-
Type(() => SoleBusiness)
|
|
4020
|
-
], SoleInvoiceTemplate.prototype, "business", void 0);
|
|
4021
|
-
__decorate([
|
|
4022
|
-
Type(() => BankAccount)
|
|
4023
|
-
], SoleInvoiceTemplate.prototype, "bankAccount", void 0);
|
|
4024
|
-
__decorate([
|
|
4025
|
-
Type(() => AppFile)
|
|
4026
|
-
], SoleInvoiceTemplate.prototype, "file", void 0);
|
|
4027
|
-
|
|
4028
4026
|
var SoleInvoiceStatusesEnum;
|
|
4029
4027
|
(function (SoleInvoiceStatusesEnum) {
|
|
4030
4028
|
SoleInvoiceStatusesEnum[SoleInvoiceStatusesEnum["CANCELED"] = 0] = "CANCELED";
|
|
@@ -4040,12 +4038,6 @@ var SoleInvoiceTaxTypeEnum;
|
|
|
4040
4038
|
SoleInvoiceTaxTypeEnum[SoleInvoiceTaxTypeEnum["NO_TAX"] = 2] = "NO_TAX";
|
|
4041
4039
|
})(SoleInvoiceTaxTypeEnum || (SoleInvoiceTaxTypeEnum = {}));
|
|
4042
4040
|
|
|
4043
|
-
class SoleInvoiceItemCollection extends Collection {
|
|
4044
|
-
get gstPrice() {
|
|
4045
|
-
return this.filterBy('isGST', true).sumBy('totalPrice');
|
|
4046
|
-
}
|
|
4047
|
-
}
|
|
4048
|
-
|
|
4049
4041
|
class SoleInvoice extends SoleInvoice$1 {
|
|
4050
4042
|
constructor() {
|
|
4051
4043
|
super(...arguments);
|
|
@@ -4175,13 +4167,42 @@ __decorate([
|
|
|
4175
4167
|
__decorate([
|
|
4176
4168
|
Type(() => SoleContact)
|
|
4177
4169
|
], SoleInvoice.prototype, "payer", void 0);
|
|
4178
|
-
__decorate([
|
|
4179
|
-
Type(() => SoleInvoiceTemplate)
|
|
4180
|
-
], SoleInvoice.prototype, "template", void 0);
|
|
4181
4170
|
__decorate([
|
|
4182
4171
|
Type(() => BankAccount)
|
|
4183
4172
|
], SoleInvoice.prototype, "bankAccount", void 0);
|
|
4184
4173
|
|
|
4174
|
+
var SoleInvoiceTemplateTaxTypeEnum;
|
|
4175
|
+
(function (SoleInvoiceTemplateTaxTypeEnum) {
|
|
4176
|
+
SoleInvoiceTemplateTaxTypeEnum[SoleInvoiceTemplateTaxTypeEnum["TAX_EXCLUSIVE"] = 0] = "TAX_EXCLUSIVE";
|
|
4177
|
+
SoleInvoiceTemplateTaxTypeEnum[SoleInvoiceTemplateTaxTypeEnum["TAX_INCLUSIVE"] = 1] = "TAX_INCLUSIVE";
|
|
4178
|
+
SoleInvoiceTemplateTaxTypeEnum[SoleInvoiceTemplateTaxTypeEnum["NO_TAX"] = 2] = "NO_TAX";
|
|
4179
|
+
})(SoleInvoiceTemplateTaxTypeEnum || (SoleInvoiceTemplateTaxTypeEnum = {}));
|
|
4180
|
+
|
|
4181
|
+
class SoleInvoiceTemplate extends SoleInvoiceTemplate$1 {
|
|
4182
|
+
constructor() {
|
|
4183
|
+
super(...arguments);
|
|
4184
|
+
/**
|
|
4185
|
+
* Affects to SoleInvoiceItem.isGST flag availability.
|
|
4186
|
+
* When NONE: isGST is unavailable
|
|
4187
|
+
* When EXCLUSIVE: GST amount added additionaly to invoice total price
|
|
4188
|
+
* When INCLUSIVE: GST amount is already included to invoice total price
|
|
4189
|
+
*/
|
|
4190
|
+
this.taxType = SoleInvoiceTemplateTaxTypeEnum.NO_TAX;
|
|
4191
|
+
}
|
|
4192
|
+
/**
|
|
4193
|
+
* Get term duration in milliseconds
|
|
4194
|
+
*/
|
|
4195
|
+
get termTime() {
|
|
4196
|
+
return this.term * 24 * 3600 * 1000;
|
|
4197
|
+
}
|
|
4198
|
+
}
|
|
4199
|
+
__decorate([
|
|
4200
|
+
Type(() => SoleBusiness)
|
|
4201
|
+
], SoleInvoiceTemplate.prototype, "business", void 0);
|
|
4202
|
+
__decorate([
|
|
4203
|
+
Type(() => BankAccount)
|
|
4204
|
+
], SoleInvoiceTemplate.prototype, "bankAccount", void 0);
|
|
4205
|
+
|
|
4185
4206
|
/**
|
|
4186
4207
|
* Class contains traveled kilometers and work usage percent in 12 weeks date range
|
|
4187
4208
|
* @TODO Vik: Best period: move this and related logic to backend
|
|
@@ -4427,22 +4448,6 @@ __decorate([
|
|
|
4427
4448
|
Type(() => Date)
|
|
4428
4449
|
], BasReport.prototype, "dateTo", void 0);
|
|
4429
4450
|
|
|
4430
|
-
/**
|
|
4431
|
-
* role hierarchy
|
|
4432
|
-
*/
|
|
4433
|
-
const USER_ROLES = {
|
|
4434
|
-
ROLE_FIRM_OWNER: [UserRolesEnum.FIRM_OWNER, UserRolesEnum.FIRM_MANAGER, UserRolesEnum.ACCOUNTANT, UserRolesEnum.ADVISOR],
|
|
4435
|
-
ROLE_FIRM_MANAGER: [UserRolesEnum.FIRM_MANAGER, UserRolesEnum.ACCOUNTANT, UserRolesEnum.ADVISOR],
|
|
4436
|
-
ROLE_EMPLOYEE: [UserRolesEnum.ACCOUNTANT, UserRolesEnum.ADVISOR],
|
|
4437
|
-
ROLE_ACCOUNTANT: [UserRolesEnum.ACCOUNTANT],
|
|
4438
|
-
ROLE_ADVISOR: [UserRolesEnum.ADVISOR],
|
|
4439
|
-
ROLE_CLIENT: [UserRolesEnum.CLIENT],
|
|
4440
|
-
ROLE_USER_SUBSCRIPTION: [UserRolesEnum.SUBSCRIPTION],
|
|
4441
|
-
ROLE_USER_WORK: [UserRolesEnum.WORK_TANK],
|
|
4442
|
-
ROLE_USER_PROPERTY: [UserRolesEnum.PROPERTY_TANK],
|
|
4443
|
-
ROLE_USER_SOLE: [UserRolesEnum.SOLE_TANK],
|
|
4444
|
-
};
|
|
4445
|
-
|
|
4446
4451
|
class User extends User$1 {
|
|
4447
4452
|
get fullName() {
|
|
4448
4453
|
return `${this.firstName} ${this.lastName}`;
|
|
@@ -4613,7 +4618,7 @@ class PropertyCategory extends PropertyCategory$1 {
|
|
|
4613
4618
|
class PropertyDocument extends PropertyDocument$1 {
|
|
4614
4619
|
constructor() {
|
|
4615
4620
|
super(...arguments);
|
|
4616
|
-
this.type = AssetTypeEnum.
|
|
4621
|
+
this.type = AssetTypeEnum.PROPERTY;
|
|
4617
4622
|
this.entityType = AssetEntityTypeEnum.PROPERTIES;
|
|
4618
4623
|
}
|
|
4619
4624
|
getApiUrlPrefix() {
|
|
@@ -5619,6 +5624,13 @@ class Dictionary {
|
|
|
5619
5624
|
}
|
|
5620
5625
|
}
|
|
5621
5626
|
|
|
5627
|
+
/**
|
|
5628
|
+
* The model renamed for more comfortable work because File already exist in JS
|
|
5629
|
+
* @TODO Alex: consider a better name like document
|
|
5630
|
+
*/
|
|
5631
|
+
class AppFile extends File$1 {
|
|
5632
|
+
}
|
|
5633
|
+
|
|
5622
5634
|
const MONTHS = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec', 'Jan'];
|
|
5623
5635
|
|
|
5624
5636
|
/**
|
|
@@ -6125,37 +6137,6 @@ var ShareFilterOptionsEnum;
|
|
|
6125
6137
|
ShareFilterOptionsEnum[ShareFilterOptionsEnum["SHARED"] = 3] = "SHARED";
|
|
6126
6138
|
})(ShareFilterOptionsEnum || (ShareFilterOptionsEnum = {}));
|
|
6127
6139
|
|
|
6128
|
-
var MyAccountHistoryInitiatedByEnum;
|
|
6129
|
-
(function (MyAccountHistoryInitiatedByEnum) {
|
|
6130
|
-
MyAccountHistoryInitiatedByEnum[MyAccountHistoryInitiatedByEnum["OWNER"] = 0] = "OWNER";
|
|
6131
|
-
MyAccountHistoryInitiatedByEnum[MyAccountHistoryInitiatedByEnum["ACCOUNTANT"] = 1] = "ACCOUNTANT";
|
|
6132
|
-
})(MyAccountHistoryInitiatedByEnum || (MyAccountHistoryInitiatedByEnum = {}));
|
|
6133
|
-
|
|
6134
|
-
var MyAccountHistoryStatusEnum;
|
|
6135
|
-
(function (MyAccountHistoryStatusEnum) {
|
|
6136
|
-
MyAccountHistoryStatusEnum[MyAccountHistoryStatusEnum["SUCCESS"] = 0] = "SUCCESS";
|
|
6137
|
-
MyAccountHistoryStatusEnum[MyAccountHistoryStatusEnum["ERROR"] = 1] = "ERROR";
|
|
6138
|
-
})(MyAccountHistoryStatusEnum || (MyAccountHistoryStatusEnum = {}));
|
|
6139
|
-
|
|
6140
|
-
var MyAccountHistoryTypeEnum;
|
|
6141
|
-
(function (MyAccountHistoryTypeEnum) {
|
|
6142
|
-
MyAccountHistoryTypeEnum[MyAccountHistoryTypeEnum["REVIEW"] = 0] = "REVIEW";
|
|
6143
|
-
MyAccountHistoryTypeEnum[MyAccountHistoryTypeEnum["UPGRADE_PLAN"] = 1] = "UPGRADE_PLAN";
|
|
6144
|
-
MyAccountHistoryTypeEnum[MyAccountHistoryTypeEnum["UPLOAD_DOCUMENT"] = 2] = "UPLOAD_DOCUMENT";
|
|
6145
|
-
})(MyAccountHistoryTypeEnum || (MyAccountHistoryTypeEnum = {}));
|
|
6146
|
-
|
|
6147
|
-
class MyAccountHistory {
|
|
6148
|
-
}
|
|
6149
|
-
|
|
6150
|
-
class Occupation extends Occupation$1 {
|
|
6151
|
-
}
|
|
6152
|
-
|
|
6153
|
-
/**
|
|
6154
|
-
* Class with basic information about registering user
|
|
6155
|
-
*/
|
|
6156
|
-
class UserToRegister {
|
|
6157
|
-
}
|
|
6158
|
-
|
|
6159
6140
|
class MessageCollection extends Collection {
|
|
6160
6141
|
getFirstUnreadMessage(user) {
|
|
6161
6142
|
return this.items.find((message) => {
|
|
@@ -7070,6 +7051,12 @@ class SoleBusinessLossesCollection extends Collection {
|
|
|
7070
7051
|
}
|
|
7071
7052
|
}
|
|
7072
7053
|
|
|
7054
|
+
class SoleInvoiceItemCollection extends Collection {
|
|
7055
|
+
get gstPrice() {
|
|
7056
|
+
return this.filterBy('isGST', true).sumBy('totalPrice');
|
|
7057
|
+
}
|
|
7058
|
+
}
|
|
7059
|
+
|
|
7073
7060
|
class SoleInvoiceCollection extends Collection {
|
|
7074
7061
|
getOverdue() {
|
|
7075
7062
|
return this.filter((invoice) => invoice.isOverdue());
|
|
@@ -16170,27 +16157,6 @@ class SoleBusinessLossForm extends AbstractForm {
|
|
|
16170
16157
|
}
|
|
16171
16158
|
}
|
|
16172
16159
|
|
|
16173
|
-
const phonePattern = /^(((\s*)?([- ()]?\d[- ()]?){0,30}(\s*)?)|)$/;
|
|
16174
|
-
/**
|
|
16175
|
-
* Validator for phone number
|
|
16176
|
-
* Allowed special symbols"-", "(", ")"
|
|
16177
|
-
*/
|
|
16178
|
-
function phoneNumberValidator() {
|
|
16179
|
-
return (control) => {
|
|
16180
|
-
return phonePattern.test(control.value) ? null : { phoneInvalid: true };
|
|
16181
|
-
};
|
|
16182
|
-
}
|
|
16183
|
-
|
|
16184
|
-
class PhoneForm extends AbstractForm {
|
|
16185
|
-
constructor(phone = plainToClass(Phone, {})) {
|
|
16186
|
-
super({
|
|
16187
|
-
type: new FormControl(phone.type, Validators.required),
|
|
16188
|
-
country: new FormControl(phone.country, Validators.required),
|
|
16189
|
-
number: new FormControl(phone.number, [Validators.required, phoneNumberValidator()])
|
|
16190
|
-
}, phone);
|
|
16191
|
-
}
|
|
16192
|
-
}
|
|
16193
|
-
|
|
16194
16160
|
class SoleContactForm extends AbstractForm {
|
|
16195
16161
|
constructor(contact = plainToClass(SoleContact, {})) {
|
|
16196
16162
|
super({
|
|
@@ -16199,7 +16165,7 @@ class SoleContactForm extends AbstractForm {
|
|
|
16199
16165
|
firstName: new FormControl(contact.firstName, Validators.required),
|
|
16200
16166
|
lastName: new FormControl(contact.lastName, Validators.required),
|
|
16201
16167
|
email: new FormControl(contact.email, [Validators.required, Validators.email]),
|
|
16202
|
-
phone: new
|
|
16168
|
+
phone: new FormControl(contact.phone),
|
|
16203
16169
|
address: new AddressForm(contact.address || plainToClass(Address, {}))
|
|
16204
16170
|
}, contact);
|
|
16205
16171
|
}
|
|
@@ -16409,7 +16375,6 @@ class SoleInvoiceTemplateForm extends AbstractForm {
|
|
|
16409
16375
|
// 32767 - max value because we have small int data type in database for this field, but we don't have actual max validation for term
|
|
16410
16376
|
term: new FormControl(invoiceTemplate.term, [Validators.required, Validators.min(0), Validators.max(32767)]),
|
|
16411
16377
|
bankAccount: new FormControl(invoiceTemplate.bankAccount, [Validators.required]),
|
|
16412
|
-
file: new FormControl(invoiceTemplate.file)
|
|
16413
16378
|
}, invoiceTemplate);
|
|
16414
16379
|
}
|
|
16415
16380
|
}
|
|
@@ -16680,6 +16645,29 @@ class LoginForm extends AbstractForm {
|
|
|
16680
16645
|
}
|
|
16681
16646
|
}
|
|
16682
16647
|
|
|
16648
|
+
const phonePattern = /^(((\s*)?([- ()]?\d[- ()]?){0,30}(\s*)?)|)$/;
|
|
16649
|
+
/**
|
|
16650
|
+
* Validator for phone number
|
|
16651
|
+
* Allowed special symbols"-", "(", ")"
|
|
16652
|
+
*/
|
|
16653
|
+
function phoneNumberValidator() {
|
|
16654
|
+
return (control) => {
|
|
16655
|
+
return phonePattern.test(control.value) ? null : { phoneInvalid: true };
|
|
16656
|
+
};
|
|
16657
|
+
}
|
|
16658
|
+
|
|
16659
|
+
class PhoneForm extends AbstractForm {
|
|
16660
|
+
constructor(
|
|
16661
|
+
// no default value because this form is always built-in, so phone passed from parent form
|
|
16662
|
+
phone) {
|
|
16663
|
+
super({
|
|
16664
|
+
type: new FormControl((phone === null || phone === void 0 ? void 0 : phone.type) || PhoneTypeEnum.MOBILE, Validators.required),
|
|
16665
|
+
country: new FormControl((phone === null || phone === void 0 ? void 0 : phone.country) || Country.australia, Validators.required),
|
|
16666
|
+
number: new FormControl((phone === null || phone === void 0 ? void 0 : phone.number) || null, [Validators.required, phoneNumberValidator()])
|
|
16667
|
+
}, phone);
|
|
16668
|
+
}
|
|
16669
|
+
}
|
|
16670
|
+
|
|
16683
16671
|
// @TODO Alex: Create a model and handle request fields via class-transformer
|
|
16684
16672
|
class PasswordForm extends AbstractForm {
|
|
16685
16673
|
constructor() {
|