@unifylib/ui-lib 1.1.4 → 1.1.6
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/esm2022/lib/base-model/field-info.mjs +2 -1
- package/esm2022/lib/components/action-confirmation/action-confirmation.component.mjs +3 -3
- package/esm2022/lib/components/activity-report-form/activity-report-form.component.mjs +2 -2
- package/esm2022/lib/components/advanced-filter/filter-builder/filter-builder.component.mjs +23 -4
- package/esm2022/lib/components/base-form/base-form.component.mjs +2 -2
- package/esm2022/lib/components/base-form-canvas/base-form-canvas.component.mjs +3 -3
- package/esm2022/lib/components/base-input-dialog/base-input-dialog.component.mjs +2 -2
- package/esm2022/lib/components/base-table/base-table.component.mjs +48 -5
- package/esm2022/lib/components/editable-base-table/editable-base-table.component.mjs +2 -2
- package/esm2022/lib/components/item-line-editor/item-line-editor.component.mjs +2 -2
- package/esm2022/lib/components/paginator/paginator.component.mjs +49 -8
- package/esm2022/lib/components/rejection-comment/action-comment.component.mjs +88 -0
- package/esm2022/lib/components/report-form/report-form.component.mjs +2 -2
- package/esm2022/lib/components/title-bar/title-bar.component.mjs +6 -3
- package/fesm2022/iq-ui-lib.mjs +143 -35
- package/fesm2022/iq-ui-lib.mjs.map +1 -1
- package/fesm2022/unifylib-ui-lib.mjs +143 -35
- package/fesm2022/unifylib-ui-lib.mjs.map +1 -1
- package/lib/base-model/field-info.d.ts +1 -0
- package/lib/components/advanced-filter/filter-builder/filter-builder.component.d.ts +5 -1
- package/lib/components/base-table/base-table.component.d.ts +9 -0
- package/lib/components/paginator/paginator.component.d.ts +3 -0
- package/lib/components/rejection-comment/action-comment.component.d.ts +24 -0
- package/lib/components/title-bar/title-bar.component.d.ts +2 -1
- package/package.json +2 -4
|
@@ -56,7 +56,7 @@ export class ItemLineEditorComponent {
|
|
|
56
56
|
: `${this.pageInfo.labelsSection}.${configuredKey}`;
|
|
57
57
|
}
|
|
58
58
|
blankItem() {
|
|
59
|
-
return { gtinCode: '', description: '', unitPrice:
|
|
59
|
+
return { gtinCode: '', description: '', unitPrice: 0, qty: 1, discount: 0, total: 0 };
|
|
60
60
|
}
|
|
61
61
|
ngOnChanges(changes) {
|
|
62
62
|
if (changes['items'] && changes['items'].currentValue) {
|
|
@@ -296,4 +296,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
296
296
|
}], editStateChange: [{
|
|
297
297
|
type: Output
|
|
298
298
|
}] } });
|
|
299
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"item-line-editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/invoiceq/ui-lib/src/lib/components/item-line-editor/item-line-editor.component.ts","../../../../../../../projects/invoiceq/ui-lib/src/lib/components/item-line-editor/item-line-editor.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,KAAK,EAAa,MAAM,EAAgB,MAAM,eAAe,CAAC;AAC/F,OAAO,EAAkB,WAAW,EAAC,MAAM,gBAAgB,CAAC;AAC5D,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAC,eAAe,EAAC,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAC,aAAa,EAAC,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAC,uBAAuB,EAAC,MAAM,gDAAgD,CAAC;AAGvF,OAAO,EAAC,eAAe,EAAC,MAAM,qBAAqB,CAAC;;;;;;AAmBpD,MAAM,OAAO,uBAAuB;IAhBpC;QAyBW,aAAQ,GAAY,IAAI,CAAC;QACzB,gBAAW,GAAY,IAAI,CAAC;QAC5B,aAAQ,GAAY,IAAI,CAAC;QAEzB,WAAM,GAAgB,EAAE,CAAC;QAKzB,UAAK,GAAe,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QAEtC,gBAAW,GAAG,IAAI,YAAY,EAAc,CAAC;QAC7C,cAAS,GAAG,IAAI,YAAY,EAAgC,CAAC;QAC7D,gBAAW,GAAG,IAAI,YAAY,EAAqB,CAAC;QACpD,iBAAY,GAAG,IAAI,YAAY,EAAc,CAAC;QAC9C,oBAAe,GAAG,IAAI,YAAY,EAAuC,CAAC;QACpF,aAAQ,GAA8B,EAAE,CAAC;QAEzC,YAAO,GAAc,CAAC,IAAI,CAAC,CAAC;QAC5B,gBAAW,GAAY,KAAK,CAAA;KA0P7B;IAxPC,IAAI,YAAY;QACd,OAAO,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;IAC1F,CAAC;IAED,IAAI,qBAAqB;QACvB,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAO,KAAK,CAAC;QAClD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC9C,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YAC7B,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,GAAG,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC;gBAC1C,OAAO,IAAI,CAAC;YACd,CAAC;QACH,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,SAAS;QACX,OAAO,CAAC,IAAI,CAAC,qBAAqB,CAAC;IACrC,CAAC;IAED,OAAO,CAAC,KAAa;QACnB,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,CAAC;QACnC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC;YAAE,OAAO,IAAI,CAAC;QACxC,OAAO,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC;IAC5B,CAAC;IAED,OAAO,CAAC,KAAgB;QACtB,MAAM,aAAa,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC;QACjE,OAAO,aAAa,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC;YAC1D,CAAC,CAAC,aAAa;YACf,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,IAAI,aAAa,EAAE,CAAC;IACxD,CAAC;IAEO,SAAS;QACf,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,WAAW,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;IACpG,CAAC;IACD,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,OAAO,CAAC,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC,YAAY,EAAE,CAAC;YACtD,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC;YACtC,IAAI,CAAC,WAAW,GAAG,GAAG,IAAI,CAAC,CAAC;YAC5B,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC;gBACjC,IAAI,CAAC,QAAQ,GAAG,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;gBAC/C,IAAI,CAAC,OAAO,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;YAC/D,CAAC;iBAAM,CAAC;gBACN,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,EAAE,MAAM,IAAI,CAAC,CAAC;gBAGzC,IAAI,CAAC,IAAI,CAAC,QAAQ;oBAAE,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;gBACvC,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,GAAG,EAAE,CAAC;oBAC/B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;gBAC9C,CAAC;qBAAM,CAAC;oBACN,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,GAAG;wBAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;gBACnE,CAAC;gBAGD,IAAI,CAAC,IAAI,CAAC,OAAO;oBAAE,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;gBACrC,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,GAAG,EAAE,CAAC;oBAC9B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;gBAC5C,CAAC;qBAAM,CAAC;oBACN,KAAK,IAAI,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;wBAC/C,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;oBACzB,CAAC;gBACH,CAAC;gBAGD,IAAI,MAAM,KAAK,CAAC,IAAI,GAAG,GAAG,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,SAAS,EAAE,CAAC;oBAC7D,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;gBACzB,CAAC;YACH,CAAC;YACD,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC;QACD,IAAI,OAAO,CAAC,QAAQ,CAAC,IAAI,OAAO,CAAC,QAAQ,CAAC,CAAC,YAAY,EAAE,CAAC;YACxD,IAAI,CAAC,kBAAkB,GAAG,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAC,GAAG,CAAC,EAAC,CAAC,CAAC,CAAC;QACnE,CAAC;IACH,CAAC;IAED,aAAa,CAAC,IAAe,EAAE,KAAa;QAC1C,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QAE1C,IAAI,YAAY,EAAE,CAAC;YAEjB,MAAM,QAAQ,GAAG,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YACxE,YAAY,CAAC,aAAa,CAAC;gBACzB,GAAG,QAAQ;gBACX,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC;aAC9B,CAAC,CAAC;YAEH,YAAY,CAAC,sBAAsB,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;QAC5D,CAAC;QAED,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC;YACH,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE;gBAC5C,IAAI,CAAC,KAAK,KAAK;oBAAE,OAAO,EAAE,CAAC;gBAC3B,MAAM,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC;gBAC/C,MAAM,EAAE,GAAG,MAAM,CAAC,CAAC,EAAE,SAAS,IAAI,CAAC,CAAC,CAAC;gBACrC,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC;gBAC9B,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,EAAE,QAAQ,IAAI,CAAC,CAAC,CAAC;gBACtC,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;gBACzC,OAAO,EAAE,GAAG,EAAE,EAAE,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC;YAChC,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACtC,CAAC;QAAC,OAAO,EAAE,EAAE,CAAC;QAEd,CAAC;QACD,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED,UAAU;QACR,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QAClC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC9B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAExB,IAAI,CAAC,yBAAyB,EAAE,CAAC;QACjC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QACvC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;QAC3E,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED,OAAO,CAAC,KAAa;QAEnB,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,CAAC;QACnC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC;YAE9C,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,EAAE,CAAC,CAAC;YAC5D,OAAO;QACT,CAAC;QACD,MAAM,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,CAAC,CAAC;YAAE,OAAO;QACf,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,EAAE,CAAC;QAE/D,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;QAE5B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QAC7B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QACvC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACxD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;QACrD,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED,UAAU,CAAC,KAAa;QACtB,IAAI,KAAK,GAAG,CAAC,IAAI,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM;YAAE,OAAO;QACpD,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAC5B,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAC/B,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAE9B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QACvC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QACjC,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QAChC,IAAI,CAAC,QAAQ,GAAG,CAAC,SAAS,CAAC,CAAC;QAC5B,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,CAAC;QACtB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QACvC,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED,gBAAgB,CAAC,KAAa;QAC5B,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACtC,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAEjC,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;QACrC,MAAM,GAAG,GAAG,CAAC,SAAS,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,GAAG,GAAG,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC;QACzE,IAAI,CAAC,GAAG;YAAE,OAAO,IAAI,CAAC;QACtB,MAAM,GAAG,GAAQ,EAAE,GAAG,GAAG,EAAE,CAAC;QAC5B,GAAG,CAAC,SAAS,GAAG,GAAG,CAAC,SAAS,KAAK,IAAI,IAAI,GAAG,CAAC,SAAS,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC9F,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,KAAK,IAAI,IAAI,GAAG,CAAC,GAAG,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACtE,GAAG,CAAC,QAAQ,GAAG,GAAG,CAAC,QAAQ,KAAK,IAAI,IAAI,GAAG,CAAC,QAAQ,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC1F,OAAO,GAAG,CAAC;IACb,CAAC;IAED,aAAa,CAAC,KAAa;QACzB,MAAM,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QACzC,IAAI,CAAC,GAAG;YAAE,OAAO,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,KAAK,IAAI,CAAC,CAAC,CAAC;QACvD,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,SAAS,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,CAAC,CAAC,CAAC;IAClF,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE;YACrC,MAAM,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;YACnC,MAAM,EAAE,GAAG,MAAM,CAAC,CAAC,EAAE,SAAS,IAAI,CAAC,CAAC,CAAC;YACrC,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC;YAC9B,OAAO,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;QACtB,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE;YACrC,MAAM,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;YACnC,OAAO,CAAC,GAAG,MAAM,CAAC,CAAC,EAAE,QAAQ,IAAI,CAAC,CAAC,CAAC;QACtC,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACxE,CAAC;IAED,YAAY,CAAC,KAAa,EAAE,KAAU;QACpC,OAAO,KAAK,CAAC;IACf,CAAC;IAED,OAAO,CAAC,KAAa;QACnB,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,yBAAyB,EAAE,CAAC;QACjC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;IACtD,CAAC;IAEO,UAAU;QAChB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;YACrB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,QAAQ,EAAE,IAAI,CAAC,aAAa;YAC5B,UAAU,EAAE,IAAI,CAAC,UAAU;SAC5B,CAAC,CAAC;IACL,CAAC;IAEO,iBAAiB,CAAC,KAAc;QACtC,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;IAC1E,CAAC;IAEO,yBAAyB;QAC/B,IAAI,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,CAAC;YAC9D,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAC,GAAG,CAAC,EAAC,CAAC,CAAC,CAAC;QAC3D,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;QAChC,CAAC;IACH,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC3C,CAAC;IAEO,iBAAiB,CAAC,KAAa;QACrC,OAAO,CAAC,OAAwB,EAAE,EAAE;YAClC,MAAM,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;YACzC,IAAI,CAAC,GAAG;gBAAE,OAAO,IAAI,CAAC;YAEtB,MAAM,mBAAmB,GAAG,CAAC,GAAG,CAAC,SAAS,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;YAClE,MAAM,QAAQ,GAAG,GAAG,CAAC,QAAQ,IAAI,IAAI,CAAC;YAEtC,IAAI,QAAQ,IAAI,IAAI,IAAI,QAAQ,GAAG,mBAAmB,EAAE,CAAC;gBACvD,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC;YACnC,CAAC;YAED,OAAO,IAAI,CAAC;QACd,CAAC,CAAC;IACJ,CAAC;+GApRU,uBAAuB;mGAAvB,uBAAuB,4mBC3BpC,qyHAsGA,wxDDtFI,YAAY,+YACZ,WAAW,8BACX,eAAe,2NACf,aAAa,oLACb,uBAAuB,kZACvB,eAAe;;4FAMN,uBAAuB;kBAhBnC,SAAS;+BACE,sBAAsB,cAEpB,IAAI,WACP;wBACP,YAAY;wBACZ,WAAW;wBACX,eAAe;wBACf,aAAa;wBACb,uBAAuB;wBACvB,eAAe;qBAChB;8BAMQ,eAAe;sBAAvB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBAKG,KAAK;sBAAb,KAAK;gBAEI,WAAW;sBAApB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,YAAY;sBAArB,MAAM;gBACG,eAAe;sBAAxB,MAAM","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, Output, SimpleChanges} from '@angular/core';\r\nimport {AbstractControl, FormsModule} from \"@angular/forms\";\r\nimport {CommonModule} from \"@angular/common\";\r\nimport {MatButtonModule} from \"@angular/material/button\";\r\nimport {MatIconModule} from \"@angular/material/icon\";\r\nimport {BaseFormCanvasComponent} from \"../base-form-canvas/base-form-canvas.component\";\r\nimport {FieldInfo, EMPTY_PAGE_INFO, PageInfo} from \"../../base-model\";\r\nimport {FormGroup} from \"@angular/forms\";\r\nimport {TranslateModule} from \"@ngx-translate/core\";\r\nimport {LineItem} from \"../../base-model/line-item.model\";\r\nimport {ItemsTotal} from \"../../base-model/items-total.model\";\r\n@Component({\r\n  selector: 'app-item-line-editor',\r\n  templateUrl: './item-line-editor.component.html',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    MatButtonModule,\r\n    MatIconModule,\r\n    BaseFormCanvasComponent,\r\n    TranslateModule\r\n  ],\r\n  styleUrls: ['./item-line-editor.component.scss']\r\n})\r\n\r\n\r\nexport class ItemLineEditorComponent implements OnChanges {\r\n  @Input() noDataFoundIcon: string;\r\n  @Input() noDataFoundTitle: string;\r\n  @Input() noDataFoundSubtitle: string;\r\n\r\n  @Input() pageInfo: PageInfo;\r\n  @Input() columnHeaderWidths: string[];\r\n  @Input() title: string;\r\n  @Input() subtitle: string;\r\n  @Input() allowAdd: boolean = true;\r\n  @Input() allowDelete: boolean = true;\r\n  @Input() editable: boolean = true;\r\n  @Input() currency: string;\r\n  @Input() fields: FieldInfo[] = [];\r\n\r\n  private baseFieldsSnapshot: FieldInfo[] | undefined;\r\n\r\n\r\n  @Input() items: LineItem[] = [this.blankItem()];\r\n\r\n  @Output() itemsChange = new EventEmitter<LineItem[]>();\r\n  @Output() itemSaved = new EventEmitter<{ index: number, item: any }>();\r\n  @Output() itemDeleted = new EventEmitter<{ index: number }>();\r\n  @Output() totalsChange = new EventEmitter<ItemsTotal>();\r\n  @Output() editStateChange = new EventEmitter<{ index: number, editing: boolean }>();\r\n  formRefs: (FormGroup | undefined)[] = [];\r\n\r\n  editing: boolean[] = [true];\r\n  noDataFound: boolean = false\r\n\r\n  get headerFields(): FieldInfo[] {\r\n    return (this.fields || []).filter(f => f.visible && f.row === 1 && f.type !== 'spacer');\r\n  }\r\n\r\n  get hasInvalidEditingForm(): boolean {\r\n    if (!this.formRefs || !this.editing) return false;\r\n    for (let i = 0; i < this.formRefs.length; i++) {\r\n      const frm = this.formRefs[i];\r\n      if (this.editing[i] && frm && frm.invalid) {\r\n        return true;\r\n      }\r\n    }\r\n    return false;\r\n  }\r\n\r\n  get canAddNew(): boolean {\r\n    return !this.hasInvalidEditingForm;\r\n  }\r\n\r\n  canSave(index: number): boolean {\r\n    const frm = this.formRefs?.[index];\r\n    if (!this.editing?.[index]) return true;\r\n    return !!frm && frm.valid;\r\n  }\r\n\r\n  labelOf(field: FieldInfo): string {\r\n    const configuredKey = field.label ? field.label : field.property;\r\n    return configuredKey.startsWith(this.pageInfo.labelsSection)\r\n      ? configuredKey\r\n      : `${this.pageInfo.labelsSection}.${configuredKey}`;\r\n  }\r\n\r\n  private blankItem() {\r\n    return { gtinCode: '', description: '', unitPrice: null, qty: null, discount: null, total: null };\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['items'] && changes['items'].currentValue) {\r\n      const len = (this.items || []).length;\r\n      this.noDataFound = len <= 0;\r\n      if (changes['items'].firstChange) {\r\n        this.formRefs = new Array(len).fill(undefined);\r\n        this.editing = len > 0 ? new Array(len).fill(false) : [true];\r\n      } else {\r\n        const oldLen = this.editing?.length || 0;\r\n\r\n\r\n        if (!this.formRefs) this.formRefs = [];\r\n        if (this.formRefs.length > len) {\r\n          this.formRefs = this.formRefs.slice(0, len);\r\n        } else {\r\n          while (this.formRefs.length < len) this.formRefs.push(undefined);\r\n        }\r\n\r\n\r\n        if (!this.editing) this.editing = [];\r\n        if (this.editing.length > len) {\r\n          this.editing = this.editing.slice(0, len);\r\n        } else {\r\n          for (let i = this.editing.length; i < len; i++) {\r\n            this.editing[i] = true;\r\n          }\r\n        }\r\n\r\n\r\n        if (oldLen === 0 && len > 0 && this.editing[0] === undefined) {\r\n          this.editing[0] = true;\r\n        }\r\n      }\r\n      this.emitTotals();\r\n    }\r\n    if (changes['fields'] && changes['fields'].currentValue) {\r\n      this.baseFieldsSnapshot = (this.fields || []).map(f => ({...f}));\r\n    }\r\n  }\r\n\r\n  onFormUpdated(form: FormGroup, index: number) {\r\n    const discountCtrl = form.get('discount');\r\n\r\n    if (discountCtrl) {\r\n\r\n      const existing = discountCtrl.validator ? [discountCtrl.validator] : [];\r\n      discountCtrl.setValidators([\r\n        ...existing,\r\n        this.discountValidator(index)\r\n      ]);\r\n\r\n      discountCtrl.updateValueAndValidity({ emitEvent: false });\r\n    }\r\n\r\n    this.formRefs[index] = form;\r\n    try {\r\n      const emittedItems = this.items.map((it, i) => {\r\n        if (i !== index) return it;\r\n        const v = this.getCurrentValues(i) || it || {};\r\n        const up = Number(v?.unitPrice || 0);\r\n        const q = Number(v?.qty || 0);\r\n        const disc = Number(v?.discount || 0);\r\n        const total = Math.max(0, up * q - disc);\r\n        return { ...it, ...v, total };\r\n      });\r\n      this.itemsChange.emit(emittedItems);\r\n    } catch (_e) {\r\n\r\n    }\r\n    this.emitTotals();\r\n  }\r\n\r\n  addNewItem() {\r\n    this.items.push(this.blankItem());\r\n    this.formRefs.push(undefined);\r\n    this.editing.push(true);\r\n\r\n    this.restoreFieldsFromSnapshot();\r\n    this.itemsChange.emit([...this.items]);\r\n    this.editStateChange.emit({ index: this.items.length - 1, editing: true });\r\n    this.emitTotals();\r\n  }\r\n\r\n  saveRow(index: number) {\r\n\r\n    const frm = this.formRefs?.[index];\r\n    if (this.editing[index] && frm && frm.invalid) {\r\n\r\n      Object.values(frm.controls).forEach(c => c.markAsTouched());\r\n      return;\r\n    }\r\n    const v = this.getCurrentValues(index);\r\n    if (!v) return;\r\n    this.items[index] = { ...v, total: this.calcLineTotal(index) };\r\n\r\n    this.editing[index] = false;\r\n\r\n    this.setFieldsReadonly(true);\r\n    this.itemsChange.emit([...this.items]);\r\n    this.itemSaved.emit({ index, item: this.items[index] });\r\n    this.editStateChange.emit({ index, editing: false });\r\n    this.emitTotals();\r\n  }\r\n\r\n  deleteItem(index: number) {\r\n    if (index < 0 || index >= this.items.length) return;\r\n    this.items.splice(index, 1);\r\n    this.formRefs.splice(index, 1);\r\n    this.editing.splice(index, 1);\r\n\r\n    this.itemsChange.emit([...this.items]);\r\n    this.itemDeleted.emit({ index });\r\n    this.emitTotals();\r\n  }\r\n\r\n  clearAll() {\r\n    this.items = [this.blankItem()];\r\n    this.formRefs = [undefined];\r\n    this.editing = [true];\r\n    this.itemsChange.emit([...this.items]);\r\n    this.emitTotals();\r\n  }\r\n\r\n  getCurrentValues(index: number) {\r\n    const isEditing = this.editing[index];\r\n    const frm = this.formRefs[index];\r\n\r\n    const base = this.items[index] || {};\r\n    const src = (isEditing && frm) ? { ...base, ...frm.value } : { ...base };\r\n    if (!src) return null;\r\n    const val: any = { ...src };\r\n    val.unitPrice = val.unitPrice === null || val.unitPrice === '' ? null : Number(val.unitPrice);\r\n    val.qty = val.qty === null || val.qty === '' ? null : Number(val.qty);\r\n    val.discount = val.discount === null || val.discount === '' ? null : Number(val.discount);\r\n    return val;\r\n  }\r\n\r\n  calcLineTotal(index: number): number {\r\n    const val = this.getCurrentValues(index);\r\n    if (!val) return Number(this.items[index]?.total || 0);\r\n    return Math.max(0, (val.unitPrice || 0) * (val.qty || 0) - (val.discount || 0));\r\n  }\r\n\r\n  get subtotal(): number {\r\n    return this.items.reduce((s, _it, i) => {\r\n      const v = this.getCurrentValues(i);\r\n      const up = Number(v?.unitPrice || 0);\r\n      const q = Number(v?.qty || 0);\r\n      return s + (up * q);\r\n    }, 0);\r\n  }\r\n\r\n  get discountTotal(): number {\r\n    return this.items.reduce((s, _it, i) => {\r\n      const v = this.getCurrentValues(i);\r\n      return s + Number(v?.discount || 0);\r\n    }, 0);\r\n  }\r\n\r\n  get grandTotal(): number {\r\n    return this.items.reduce((s, _it, i) => s + this.calcLineTotal(i), 0);\r\n  }\r\n\r\n  trackByIndex(index: number, _item: any) {\r\n    return index;\r\n  }\r\n\r\n  editRow(index: number) {\r\n    this.editing[index] = true;\r\n    this.restoreFieldsFromSnapshot();\r\n    this.editStateChange.emit({ index, editing: true });\r\n  }\r\n\r\n  private emitTotals() {\r\n    this.totalsChange.emit({\r\n      subtotal: this.subtotal,\r\n      discount: this.discountTotal,\r\n      grandTotal: this.grandTotal\r\n    });\r\n  }\r\n\r\n  private setFieldsReadonly(state: boolean) {\r\n    this.fields = (this.fields || []).map(f => ({ ...f, readonly: state }));\r\n  }\r\n\r\n  private restoreFieldsFromSnapshot() {\r\n    if (this.baseFieldsSnapshot && this.baseFieldsSnapshot.length) {\r\n      this.fields = this.baseFieldsSnapshot.map(f => ({...f}));\r\n    } else {\r\n      this.setFieldsReadonly(false);\r\n    }\r\n  }\r\n\r\n  get gridTemplate() {\r\n    return this.columnHeaderWidths.join(' ');\r\n  }\r\n\r\n  private discountValidator(index: number) {\r\n    return (control: AbstractControl) => {\r\n      const val = this.getCurrentValues(index);\r\n      if (!val) return null;\r\n\r\n      const totalBeforeDiscount = (val.unitPrice ?? 0) * (val.qty ?? 0);\r\n      const discount = val.discount ?? null;\r\n\r\n      if (discount != null && discount > totalBeforeDiscount) {\r\n        return { discountTooHigh: true };\r\n      }\r\n\r\n      return null;\r\n    };\r\n  }\r\n\r\n}\r\n","<div class=\"item-line-editor\">\r\n\r\n  <h3 class=\"title\">{{ title | translate }}</h3>\r\n  <p class=\"subtitle\">{{ subtitle | translate }}</p>\r\n\r\n  <div class=\"table-header\" [ngStyle]=\"{ 'grid-template-columns': gridTemplate }\">\r\n    <ng-container *ngFor=\"let f of headerFields; let idx = index\">\r\n      <div class=\"col\">\r\n        {{ labelOf(f)  | translate }}\r\n      </div>\r\n    </ng-container>\r\n  </div>\r\n  @if (!noDataFound) {\r\n    <div class=\"table-body\" *ngFor=\"let it of items; let i = index; trackBy: trackByIndex\">\r\n\r\n      <div class=\"table-row\">\r\n\r\n        <div class=\"row-inputs\">\r\n          <app-base-form-canvas\r\n            [pageInfo]=\"pageInfo\"\r\n            [fields]=\"fields\"\r\n            [editable]=\"editing[i]\"\r\n            [emitOnValueChanges]=\"true\"\r\n            [item]=\"it\"\r\n            [currency]=\"currency\"\r\n            (formUpdated)=\"onFormUpdated($event, i)\">\r\n          </app-base-form-canvas>\r\n        </div>\r\n\r\n\r\n      </div>\r\n      <div class=\"row-actions\">\r\n\r\n        <button *ngIf=\"editing[i]\" mat-stroked-button class=\"btn-none-background-primary save-btn\" (click)=\"saveRow(i)\"\r\n                [disabled]=\"!canSave(i)\">\r\n          <div class=\"button-text\">\r\n            <mat-icon>check</mat-icon>\r\n            <span>{{ 'item-line.save' | translate }}</span>\r\n          </div>\r\n        </button>\r\n\r\n        <button *ngIf=\"!editing[i] && editable\" mat-stroked-button class=\"btn-none-background-primary edit-btn\"\r\n                (click)=\"editRow(i)\">\r\n          <div class=\"button-text\">\r\n            <mat-icon>edit</mat-icon>\r\n            <span>{{ 'item-line.edit' | translate }}</span>\r\n          </div>\r\n        </button>\r\n\r\n        <button *ngIf=\"allowDelete && editable\" mat-stroked-button class=\"btn-none-background-primary delete-btn\"\r\n                (click)=\"deleteItem(i)\" type=\"button\">\r\n          <div class=\"button-text\">\r\n            <mat-icon>delete</mat-icon>\r\n            <span>{{ 'item-line.delete' | translate }}</span>\r\n          </div>\r\n        </button>\r\n      </div>\r\n    </div>\r\n  }\r\n  @if (noDataFound) {\r\n    <div class=\"dataNotFound flex-column\">\r\n      <mat-icon class=\"dataNotFound__icon\">{{ noDataFoundIcon }}</mat-icon>\r\n      <span class=\"dataNotFound__title\">{{ noDataFoundTitle | translate }}</span>\r\n      <span class=\"dataNotFound__subtitle\">{{ noDataFoundSubtitle | translate }}</span>\r\n    </div>\r\n\r\n  }\r\n  <div class=\"add-item\" *ngIf=\"allowAdd && editable\">\r\n    <div class=\"divider\" style=\"border-top: 1px solid var(--primary-color-3nd)\"></div>\r\n    <button mat-stroked-button color=\"primary\" class=\"btn-none-background-primary\" (click)=\"addNewItem()\"\r\n            [disabled]=\"!canAddNew\">\r\n      <div class=\"button-text\">\r\n        <mat-icon>add</mat-icon>\r\n        <span>  {{ 'item-line.addNewItem' | translate }}</span>\r\n      </div>\r\n    </button>\r\n\r\n  </div>\r\n\r\n  @if (!noDataFound) {\r\n    <div class=\"totals-box\">\r\n\r\n      <div class=\"total-row\">\r\n        <span class=\"label\">{{ 'item-line.discount' | translate }}</span>\r\n        <span class=\"value red\">{{ discountTotal | currency:currency }}</span>\r\n      </div>\r\n\r\n      <div class=\"total-row\">\r\n        <span class=\"label\">{{ 'item-line.amount' | translate }}</span>\r\n        <span class=\"value\">{{ subtotal | currency:currency }}</span>\r\n      </div>\r\n\r\n      <div class=\"divider\"></div>\r\n\r\n      <div class=\"total-row grand\">\r\n        <span class=\"label\">{{ 'item-line.grandTotal' | translate }}</span>\r\n        <span class=\"value strong green\">{{ grandTotal | currency:currency }}</span>\r\n      </div>\r\n    </div>\r\n  }\r\n\r\n</div>\r\n"]}
|
|
299
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"item-line-editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/invoiceq/ui-lib/src/lib/components/item-line-editor/item-line-editor.component.ts","../../../../../../../projects/invoiceq/ui-lib/src/lib/components/item-line-editor/item-line-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, Output, SimpleChanges} from '@angular/core';\r\nimport {AbstractControl, FormsModule} from \"@angular/forms\";\r\nimport {CommonModule} from \"@angular/common\";\r\nimport {MatButtonModule} from \"@angular/material/button\";\r\nimport {MatIconModule} from \"@angular/material/icon\";\r\nimport {BaseFormCanvasComponent} from \"../base-form-canvas/base-form-canvas.component\";\r\nimport {FieldInfo, EMPTY_PAGE_INFO, PageInfo} from \"../../base-model\";\r\nimport {FormGroup} from \"@angular/forms\";\r\nimport {TranslateModule} from \"@ngx-translate/core\";\r\nimport {LineItem} from \"../../base-model/line-item.model\";\r\nimport {ItemsTotal} from \"../../base-model/items-total.model\";\r\n@Component({\r\n  selector: 'app-item-line-editor',\r\n  templateUrl: './item-line-editor.component.html',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    MatButtonModule,\r\n    MatIconModule,\r\n    BaseFormCanvasComponent,\r\n    TranslateModule\r\n  ],\r\n  styleUrls: ['./item-line-editor.component.scss']\r\n})\r\n\r\n\r\nexport class ItemLineEditorComponent implements OnChanges {\r\n  @Input() noDataFoundIcon: string;\r\n  @Input() noDataFoundTitle: string;\r\n  @Input() noDataFoundSubtitle: string;\r\n\r\n  @Input() pageInfo: PageInfo;\r\n  @Input() columnHeaderWidths: string[];\r\n  @Input() title: string;\r\n  @Input() subtitle: string;\r\n  @Input() allowAdd: boolean = true;\r\n  @Input() allowDelete: boolean = true;\r\n  @Input() editable: boolean = true;\r\n  @Input() currency: string;\r\n  @Input() fields: FieldInfo[] = [];\r\n\r\n  private baseFieldsSnapshot: FieldInfo[] | undefined;\r\n\r\n\r\n  @Input() items: LineItem[] = [this.blankItem()];\r\n\r\n  @Output() itemsChange = new EventEmitter<LineItem[]>();\r\n  @Output() itemSaved = new EventEmitter<{ index: number, item: any }>();\r\n  @Output() itemDeleted = new EventEmitter<{ index: number }>();\r\n  @Output() totalsChange = new EventEmitter<ItemsTotal>();\r\n  @Output() editStateChange = new EventEmitter<{ index: number, editing: boolean }>();\r\n  formRefs: (FormGroup | undefined)[] = [];\r\n\r\n  editing: boolean[] = [true];\r\n  noDataFound: boolean = false\r\n\r\n  get headerFields(): FieldInfo[] {\r\n    return (this.fields || []).filter(f => f.visible && f.row === 1 && f.type !== 'spacer');\r\n  }\r\n\r\n  get hasInvalidEditingForm(): boolean {\r\n    if (!this.formRefs || !this.editing) return false;\r\n    for (let i = 0; i < this.formRefs.length; i++) {\r\n      const frm = this.formRefs[i];\r\n      if (this.editing[i] && frm && frm.invalid) {\r\n        return true;\r\n      }\r\n    }\r\n    return false;\r\n  }\r\n\r\n  get canAddNew(): boolean {\r\n    return !this.hasInvalidEditingForm;\r\n  }\r\n\r\n  canSave(index: number): boolean {\r\n    const frm = this.formRefs?.[index];\r\n    if (!this.editing?.[index]) return true;\r\n    return !!frm && frm.valid;\r\n  }\r\n\r\n  labelOf(field: FieldInfo): string {\r\n    const configuredKey = field.label ? field.label : field.property;\r\n    return configuredKey.startsWith(this.pageInfo.labelsSection)\r\n      ? configuredKey\r\n      : `${this.pageInfo.labelsSection}.${configuredKey}`;\r\n  }\r\n\r\n  private blankItem() {\r\n    return { gtinCode: '', description: '', unitPrice: 0, qty: 1, discount: 0, total: 0 };\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['items'] && changes['items'].currentValue) {\r\n      const len = (this.items || []).length;\r\n      this.noDataFound = len <= 0;\r\n      if (changes['items'].firstChange) {\r\n        this.formRefs = new Array(len).fill(undefined);\r\n        this.editing = len > 0 ? new Array(len).fill(false) : [true];\r\n      } else {\r\n        const oldLen = this.editing?.length || 0;\r\n\r\n\r\n        if (!this.formRefs) this.formRefs = [];\r\n        if (this.formRefs.length > len) {\r\n          this.formRefs = this.formRefs.slice(0, len);\r\n        } else {\r\n          while (this.formRefs.length < len) this.formRefs.push(undefined);\r\n        }\r\n\r\n\r\n        if (!this.editing) this.editing = [];\r\n        if (this.editing.length > len) {\r\n          this.editing = this.editing.slice(0, len);\r\n        } else {\r\n          for (let i = this.editing.length; i < len; i++) {\r\n            this.editing[i] = true;\r\n          }\r\n        }\r\n\r\n\r\n        if (oldLen === 0 && len > 0 && this.editing[0] === undefined) {\r\n          this.editing[0] = true;\r\n        }\r\n      }\r\n      this.emitTotals();\r\n    }\r\n    if (changes['fields'] && changes['fields'].currentValue) {\r\n      this.baseFieldsSnapshot = (this.fields || []).map(f => ({...f}));\r\n    }\r\n  }\r\n\r\n  onFormUpdated(form: FormGroup, index: number) {\r\n    const discountCtrl = form.get('discount');\r\n\r\n    if (discountCtrl) {\r\n\r\n      const existing = discountCtrl.validator ? [discountCtrl.validator] : [];\r\n      discountCtrl.setValidators([\r\n        ...existing,\r\n        this.discountValidator(index)\r\n      ]);\r\n\r\n      discountCtrl.updateValueAndValidity({ emitEvent: false });\r\n    }\r\n\r\n    this.formRefs[index] = form;\r\n    try {\r\n      const emittedItems = this.items.map((it, i) => {\r\n        if (i !== index) return it;\r\n        const v = this.getCurrentValues(i) || it || {};\r\n        const up = Number(v?.unitPrice || 0);\r\n        const q = Number(v?.qty || 0);\r\n        const disc = Number(v?.discount || 0);\r\n        const total = Math.max(0, up * q - disc);\r\n        return { ...it, ...v, total };\r\n      });\r\n      this.itemsChange.emit(emittedItems);\r\n    } catch (_e) {\r\n\r\n    }\r\n    this.emitTotals();\r\n  }\r\n\r\n  addNewItem() {\r\n    this.items.push(this.blankItem());\r\n    this.formRefs.push(undefined);\r\n    this.editing.push(true);\r\n\r\n    this.restoreFieldsFromSnapshot();\r\n    this.itemsChange.emit([...this.items]);\r\n    this.editStateChange.emit({ index: this.items.length - 1, editing: true });\r\n    this.emitTotals();\r\n  }\r\n\r\n  saveRow(index: number) {\r\n\r\n    const frm = this.formRefs?.[index];\r\n    if (this.editing[index] && frm && frm.invalid) {\r\n\r\n      Object.values(frm.controls).forEach(c => c.markAsTouched());\r\n      return;\r\n    }\r\n    const v = this.getCurrentValues(index);\r\n    if (!v) return;\r\n    this.items[index] = { ...v, total: this.calcLineTotal(index) };\r\n\r\n    this.editing[index] = false;\r\n\r\n    this.setFieldsReadonly(true);\r\n    this.itemsChange.emit([...this.items]);\r\n    this.itemSaved.emit({ index, item: this.items[index] });\r\n    this.editStateChange.emit({ index, editing: false });\r\n    this.emitTotals();\r\n  }\r\n\r\n  deleteItem(index: number) {\r\n    if (index < 0 || index >= this.items.length) return;\r\n    this.items.splice(index, 1);\r\n    this.formRefs.splice(index, 1);\r\n    this.editing.splice(index, 1);\r\n\r\n    this.itemsChange.emit([...this.items]);\r\n    this.itemDeleted.emit({ index });\r\n    this.emitTotals();\r\n  }\r\n\r\n  clearAll() {\r\n    this.items = [this.blankItem()];\r\n    this.formRefs = [undefined];\r\n    this.editing = [true];\r\n    this.itemsChange.emit([...this.items]);\r\n    this.emitTotals();\r\n  }\r\n\r\n  getCurrentValues(index: number) {\r\n    const isEditing = this.editing[index];\r\n    const frm = this.formRefs[index];\r\n\r\n    const base = this.items[index] || {};\r\n    const src = (isEditing && frm) ? { ...base, ...frm.value } : { ...base };\r\n    if (!src) return null;\r\n    const val: any = { ...src };\r\n    val.unitPrice = val.unitPrice === null || val.unitPrice === '' ? null : Number(val.unitPrice);\r\n    val.qty = val.qty === null || val.qty === '' ? null : Number(val.qty);\r\n    val.discount = val.discount === null || val.discount === '' ? null : Number(val.discount);\r\n    return val;\r\n  }\r\n\r\n  calcLineTotal(index: number): number {\r\n    const val = this.getCurrentValues(index);\r\n    if (!val) return Number(this.items[index]?.total || 0);\r\n    return Math.max(0, (val.unitPrice || 0) * (val.qty || 0) - (val.discount || 0));\r\n  }\r\n\r\n  get subtotal(): number {\r\n    return this.items.reduce((s, _it, i) => {\r\n      const v = this.getCurrentValues(i);\r\n      const up = Number(v?.unitPrice || 0);\r\n      const q = Number(v?.qty || 0);\r\n      return s + (up * q);\r\n    }, 0);\r\n  }\r\n\r\n  get discountTotal(): number {\r\n    return this.items.reduce((s, _it, i) => {\r\n      const v = this.getCurrentValues(i);\r\n      return s + Number(v?.discount || 0);\r\n    }, 0);\r\n  }\r\n\r\n  get grandTotal(): number {\r\n    return this.items.reduce((s, _it, i) => s + this.calcLineTotal(i), 0);\r\n  }\r\n\r\n  trackByIndex(index: number, _item: any) {\r\n    return index;\r\n  }\r\n\r\n  editRow(index: number) {\r\n    this.editing[index] = true;\r\n    this.restoreFieldsFromSnapshot();\r\n    this.editStateChange.emit({ index, editing: true });\r\n  }\r\n\r\n  private emitTotals() {\r\n    this.totalsChange.emit({\r\n      subtotal: this.subtotal,\r\n      discount: this.discountTotal,\r\n      grandTotal: this.grandTotal\r\n    });\r\n  }\r\n\r\n  private setFieldsReadonly(state: boolean) {\r\n    this.fields = (this.fields || []).map(f => ({ ...f, readonly: state }));\r\n  }\r\n\r\n  private restoreFieldsFromSnapshot() {\r\n    if (this.baseFieldsSnapshot && this.baseFieldsSnapshot.length) {\r\n      this.fields = this.baseFieldsSnapshot.map(f => ({...f}));\r\n    } else {\r\n      this.setFieldsReadonly(false);\r\n    }\r\n  }\r\n\r\n  get gridTemplate() {\r\n    return this.columnHeaderWidths.join(' ');\r\n  }\r\n\r\n  private discountValidator(index: number) {\r\n    return (control: AbstractControl) => {\r\n      const val = this.getCurrentValues(index);\r\n      if (!val) return null;\r\n\r\n      const totalBeforeDiscount = (val.unitPrice ?? 0) * (val.qty ?? 0);\r\n      const discount = val.discount ?? null;\r\n\r\n      if (discount != null && discount > totalBeforeDiscount) {\r\n        return { discountTooHigh: true };\r\n      }\r\n\r\n      return null;\r\n    };\r\n  }\r\n\r\n}\r\n","<div class=\"item-line-editor\">\r\n\r\n  <h3 class=\"title\">{{ title | translate }}</h3>\r\n  <p class=\"subtitle\">{{ subtitle | translate }}</p>\r\n\r\n  <div class=\"table-header\" [ngStyle]=\"{ 'grid-template-columns': gridTemplate }\">\r\n    <ng-container *ngFor=\"let f of headerFields; let idx = index\">\r\n      <div class=\"col\">\r\n        {{ labelOf(f)  | translate }}\r\n      </div>\r\n    </ng-container>\r\n  </div>\r\n  @if (!noDataFound) {\r\n    <div class=\"table-body\" *ngFor=\"let it of items; let i = index; trackBy: trackByIndex\">\r\n\r\n      <div class=\"table-row\">\r\n\r\n        <div class=\"row-inputs\">\r\n          <app-base-form-canvas\r\n            [pageInfo]=\"pageInfo\"\r\n            [fields]=\"fields\"\r\n            [editable]=\"editing[i]\"\r\n            [emitOnValueChanges]=\"true\"\r\n            [item]=\"it\"\r\n            [currency]=\"currency\"\r\n            (formUpdated)=\"onFormUpdated($event, i)\">\r\n          </app-base-form-canvas>\r\n        </div>\r\n\r\n\r\n      </div>\r\n      <div class=\"row-actions\">\r\n\r\n        <button *ngIf=\"editing[i]\" mat-stroked-button class=\"btn-none-background-primary save-btn\" (click)=\"saveRow(i)\"\r\n                [disabled]=\"!canSave(i)\">\r\n          <div class=\"button-text\">\r\n            <mat-icon>check</mat-icon>\r\n            <span>{{ 'item-line.save' | translate }}</span>\r\n          </div>\r\n        </button>\r\n\r\n        <button *ngIf=\"!editing[i] && editable\" mat-stroked-button class=\"btn-none-background-primary edit-btn\"\r\n                (click)=\"editRow(i)\">\r\n          <div class=\"button-text\">\r\n            <mat-icon>edit</mat-icon>\r\n            <span>{{ 'item-line.edit' | translate }}</span>\r\n          </div>\r\n        </button>\r\n\r\n        <button *ngIf=\"allowDelete && editable\" mat-stroked-button class=\"btn-none-background-primary delete-btn\"\r\n                (click)=\"deleteItem(i)\" type=\"button\">\r\n          <div class=\"button-text\">\r\n            <mat-icon>delete</mat-icon>\r\n            <span>{{ 'item-line.delete' | translate }}</span>\r\n          </div>\r\n        </button>\r\n      </div>\r\n    </div>\r\n  }\r\n  @if (noDataFound) {\r\n    <div class=\"dataNotFound flex-column\">\r\n      <mat-icon class=\"dataNotFound__icon\">{{ noDataFoundIcon }}</mat-icon>\r\n      <span class=\"dataNotFound__title\">{{ noDataFoundTitle | translate }}</span>\r\n      <span class=\"dataNotFound__subtitle\">{{ noDataFoundSubtitle | translate }}</span>\r\n    </div>\r\n\r\n  }\r\n  <div class=\"add-item\" *ngIf=\"allowAdd && editable\">\r\n    <div class=\"divider\" style=\"border-top: 1px solid var(--primary-color-3nd)\"></div>\r\n    <button mat-stroked-button color=\"primary\" class=\"btn-none-background-primary\" (click)=\"addNewItem()\"\r\n            [disabled]=\"!canAddNew\">\r\n      <div class=\"button-text\">\r\n        <mat-icon>add</mat-icon>\r\n        <span>  {{ 'item-line.addNewItem' | translate }}</span>\r\n      </div>\r\n    </button>\r\n\r\n  </div>\r\n\r\n  @if (!noDataFound) {\r\n    <div class=\"totals-box\">\r\n\r\n      <div class=\"total-row\">\r\n        <span class=\"label\">{{ 'item-line.discount' | translate }}</span>\r\n        <span class=\"value red\">{{ discountTotal | currency:currency }}</span>\r\n      </div>\r\n\r\n      <div class=\"total-row\">\r\n        <span class=\"label\">{{ 'item-line.amount' | translate }}</span>\r\n        <span class=\"value\">{{ subtotal | currency:currency }}</span>\r\n      </div>\r\n\r\n      <div class=\"divider\"></div>\r\n\r\n      <div class=\"total-row grand\">\r\n        <span class=\"label\">{{ 'item-line.grandTotal' | translate }}</span>\r\n        <span class=\"value strong green\">{{ grandTotal | currency:currency }}</span>\r\n      </div>\r\n    </div>\r\n  }\r\n\r\n</div>\r\n"]}
|
|
@@ -1,14 +1,10 @@
|
|
|
1
1
|
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
2
2
|
import { MatIconModule } from '@angular/material/icon';
|
|
3
3
|
import { MatButtonModule } from '@angular/material/button';
|
|
4
|
-
import { NgIf, NgForOf
|
|
5
|
-
import { MatOption, MatSelect } from '@angular/material/select';
|
|
6
|
-
import { TranslateModule } from "@ngx-translate/core";
|
|
4
|
+
import { NgIf, NgForOf } from '@angular/common';
|
|
7
5
|
import * as i0 from "@angular/core";
|
|
8
6
|
import * as i1 from "@angular/cdk/bidi";
|
|
9
7
|
import * as i2 from "@angular/material/icon";
|
|
10
|
-
import * as i3 from "@angular/material/button";
|
|
11
|
-
import * as i4 from "@ngx-translate/core";
|
|
12
8
|
export class PaginatorComponent {
|
|
13
9
|
constructor(directionality) {
|
|
14
10
|
this.directionality = directionality;
|
|
@@ -69,12 +65,57 @@ export class PaginatorComponent {
|
|
|
69
65
|
this.pageSizeChange.emit(this.pageSize);
|
|
70
66
|
this.pageChange.emit(this.currentPage);
|
|
71
67
|
}
|
|
68
|
+
getPageNumbers() {
|
|
69
|
+
const TOTAL = this.totalPages;
|
|
70
|
+
const CURRENT = this.currentPage;
|
|
71
|
+
const PAGES = [];
|
|
72
|
+
if (TOTAL <= 7) {
|
|
73
|
+
for (let i = 1; i <= TOTAL; i++) {
|
|
74
|
+
PAGES.push(i);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
PAGES.push(1);
|
|
79
|
+
if (CURRENT <= 3) {
|
|
80
|
+
for (let i = 2; i <= 4; i++) {
|
|
81
|
+
PAGES.push(i);
|
|
82
|
+
}
|
|
83
|
+
PAGES.push('...');
|
|
84
|
+
PAGES.push(TOTAL - 1);
|
|
85
|
+
PAGES.push(TOTAL);
|
|
86
|
+
}
|
|
87
|
+
else if (CURRENT >= TOTAL - 2) {
|
|
88
|
+
PAGES.push(2);
|
|
89
|
+
PAGES.push('...');
|
|
90
|
+
for (let i = TOTAL - 3; i <= TOTAL; i++) {
|
|
91
|
+
PAGES.push(i);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
PAGES.push(2);
|
|
96
|
+
PAGES.push('...');
|
|
97
|
+
PAGES.push(CURRENT - 1);
|
|
98
|
+
PAGES.push(CURRENT);
|
|
99
|
+
PAGES.push(CURRENT + 1);
|
|
100
|
+
PAGES.push('...');
|
|
101
|
+
PAGES.push(TOTAL - 1);
|
|
102
|
+
PAGES.push(TOTAL);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
return PAGES;
|
|
106
|
+
}
|
|
107
|
+
isEllipsis(page) {
|
|
108
|
+
return page === '...';
|
|
109
|
+
}
|
|
110
|
+
isActive(page) {
|
|
111
|
+
return typeof page === 'number' && page === this.currentPage;
|
|
112
|
+
}
|
|
72
113
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PaginatorComponent, deps: [{ token: i1.Directionality }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
73
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PaginatorComponent, isStandalone: true, selector: "app-paginator", inputs: { currentPage: "currentPage", totalItems: "totalItems", pageSize: "pageSize", pageSizeOptions: "pageSizeOptions" }, outputs: { pageChange: "pageChange", pageSizeChange: "pageSizeChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"
|
|
114
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: PaginatorComponent, isStandalone: true, selector: "app-paginator", inputs: { currentPage: "currentPage", totalItems: "totalItems", pageSize: "pageSize", pageSizeOptions: "pageSizeOptions" }, outputs: { pageChange: "pageChange", pageSizeChange: "pageSizeChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"paginator-container\" [dir]=\"currentDirection\" [class.rtl]=\"currentDirection === 'rtl'\">\r\n <button\r\n class=\"paginator-button paginator-nav-button\"\r\n [class.disabled]=\"currentPage === 1\"\r\n [disabled]=\"currentPage === 1\"\r\n (click)=\"previousPage()\"\r\n type=\"button\">\r\n <mat-icon class=\"paginator-icon paginator-icon-left\">chevron_left</mat-icon>\r\n </button>\r\n\r\n <ng-container *ngFor=\"let page of getPageNumbers()\">\r\n <button\r\n *ngIf=\"!isEllipsis(page)\"\r\n class=\"paginator-button paginator-page-button\"\r\n [class.active]=\"isActive(page)\"\r\n [disabled]=\"isActive(page)\"\r\n (click)=\"goToPage(+page)\"\r\n type=\"button\">\r\n <span class=\"paginator-page-number\">{{ page }}</span>\r\n </button>\r\n <div *ngIf=\"isEllipsis(page)\" class=\"paginator-button paginator-ellipsis\">\r\n <span class=\"paginator-ellipsis-text\">...</span>\r\n </div>\r\n </ng-container>\r\n\r\n <button\r\n class=\"paginator-button paginator-nav-button\"\r\n [class.disabled]=\"currentPage === totalPages\"\r\n [disabled]=\"currentPage === totalPages\"\r\n (click)=\"nextPage()\"\r\n type=\"button\">\r\n <mat-icon class=\"paginator-icon paginator-icon-right\">chevron_right</mat-icon>\r\n </button>\r\n</div>\r\n", styles: [".paginator-container{display:flex;align-items:center;justify-content:flex-end;gap:8px;width:100%;margin-top:16px}.paginator-container.rtl .paginator-icon,.paginator-container[dir=rtl] .paginator-icon{transform:rotate(180deg)}.paginator-button{width:32px;height:32px;border-radius:8px;border:1px solid #f0eeee;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;box-sizing:border-box;transition:all .2s;font-family:Lusail,sans-serif;font-size:14px;line-height:1.2;color:#888;font-weight:300}.paginator-button:hover:not(.disabled):not(.active){background:#fafafa}.paginator-button.disabled{cursor:not-allowed;opacity:.5}.paginator-page-button{font-weight:300}.paginator-page-button.active{border-color:#0d4261;background:#fff;color:#0d4261;font-weight:500;cursor:default}.paginator-page-number{font-family:Lusail,sans-serif;font-size:14px;line-height:1.2;font-weight:inherit;color:inherit;height:14px}.paginator-ellipsis{border:1px solid #f0eeee;background:#fff;cursor:default;color:#888}.paginator-ellipsis-text{font-family:Lusail,sans-serif;font-size:14px;line-height:1.2;font-weight:300;color:#888}.paginator-nav-button{border:1px solid #f0eeee;background:#fff}.paginator-icon{font-size:16px;width:16px;height:16px;color:#000;display:flex;align-items:center;justify-content:center}.paginator-button.disabled .paginator-icon{opacity:.5}\n"], dependencies: [{ kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i1.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] }); }
|
|
74
115
|
}
|
|
75
116
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PaginatorComponent, decorators: [{
|
|
76
117
|
type: Component,
|
|
77
|
-
args: [{ selector: 'app-paginator', standalone: true, imports: [MatIconModule, MatButtonModule, NgIf, NgForOf
|
|
118
|
+
args: [{ selector: 'app-paginator', standalone: true, imports: [MatIconModule, MatButtonModule, NgIf, NgForOf], template: "<div class=\"paginator-container\" [dir]=\"currentDirection\" [class.rtl]=\"currentDirection === 'rtl'\">\r\n <button\r\n class=\"paginator-button paginator-nav-button\"\r\n [class.disabled]=\"currentPage === 1\"\r\n [disabled]=\"currentPage === 1\"\r\n (click)=\"previousPage()\"\r\n type=\"button\">\r\n <mat-icon class=\"paginator-icon paginator-icon-left\">chevron_left</mat-icon>\r\n </button>\r\n\r\n <ng-container *ngFor=\"let page of getPageNumbers()\">\r\n <button\r\n *ngIf=\"!isEllipsis(page)\"\r\n class=\"paginator-button paginator-page-button\"\r\n [class.active]=\"isActive(page)\"\r\n [disabled]=\"isActive(page)\"\r\n (click)=\"goToPage(+page)\"\r\n type=\"button\">\r\n <span class=\"paginator-page-number\">{{ page }}</span>\r\n </button>\r\n <div *ngIf=\"isEllipsis(page)\" class=\"paginator-button paginator-ellipsis\">\r\n <span class=\"paginator-ellipsis-text\">...</span>\r\n </div>\r\n </ng-container>\r\n\r\n <button\r\n class=\"paginator-button paginator-nav-button\"\r\n [class.disabled]=\"currentPage === totalPages\"\r\n [disabled]=\"currentPage === totalPages\"\r\n (click)=\"nextPage()\"\r\n type=\"button\">\r\n <mat-icon class=\"paginator-icon paginator-icon-right\">chevron_right</mat-icon>\r\n </button>\r\n</div>\r\n", styles: [".paginator-container{display:flex;align-items:center;justify-content:flex-end;gap:8px;width:100%;margin-top:16px}.paginator-container.rtl .paginator-icon,.paginator-container[dir=rtl] .paginator-icon{transform:rotate(180deg)}.paginator-button{width:32px;height:32px;border-radius:8px;border:1px solid #f0eeee;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;box-sizing:border-box;transition:all .2s;font-family:Lusail,sans-serif;font-size:14px;line-height:1.2;color:#888;font-weight:300}.paginator-button:hover:not(.disabled):not(.active){background:#fafafa}.paginator-button.disabled{cursor:not-allowed;opacity:.5}.paginator-page-button{font-weight:300}.paginator-page-button.active{border-color:#0d4261;background:#fff;color:#0d4261;font-weight:500;cursor:default}.paginator-page-number{font-family:Lusail,sans-serif;font-size:14px;line-height:1.2;font-weight:inherit;color:inherit;height:14px}.paginator-ellipsis{border:1px solid #f0eeee;background:#fff;cursor:default;color:#888}.paginator-ellipsis-text{font-family:Lusail,sans-serif;font-size:14px;line-height:1.2;font-weight:300;color:#888}.paginator-nav-button{border:1px solid #f0eeee;background:#fff}.paginator-icon{font-size:16px;width:16px;height:16px;color:#000;display:flex;align-items:center;justify-content:center}.paginator-button.disabled .paginator-icon{opacity:.5}\n"] }]
|
|
78
119
|
}], ctorParameters: () => [{ type: i1.Directionality }], propDecorators: { currentPage: [{
|
|
79
120
|
type: Input
|
|
80
121
|
}], totalItems: [{
|
|
@@ -88,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
88
129
|
}], pageSizeChange: [{
|
|
89
130
|
type: Output
|
|
90
131
|
}] } });
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../../../../projects/invoiceq/ui-lib/src/lib/components/paginator/paginator.component.ts","../../../../../../../projects/invoiceq/ui-lib/src/lib/components/paginator/paginator.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges } from '@angular/core';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport {NgIf, NgForOf, NgClass} from '@angular/common';\r\nimport { Directionality } from '@angular/cdk/bidi';\r\nimport { MatOption, MatSelect } from '@angular/material/select';\r\nimport {TranslateModule} from \"@ngx-translate/core\";\r\n\r\n@Component({\r\n  selector: 'app-paginator',\r\n  templateUrl: './paginator.component.html',\r\n  styleUrls: ['./paginator.component.css'],\r\n  standalone: true,\r\n  imports: [MatIconModule, MatButtonModule, NgIf, NgForOf, MatSelect, MatOption, NgClass, TranslateModule],\r\n})\r\nexport class PaginatorComponent implements OnInit, OnChanges {\r\n  @Input() currentPage = 1;\r\n  @Input() totalItems = 0;\r\n  @Input() pageSize = 10;\r\n  @Input() pageSizeOptions: number[] = [5, 10, 25, 50];\r\n\r\n  @Output() pageChange = new EventEmitter<number>();\r\n  @Output() pageSizeChange = new EventEmitter<number>();\r\n\r\n  currentDirection: 'ltr' | 'rtl' = 'ltr';\r\n\r\n  constructor(private directionality: Directionality) {}\r\n\r\n  ngOnInit() {\r\n    this.currentDirection = this.directionality.value;\r\n    this.directionality.change?.subscribe((value) => {\r\n      this.currentDirection = value;\r\n    });\r\n    if (!this.pageSizeOptions.includes(this.pageSize)) {\r\n      Promise.resolve().then(() => {\r\n        this.pageSize = this.pageSizeOptions[1];\r\n        this.pageSizeChange.emit(this.pageSize);\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnChanges() {\r\n    if (this.currentPage > this.totalPages) {\r\n      this.currentPage = this.totalPages || 1;\r\n    }\r\n  }\r\n\r\n  get totalPages(): number {\r\n    return Math.ceil(this.totalItems / this.pageSize);\r\n  }\r\n\r\n  get startIndex(): number {\r\n    return this.totalItems === 0 ? 0 : (this.currentPage - 1) * this.pageSize + 1;\r\n  }\r\n\r\n  get endIndex(): number {\r\n    return Math.min(this.currentPage * this.pageSize, this.totalItems);\r\n  }\r\n\r\n  goToPage(page: number) {\r\n    if (page >= 1 && page <= this.totalPages) {\r\n      this.currentPage = page;\r\n      this.pageChange.emit(this.currentPage);\r\n    }\r\n  }\r\n\r\n  nextPage() {\r\n    if (this.currentPage < this.totalPages) {\r\n      this.goToPage(this.currentPage + 1);\r\n    }\r\n  }\r\n\r\n  previousPage() {\r\n    if (this.currentPage > 1) {\r\n      this.goToPage(this.currentPage - 1);\r\n    }\r\n  }\r\n\r\n  onPageSizeChange(size: number) {\r\n    this.pageSize = size;\r\n    this.currentPage = 1;\r\n    this.pageSizeChange.emit(this.pageSize);\r\n    this.pageChange.emit(this.currentPage);\r\n  }\r\n\r\n  protected readonly Math = Math;\r\n}\r\n","<div class=\"custom-paginator\" [dir]=\"currentDirection\">\r\n  <span class=\"range-label\">\r\n    {{ (currentPage - 1) * pageSize + 1 }} -\r\n    {{ Math.min(currentPage * pageSize, totalItems) }}\r\n    {{'PAGINATION.of' | translate}} {{ totalItems }}\r\n  </span>\r\n\r\n  <div class=\"right-section\">\r\n    <div class=\"rows-per-page\">\r\n      {{'PAGINATION.rowsPerPage' | translate}}:\r\n      <mat-select [(value)]=\"pageSize\" (selectionChange)=\"onPageSizeChange($event.value)\">\r\n        <mat-option *ngFor=\"let size of pageSizeOptions\" [value]=\"size\">{{ size }}</mat-option>\r\n      </mat-select>\r\n    </div>\r\n\r\n    <div class=\"nav-buttons\">\r\n      <button mat-icon-button (click)=\"previousPage()\" [disabled]=\"currentPage === 1\" id=\"paginator-prev-btn\">\r\n        <mat-icon>{{ currentDirection === 'rtl' ? 'chevron_right' : 'chevron_left' }}</mat-icon>\r\n      </button>\r\n      <span><span style=\"color: var(--primary-color)\">{{ currentPage }}</span> / {{ totalPages }}</span>\r\n      <button mat-icon-button\r\n              (click)=\"nextPage()\"\r\n              [disabled]=\"currentPage === totalPages\"\r\n              [ngClass]=\"{'active-chevron': currentPage !== totalPages, 'disabled-chevron': currentPage === totalPages}\"\r\n              id=\"paginator-next-btn\">\r\n        <mat-icon>{{ currentDirection === 'rtl' ? 'chevron_left' : 'chevron_right' }}</mat-icon>\r\n      </button>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../../../../projects/invoiceq/ui-lib/src/lib/components/paginator/paginator.component.ts","../../../../../../../projects/invoiceq/ui-lib/src/lib/components/paginator/paginator.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges } from '@angular/core';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { NgIf, NgForOf } from '@angular/common';\r\nimport { Directionality } from '@angular/cdk/bidi';\r\n\r\n@Component({\r\n  selector: 'app-paginator',\r\n  templateUrl: './paginator.component.html',\r\n  styleUrls: ['./paginator.component.css'],\r\n  standalone: true,\r\n  imports: [MatIconModule, MatButtonModule, NgIf, NgForOf],\r\n})\r\nexport class PaginatorComponent implements OnInit, OnChanges {\r\n  @Input() currentPage = 1;\r\n  @Input() totalItems = 0;\r\n  @Input() pageSize = 10;\r\n  @Input() pageSizeOptions: number[] = [5, 10, 25, 50];\r\n\r\n  @Output() pageChange = new EventEmitter<number>();\r\n  @Output() pageSizeChange = new EventEmitter<number>();\r\n\r\n  currentDirection: 'ltr' | 'rtl' = 'ltr';\r\n\r\n  constructor(private directionality: Directionality) {}\r\n\r\n  ngOnInit() {\r\n    this.currentDirection = this.directionality.value;\r\n    this.directionality.change?.subscribe((value) => {\r\n      this.currentDirection = value;\r\n    });\r\n    if (!this.pageSizeOptions.includes(this.pageSize)) {\r\n      Promise.resolve().then(() => {\r\n        this.pageSize = this.pageSizeOptions[1];\r\n        this.pageSizeChange.emit(this.pageSize);\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnChanges() {\r\n    if (this.currentPage > this.totalPages) {\r\n      this.currentPage = this.totalPages || 1;\r\n    }\r\n  }\r\n\r\n  get totalPages(): number {\r\n    return Math.ceil(this.totalItems / this.pageSize);\r\n  }\r\n\r\n  get startIndex(): number {\r\n    return this.totalItems === 0 ? 0 : (this.currentPage - 1) * this.pageSize + 1;\r\n  }\r\n\r\n  get endIndex(): number {\r\n    return Math.min(this.currentPage * this.pageSize, this.totalItems);\r\n  }\r\n\r\n  goToPage(page: number) {\r\n    if (page >= 1 && page <= this.totalPages) {\r\n      this.currentPage = page;\r\n      this.pageChange.emit(this.currentPage);\r\n    }\r\n  }\r\n\r\n  nextPage() {\r\n    if (this.currentPage < this.totalPages) {\r\n      this.goToPage(this.currentPage + 1);\r\n    }\r\n  }\r\n\r\n  previousPage() {\r\n    if (this.currentPage > 1) {\r\n      this.goToPage(this.currentPage - 1);\r\n    }\r\n  }\r\n\r\n  onPageSizeChange(size: number) {\r\n    this.pageSize = size;\r\n    this.currentPage = 1;\r\n    this.pageSizeChange.emit(this.pageSize);\r\n    this.pageChange.emit(this.currentPage);\r\n  }\r\n\r\n  getPageNumbers(): (number | string)[] {\r\n    const TOTAL = this.totalPages;\r\n    const CURRENT = this.currentPage;\r\n    const PAGES: (number | string)[] = [];\r\n\r\n    if (TOTAL <= 7) {\r\n      for (let i = 1; i <= TOTAL; i++) {\r\n        PAGES.push(i);\r\n      }\r\n    } else {\r\n      PAGES.push(1);\r\n\r\n      if (CURRENT <= 3) {\r\n        for (let i = 2; i <= 4; i++) {\r\n          PAGES.push(i);\r\n        }\r\n        PAGES.push('...');\r\n        PAGES.push(TOTAL - 1);\r\n        PAGES.push(TOTAL);\r\n      } else if (CURRENT >= TOTAL - 2) {\r\n        PAGES.push(2);\r\n        PAGES.push('...');\r\n        for (let i = TOTAL - 3; i <= TOTAL; i++) {\r\n          PAGES.push(i);\r\n        }\r\n      } else {\r\n        PAGES.push(2);\r\n        PAGES.push('...');\r\n        PAGES.push(CURRENT - 1);\r\n        PAGES.push(CURRENT);\r\n        PAGES.push(CURRENT + 1);\r\n        PAGES.push('...');\r\n        PAGES.push(TOTAL - 1);\r\n        PAGES.push(TOTAL);\r\n      }\r\n    }\r\n\r\n    return PAGES;\r\n  }\r\n\r\n  isEllipsis(page: number | string): boolean {\r\n    return page === '...';\r\n  }\r\n\r\n  isActive(page: number | string): boolean {\r\n    return typeof page === 'number' && page === this.currentPage;\r\n  }\r\n\r\n  protected readonly Math = Math;\r\n}\r\n","<div class=\"paginator-container\" [dir]=\"currentDirection\" [class.rtl]=\"currentDirection === 'rtl'\">\r\n  <button\r\n    class=\"paginator-button paginator-nav-button\"\r\n    [class.disabled]=\"currentPage === 1\"\r\n    [disabled]=\"currentPage === 1\"\r\n    (click)=\"previousPage()\"\r\n    type=\"button\">\r\n    <mat-icon class=\"paginator-icon paginator-icon-left\">chevron_left</mat-icon>\r\n  </button>\r\n\r\n  <ng-container *ngFor=\"let page of getPageNumbers()\">\r\n    <button\r\n      *ngIf=\"!isEllipsis(page)\"\r\n      class=\"paginator-button paginator-page-button\"\r\n      [class.active]=\"isActive(page)\"\r\n      [disabled]=\"isActive(page)\"\r\n      (click)=\"goToPage(+page)\"\r\n      type=\"button\">\r\n      <span class=\"paginator-page-number\">{{ page }}</span>\r\n    </button>\r\n    <div *ngIf=\"isEllipsis(page)\" class=\"paginator-button paginator-ellipsis\">\r\n      <span class=\"paginator-ellipsis-text\">...</span>\r\n    </div>\r\n  </ng-container>\r\n\r\n  <button\r\n    class=\"paginator-button paginator-nav-button\"\r\n    [class.disabled]=\"currentPage === totalPages\"\r\n    [disabled]=\"currentPage === totalPages\"\r\n    (click)=\"nextPage()\"\r\n    type=\"button\">\r\n    <mat-icon class=\"paginator-icon paginator-icon-right\">chevron_right</mat-icon>\r\n  </button>\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { Component, HostListener, Inject } from '@angular/core';
|
|
2
|
+
import { MAT_DIALOG_DATA, MatDialogActions, MatDialogContent, MatDialogTitle } from "@angular/material/dialog";
|
|
3
|
+
import { MatFormField } from "@angular/material/form-field";
|
|
4
|
+
import { FormsModule } from "@angular/forms";
|
|
5
|
+
import { CdkTextareaAutosize } from "@angular/cdk/text-field";
|
|
6
|
+
import { TranslateModule } from "@ngx-translate/core";
|
|
7
|
+
import { MatCheckbox } from "@angular/material/checkbox";
|
|
8
|
+
import { MatButton } from "@angular/material/button";
|
|
9
|
+
import { MatInput } from "@angular/material/input";
|
|
10
|
+
import { NgIf } from "@angular/common";
|
|
11
|
+
import { MatIcon } from "@angular/material/icon";
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
import * as i1 from "@angular/material/dialog";
|
|
14
|
+
import * as i2 from "@angular/forms";
|
|
15
|
+
import * as i3 from "@ngx-translate/core";
|
|
16
|
+
export class ActionCommentComponent {
|
|
17
|
+
constructor(dialogRef, data) {
|
|
18
|
+
this.dialogRef = dialogRef;
|
|
19
|
+
this.data = data;
|
|
20
|
+
this.actionLabel = '';
|
|
21
|
+
this.isTermination = false;
|
|
22
|
+
this.comment = '';
|
|
23
|
+
this.external = false;
|
|
24
|
+
this.signingRequired = false;
|
|
25
|
+
this.tokenReference = "";
|
|
26
|
+
this.otp = "";
|
|
27
|
+
this.isSubmitted = false;
|
|
28
|
+
this.showExternalBox = true;
|
|
29
|
+
this.warningMsg = false;
|
|
30
|
+
dialogRef.disableClose = true;
|
|
31
|
+
}
|
|
32
|
+
onKeyUp() {
|
|
33
|
+
this.dialogRef.close();
|
|
34
|
+
}
|
|
35
|
+
ngOnInit() {
|
|
36
|
+
this.actionLabel = this.data.label;
|
|
37
|
+
this.isTermination = this.data.isTermination;
|
|
38
|
+
this.signingRequired = this.data.signingRequired;
|
|
39
|
+
this.tokenReference = this.data.tokenReference;
|
|
40
|
+
this.warningMsg = this.data.warningMsg || false;
|
|
41
|
+
}
|
|
42
|
+
commentAndClose() {
|
|
43
|
+
this.isSubmitted = true;
|
|
44
|
+
if (this.signingRequired && !this.otp)
|
|
45
|
+
return false; //validation
|
|
46
|
+
let obj = {
|
|
47
|
+
comment: this.comment,
|
|
48
|
+
shareExternal: this.external
|
|
49
|
+
};
|
|
50
|
+
//
|
|
51
|
+
if (this.signingRequired)
|
|
52
|
+
obj["token"] = this.otp;
|
|
53
|
+
if (this.signingRequired)
|
|
54
|
+
obj["tokenReference"] = this.tokenReference;
|
|
55
|
+
//
|
|
56
|
+
this.dialogRef.close(obj);
|
|
57
|
+
return "";
|
|
58
|
+
}
|
|
59
|
+
cancel() {
|
|
60
|
+
this.dialogRef.close();
|
|
61
|
+
}
|
|
62
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ActionCommentComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
63
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ActionCommentComponent, isStandalone: true, selector: "app-action-comment", host: { listeners: { "window:keyup.esc": "onKeyUp()" } }, ngImport: i0, template: "<div *ngIf=\"signingRequired\">\r\n <p mat-dialog-title align=\"start\" class=\"invoice-note-text invoice-section m-0\">\r\n {{ 'comment.OTP' | translate }}\r\n <span *ngIf=\"isTermination\" class=\"text-red\">*</span>\r\n </p>\r\n <mat-dialog-content class=\"mat-typography\">\r\n <mat-form-field appearance=\"outline\" class=\"w-100\" [class.error-input]=\"isSubmitted && !otp\">\r\n <input cdkFocusInitial agAcceptOnlyNumeric [(ngModel)]=\"otp\" matInput type=\"text\" class=\"pad-top\"/>\r\n </mat-form-field>\r\n </mat-dialog-content>\r\n</div>\r\n<div>\r\n <div class=\"action-comment\">\r\n <p class=\"invoice-note-text invoice-section\">\r\n <span style=\"padding: 10px 15px\">{{ actionLabel | translate }}</span>\r\n <span *ngIf=\"isTermination\" class=\"text-red\">*</span>\r\n </p>\r\n <mat-icon (click)=\"cancel()\">close</mat-icon>\r\n<!-- <span class=\"material-icons\" (click)=\"cancel()\">close</span>-->\r\n </div>\r\n <mat-dialog-content class=\"mat-typography overflow-hidden\">\r\n <mat-form-field appearance=\"outline\" class=\"w-100\">\r\n <textarea cdkFocusInitial [(ngModel)]=\"comment\" matInput class=\"form-style\"\r\n [id]=\"isTermination ? 'warn' : 'primary'\"\r\n cdkTextareaAutosize\r\n cdkAutosizeMinRows=\"4\"\r\n cdkAutosizeMaxRows=\"5\"\r\n placeholder=\"{{'PAYER.placeHolder' | translate}}\">\r\n </textarea>\r\n </mat-form-field>\r\n </mat-dialog-content>\r\n\r\n <div style=\"margin-top: 10px\">\r\n <p *ngIf=\"warningMsg\" mat-dialog-title align=\"start\" class=\"invoice-section m-0 text-red\">\r\n {{ 'vendorWarning' | translate }}\r\n </p>\r\n </div>\r\n\r\n <mat-dialog-actions align=\"end\" class=\"modal-footer\">\r\n\r\n <button mat-stroked-button [color]=\"isTermination ? 'warn': 'primary'\" [disabled]=\"isTermination && !comment\"\r\n (click)=\"commentAndClose()\" id=\"actionLabel\">\r\n {{ 'Proceed' | translate }}\r\n </button>\r\n </mat-dialog-actions>\r\n</div>\r\n", styles: [".m-0{margin:0!important}.w-100{width:100%}.form-style{min-height:12vh!important;height:auto!important}.text-red{color:red!important}.modal-footer{margin-top:5vh}.overflow-hidden{overflow:hidden}.pad-top{margin-top:-7px;display:block}.action-comment{display:flex;justify-content:space-between}.material-icons{color:#e22222;padding:10px;cursor:pointer}textarea#warn::placeholder{color:red}\n"], dependencies: [{ kind: "directive", type: MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "component", type: MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "directive", type: MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "component", type: MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "directive", type: MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] }); }
|
|
64
|
+
}
|
|
65
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ActionCommentComponent, decorators: [{
|
|
66
|
+
type: Component,
|
|
67
|
+
args: [{ selector: 'app-action-comment', standalone: true, imports: [
|
|
68
|
+
MatDialogTitle,
|
|
69
|
+
MatFormField,
|
|
70
|
+
MatDialogContent,
|
|
71
|
+
FormsModule,
|
|
72
|
+
CdkTextareaAutosize,
|
|
73
|
+
TranslateModule,
|
|
74
|
+
MatCheckbox,
|
|
75
|
+
MatDialogActions,
|
|
76
|
+
MatButton,
|
|
77
|
+
MatInput,
|
|
78
|
+
NgIf,
|
|
79
|
+
MatIcon
|
|
80
|
+
], template: "<div *ngIf=\"signingRequired\">\r\n <p mat-dialog-title align=\"start\" class=\"invoice-note-text invoice-section m-0\">\r\n {{ 'comment.OTP' | translate }}\r\n <span *ngIf=\"isTermination\" class=\"text-red\">*</span>\r\n </p>\r\n <mat-dialog-content class=\"mat-typography\">\r\n <mat-form-field appearance=\"outline\" class=\"w-100\" [class.error-input]=\"isSubmitted && !otp\">\r\n <input cdkFocusInitial agAcceptOnlyNumeric [(ngModel)]=\"otp\" matInput type=\"text\" class=\"pad-top\"/>\r\n </mat-form-field>\r\n </mat-dialog-content>\r\n</div>\r\n<div>\r\n <div class=\"action-comment\">\r\n <p class=\"invoice-note-text invoice-section\">\r\n <span style=\"padding: 10px 15px\">{{ actionLabel | translate }}</span>\r\n <span *ngIf=\"isTermination\" class=\"text-red\">*</span>\r\n </p>\r\n <mat-icon (click)=\"cancel()\">close</mat-icon>\r\n<!-- <span class=\"material-icons\" (click)=\"cancel()\">close</span>-->\r\n </div>\r\n <mat-dialog-content class=\"mat-typography overflow-hidden\">\r\n <mat-form-field appearance=\"outline\" class=\"w-100\">\r\n <textarea cdkFocusInitial [(ngModel)]=\"comment\" matInput class=\"form-style\"\r\n [id]=\"isTermination ? 'warn' : 'primary'\"\r\n cdkTextareaAutosize\r\n cdkAutosizeMinRows=\"4\"\r\n cdkAutosizeMaxRows=\"5\"\r\n placeholder=\"{{'PAYER.placeHolder' | translate}}\">\r\n </textarea>\r\n </mat-form-field>\r\n </mat-dialog-content>\r\n\r\n <div style=\"margin-top: 10px\">\r\n <p *ngIf=\"warningMsg\" mat-dialog-title align=\"start\" class=\"invoice-section m-0 text-red\">\r\n {{ 'vendorWarning' | translate }}\r\n </p>\r\n </div>\r\n\r\n <mat-dialog-actions align=\"end\" class=\"modal-footer\">\r\n\r\n <button mat-stroked-button [color]=\"isTermination ? 'warn': 'primary'\" [disabled]=\"isTermination && !comment\"\r\n (click)=\"commentAndClose()\" id=\"actionLabel\">\r\n {{ 'Proceed' | translate }}\r\n </button>\r\n </mat-dialog-actions>\r\n</div>\r\n", styles: [".m-0{margin:0!important}.w-100{width:100%}.form-style{min-height:12vh!important;height:auto!important}.text-red{color:red!important}.modal-footer{margin-top:5vh}.overflow-hidden{overflow:hidden}.pad-top{margin-top:-7px;display:block}.action-comment{display:flex;justify-content:space-between}.material-icons{color:#e22222;padding:10px;cursor:pointer}textarea#warn::placeholder{color:red}\n"] }]
|
|
81
|
+
}], ctorParameters: () => [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
|
|
82
|
+
type: Inject,
|
|
83
|
+
args: [MAT_DIALOG_DATA]
|
|
84
|
+
}] }], propDecorators: { onKeyUp: [{
|
|
85
|
+
type: HostListener,
|
|
86
|
+
args: ['window:keyup.esc']
|
|
87
|
+
}] } });
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-comment.component.js","sourceRoot":"","sources":["../../../../../../../projects/invoiceq/ui-lib/src/lib/components/rejection-comment/action-comment.component.ts","../../../../../../../projects/invoiceq/ui-lib/src/lib/components/rejection-comment/action-comment.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, HostListener, Inject, OnInit} from '@angular/core';\r\nimport {\r\n  MAT_DIALOG_DATA,\r\n  MatDialogActions,\r\n  MatDialogContent,\r\n  MatDialogRef,\r\n  MatDialogTitle\r\n} from \"@angular/material/dialog\";\r\nimport {MatFormField} from \"@angular/material/form-field\";\r\nimport {FormsModule} from \"@angular/forms\";\r\nimport {CdkTextareaAutosize} from \"@angular/cdk/text-field\";\r\nimport {TranslateModule} from \"@ngx-translate/core\";\r\nimport {MatCheckbox} from \"@angular/material/checkbox\";\r\nimport {MatButton} from \"@angular/material/button\";\r\nimport {MatInput} from \"@angular/material/input\";\r\nimport {NgIf} from \"@angular/common\";\r\nimport {MatIcon} from \"@angular/material/icon\";\r\n\r\n@Component({\r\n  selector: 'app-action-comment',\r\n  standalone: true,\r\n  imports: [\r\n    MatDialogTitle,\r\n    MatFormField,\r\n    MatDialogContent,\r\n    FormsModule,\r\n    CdkTextareaAutosize,\r\n    TranslateModule,\r\n    MatCheckbox,\r\n    MatDialogActions,\r\n    MatButton,\r\n    MatInput,\r\n    NgIf,\r\n    MatIcon\r\n  ],\r\n  templateUrl: './action-comment.component.html',\r\n  styleUrl: './action-comment.component.css'\r\n})\r\nexport class ActionCommentComponent implements OnInit {\r\n  actionLabel : string =''\r\n  isTermination : boolean=false;\r\n  comment: string = '';\r\n  external: boolean = false;\r\n  signingRequired: boolean = false;\r\n  tokenReference: string = \"\";\r\n  otp: string = \"\";\r\n  isSubmitted: boolean = false;\r\n  showExternalBox = true;\r\n  warningMsg = false;\r\n  constructor(public dialogRef: MatDialogRef<ActionCommentComponent>,\r\n              @Inject(MAT_DIALOG_DATA) public data: any) {\r\n    dialogRef.disableClose = true;\r\n  }\r\n  @HostListener('window:keyup.esc') onKeyUp() {\r\n    this.dialogRef.close();\r\n  }\r\n  ngOnInit(): void {\r\n    this.actionLabel = this.data.label;\r\n    this.isTermination = this.data.isTermination ;\r\n    this.signingRequired = this.data.signingRequired;\r\n    this.tokenReference = this.data.tokenReference;\r\n    this.warningMsg = this.data.warningMsg || false;\r\n  }\r\n\r\n\r\n  commentAndClose() {\r\n    this.isSubmitted = true;\r\n    if (this.signingRequired && !this.otp) return false;//validation\r\n    let obj:{[key: string]:any} = {\r\n      comment: this.comment,\r\n      shareExternal : this.external\r\n    };\r\n    //\r\n    if(this.signingRequired) obj[\"token\"] = this.otp;\r\n    if(this.signingRequired) obj[\"tokenReference\"] = this.tokenReference;\r\n    //\r\n    this.dialogRef.close(obj);\r\n\r\n    return \"\";\r\n  }\r\n\r\n  cancel() {\r\n    this.dialogRef.close();\r\n  }\r\n\r\n}\r\n","<div *ngIf=\"signingRequired\">\r\n  <p mat-dialog-title align=\"start\" class=\"invoice-note-text invoice-section m-0\">\r\n    {{ 'comment.OTP' | translate }}\r\n    <span *ngIf=\"isTermination\" class=\"text-red\">*</span>\r\n  </p>\r\n  <mat-dialog-content class=\"mat-typography\">\r\n    <mat-form-field appearance=\"outline\" class=\"w-100\" [class.error-input]=\"isSubmitted && !otp\">\r\n      <input cdkFocusInitial agAcceptOnlyNumeric [(ngModel)]=\"otp\" matInput type=\"text\" class=\"pad-top\"/>\r\n    </mat-form-field>\r\n  </mat-dialog-content>\r\n</div>\r\n<div>\r\n  <div class=\"action-comment\">\r\n    <p class=\"invoice-note-text invoice-section\">\r\n      <span style=\"padding: 10px 15px\">{{ actionLabel | translate }}</span>\r\n      <span *ngIf=\"isTermination\" class=\"text-red\">*</span>\r\n    </p>\r\n    <mat-icon (click)=\"cancel()\">close</mat-icon>\r\n<!--    <span class=\"material-icons\" (click)=\"cancel()\">close</span>-->\r\n  </div>\r\n  <mat-dialog-content class=\"mat-typography overflow-hidden\">\r\n    <mat-form-field appearance=\"outline\" class=\"w-100\">\r\n                <textarea cdkFocusInitial [(ngModel)]=\"comment\" matInput class=\"form-style\"\r\n                          [id]=\"isTermination ? 'warn' : 'primary'\"\r\n                          cdkTextareaAutosize\r\n                          cdkAutosizeMinRows=\"4\"\r\n                          cdkAutosizeMaxRows=\"5\"\r\n                          placeholder=\"{{'PAYER.placeHolder' | translate}}\">\r\n                </textarea>\r\n    </mat-form-field>\r\n  </mat-dialog-content>\r\n\r\n  <div style=\"margin-top: 10px\">\r\n    <p *ngIf=\"warningMsg\" mat-dialog-title align=\"start\" class=\"invoice-section m-0 text-red\">\r\n      {{ 'vendorWarning' | translate }}\r\n    </p>\r\n  </div>\r\n\r\n  <mat-dialog-actions align=\"end\" class=\"modal-footer\">\r\n\r\n    <button mat-stroked-button [color]=\"isTermination ? 'warn': 'primary'\" [disabled]=\"isTermination && !comment\"\r\n            (click)=\"commentAndClose()\" id=\"actionLabel\">\r\n      {{ 'Proceed' | translate }}\r\n    </button>\r\n  </mat-dialog-actions>\r\n</div>\r\n"]}
|