ngx-t-forms 2.0.16 → 2.0.18

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.
Files changed (96) hide show
  1. package/fesm2022/{ngx-t-forms-api-value-access-rules.component-DADGz7pX.mjs → ngx-t-forms-api-value-access-rules.component-Drlk8YPy.mjs} +13 -13
  2. package/fesm2022/ngx-t-forms-api-value-access-rules.component-Drlk8YPy.mjs.map +1 -0
  3. package/fesm2022/{ngx-t-forms-calculated-field-rules.component-BkkHK5vI.mjs → ngx-t-forms-calculated-field-rules.component-Byim7p5A.mjs} +8 -7
  4. package/fesm2022/ngx-t-forms-calculated-field-rules.component-Byim7p5A.mjs.map +1 -0
  5. package/fesm2022/{ngx-t-forms-chip-options-creator-editor.component-CHnQQdI8.mjs → ngx-t-forms-chip-options-creator-editor.component-DJdo617E.mjs} +4 -4
  6. package/fesm2022/{ngx-t-forms-chip-options-creator-editor.component-CHnQQdI8.mjs.map → ngx-t-forms-chip-options-creator-editor.component-DJdo617E.mjs.map} +1 -1
  7. package/fesm2022/{ngx-t-forms-config-mscoa-additional-inputs.component-AhbjCCQv.mjs → ngx-t-forms-config-mscoa-additional-inputs.component-D9iDMGP4.mjs} +6 -6
  8. package/fesm2022/ngx-t-forms-config-mscoa-additional-inputs.component-D9iDMGP4.mjs.map +1 -0
  9. package/fesm2022/{ngx-t-forms-data-source-picker.component-BOlk7nkl.mjs → ngx-t-forms-data-source-picker.component-baq9XVW_.mjs} +8 -9
  10. package/fesm2022/ngx-t-forms-data-source-picker.component-baq9XVW_.mjs.map +1 -0
  11. package/fesm2022/{ngx-t-forms-document-list-label-config-editor.component-Bc-qTS2m.mjs → ngx-t-forms-document-list-label-config-editor.component-O0z6NtqG.mjs} +6 -7
  12. package/fesm2022/ngx-t-forms-document-list-label-config-editor.component-O0z6NtqG.mjs.map +1 -0
  13. package/fesm2022/{ngx-t-forms-form-input-selector.component-BuVzRUkY.mjs → ngx-t-forms-form-input-selector.component-DdTRH1a0.mjs} +6 -6
  14. package/fesm2022/{ngx-t-forms-form-input-selector.component-BuVzRUkY.mjs.map → ngx-t-forms-form-input-selector.component-DdTRH1a0.mjs.map} +1 -1
  15. package/fesm2022/{ngx-t-forms-form-json-view.component-hCrrYu82.mjs → ngx-t-forms-form-json-view.component-BAcSfl3f.mjs} +2 -2
  16. package/fesm2022/{ngx-t-forms-form-json-view.component-hCrrYu82.mjs.map → ngx-t-forms-form-json-view.component-BAcSfl3f.mjs.map} +1 -1
  17. package/fesm2022/ngx-t-forms-form-section-stepper.component-npSCBik4.mjs +257 -0
  18. package/fesm2022/ngx-t-forms-form-section-stepper.component-npSCBik4.mjs.map +1 -0
  19. package/fesm2022/{ngx-t-forms-forms-builder-menu.component-DuXf9zC_.mjs → ngx-t-forms-forms-builder-menu.component-DIHHOIPI.mjs} +12 -12
  20. package/fesm2022/{ngx-t-forms-forms-builder-menu.component-DuXf9zC_.mjs.map → ngx-t-forms-forms-builder-menu.component-DIHHOIPI.mjs.map} +1 -1
  21. package/fesm2022/{ngx-t-forms-input-editor.component-C5cPOIhT.mjs → ngx-t-forms-input-editor.component-BCRKxzzO.mjs} +7 -7
  22. package/fesm2022/{ngx-t-forms-input-editor.component-C5cPOIhT.mjs.map → ngx-t-forms-input-editor.component-BCRKxzzO.mjs.map} +1 -1
  23. package/fesm2022/{ngx-t-forms-mat-chip-list-editor.component-C9Hd21i1.mjs → ngx-t-forms-mat-chip-list-editor.component-CK-W-ltG.mjs} +2 -2
  24. package/fesm2022/{ngx-t-forms-mat-chip-list-editor.component-C9Hd21i1.mjs.map → ngx-t-forms-mat-chip-list-editor.component-CK-W-ltG.mjs.map} +1 -1
  25. package/fesm2022/{ngx-t-forms-mat-slider-editor.component-9K8e2gqm.mjs → ngx-t-forms-mat-slider-editor.component-T764zgZ1.mjs} +2 -2
  26. package/fesm2022/{ngx-t-forms-mat-slider-editor.component-9K8e2gqm.mjs.map → ngx-t-forms-mat-slider-editor.component-T764zgZ1.mjs.map} +1 -1
  27. package/fesm2022/{ngx-t-forms-mat-slider-toggle-editor.component-CbYV5fCZ.mjs → ngx-t-forms-mat-slider-toggle-editor.component-DfTrKkE_.mjs} +2 -2
  28. package/fesm2022/{ngx-t-forms-mat-slider-toggle-editor.component-CbYV5fCZ.mjs.map → ngx-t-forms-mat-slider-toggle-editor.component-DfTrKkE_.mjs.map} +1 -1
  29. package/fesm2022/{ngx-t-forms-missing-form-configs.component-DynxybEE.mjs → ngx-t-forms-missing-form-configs.component-BXGNkL4Z.mjs} +6 -6
  30. package/fesm2022/{ngx-t-forms-missing-form-configs.component-DynxybEE.mjs.map → ngx-t-forms-missing-form-configs.component-BXGNkL4Z.mjs.map} +1 -1
  31. package/fesm2022/{ngx-t-forms-mscoa-segment-config.component-C1zx7OZB.mjs → ngx-t-forms-mscoa-segment-config.component-DqCaJoe6.mjs} +5 -6
  32. package/fesm2022/ngx-t-forms-mscoa-segment-config.component-DqCaJoe6.mjs.map +1 -0
  33. package/fesm2022/{ngx-t-forms-ngx-t-forms-BX1gh-MK.mjs → ngx-t-forms-ngx-t-forms-B4C0NbAb.mjs} +593 -233
  34. package/fesm2022/ngx-t-forms-ngx-t-forms-B4C0NbAb.mjs.map +1 -0
  35. package/fesm2022/ngx-t-forms-pipeline-generator.component-CLs9AZ8p.mjs +727 -0
  36. package/fesm2022/ngx-t-forms-pipeline-generator.component-CLs9AZ8p.mjs.map +1 -0
  37. package/fesm2022/ngx-t-forms-required-inputs.component-DDHYfkyu.mjs +189 -0
  38. package/fesm2022/ngx-t-forms-required-inputs.component-DDHYfkyu.mjs.map +1 -0
  39. package/fesm2022/{ngx-t-forms-rest-api-call-setup.component-CDraedkm.mjs → ngx-t-forms-rest-api-call-setup.component-BqiD8UGC.mjs} +8 -8
  40. package/fesm2022/{ngx-t-forms-rest-api-call-setup.component-CDraedkm.mjs.map → ngx-t-forms-rest-api-call-setup.component-BqiD8UGC.mjs.map} +1 -1
  41. package/fesm2022/{ngx-t-forms-section-report.component-DFvcLFZn.mjs → ngx-t-forms-section-report.component-Cl3KWTOq.mjs} +8 -8
  42. package/fesm2022/{ngx-t-forms-section-report.component-DFvcLFZn.mjs.map → ngx-t-forms-section-report.component-Cl3KWTOq.mjs.map} +1 -1
  43. package/fesm2022/{ngx-t-forms-selection-options-editor.component-Cj7fqo70.mjs → ngx-t-forms-selection-options-editor.component-BZFa1mmi.mjs} +5 -5
  44. package/fesm2022/ngx-t-forms-selection-options-editor.component-BZFa1mmi.mjs.map +1 -0
  45. package/fesm2022/ngx-t-forms-t-workflow-picker.component-DQA2XovD.mjs +171 -0
  46. package/fesm2022/ngx-t-forms-t-workflow-picker.component-DQA2XovD.mjs.map +1 -0
  47. package/fesm2022/ngx-t-forms-validators-config.component-BkzKKK07.mjs +218 -0
  48. package/fesm2022/ngx-t-forms-validators-config.component-BkzKKK07.mjs.map +1 -0
  49. package/fesm2022/ngx-t-forms.mjs +1 -1
  50. package/lib/components/t-dynamic-data-edit/elements/pipeline-generator/pipeline-generator.component.d.ts +1 -3
  51. package/lib/components/t-dynamic-data-edit/elements/t-workflow-picker/t-workflow-picker.component.d.ts +44 -8
  52. package/lib/components/t-form-input/elements/Geo-location-form-input/geo-location.component.d.ts +4 -1
  53. package/lib/components/t-form-input/elements/auto-complete-input-element/auto-complete-input-element.component.d.ts +4 -1
  54. package/lib/components/t-form-input/elements/basic-input-input-element/basic-input-input-element.component.d.ts +4 -1
  55. package/lib/components/t-form-input/elements/date-picker-input-element/date-picker-input-element.component.d.ts +4 -1
  56. package/lib/components/t-form-input/elements/date-range-picker-input-element/date-range-picker-input-element.component.d.ts +4 -1
  57. package/lib/components/t-form-input/elements/document-picker/core/document-picker-reactive-input/document-picker-reactive-input.component.d.ts +47 -0
  58. package/lib/components/t-form-input/elements/document-picker/document-picker.component.d.ts +15 -0
  59. package/lib/components/t-form-input/elements/editor-input-element/editor-input-element.component.d.ts +4 -1
  60. package/lib/components/t-form-input/elements/file-upload-input-element/file-upload-input-element.component.d.ts +4 -1
  61. package/lib/components/t-form-input/elements/image-capture-input-element/image-capture-input-element.component.d.ts +4 -1
  62. package/lib/components/t-form-input/elements/mscoa-form-input/mscoa-form-input.component.d.ts +4 -1
  63. package/lib/components/t-form-input/elements/mscoa-form-input/store/mscoa-component-store.service.d.ts +0 -1
  64. package/lib/components/t-form-input/elements/multiple-input-input-element/core/multiple-input-table/multiple-input-table.component.d.ts +1 -0
  65. package/lib/components/t-form-input/elements/multiple-input-input-element/core/multiple-input-table-view/multiple-input-table-view.component.d.ts +9 -2
  66. package/lib/components/t-form-input/elements/multiple-input-input-element/multiple-input-input-element.component.d.ts +4 -1
  67. package/lib/components/t-form-input/elements/select-input-element/select-input-element.component.d.ts +4 -1
  68. package/lib/components/t-form-input/elements/signature-input-element/signature-input-element.component.d.ts +4 -1
  69. package/lib/components/t-form-input/elements/textarea-input-element/textarea-input-element.component.d.ts +4 -1
  70. package/lib/components/t-form-input/elements/toggle-input-element/toggle-input-element.component.d.ts +4 -1
  71. package/lib/components/t-form-input/t-form-input.component.d.ts +2 -1
  72. package/lib/components/user-form-stepper/user-form-stepper.component.d.ts +2 -0
  73. package/lib/injection-tokens/index.d.ts +3 -3
  74. package/lib/services/core/t-input-controller/functions/configureCols.d.ts +1 -1
  75. package/lib/shared/pipes/format-Data.pipe.d.ts +8 -0
  76. package/lib/shared/pipes/index.d.ts +2 -0
  77. package/package.json +2 -2
  78. package/public-api.d.ts +1 -0
  79. package/fesm2022/ngx-t-forms-api-value-access-rules.component-DADGz7pX.mjs.map +0 -1
  80. package/fesm2022/ngx-t-forms-calculated-field-rules.component-BkkHK5vI.mjs.map +0 -1
  81. package/fesm2022/ngx-t-forms-config-mscoa-additional-inputs.component-AhbjCCQv.mjs.map +0 -1
  82. package/fesm2022/ngx-t-forms-data-source-picker.component-BOlk7nkl.mjs.map +0 -1
  83. package/fesm2022/ngx-t-forms-document-list-label-config-editor.component-Bc-qTS2m.mjs.map +0 -1
  84. package/fesm2022/ngx-t-forms-form-section-stepper.component-CR3gyw3D.mjs +0 -253
  85. package/fesm2022/ngx-t-forms-form-section-stepper.component-CR3gyw3D.mjs.map +0 -1
  86. package/fesm2022/ngx-t-forms-mscoa-segment-config.component-C1zx7OZB.mjs.map +0 -1
  87. package/fesm2022/ngx-t-forms-ngx-t-forms-BX1gh-MK.mjs.map +0 -1
  88. package/fesm2022/ngx-t-forms-pipeline-generator.component-CmSkYW71.mjs +0 -780
  89. package/fesm2022/ngx-t-forms-pipeline-generator.component-CmSkYW71.mjs.map +0 -1
  90. package/fesm2022/ngx-t-forms-required-inputs.component-QsOGfmug.mjs +0 -189
  91. package/fesm2022/ngx-t-forms-required-inputs.component-QsOGfmug.mjs.map +0 -1
  92. package/fesm2022/ngx-t-forms-selection-options-editor.component-Cj7fqo70.mjs.map +0 -1
  93. package/fesm2022/ngx-t-forms-validators-config.component-DPD3QcOu.mjs +0 -218
  94. package/fesm2022/ngx-t-forms-validators-config.component-DPD3QcOu.mjs.map +0 -1
  95. package/lib/components/t-form-input/elements/select-table-input/elements/input-table/input-table.component.d.ts +0 -29
  96. package/lib/components/t-form-input/elements/select-table-input/select-table-input.component.d.ts +0 -10
@@ -5,7 +5,7 @@ import { inject, EventEmitter, Output, Input, HostBinding, Optional, Self, Compo
5
5
  import * as i1 from '@angular/forms';
6
6
  import { Validators, ReactiveFormsModule, FormsModule } from '@angular/forms';
7
7
  import { Subject, BehaviorSubject, take, tap, catchError, takeUntil } from 'rxjs';
8
- import { M as MatModulesModule } from './ngx-t-forms-ngx-t-forms-BX1gh-MK.mjs';
8
+ import { M as MatModulesModule } from './ngx-t-forms-ngx-t-forms-B4C0NbAb.mjs';
9
9
  import { MatFormFieldControl } from '@angular/material/form-field';
10
10
  import { v4 } from 'uuid';
11
11
  import { LiveAnnouncer } from '@angular/cdk/a11y';
@@ -13,7 +13,7 @@ import * as i3 from '@angular/material/autocomplete';
13
13
  import * as i2$1 from '@angular/material/button';
14
14
  import * as i3$1 from '@angular/material/card';
15
15
  import * as i4 from '@angular/material/chips';
16
- import * as i6 from '@angular/material/icon';
16
+ import * as i5 from '@angular/material/icon';
17
17
  import * as i3$2 from '@angular/material/select';
18
18
  import * as i9 from '@angular/material/slide-toggle';
19
19
  import * as i9$1 from '@angular/material/toolbar';
@@ -193,7 +193,6 @@ class MscoaSegmentConfigComponent {
193
193
  }
194
194
  singleSelectChange(event) {
195
195
  this.segmentForm.patchValue({ singleSelect: event.checked });
196
- console.error('singleSelectChange', this.segmentForm.value);
197
196
  }
198
197
  removeSegment(index) {
199
198
  const updatedValue = this.value.filter((_, i) => i !== index);
@@ -246,7 +245,7 @@ class MscoaSegmentConfigComponent {
246
245
  this.markAsTouched();
247
246
  }
248
247
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.6", ngImport: i0, type: MscoaSegmentConfigComponent, deps: [{ token: i1.FormBuilder }, { token: i1.NgControl, optional: true, self: true }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
249
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.6", type: MscoaSegmentConfigComponent, isStandalone: true, selector: "app-mscoa-segment-config", inputs: { disabled: "disabled", errors: "errors", dataValue: "dataValue", value: "value", showAllSegments: "showAllSegments", getMscoaTree: "getMscoaTree" }, outputs: { valueChanged: "valueChanged" }, host: { properties: { "id": "this.id" } }, providers: [{ provide: MatFormFieldControl, useExisting: MscoaSegmentConfigComponent }], ngImport: i0, template: "<div *ngIf=\"(value||[]).length>0\" class=\"tree-instructions\">\n <mat-icon class=\"info-icon\" color=\"primary\">info</mat-icon>\n <span>SCOA Segments Configuration</span>\n</div>\n\n<mat-chip-listbox [disabled]=\"disabled\" *ngIf=\"(value?.length || 0) > 0; else noSegments\" aria-label=\"Fish selection\">\n @for (segment of value||[]; track segment.segment) {\n <mat-chip-option (removed)=\"removeSegment($index)\" (click)=\"startEdit($index)\" color=\"accent\"\n [value]=\"segment?.segment\" [selected]=\"this.editingIndex === $index\">\n <div style=\" \n display: flex;\n align-items: center;\n gap: 1px;\">\n <span style=\"margin-right: 2px;\">\n {{ segment.label }}\n </span>\n <mat-icon class=\"icons\">\n {{ segment.singleSelect ? 'done' : ' done_all' }}\n </mat-icon>\n <mat-icon class=\"icons\">\n\n {{ segment.readOnly ? 'edit_off' : 'edit' }}\n </mat-icon>\n </div>\n\n @if ( showAllSegments === false) {\n <button matChipRemove [attr.aria-label]=\"'remove' \">\n <mat-icon>cancel</mat-icon>\n </button>\n }\n\n </mat-chip-option>\n }\n</mat-chip-listbox>\n\n\n\n\n\n<ng-template #noSegments>\n <div class=\"tree-instructions\">\n <mat-icon class=\"info-icon\" color=\"primary\">info</mat-icon>\n <span>No segment configuration available. Start by adding a segment below.</span>\n </div>\n</ng-template>\n\n<mat-toolbar *ngIf=\"!isAddingNew && editingIndex === null && showAllSegments === false\">\n <button style=\"width:100%\" \n [disabled]=\"disabled\"\n mat-stroked-button (click)=\"startAddNew()\">\n Add New Segment <mat-icon>add</mat-icon>\n </button>\n</mat-toolbar>\n\n@if (!!getMscoaError) {\n<div class=\"tree-instructions\">\n <mat-icon class=\"info-icon\" color=\"primary\">info</mat-icon>\n <span>\n {{ getMscoaError }}\n </span>\n</div>\n}\n<mat-card *ngIf=\"isAddingNew || editingIndex !== null\">\n <mat-card-header>\n <mat-card-subtitle>\n {{ isAddingNew ? 'Add a new' : 'Update' }} Segment\n </mat-card-subtitle>\n </mat-card-header>\n <mat-card-content>\n <form [formGroup]=\"segmentForm\" (ngSubmit)=\"saveSegment()\">\n <mat-toolbar class=\"segment-toolbar\">\n <mat-slide-toggle \n (change)=\"multiLevelSelectChange($event)\" \n [checked]=\"segmentForm.value.segmentExtension\">\n Enable Multi-Level Segmentation\n </mat-slide-toggle>\n \n </mat-toolbar>\n <mat-hint class=\"segment-hint\">\n This allows sub-classifications within this segment for more detailed accounting hierarchies\n </mat-hint>\n <mat-form-field subscriptSizing=\"dynamic\" floatLabel=\"always\" appearance=\"outline\">\n <mat-label>Segment</mat-label>\n <mat-select (selectionChange)=\"selectSegment($event)\" matNativeControl \n formControlName=\"segment\" [value]=\"value\" placeholder=\"Select segment\">\n @for ( segment of treeSegments; track segment.segment) {\n <mat-option [disabled]=\"alreadyExists(segment)\" [value]=\"segment.segment\"> \n {{ segment.label }}\n </mat-option>\n }\n </mat-select>\n \n </mat-form-field>\n <mat-hint class=\"segment-hint\">\n Select an account segment type from your chart of accounts\n </mat-hint>\n \n <mat-form-field subscriptSizing=\"dynamic\" floatLabel=\"always\" appearance=\"outline\">\n <mat-label>Label</mat-label>\n <input matInput formControlName=\"label\"\n [disabled]=\"!this.segmentForm.value.segmentExtension\"\n placeholder=\"Enter label\">\n <mat-hint>Provide a descriptive name for this segment (e.g., 'Department', 'Project', 'Cost Center')</mat-hint>\n </mat-form-field>\n \n <mat-toolbar class=\"segment-toolbar\">\n <mat-slide-toggle (change)=\"singleSelectChange($event)\" [checked]=\"segmentForm.value.singleSelect\">\n Single Value Selection\n </mat-slide-toggle>\n\n </mat-toolbar>\n <mat-hint class=\"segment-hint\">\n When enabled, transactions can only be assigned to one value within this segment. When disabled, transactions can be split across multiple values.\n </mat-hint>\n <mat-toolbar class=\"segment-toolbar\">\n <mat-slide-toggle (change)=\"readOnly($event)\" [checked]=\"segmentForm.value.readOnly\">\n Read-Only Segment\n </mat-slide-toggle>\n \n </mat-toolbar>\n <mat-hint class=\"segment-hint\">\n Prevents users from modifying segment values after initial setup. Use for regulatory or policy-controlled segments.\n </mat-hint>\n <mat-form-field subscriptSizing=\"dynamic\" floatLabel=\"always\" appearance=\"outline\">\n <mat-label>\n Additional accounts\n </mat-label>\n \n \n <mat-select (selectionChange)=\"additionalAccountsChanged($event)\" matNativeControl \n [value]=\"segmentForm.value.additionalAccounts\"\n formControlName=\"additionalAccounts\" multiple placeholder=\"Select counter accounts\">\n @for (ext of extensionAccountsForSegments; track ext) {\n <mat-option [value]=\"ext\">{{ext}}</mat-option>\n }\n </mat-select>\n </mat-form-field>\n \n <mat-hint class=\"segment-hint\">\n This allows you to add additional accounts to this segment. For example, VAT accounts, tax accounts, or any other\n </mat-hint>\n <br>\n <mat-card-actions>\n <button mat-flat-button color=\"primary\" type=\"submit\" [disabled]=\"!segmentForm.valid\">Save</button>\n <button mat-button (click)=\"cancelEdit()\">Cancel</button>\n </mat-card-actions>\n </form>\n </mat-card-content>\n</mat-card>\n\n<span color=\"danger\" *ngIf=\"error$ | async as error\">\n <p>{{ error }}</p>\n</span>", styles: [".info-icon{min-width:38px}.tree-instructions{display:flex;align-items:center;gap:8px;padding:12px;background:azure;border-radius:4px;margin-bottom:16px}.json-error{background:inherit;color:#e74c3c}mat-form-field{width:100%;margin-bottom:8px;background:azure}.segment-toolbar{background:azure}.icons{font-size:14px;height:14px;width:14px}.segment-hint{display:block;padding:0 16px;margin-bottom:8px;-webkit-font-smoothing:antialiased;font-family:var(--mat-form-field-subscript-text-font, var(--mat-sys-body-small-font));line-height:var(--mat-form-field-subscript-text-line-height, var(--mat-sys-body-small-line-height));font-size:var(--mat-form-field-subscript-text-size, var(--mat-sys-body-small-size));letter-spacing:var(--mat-form-field-subscript-text-tracking, var(--mat-sys-body-small-tracking));font-weight:var(--mat-form-field-subscript-text-weight, var(--mat-sys-body-small-weight))}mat-card{background:var(--mat-toolbar-container-background-color, var(--mat-sys-surface))}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatModulesModule }, { kind: "component", type: i3.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "component", type: i2$1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i3$1.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i3$1.MatCardActions, selector: "mat-card-actions", inputs: ["align"], exportAs: ["matCardActions"] }, { kind: "directive", type: i3$1.MatCardContent, selector: "mat-card-content" }, { kind: "component", type: i3$1.MatCardHeader, selector: "mat-card-header" }, { kind: "directive", type: i3$1.MatCardSubtitle, selector: "mat-card-subtitle, [mat-card-subtitle], [matCardSubtitle]" }, { kind: "component", type: i4.MatChipListbox, selector: "mat-chip-listbox", inputs: ["multiple", "aria-orientation", "selectable", "compareWith", "required", "hideSingleSelectionIndicator", "value"], outputs: ["change"] }, { kind: "component", type: i4.MatChipOption, selector: "mat-basic-chip-option, [mat-basic-chip-option], mat-chip-option, [mat-chip-option]", inputs: ["selectable", "selected"], outputs: ["selectionChange"] }, { kind: "directive", type: i4.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3$2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3$2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3$2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "component", type: i3$2.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth", "canSelectNullableOptions"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i9.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "color", "disabled", "disableRipple", "tabIndex", "checked", "hideIcon", "disabledInteractive"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { kind: "component", type: i9$1.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "directive", type: i12.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly", "disabledInteractive"], exportAs: ["matInput"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: FormsModule }] }); }
248
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.6", type: MscoaSegmentConfigComponent, isStandalone: true, selector: "app-mscoa-segment-config", inputs: { disabled: "disabled", errors: "errors", dataValue: "dataValue", value: "value", showAllSegments: "showAllSegments", getMscoaTree: "getMscoaTree" }, outputs: { valueChanged: "valueChanged" }, host: { properties: { "id": "this.id" } }, providers: [{ provide: MatFormFieldControl, useExisting: MscoaSegmentConfigComponent }], ngImport: i0, template: "<div *ngIf=\"(value||[]).length>0\" class=\"tree-instructions\">\n <mat-icon class=\"info-icon\" color=\"primary\">info</mat-icon>\n <span>SCOA Segments Configuration</span>\n</div>\n\n<mat-chip-listbox [disabled]=\"disabled\" *ngIf=\"(value?.length || 0) > 0; else noSegments\" aria-label=\"Fish selection\">\n @for (segment of value||[]; track segment.segment) {\n <mat-chip-option (removed)=\"removeSegment($index)\" (click)=\"startEdit($index)\" color=\"accent\"\n [value]=\"segment?.segment\" [selected]=\"this.editingIndex === $index\">\n <div style=\" \n display: flex;\n align-items: center;\n gap: 1px;\">\n <span style=\"margin-right: 2px;\">\n {{ segment.label }}\n </span>\n <mat-icon class=\"icons\">\n {{ segment.singleSelect ? 'done' : ' done_all' }}\n </mat-icon>\n <mat-icon class=\"icons\">\n\n {{ segment.readOnly ? 'edit_off' : 'edit' }}\n </mat-icon>\n </div>\n\n @if ( showAllSegments === false) {\n <button matChipRemove [attr.aria-label]=\"'remove' \">\n <mat-icon>cancel</mat-icon>\n </button>\n }\n\n </mat-chip-option>\n }\n</mat-chip-listbox>\n\n\n\n\n\n<ng-template #noSegments>\n <div class=\"tree-instructions\">\n <mat-icon class=\"info-icon\" color=\"primary\">info</mat-icon>\n <span>No segment configuration available. Start by adding a segment below.</span>\n </div>\n</ng-template>\n\n<mat-toolbar *ngIf=\"!isAddingNew && editingIndex === null && showAllSegments === false\">\n <button style=\"width:100%\" \n [disabled]=\"disabled\"\n mat-stroked-button (click)=\"startAddNew()\">\n Add New Segment <mat-icon>add</mat-icon>\n </button>\n</mat-toolbar>\n\n@if (!!getMscoaError) {\n<div class=\"tree-instructions\">\n <mat-icon class=\"info-icon\" color=\"primary\">info</mat-icon>\n <span>\n {{ getMscoaError }}\n </span>\n</div>\n}\n<mat-card *ngIf=\"isAddingNew || editingIndex !== null\">\n <mat-card-header>\n <mat-card-subtitle>\n {{ isAddingNew ? 'Add a new' : 'Update' }} Segment\n </mat-card-subtitle>\n </mat-card-header>\n <mat-card-content>\n <form [formGroup]=\"segmentForm\" (ngSubmit)=\"saveSegment()\">\n <mat-toolbar class=\"segment-toolbar\">\n <mat-slide-toggle \n (change)=\"multiLevelSelectChange($event)\" \n [checked]=\"segmentForm.value.segmentExtension\">\n Enable Multi-Level Segmentation\n </mat-slide-toggle>\n \n </mat-toolbar>\n <mat-hint class=\"segment-hint\">\n This allows sub-classifications within this segment for more detailed accounting hierarchies\n </mat-hint>\n <mat-form-field subscriptSizing=\"dynamic\" floatLabel=\"always\" appearance=\"outline\">\n <mat-label>Segment</mat-label>\n <mat-select (selectionChange)=\"selectSegment($event)\" matNativeControl \n formControlName=\"segment\" [value]=\"value\" placeholder=\"Select segment\">\n @for ( segment of treeSegments; track segment.segment) {\n <mat-option [disabled]=\"alreadyExists(segment)\" [value]=\"segment.segment\"> \n {{ segment.label }}\n </mat-option>\n }\n </mat-select>\n \n </mat-form-field>\n <mat-hint class=\"segment-hint\">\n Select an account segment type from your chart of accounts\n </mat-hint>\n \n <mat-form-field subscriptSizing=\"dynamic\" floatLabel=\"always\" appearance=\"outline\">\n <mat-label>Label</mat-label>\n <input matInput formControlName=\"label\"\n [disabled]=\"!this.segmentForm.value.segmentExtension\"\n placeholder=\"Enter label\">\n <mat-hint>Provide a descriptive name for this segment (e.g., 'Department', 'Project', 'Cost Center')</mat-hint>\n </mat-form-field>\n \n <mat-toolbar class=\"segment-toolbar\">\n <mat-slide-toggle (change)=\"singleSelectChange($event)\" [checked]=\"segmentForm.value.singleSelect\">\n Single Value Selection\n </mat-slide-toggle>\n\n </mat-toolbar>\n <mat-hint class=\"segment-hint\">\n When enabled, transactions can only be assigned to one value within this segment. When disabled, transactions can be split across multiple values.\n </mat-hint>\n <mat-toolbar class=\"segment-toolbar\">\n <mat-slide-toggle (change)=\"readOnly($event)\" [checked]=\"segmentForm.value.readOnly\">\n Read-Only Segment\n </mat-slide-toggle>\n \n </mat-toolbar>\n <mat-hint class=\"segment-hint\">\n Prevents users from modifying segment values after initial setup. Use for regulatory or policy-controlled segments.\n </mat-hint>\n <mat-form-field subscriptSizing=\"dynamic\" floatLabel=\"always\" appearance=\"outline\">\n <mat-label>\n Additional accounts\n </mat-label>\n \n \n <mat-select (selectionChange)=\"additionalAccountsChanged($event)\" matNativeControl \n [value]=\"segmentForm.value.additionalAccounts\"\n formControlName=\"additionalAccounts\" multiple placeholder=\"Select counter accounts\">\n @for (ext of extensionAccountsForSegments; track ext) {\n <mat-option [value]=\"ext\">{{ext}}</mat-option>\n }\n </mat-select>\n </mat-form-field>\n \n <mat-hint class=\"segment-hint\">\n This allows you to add additional accounts to this segment. For example, VAT accounts, tax accounts, or any other\n </mat-hint>\n <br>\n <mat-card-actions>\n <button mat-flat-button color=\"primary\" type=\"submit\" [disabled]=\"!segmentForm.valid\">Save</button>\n <button mat-button (click)=\"cancelEdit()\">Cancel</button>\n </mat-card-actions>\n </form>\n </mat-card-content>\n</mat-card>\n\n<span color=\"danger\" *ngIf=\"error$ | async as error\">\n <p>{{ error }}</p>\n</span>", styles: [".info-icon{min-width:38px}.tree-instructions{display:flex;align-items:center;gap:8px;padding:12px;background:azure;border-radius:4px;margin-bottom:16px}.json-error{background:inherit;color:#e74c3c}mat-form-field{width:100%;margin-bottom:8px;background:azure}.segment-toolbar{background:azure}.icons{font-size:14px;height:14px;width:14px}.segment-hint{display:block;padding:0 16px;margin-bottom:8px;-webkit-font-smoothing:antialiased;font-family:var(--mat-form-field-subscript-text-font, var(--mat-sys-body-small-font));line-height:var(--mat-form-field-subscript-text-line-height, var(--mat-sys-body-small-line-height));font-size:var(--mat-form-field-subscript-text-size, var(--mat-sys-body-small-size));letter-spacing:var(--mat-form-field-subscript-text-tracking, var(--mat-sys-body-small-tracking));font-weight:var(--mat-form-field-subscript-text-weight, var(--mat-sys-body-small-weight))}mat-card{background:var(--mat-sys-surface-container, var(--mat-sys-surface))}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatModulesModule }, { kind: "component", type: i3.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "component", type: i2$1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i3$1.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i3$1.MatCardActions, selector: "mat-card-actions", inputs: ["align"], exportAs: ["matCardActions"] }, { kind: "directive", type: i3$1.MatCardContent, selector: "mat-card-content" }, { kind: "component", type: i3$1.MatCardHeader, selector: "mat-card-header" }, { kind: "directive", type: i3$1.MatCardSubtitle, selector: "mat-card-subtitle, [mat-card-subtitle], [matCardSubtitle]" }, { kind: "component", type: i4.MatChipListbox, selector: "mat-chip-listbox", inputs: ["multiple", "aria-orientation", "selectable", "compareWith", "required", "hideSingleSelectionIndicator", "value"], outputs: ["change"] }, { kind: "component", type: i4.MatChipOption, selector: "mat-basic-chip-option, [mat-basic-chip-option], mat-chip-option, [mat-chip-option]", inputs: ["selectable", "selected"], outputs: ["selectionChange"] }, { kind: "directive", type: i4.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3$2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3$2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3$2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "component", type: i3$2.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth", "canSelectNullableOptions"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i9.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "color", "disabled", "disableRipple", "tabIndex", "checked", "hideIcon", "disabledInteractive"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { kind: "component", type: i9$1.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "directive", type: i12.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly", "disabledInteractive"], exportAs: ["matInput"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: FormsModule }] }); }
250
249
  }
251
250
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.6", ngImport: i0, type: MscoaSegmentConfigComponent, decorators: [{
252
251
  type: Component,
@@ -255,7 +254,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.6", ngImpor
255
254
  MatModulesModule,
256
255
  ReactiveFormsModule,
257
256
  FormsModule
258
- ], providers: [{ provide: MatFormFieldControl, useExisting: MscoaSegmentConfigComponent }], template: "<div *ngIf=\"(value||[]).length>0\" class=\"tree-instructions\">\n <mat-icon class=\"info-icon\" color=\"primary\">info</mat-icon>\n <span>SCOA Segments Configuration</span>\n</div>\n\n<mat-chip-listbox [disabled]=\"disabled\" *ngIf=\"(value?.length || 0) > 0; else noSegments\" aria-label=\"Fish selection\">\n @for (segment of value||[]; track segment.segment) {\n <mat-chip-option (removed)=\"removeSegment($index)\" (click)=\"startEdit($index)\" color=\"accent\"\n [value]=\"segment?.segment\" [selected]=\"this.editingIndex === $index\">\n <div style=\" \n display: flex;\n align-items: center;\n gap: 1px;\">\n <span style=\"margin-right: 2px;\">\n {{ segment.label }}\n </span>\n <mat-icon class=\"icons\">\n {{ segment.singleSelect ? 'done' : ' done_all' }}\n </mat-icon>\n <mat-icon class=\"icons\">\n\n {{ segment.readOnly ? 'edit_off' : 'edit' }}\n </mat-icon>\n </div>\n\n @if ( showAllSegments === false) {\n <button matChipRemove [attr.aria-label]=\"'remove' \">\n <mat-icon>cancel</mat-icon>\n </button>\n }\n\n </mat-chip-option>\n }\n</mat-chip-listbox>\n\n\n\n\n\n<ng-template #noSegments>\n <div class=\"tree-instructions\">\n <mat-icon class=\"info-icon\" color=\"primary\">info</mat-icon>\n <span>No segment configuration available. Start by adding a segment below.</span>\n </div>\n</ng-template>\n\n<mat-toolbar *ngIf=\"!isAddingNew && editingIndex === null && showAllSegments === false\">\n <button style=\"width:100%\" \n [disabled]=\"disabled\"\n mat-stroked-button (click)=\"startAddNew()\">\n Add New Segment <mat-icon>add</mat-icon>\n </button>\n</mat-toolbar>\n\n@if (!!getMscoaError) {\n<div class=\"tree-instructions\">\n <mat-icon class=\"info-icon\" color=\"primary\">info</mat-icon>\n <span>\n {{ getMscoaError }}\n </span>\n</div>\n}\n<mat-card *ngIf=\"isAddingNew || editingIndex !== null\">\n <mat-card-header>\n <mat-card-subtitle>\n {{ isAddingNew ? 'Add a new' : 'Update' }} Segment\n </mat-card-subtitle>\n </mat-card-header>\n <mat-card-content>\n <form [formGroup]=\"segmentForm\" (ngSubmit)=\"saveSegment()\">\n <mat-toolbar class=\"segment-toolbar\">\n <mat-slide-toggle \n (change)=\"multiLevelSelectChange($event)\" \n [checked]=\"segmentForm.value.segmentExtension\">\n Enable Multi-Level Segmentation\n </mat-slide-toggle>\n \n </mat-toolbar>\n <mat-hint class=\"segment-hint\">\n This allows sub-classifications within this segment for more detailed accounting hierarchies\n </mat-hint>\n <mat-form-field subscriptSizing=\"dynamic\" floatLabel=\"always\" appearance=\"outline\">\n <mat-label>Segment</mat-label>\n <mat-select (selectionChange)=\"selectSegment($event)\" matNativeControl \n formControlName=\"segment\" [value]=\"value\" placeholder=\"Select segment\">\n @for ( segment of treeSegments; track segment.segment) {\n <mat-option [disabled]=\"alreadyExists(segment)\" [value]=\"segment.segment\"> \n {{ segment.label }}\n </mat-option>\n }\n </mat-select>\n \n </mat-form-field>\n <mat-hint class=\"segment-hint\">\n Select an account segment type from your chart of accounts\n </mat-hint>\n \n <mat-form-field subscriptSizing=\"dynamic\" floatLabel=\"always\" appearance=\"outline\">\n <mat-label>Label</mat-label>\n <input matInput formControlName=\"label\"\n [disabled]=\"!this.segmentForm.value.segmentExtension\"\n placeholder=\"Enter label\">\n <mat-hint>Provide a descriptive name for this segment (e.g., 'Department', 'Project', 'Cost Center')</mat-hint>\n </mat-form-field>\n \n <mat-toolbar class=\"segment-toolbar\">\n <mat-slide-toggle (change)=\"singleSelectChange($event)\" [checked]=\"segmentForm.value.singleSelect\">\n Single Value Selection\n </mat-slide-toggle>\n\n </mat-toolbar>\n <mat-hint class=\"segment-hint\">\n When enabled, transactions can only be assigned to one value within this segment. When disabled, transactions can be split across multiple values.\n </mat-hint>\n <mat-toolbar class=\"segment-toolbar\">\n <mat-slide-toggle (change)=\"readOnly($event)\" [checked]=\"segmentForm.value.readOnly\">\n Read-Only Segment\n </mat-slide-toggle>\n \n </mat-toolbar>\n <mat-hint class=\"segment-hint\">\n Prevents users from modifying segment values after initial setup. Use for regulatory or policy-controlled segments.\n </mat-hint>\n <mat-form-field subscriptSizing=\"dynamic\" floatLabel=\"always\" appearance=\"outline\">\n <mat-label>\n Additional accounts\n </mat-label>\n \n \n <mat-select (selectionChange)=\"additionalAccountsChanged($event)\" matNativeControl \n [value]=\"segmentForm.value.additionalAccounts\"\n formControlName=\"additionalAccounts\" multiple placeholder=\"Select counter accounts\">\n @for (ext of extensionAccountsForSegments; track ext) {\n <mat-option [value]=\"ext\">{{ext}}</mat-option>\n }\n </mat-select>\n </mat-form-field>\n \n <mat-hint class=\"segment-hint\">\n This allows you to add additional accounts to this segment. For example, VAT accounts, tax accounts, or any other\n </mat-hint>\n <br>\n <mat-card-actions>\n <button mat-flat-button color=\"primary\" type=\"submit\" [disabled]=\"!segmentForm.valid\">Save</button>\n <button mat-button (click)=\"cancelEdit()\">Cancel</button>\n </mat-card-actions>\n </form>\n </mat-card-content>\n</mat-card>\n\n<span color=\"danger\" *ngIf=\"error$ | async as error\">\n <p>{{ error }}</p>\n</span>", styles: [".info-icon{min-width:38px}.tree-instructions{display:flex;align-items:center;gap:8px;padding:12px;background:azure;border-radius:4px;margin-bottom:16px}.json-error{background:inherit;color:#e74c3c}mat-form-field{width:100%;margin-bottom:8px;background:azure}.segment-toolbar{background:azure}.icons{font-size:14px;height:14px;width:14px}.segment-hint{display:block;padding:0 16px;margin-bottom:8px;-webkit-font-smoothing:antialiased;font-family:var(--mat-form-field-subscript-text-font, var(--mat-sys-body-small-font));line-height:var(--mat-form-field-subscript-text-line-height, var(--mat-sys-body-small-line-height));font-size:var(--mat-form-field-subscript-text-size, var(--mat-sys-body-small-size));letter-spacing:var(--mat-form-field-subscript-text-tracking, var(--mat-sys-body-small-tracking));font-weight:var(--mat-form-field-subscript-text-weight, var(--mat-sys-body-small-weight))}mat-card{background:var(--mat-toolbar-container-background-color, var(--mat-sys-surface))}\n"] }]
257
+ ], providers: [{ provide: MatFormFieldControl, useExisting: MscoaSegmentConfigComponent }], template: "<div *ngIf=\"(value||[]).length>0\" class=\"tree-instructions\">\n <mat-icon class=\"info-icon\" color=\"primary\">info</mat-icon>\n <span>SCOA Segments Configuration</span>\n</div>\n\n<mat-chip-listbox [disabled]=\"disabled\" *ngIf=\"(value?.length || 0) > 0; else noSegments\" aria-label=\"Fish selection\">\n @for (segment of value||[]; track segment.segment) {\n <mat-chip-option (removed)=\"removeSegment($index)\" (click)=\"startEdit($index)\" color=\"accent\"\n [value]=\"segment?.segment\" [selected]=\"this.editingIndex === $index\">\n <div style=\" \n display: flex;\n align-items: center;\n gap: 1px;\">\n <span style=\"margin-right: 2px;\">\n {{ segment.label }}\n </span>\n <mat-icon class=\"icons\">\n {{ segment.singleSelect ? 'done' : ' done_all' }}\n </mat-icon>\n <mat-icon class=\"icons\">\n\n {{ segment.readOnly ? 'edit_off' : 'edit' }}\n </mat-icon>\n </div>\n\n @if ( showAllSegments === false) {\n <button matChipRemove [attr.aria-label]=\"'remove' \">\n <mat-icon>cancel</mat-icon>\n </button>\n }\n\n </mat-chip-option>\n }\n</mat-chip-listbox>\n\n\n\n\n\n<ng-template #noSegments>\n <div class=\"tree-instructions\">\n <mat-icon class=\"info-icon\" color=\"primary\">info</mat-icon>\n <span>No segment configuration available. Start by adding a segment below.</span>\n </div>\n</ng-template>\n\n<mat-toolbar *ngIf=\"!isAddingNew && editingIndex === null && showAllSegments === false\">\n <button style=\"width:100%\" \n [disabled]=\"disabled\"\n mat-stroked-button (click)=\"startAddNew()\">\n Add New Segment <mat-icon>add</mat-icon>\n </button>\n</mat-toolbar>\n\n@if (!!getMscoaError) {\n<div class=\"tree-instructions\">\n <mat-icon class=\"info-icon\" color=\"primary\">info</mat-icon>\n <span>\n {{ getMscoaError }}\n </span>\n</div>\n}\n<mat-card *ngIf=\"isAddingNew || editingIndex !== null\">\n <mat-card-header>\n <mat-card-subtitle>\n {{ isAddingNew ? 'Add a new' : 'Update' }} Segment\n </mat-card-subtitle>\n </mat-card-header>\n <mat-card-content>\n <form [formGroup]=\"segmentForm\" (ngSubmit)=\"saveSegment()\">\n <mat-toolbar class=\"segment-toolbar\">\n <mat-slide-toggle \n (change)=\"multiLevelSelectChange($event)\" \n [checked]=\"segmentForm.value.segmentExtension\">\n Enable Multi-Level Segmentation\n </mat-slide-toggle>\n \n </mat-toolbar>\n <mat-hint class=\"segment-hint\">\n This allows sub-classifications within this segment for more detailed accounting hierarchies\n </mat-hint>\n <mat-form-field subscriptSizing=\"dynamic\" floatLabel=\"always\" appearance=\"outline\">\n <mat-label>Segment</mat-label>\n <mat-select (selectionChange)=\"selectSegment($event)\" matNativeControl \n formControlName=\"segment\" [value]=\"value\" placeholder=\"Select segment\">\n @for ( segment of treeSegments; track segment.segment) {\n <mat-option [disabled]=\"alreadyExists(segment)\" [value]=\"segment.segment\"> \n {{ segment.label }}\n </mat-option>\n }\n </mat-select>\n \n </mat-form-field>\n <mat-hint class=\"segment-hint\">\n Select an account segment type from your chart of accounts\n </mat-hint>\n \n <mat-form-field subscriptSizing=\"dynamic\" floatLabel=\"always\" appearance=\"outline\">\n <mat-label>Label</mat-label>\n <input matInput formControlName=\"label\"\n [disabled]=\"!this.segmentForm.value.segmentExtension\"\n placeholder=\"Enter label\">\n <mat-hint>Provide a descriptive name for this segment (e.g., 'Department', 'Project', 'Cost Center')</mat-hint>\n </mat-form-field>\n \n <mat-toolbar class=\"segment-toolbar\">\n <mat-slide-toggle (change)=\"singleSelectChange($event)\" [checked]=\"segmentForm.value.singleSelect\">\n Single Value Selection\n </mat-slide-toggle>\n\n </mat-toolbar>\n <mat-hint class=\"segment-hint\">\n When enabled, transactions can only be assigned to one value within this segment. When disabled, transactions can be split across multiple values.\n </mat-hint>\n <mat-toolbar class=\"segment-toolbar\">\n <mat-slide-toggle (change)=\"readOnly($event)\" [checked]=\"segmentForm.value.readOnly\">\n Read-Only Segment\n </mat-slide-toggle>\n \n </mat-toolbar>\n <mat-hint class=\"segment-hint\">\n Prevents users from modifying segment values after initial setup. Use for regulatory or policy-controlled segments.\n </mat-hint>\n <mat-form-field subscriptSizing=\"dynamic\" floatLabel=\"always\" appearance=\"outline\">\n <mat-label>\n Additional accounts\n </mat-label>\n \n \n <mat-select (selectionChange)=\"additionalAccountsChanged($event)\" matNativeControl \n [value]=\"segmentForm.value.additionalAccounts\"\n formControlName=\"additionalAccounts\" multiple placeholder=\"Select counter accounts\">\n @for (ext of extensionAccountsForSegments; track ext) {\n <mat-option [value]=\"ext\">{{ext}}</mat-option>\n }\n </mat-select>\n </mat-form-field>\n \n <mat-hint class=\"segment-hint\">\n This allows you to add additional accounts to this segment. For example, VAT accounts, tax accounts, or any other\n </mat-hint>\n <br>\n <mat-card-actions>\n <button mat-flat-button color=\"primary\" type=\"submit\" [disabled]=\"!segmentForm.valid\">Save</button>\n <button mat-button (click)=\"cancelEdit()\">Cancel</button>\n </mat-card-actions>\n </form>\n </mat-card-content>\n</mat-card>\n\n<span color=\"danger\" *ngIf=\"error$ | async as error\">\n <p>{{ error }}</p>\n</span>", styles: [".info-icon{min-width:38px}.tree-instructions{display:flex;align-items:center;gap:8px;padding:12px;background:azure;border-radius:4px;margin-bottom:16px}.json-error{background:inherit;color:#e74c3c}mat-form-field{width:100%;margin-bottom:8px;background:azure}.segment-toolbar{background:azure}.icons{font-size:14px;height:14px;width:14px}.segment-hint{display:block;padding:0 16px;margin-bottom:8px;-webkit-font-smoothing:antialiased;font-family:var(--mat-form-field-subscript-text-font, var(--mat-sys-body-small-font));line-height:var(--mat-form-field-subscript-text-line-height, var(--mat-sys-body-small-line-height));font-size:var(--mat-form-field-subscript-text-size, var(--mat-sys-body-small-size));letter-spacing:var(--mat-form-field-subscript-text-tracking, var(--mat-sys-body-small-tracking));font-weight:var(--mat-form-field-subscript-text-weight, var(--mat-sys-body-small-weight))}mat-card{background:var(--mat-sys-surface-container, var(--mat-sys-surface))}\n"] }]
259
258
  }], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i1.NgControl, decorators: [{
260
259
  type: Optional
261
260
  }, {
@@ -279,4 +278,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.6", ngImpor
279
278
  }] } });
280
279
 
281
280
  export { MscoaSegmentConfigComponent };
282
- //# sourceMappingURL=ngx-t-forms-mscoa-segment-config.component-C1zx7OZB.mjs.map
281
+ //# sourceMappingURL=ngx-t-forms-mscoa-segment-config.component-DqCaJoe6.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ngx-t-forms-mscoa-segment-config.component-DqCaJoe6.mjs","sources":["../../../projects/ngx-t-forms/src/lib/components/t-dynamic-data-edit/elements/mscoa-segment-config/mscoa-segment-config.component.ts","../../../projects/ngx-t-forms/src/lib/components/t-dynamic-data-edit/elements/mscoa-segment-config/mscoa-segment-config.component.html"],"sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, ElementRef, EventEmitter, HostBinding, inject, Input, OnDestroy, OnInit, Optional, Output, Self } from '@angular/core';\r\nimport { FormGroup, FormBuilder, Validators, ReactiveFormsModule, NgControl, FormsModule } from '@angular/forms';\r\nimport { BehaviorSubject, catchError, Observable, Subject, take, takeUntil, tap } from 'rxjs';\r\n\r\nimport { MatModulesModule } from '../../../../shared/modules/mat-modules.module';\r\nimport { IGetTreeResponse, IIncludedSegmentConfig } from 'ngx-t-forms-types';\r\n\r\nimport { MatSlideToggleChange } from '@angular/material/slide-toggle';\r\nimport { MatFormFieldControl } from '@angular/material/form-field';\r\nimport { IConfigElementError } from '../../t-dynamic-data-edit.component';\r\nimport { MatSelectChange } from '@angular/material/select';\r\nimport { v4 as uuidv4 } from 'uuid';\r\n\r\nimport { LiveAnnouncer } from '@angular/cdk/a11y';\r\nimport { IScoaInput } from 'ngx-t-forms-types';\r\n@Component({\r\n selector: 'app-mscoa-segment-config',\r\n templateUrl: './mscoa-segment-config.component.html',\r\n styleUrls: ['./mscoa-segment-config.component.scss'],\r\n standalone: true,\r\n imports: [\r\n CommonModule,\r\n MatModulesModule,\r\n ReactiveFormsModule,\r\n FormsModule\r\n ],\r\n providers: [{ provide: MatFormFieldControl, useExisting: MscoaSegmentConfigComponent }],\r\n\r\n})\r\nexport class MscoaSegmentConfigComponent implements OnInit, OnDestroy, MatFormFieldControl<IIncludedSegmentConfig[] | undefined> {\r\n readonly announcer = inject(LiveAnnouncer);\r\n static nextId = 0;\r\n stateChanges = new Subject<void>();\r\n\r\n @HostBinding() id = `app-mscoa-segment-config'-${MscoaSegmentConfigComponent.nextId++}`;\r\n\r\n placeholder: string = ''\r\n constructor(\r\n private fb: FormBuilder,\r\n @Optional() @Self() public ngControl: NgControl, private _elementRef: ElementRef<HTMLElement>,\r\n ) {\r\n this.segmentForm = this.createSegmentForm();\r\n\r\n }\r\n\r\n focused: boolean = false;\r\n get empty() {\r\n return !this.value\r\n }\r\n get shouldLabelFloat() {\r\n return this.focused || !this.empty;\r\n }\r\n required: boolean = false;\r\n @Input() disabled: boolean = false;\r\n get errorState(): boolean {\r\n const hasError = !!this.ngControl?.control?.errors || (this.errors || []).length > 0 && this.touched\r\n return !this.value && !!this.required || hasError\r\n }\r\n\r\n controlType?: string | undefined;\r\n autofilled?: boolean | undefined;\r\n userAriaDescribedBy?: string | undefined;\r\n disableAutomaticLabeling?: boolean | undefined;\r\n setDescribedByIds(ids: string[]) {\r\n // Ensure the component view is initialized\r\n if (this._elementRef && this._elementRef.nativeElement) {\r\n const controlElement = this._elementRef.nativeElement.querySelector('.app-mscoa-segment-config');\r\n // Check if the controlElement exists before attempting to set its attribute\r\n if (controlElement) {\r\n controlElement.setAttribute('aria-describedby', ids.join(' '));\r\n }\r\n }\r\n }\r\n onContainerClick(event: MouseEvent): void {\r\n this.markAsTouched();\r\n this.stateChanges.next();\r\n }\r\n\r\n touched: boolean = false;\r\n onTouched = () => { };\r\n markAsTouched() {\r\n console.log('markAsTouched')\r\n if (!this.touched) {\r\n this.onTouched();\r\n this.touched = true;\r\n }\r\n }\r\n\r\n\r\n @Input() errors: IConfigElementError[] | undefined = [];\r\n @Input() dataValue: IScoaInput | undefined = undefined;\r\n @Input() set value(val: IIncludedSegmentConfig[]) {\r\n this._value.next(val || []);\r\n }\r\n\r\n get value(): IIncludedSegmentConfig[] {\r\n return this._value.value;\r\n }\r\n _getMscoaTree: Observable<IGetTreeResponse | undefined> | undefined;\r\n _showAllSegments: boolean = false;\r\n @Input() set showAllSegments(val: boolean) {\r\n\r\n if (!!val) {\r\n this.checkShowAllSegments()\r\n }\r\n this._showAllSegments = !!val\r\n\r\n }\r\n get showAllSegments() {\r\n return this._showAllSegments\r\n }\r\n\r\n @Input() set getMscoaTree(options$: Observable<IGetTreeResponse | undefined>) {\r\n if (!!options$ && this._getMscoaTree === undefined) {\r\n this.getMscoaError = undefined\r\n this._getMscoaTree = options$\r\n\r\n this.loadMscoa()\r\n } else if (!options$) {\r\n this.getMscoaError = 'No loader provided'\r\n\r\n }\r\n }\r\n @Output() valueChanged = new EventEmitter<IIncludedSegmentConfig[]>();\r\n private _value = new BehaviorSubject<IIncludedSegmentConfig[]>([]);\r\n private destroy$ = new Subject<void>();\r\n mscoaTree!: IGetTreeResponse | undefined;\r\n treeSegments!: IIncludedSegmentConfig[];\r\n error$ = new BehaviorSubject<string | null>(null);\r\n\r\n segmentForm: FormGroup;\r\n editingIndex: number | null = null;\r\n isAddingNew = false;\r\n\r\n\r\n\r\n ngOnInit() {\r\n this.listenToFormChanges();\r\n }\r\n\r\n ngOnDestroy() {\r\n this.destroy$.next();\r\n this.destroy$.complete();\r\n }\r\n getMscoaError: string | undefined = undefined\r\n private loadMscoa() {\r\n\r\n this._getMscoaTree?.pipe(\r\n take(1),\r\n tap((options) => {\r\n this.mscoaTree = options;\r\n this.treeSegments = options?.accountTreeKeys?.map((treeKey) => ({\r\n id: uuidv4(),\r\n segment: treeKey,\r\n singleSelect: true,\r\n additionalAccounts: [],\r\n segmentExtension: false,\r\n label: this.toTitleCase(treeKey),\r\n readOnly: this.value.find((v) => v.segment === treeKey)?.readOnly || false,\r\n })) || [];\r\n }),\r\n catchError((error) => {\r\n this.getMscoaError = 'Failed to fetch mscoa tree';\r\n console.error('Error while fetching SCOA tree:', error);\r\n return [null];\r\n })\r\n ).subscribe();\r\n }\r\n private createSegmentForm(segment: IIncludedSegmentConfig = {\r\n segment: '', label: '',\r\n id: uuidv4(),\r\n singleSelect: true,\r\n segmentExtension: false,\r\n additionalAccounts: [],\r\n readOnly: false\r\n } as any): FormGroup {\r\n return this.fb.group({\r\n segment: [segment.segment, Validators.required],\r\n segmentExtension: [segment.segmentExtension, Validators.required],\r\n readOnly: [segment.readOnly, Validators.required],\r\n additionalAccounts: [(segment as any).additionalAccounts || [],],\r\n label: [segment.label, Validators.required],\r\n singleSelect: [segment.singleSelect, Validators.required]\r\n });\r\n }\r\n\r\n private listenToFormChanges() {\r\n this.segmentForm.valueChanges\r\n .pipe(takeUntil(this.destroy$))\r\n .subscribe((v) => console.log(v));\r\n }\r\n\r\n startAddNew() {\r\n this.isAddingNew = true;\r\n this.editingIndex = null;\r\n this.segmentForm = this.createSegmentForm();\r\n }\r\n\r\n startEdit(index: number) {\r\n this.editingIndex = index;\r\n this.isAddingNew = false;\r\n this.segmentForm = this.createSegmentForm(this.value[index]);\r\n }\r\n\r\n cancelEdit() {\r\n this.editingIndex = null;\r\n this.isAddingNew = false;\r\n this.segmentForm.reset();\r\n }\r\n\r\n saveSegment() {\r\n if (this.segmentForm.valid) {\r\n const newSegment = ({\r\n id: this.segmentForm.value.id || uuidv4(),\r\n segment: this.segmentForm.value.segment,\r\n customSegment: !!this.segmentForm.value.segmentExtension ? (this.segmentForm.value.label as string)?.toLocaleUpperCase() : undefined,\r\n segmentExtension: this.segmentForm.value.segmentExtension,\r\n additionalAccounts: this.segmentForm.value.additionalAccounts,\r\n label: this.toTitleCase(this.segmentForm.value.label),\r\n singleSelect: this.segmentForm.value.singleSelect,\r\n readOnly: this.segmentForm.value.readOnly\r\n })\r\n const updatedValue = [...this.value];\r\n\r\n if (this.isAddingNew) {\r\n updatedValue.push(newSegment);\r\n } else if (this.editingIndex !== null) {\r\n updatedValue[this.editingIndex] = newSegment;\r\n }\r\n\r\n\r\n this._value.next(updatedValue);\r\n this.valueChanged.emit(updatedValue);\r\n this.cancelEdit();\r\n }\r\n }\r\n readOnly(event: MatSlideToggleChange) {\r\n this.segmentForm.patchValue({ readOnly: event.checked })\r\n }\r\n singleSelectChange(event: MatSlideToggleChange) {\r\n this.segmentForm.patchValue({ singleSelect: event.checked })\r\n\r\n }\r\n removeSegment(index: number) {\r\n const updatedValue = this.value.filter((_, i) => i !== index);\r\n this._value.next(updatedValue);\r\n this.valueChanged.emit(updatedValue);\r\n }\r\n\r\n private toTitleCase(str: string): string {\r\n return str.replace(/\\w\\S*/g, (txt) => txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase());\r\n }\r\n alreadyExists(segment: IIncludedSegmentConfig) {\r\n if (this.segmentForm.value.segmentExtension) return false\r\n return this.value.find((v) => v.segment === segment.segment)\r\n }\r\n checkShowAllSegments() {\r\n if (!this._getMscoaTree || !this.treeSegments) return;\r\n\r\n const updatedValue = this.treeSegments.map(segment => ({\r\n ...segment,\r\n ...(this.value.find(v => v.segment === segment.segment) || {})\r\n }));\r\n\r\n if (JSON.stringify(updatedValue) !== JSON.stringify(this.value)) {\r\n this.valueChanged.emit([{} as any]);\r\n setTimeout(() => {\r\n this.valueChanged.emit(updatedValue);\r\n }, 0);\r\n }\r\n }\r\n selectSegment($event: MatSelectChange<any>) {\r\n\r\n this.segmentForm.patchValue({ segment: $event.value })\r\n if (!this.segmentForm.value.segmentExtension) {\r\n this.segmentForm.patchValue({ label: this.toTitleCase($event.value) })\r\n }\r\n\r\n\r\n }\r\n multiLevelSelectChange(event: MatSlideToggleChange) {\r\n this.segmentForm.patchValue({ segmentExtension: event.checked })\r\n }\r\n\r\n\r\n get extensionAccountsForSegments():string[]{\r\n console.error('get extensionAccountsForSegments', this.dataValue?.mscoaConfig?.extensionAccountsForSegments)\r\n return this.dataValue?.mscoaConfig?.extensionAccountsForSegments || []\r\n }\r\n additionalAccountsChanged(event: MatSelectChange) {\r\n // Force update by creating a new array\r\n const newAdditionalAccounts = [...event.value];\r\n \r\n this.segmentForm.patchValue({\r\n additionalAccounts: newAdditionalAccounts\r\n }, { emitEvent: true });\r\n\r\n // Trigger state changes\r\n this.stateChanges.next();\r\n this.markAsTouched();\r\n }\r\n}","<div *ngIf=\"(value||[]).length>0\" class=\"tree-instructions\">\n <mat-icon class=\"info-icon\" color=\"primary\">info</mat-icon>\n <span>SCOA Segments Configuration</span>\n</div>\n\n<mat-chip-listbox [disabled]=\"disabled\" *ngIf=\"(value?.length || 0) > 0; else noSegments\" aria-label=\"Fish selection\">\n @for (segment of value||[]; track segment.segment) {\n <mat-chip-option (removed)=\"removeSegment($index)\" (click)=\"startEdit($index)\" color=\"accent\"\n [value]=\"segment?.segment\" [selected]=\"this.editingIndex === $index\">\n <div style=\" \n display: flex;\n align-items: center;\n gap: 1px;\">\n <span style=\"margin-right: 2px;\">\n {{ segment.label }}\n </span>\n <mat-icon class=\"icons\">\n {{ segment.singleSelect ? 'done' : ' done_all' }}\n </mat-icon>\n <mat-icon class=\"icons\">\n\n {{ segment.readOnly ? 'edit_off' : 'edit' }}\n </mat-icon>\n </div>\n\n @if ( showAllSegments === false) {\n <button matChipRemove [attr.aria-label]=\"'remove' \">\n <mat-icon>cancel</mat-icon>\n </button>\n }\n\n </mat-chip-option>\n }\n</mat-chip-listbox>\n\n\n\n\n\n<ng-template #noSegments>\n <div class=\"tree-instructions\">\n <mat-icon class=\"info-icon\" color=\"primary\">info</mat-icon>\n <span>No segment configuration available. Start by adding a segment below.</span>\n </div>\n</ng-template>\n\n<mat-toolbar *ngIf=\"!isAddingNew && editingIndex === null && showAllSegments === false\">\n <button style=\"width:100%\" \n [disabled]=\"disabled\"\n mat-stroked-button (click)=\"startAddNew()\">\n Add New Segment <mat-icon>add</mat-icon>\n </button>\n</mat-toolbar>\n\n@if (!!getMscoaError) {\n<div class=\"tree-instructions\">\n <mat-icon class=\"info-icon\" color=\"primary\">info</mat-icon>\n <span>\n {{ getMscoaError }}\n </span>\n</div>\n}\n<mat-card *ngIf=\"isAddingNew || editingIndex !== null\">\n <mat-card-header>\n <mat-card-subtitle>\n {{ isAddingNew ? 'Add a new' : 'Update' }} Segment\n </mat-card-subtitle>\n </mat-card-header>\n <mat-card-content>\n <form [formGroup]=\"segmentForm\" (ngSubmit)=\"saveSegment()\">\n <mat-toolbar class=\"segment-toolbar\">\n <mat-slide-toggle \n (change)=\"multiLevelSelectChange($event)\" \n [checked]=\"segmentForm.value.segmentExtension\">\n Enable Multi-Level Segmentation\n </mat-slide-toggle>\n \n </mat-toolbar>\n <mat-hint class=\"segment-hint\">\n This allows sub-classifications within this segment for more detailed accounting hierarchies\n </mat-hint>\n <mat-form-field subscriptSizing=\"dynamic\" floatLabel=\"always\" appearance=\"outline\">\n <mat-label>Segment</mat-label>\n <mat-select (selectionChange)=\"selectSegment($event)\" matNativeControl \n formControlName=\"segment\" [value]=\"value\" placeholder=\"Select segment\">\n @for ( segment of treeSegments; track segment.segment) {\n <mat-option [disabled]=\"alreadyExists(segment)\" [value]=\"segment.segment\"> \n {{ segment.label }}\n </mat-option>\n }\n </mat-select>\n \n </mat-form-field>\n <mat-hint class=\"segment-hint\">\n Select an account segment type from your chart of accounts\n </mat-hint>\n \n <mat-form-field subscriptSizing=\"dynamic\" floatLabel=\"always\" appearance=\"outline\">\n <mat-label>Label</mat-label>\n <input matInput formControlName=\"label\"\n [disabled]=\"!this.segmentForm.value.segmentExtension\"\n placeholder=\"Enter label\">\n <mat-hint>Provide a descriptive name for this segment (e.g., 'Department', 'Project', 'Cost Center')</mat-hint>\n </mat-form-field>\n \n <mat-toolbar class=\"segment-toolbar\">\n <mat-slide-toggle (change)=\"singleSelectChange($event)\" [checked]=\"segmentForm.value.singleSelect\">\n Single Value Selection\n </mat-slide-toggle>\n\n </mat-toolbar>\n <mat-hint class=\"segment-hint\">\n When enabled, transactions can only be assigned to one value within this segment. When disabled, transactions can be split across multiple values.\n </mat-hint>\n <mat-toolbar class=\"segment-toolbar\">\n <mat-slide-toggle (change)=\"readOnly($event)\" [checked]=\"segmentForm.value.readOnly\">\n Read-Only Segment\n </mat-slide-toggle>\n \n </mat-toolbar>\n <mat-hint class=\"segment-hint\">\n Prevents users from modifying segment values after initial setup. Use for regulatory or policy-controlled segments.\n </mat-hint>\n <mat-form-field subscriptSizing=\"dynamic\" floatLabel=\"always\" appearance=\"outline\">\n <mat-label>\n Additional accounts\n </mat-label>\n \n \n <mat-select (selectionChange)=\"additionalAccountsChanged($event)\" matNativeControl \n [value]=\"segmentForm.value.additionalAccounts\"\n formControlName=\"additionalAccounts\" multiple placeholder=\"Select counter accounts\">\n @for (ext of extensionAccountsForSegments; track ext) {\n <mat-option [value]=\"ext\">{{ext}}</mat-option>\n }\n </mat-select>\n </mat-form-field>\n \n <mat-hint class=\"segment-hint\">\n This allows you to add additional accounts to this segment. For example, VAT accounts, tax accounts, or any other\n </mat-hint>\n <br>\n <mat-card-actions>\n <button mat-flat-button color=\"primary\" type=\"submit\" [disabled]=\"!segmentForm.valid\">Save</button>\n <button mat-button (click)=\"cancelEdit()\">Cancel</button>\n </mat-card-actions>\n </form>\n </mat-card-content>\n</mat-card>\n\n<span color=\"danger\" *ngIf=\"error$ | async as error\">\n <p>{{ error }}</p>\n</span>"],"names":["uuidv4","i4","i5","i6","i7","i8","i10","i11"],"mappings":";;;;;;;;;;;;;;;;;;;;;MA8Ba,2BAA2B,CAAA;aAE/B,IAAM,CAAA,MAAA,GAAG,CAAH,CAAK;AAMlB,IAAA,WAAA,CACU,EAAe,EACI,SAAoB,EAAU,WAAoC,EAAA;QADrF,IAAE,CAAA,EAAA,GAAF,EAAE;QACiB,IAAS,CAAA,SAAA,GAAT,SAAS;QAAqB,IAAW,CAAA,WAAA,GAAX,WAAW;AAT7D,QAAA,IAAA,CAAA,SAAS,GAAG,MAAM,CAAC,aAAa,CAAC;AAE1C,QAAA,IAAA,CAAA,YAAY,GAAG,IAAI,OAAO,EAAQ;AAEnB,QAAA,IAAA,CAAA,EAAE,GAAG,CAA6B,0BAAA,EAAA,2BAA2B,CAAC,MAAM,EAAE,EAAE;QAEvF,IAAW,CAAA,WAAA,GAAW,EAAE;QASxB,IAAO,CAAA,OAAA,GAAY,KAAK;QAOxB,IAAQ,CAAA,QAAA,GAAY,KAAK;QAChB,IAAQ,CAAA,QAAA,GAAY,KAAK;QAyBlC,IAAO,CAAA,OAAA,GAAY,KAAK;AACxB,QAAA,IAAA,CAAA,SAAS,GAAG,MAAK,GAAI;QAUZ,IAAM,CAAA,MAAA,GAAsC,EAAE;QAC9C,IAAS,CAAA,SAAA,GAA2B,SAAS;QAStD,IAAgB,CAAA,gBAAA,GAAY,KAAK;AAwBvB,QAAA,IAAA,CAAA,YAAY,GAAG,IAAI,YAAY,EAA4B;AAC7D,QAAA,IAAA,CAAA,MAAM,GAAG,IAAI,eAAe,CAA2B,EAAE,CAAC;AAC1D,QAAA,IAAA,CAAA,QAAQ,GAAG,IAAI,OAAO,EAAQ;AAGtC,QAAA,IAAA,CAAA,MAAM,GAAG,IAAI,eAAe,CAAgB,IAAI,CAAC;QAGjD,IAAY,CAAA,YAAA,GAAkB,IAAI;QAClC,IAAW,CAAA,WAAA,GAAG,KAAK;QAYnB,IAAa,CAAA,aAAA,GAAuB,SAAS;AAvG3C,QAAA,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,EAAE;;AAK7C,IAAA,IAAI,KAAK,GAAA;AACP,QAAA,OAAO,CAAC,IAAI,CAAC,KAAK;;AAEpB,IAAA,IAAI,gBAAgB,GAAA;QAClB,OAAO,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK;;AAIpC,IAAA,IAAI,UAAU,GAAA;QACZ,MAAM,QAAQ,GAAG,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,EAAE,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,OAAO;AACpG,QAAA,OAAO,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,QAAQ;;AAOnD,IAAA,iBAAiB,CAAC,GAAa,EAAA;;QAE7B,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE;AACtD,YAAA,MAAM,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,aAAa,CAAC,2BAA2B,CAAC;;YAEhG,IAAI,cAAc,EAAE;AAClB,gBAAA,cAAc,CAAC,YAAY,CAAC,kBAAkB,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;;;;AAIpE,IAAA,gBAAgB,CAAC,KAAiB,EAAA;QAChC,IAAI,CAAC,aAAa,EAAE;AACpB,QAAA,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE;;IAK1B,aAAa,GAAA;AACX,QAAA,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC;AAC5B,QAAA,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,IAAI,CAAC,SAAS,EAAE;AAChB,YAAA,IAAI,CAAC,OAAO,GAAG,IAAI;;;IAOvB,IAAa,KAAK,CAAC,GAA6B,EAAA;QAC9C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,IAAI,EAAE,CAAC;;AAG7B,IAAA,IAAI,KAAK,GAAA;AACP,QAAA,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK;;IAI1B,IAAa,eAAe,CAAC,GAAY,EAAA;AAEvC,QAAA,IAAI,CAAC,CAAC,GAAG,EAAE;YACT,IAAI,CAAC,oBAAoB,EAAE;;AAE7B,QAAA,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC,GAAG;;AAG/B,IAAA,IAAI,eAAe,GAAA;QACjB,OAAO,IAAI,CAAC,gBAAgB;;IAG9B,IAAa,YAAY,CAAC,QAAkD,EAAA;QAC1E,IAAI,CAAC,CAAC,QAAQ,IAAI,IAAI,CAAC,aAAa,KAAK,SAAS,EAAE;AAClD,YAAA,IAAI,CAAC,aAAa,GAAG,SAAS;AAC9B,YAAA,IAAI,CAAC,aAAa,GAAG,QAAQ;YAE7B,IAAI,CAAC,SAAS,EAAE;;aACX,IAAI,CAAC,QAAQ,EAAE;AACpB,YAAA,IAAI,CAAC,aAAa,GAAG,oBAAoB;;;IAiB7C,QAAQ,GAAA;QACN,IAAI,CAAC,mBAAmB,EAAE;;IAG5B,WAAW,GAAA;AACT,QAAA,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE;AACpB,QAAA,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE;;IAGlB,SAAS,GAAA;AAEf,QAAA,IAAI,CAAC,aAAa,EAAE,IAAI,CACtB,IAAI,CAAC,CAAC,CAAC,EACP,GAAG,CAAC,CAAC,OAAO,KAAI;AACd,YAAA,IAAI,CAAC,SAAS,GAAG,OAAO;AACxB,YAAA,IAAI,CAAC,YAAY,GAAG,OAAO,EAAE,eAAe,EAAE,GAAG,CAAC,CAAC,OAAO,MAAM;gBAC9D,EAAE,EAAEA,EAAM,EAAE;AACZ,gBAAA,OAAO,EAAE,OAAO;AAChB,gBAAA,YAAY,EAAE,IAAI;AAClB,gBAAA,kBAAkB,EAAE,EAAE;AACtB,gBAAA,gBAAgB,EAAE,KAAK;AACvB,gBAAA,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;gBAChC,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,EAAE,QAAQ,IAAI,KAAK;aAC3E,CAAC,CAAC,IAAI,EAAE;AACX,SAAC,CAAC,EACF,UAAU,CAAC,CAAC,KAAK,KAAI;AACnB,YAAA,IAAI,CAAC,aAAa,GAAG,4BAA4B;AACjD,YAAA,OAAO,CAAC,KAAK,CAAC,iCAAiC,EAAE,KAAK,CAAC;YACvD,OAAO,CAAC,IAAI,CAAC;AACf,SAAC,CAAC,CACH,CAAC,SAAS,EAAE;;AAEP,IAAA,iBAAiB,CAAC,OAAmC,GAAA;AAC3D,QAAA,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE;QACtB,EAAE,EAAEA,EAAM,EAAE;AACZ,QAAA,YAAY,EAAE,IAAI;AAClB,QAAA,gBAAgB,EAAE,KAAK;AACvB,QAAA,kBAAkB,EAAE,EAAE;AACtB,QAAA,QAAQ,EAAE;AACJ,KAAA,EAAA;AACN,QAAA,OAAO,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YACnB,OAAO,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,UAAU,CAAC,QAAQ,CAAC;YAC/C,gBAAgB,EAAE,CAAC,OAAO,CAAC,gBAAgB,EAAE,UAAU,CAAC,QAAQ,CAAC;YACjE,QAAQ,EAAE,CAAC,OAAO,CAAC,QAAQ,EAAE,UAAU,CAAC,QAAQ,CAAC;AACjD,YAAA,kBAAkB,EAAE,CAAE,OAAe,CAAC,kBAAkB,IAAI,EAAE,EAAE;YAChE,KAAK,EAAE,CAAC,OAAO,CAAC,KAAK,EAAE,UAAU,CAAC,QAAQ,CAAC;YAC3C,YAAY,EAAE,CAAC,OAAO,CAAC,YAAY,EAAE,UAAU,CAAC,QAAQ;AACzD,SAAA,CAAC;;IAGI,mBAAmB,GAAA;QACzB,IAAI,CAAC,WAAW,CAAC;AACd,aAAA,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;AAC7B,aAAA,SAAS,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;;IAGrC,WAAW,GAAA;AACT,QAAA,IAAI,CAAC,WAAW,GAAG,IAAI;AACvB,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI;AACxB,QAAA,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,EAAE;;AAG7C,IAAA,SAAS,CAAC,KAAa,EAAA;AACrB,QAAA,IAAI,CAAC,YAAY,GAAG,KAAK;AACzB,QAAA,IAAI,CAAC,WAAW,GAAG,KAAK;AACxB,QAAA,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;;IAG9D,UAAU,GAAA;AACR,QAAA,IAAI,CAAC,YAAY,GAAG,IAAI;AACxB,QAAA,IAAI,CAAC,WAAW,GAAG,KAAK;AACxB,QAAA,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE;;IAG1B,WAAW,GAAA;AACT,QAAA,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE;YAC1B,MAAM,UAAU,IAAI;gBAClB,EAAE,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,IAAIA,EAAM,EAAE;AACzC,gBAAA,OAAO,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,OAAO;gBACvC,aAAa,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,gBAAgB,GAAI,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,KAAgB,EAAE,iBAAiB,EAAE,GAAG,SAAS;AACpI,gBAAA,gBAAgB,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,gBAAgB;AACzD,gBAAA,kBAAkB,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,kBAAkB;AAC7D,gBAAA,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC;AACrD,gBAAA,YAAY,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,YAAY;AACjD,gBAAA,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;AAClC,aAAA,CAAC;YACF,MAAM,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;AAEpC,YAAA,IAAI,IAAI,CAAC,WAAW,EAAE;AACpB,gBAAA,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC;;AACxB,iBAAA,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,EAAE;AACrC,gBAAA,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,UAAU;;AAI9C,YAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC;AAC9B,YAAA,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC;YACpC,IAAI,CAAC,UAAU,EAAE;;;AAGrB,IAAA,QAAQ,CAAC,KAA2B,EAAA;AAClC,QAAA,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE,QAAQ,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;;AAE1D,IAAA,kBAAkB,CAAC,KAA2B,EAAA;AAC5C,QAAA,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE,YAAY,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;;AAG9D,IAAA,aAAa,CAAC,KAAa,EAAA;AACzB,QAAA,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,KAAK,CAAC;AAC7D,QAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC;AAC9B,QAAA,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC;;AAG9B,IAAA,WAAW,CAAC,GAAW,EAAA;AAC7B,QAAA,OAAO,GAAG,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,GAAG,KAAK,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;;AAElG,IAAA,aAAa,CAAC,OAA+B,EAAA;AAC3C,QAAA,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,gBAAgB;AAAE,YAAA,OAAO,KAAK;AACzD,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,OAAO,CAAC;;IAE9D,oBAAoB,GAAA;QAClB,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,YAAY;YAAE;AAE/C,QAAA,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,OAAO,KAAK;AACrD,YAAA,GAAG,OAAO;YACV,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE;AAC9D,SAAA,CAAC,CAAC;AAEH,QAAA,IAAI,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YAC/D,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,EAAS,CAAC,CAAC;YACnC,UAAU,CAAC,MAAK;AACd,gBAAA,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC;aACrC,EAAE,CAAC,CAAC;;;AAGT,IAAA,aAAa,CAAC,MAA4B,EAAA;AAExC,QAAA,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC;QACtD,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,gBAAgB,EAAE;AAC5C,YAAA,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;;;AAK1E,IAAA,sBAAsB,CAAC,KAA2B,EAAA;AAChD,QAAA,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE,gBAAgB,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC;;AAIlE,IAAA,IAAI,4BAA4B,GAAA;AAC9B,QAAA,OAAO,CAAC,KAAK,CAAC,kCAAkC,EAAE,IAAI,CAAC,SAAS,EAAE,WAAW,EAAE,4BAA4B,CAAC;QAC5G,OAAO,IAAI,CAAC,SAAS,EAAE,WAAW,EAAE,4BAA4B,IAAI,EAAE;;AAExE,IAAA,yBAAyB,CAAC,KAAsB,EAAA;;QAE9C,MAAM,qBAAqB,GAAG,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC;AAE9C,QAAA,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC;AAC1B,YAAA,kBAAkB,EAAE;AACrB,SAAA,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;;AAGvB,QAAA,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE;QACxB,IAAI,CAAC,aAAa,EAAE;;8GA9QX,2BAA2B,EAAA,IAAA,EAAA,CAAA,EAAA,KAAA,EAAA,EAAA,CAAA,WAAA,EAAA,EAAA,EAAA,KAAA,EAAA,EAAA,CAAA,SAAA,EAAA,QAAA,EAAA,IAAA,EAAA,IAAA,EAAA,IAAA,EAAA,EAAA,EAAA,KAAA,EAAA,EAAA,CAAA,UAAA,EAAA,CAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA;kGAA3B,2BAA2B,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,0BAAA,EAAA,MAAA,EAAA,EAAA,QAAA,EAAA,UAAA,EAAA,MAAA,EAAA,QAAA,EAAA,SAAA,EAAA,WAAA,EAAA,KAAA,EAAA,OAAA,EAAA,eAAA,EAAA,iBAAA,EAAA,YAAA,EAAA,cAAA,EAAA,EAAA,OAAA,EAAA,EAAA,YAAA,EAAA,cAAA,EAAA,EAAA,IAAA,EAAA,EAAA,UAAA,EAAA,EAAA,IAAA,EAAA,SAAA,EAAA,EAAA,EAAA,SAAA,EAH3B,CAAC,EAAE,OAAO,EAAE,mBAAmB,EAAE,WAAW,EAAE,2BAA2B,EAAE,CAAC,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,EC3BzF,wxLAwJO,EDlIH,MAAA,EAAA,CAAA,28BAAA,CAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAAA,YAAY,uLACZ,gBAAgB,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,SAAA,EAAA,QAAA,EAAA,YAAA,EAAA,MAAA,EAAA,CAAA,OAAA,EAAA,IAAA,EAAA,UAAA,CAAA,EAAA,OAAA,EAAA,CAAA,mBAAA,CAAA,EAAA,QAAA,EAAA,CAAA,WAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAC,IAAA,CAAA,SAAA,EAAA,QAAA,EAAA,6GAAA,EAAA,QAAA,EAAA,CAAA,WAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAC,IAAA,CAAA,OAAA,EAAA,QAAA,EAAA,UAAA,EAAA,MAAA,EAAA,CAAA,YAAA,CAAA,EAAA,QAAA,EAAA,CAAA,SAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAA,IAAA,CAAA,cAAA,EAAA,QAAA,EAAA,kBAAA,EAAA,MAAA,EAAA,CAAA,OAAA,CAAA,EAAA,QAAA,EAAA,CAAA,gBAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAA,IAAA,CAAA,cAAA,EAAA,QAAA,EAAA,kBAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAA,IAAA,CAAA,aAAA,EAAA,QAAA,EAAA,iBAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAA,IAAA,CAAA,eAAA,EAAA,QAAA,EAAA,2DAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAC,EAAA,CAAA,cAAA,EAAA,QAAA,EAAA,kBAAA,EAAA,MAAA,EAAA,CAAA,UAAA,EAAA,kBAAA,EAAA,YAAA,EAAA,aAAA,EAAA,UAAA,EAAA,8BAAA,EAAA,OAAA,CAAA,EAAA,OAAA,EAAA,CAAA,QAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAA,EAAA,CAAA,aAAA,EAAA,QAAA,EAAA,oFAAA,EAAA,MAAA,EAAA,CAAA,YAAA,EAAA,UAAA,CAAA,EAAA,OAAA,EAAA,CAAA,iBAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAA,EAAA,CAAA,aAAA,EAAA,QAAA,EAAA,iBAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAC,EAAA,CAAA,OAAA,EAAA,QAAA,EAAA,UAAA,EAAA,MAAA,EAAA,CAAA,OAAA,EAAA,QAAA,EAAA,SAAA,EAAA,SAAA,EAAA,UAAA,CAAA,EAAA,QAAA,EAAA,CAAA,SAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAC,IAAA,CAAA,YAAA,EAAA,QAAA,EAAA,gBAAA,EAAA,MAAA,EAAA,CAAA,oBAAA,EAAA,OAAA,EAAA,YAAA,EAAA,YAAA,EAAA,iBAAA,EAAA,WAAA,CAAA,EAAA,QAAA,EAAA,CAAA,cAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAA,IAAA,CAAA,QAAA,EAAA,QAAA,EAAA,WAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAA,IAAA,CAAA,OAAA,EAAA,QAAA,EAAA,UAAA,EAAA,MAAA,EAAA,CAAA,OAAA,EAAA,IAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAA,IAAA,CAAA,SAAA,EAAA,QAAA,EAAA,YAAA,EAAA,MAAA,EAAA,CAAA,kBAAA,EAAA,YAAA,EAAA,UAAA,EAAA,eAAA,EAAA,UAAA,EAAA,8BAAA,EAAA,aAAA,EAAA,UAAA,EAAA,UAAA,EAAA,wBAAA,EAAA,aAAA,EAAA,OAAA,EAAA,YAAA,EAAA,iBAAA,EAAA,mBAAA,EAAA,2BAAA,EAAA,gBAAA,EAAA,IAAA,EAAA,YAAA,EAAA,0BAAA,CAAA,EAAA,OAAA,EAAA,CAAA,cAAA,EAAA,QAAA,EAAA,QAAA,EAAA,iBAAA,EAAA,aAAA,CAAA,EAAA,QAAA,EAAA,CAAA,WAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,cAAA,EAAA,QAAA,EAAA,kBAAA,EAAA,MAAA,EAAA,CAAA,MAAA,EAAA,IAAA,EAAA,eAAA,EAAA,YAAA,EAAA,iBAAA,EAAA,kBAAA,EAAA,UAAA,EAAA,OAAA,EAAA,UAAA,EAAA,eAAA,EAAA,UAAA,EAAA,SAAA,EAAA,UAAA,EAAA,qBAAA,CAAA,EAAA,OAAA,EAAA,CAAA,QAAA,EAAA,cAAA,CAAA,EAAA,QAAA,EAAA,CAAA,gBAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAC,IAAA,CAAA,UAAA,EAAA,QAAA,EAAA,aAAA,EAAA,MAAA,EAAA,CAAA,OAAA,CAAA,EAAA,QAAA,EAAA,CAAA,YAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAAC,GAAA,CAAA,QAAA,EAAA,QAAA,EAAA,yHAAA,EAAA,MAAA,EAAA,CAAA,UAAA,EAAA,IAAA,EAAA,aAAA,EAAA,MAAA,EAAA,UAAA,EAAA,MAAA,EAAA,mBAAA,EAAA,kBAAA,EAAA,OAAA,EAAA,UAAA,EAAA,qBAAA,CAAA,EAAA,QAAA,EAAA,CAAA,UAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAChB,mBAAmB,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,aAAA,EAAA,QAAA,EAAA,8CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,oBAAA,EAAA,QAAA,EAAA,8MAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,eAAA,EAAA,QAAA,EAAA,2CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,oBAAA,EAAA,QAAA,EAAA,0FAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,kBAAA,EAAA,QAAA,EAAA,aAAA,EAAA,MAAA,EAAA,CAAA,WAAA,CAAA,EAAA,OAAA,EAAA,CAAA,UAAA,CAAA,EAAA,QAAA,EAAA,CAAA,QAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,eAAA,EAAA,QAAA,EAAA,mBAAA,EAAA,MAAA,EAAA,CAAA,iBAAA,EAAA,UAAA,EAAA,SAAA,CAAA,EAAA,OAAA,EAAA,CAAA,eAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EACnB,WAAW,EAAA,CAAA,EAAA,CAAA,CAAA;;2FAKF,2BAA2B,EAAA,UAAA,EAAA,CAAA;kBAdvC,SAAS;+BACE,0BAA0B,EAAA,UAAA,EAGxB,IAAI,EACP,OAAA,EAAA;wBACP,YAAY;wBACZ,gBAAgB;wBAChB,mBAAmB;wBACnB;qBACD,EACU,SAAA,EAAA,CAAC,EAAE,OAAO,EAAE,mBAAmB,EAAE,WAAW,EAA6B,2BAAA,EAAE,CAAC,EAAA,QAAA,EAAA,wxLAAA,EAAA,MAAA,EAAA,CAAA,28BAAA,CAAA,EAAA;;0BAapF;;0BAAY;kEALA,EAAE,EAAA,CAAA;sBAAhB;gBAmBQ,QAAQ,EAAA,CAAA;sBAAhB;gBAoCQ,MAAM,EAAA,CAAA;sBAAd;gBACQ,SAAS,EAAA,CAAA;sBAAjB;gBACY,KAAK,EAAA,CAAA;sBAAjB;gBASY,eAAe,EAAA,CAAA;sBAA3B;gBAYY,YAAY,EAAA,CAAA;sBAAxB;gBAWS,YAAY,EAAA,CAAA;sBAArB;;;;;"}