@cuby-ui/core 0.0.231 → 0.0.232

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 (78) hide show
  1. package/components/banner/banner.component.d.ts +1 -2
  2. package/components/button/button.component.d.ts +1 -1
  3. package/components/sidebar/sidebar-header/sidebar-header.component.d.ts +1 -1
  4. package/components/sidebar/sidebar-navigation-item/sidebar-navigation-item.component.d.ts +1 -1
  5. package/directives/tooltip/tooltip.component.d.ts +1 -1
  6. package/esm2022/components/banner/banner.component.mjs +3 -3
  7. package/esm2022/utils/default-validators/create-default-validators.mjs +2 -2
  8. package/esm2022/utils/default-validators/index.mjs +2 -2
  9. package/esm2022/widgets/categories/components/category-form/category-form.component.mjs +3 -3
  10. package/esm2022/widgets/checklist-block/checklist-block.component.mjs +72 -0
  11. package/esm2022/widgets/checklist-block/checklist-block.options.mjs +2 -0
  12. package/esm2022/widgets/checklist-block/components/checklist-block-list/checklist-block-list.component.mjs +85 -0
  13. package/esm2022/widgets/checklist-block/components/checklist-block-list/index.mjs +2 -0
  14. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-action-card/checklist-block-list-item-action-card.component.mjs +133 -0
  15. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-action-card/index.mjs +2 -0
  16. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-action-with-verification/checklist-block-list-item-action-with-verification.component.mjs +45 -0
  17. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-action-with-verification/index.mjs +2 -0
  18. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-action-without-verification/checklist-block-list-item-action-without-verification.component.mjs +35 -0
  19. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-action-without-verification/index.mjs +2 -0
  20. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-container/checklist-block-list-item-container.component.mjs +152 -0
  21. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-container/checklist-block-list-item-container.options.mjs +2 -0
  22. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-container/index.mjs +2 -0
  23. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-evaluation/checklist-block-list-item-evaluation.component.mjs +282 -0
  24. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-evaluation/checklist-block-list-item-evaluation.options.mjs +2 -0
  25. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-evaluation/index.mjs +2 -0
  26. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-evaluation-criteria/checklist-block-list-item-evaluation-criteria.component.mjs +117 -0
  27. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-evaluation-criteria/checklist-block-list-item-evaluation-criteria.options.mjs +2 -0
  28. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-evaluation-criteria/index.mjs +2 -0
  29. package/esm2022/widgets/checklist-block/components/checklist-block-title-control/checklist-block-title-control.component.mjs +39 -0
  30. package/esm2022/widgets/checklist-block/components/checklist-block-title-control/index.mjs +2 -0
  31. package/esm2022/widgets/checklist-block/components/index.mjs +2 -0
  32. package/esm2022/widgets/checklist-block/index.mjs +2 -0
  33. package/esm2022/widgets/checklist-block/services/checklist-block.service.mjs +50 -0
  34. package/esm2022/widgets/checklist-block/services/index.mjs +2 -0
  35. package/esm2022/widgets/delete-modal/delete-modal.component.mjs +39 -0
  36. package/esm2022/widgets/delete-modal/delete-modal.options.mjs +2 -0
  37. package/esm2022/widgets/delete-modal/index.mjs +2 -0
  38. package/esm2022/widgets/index.mjs +6 -2
  39. package/esm2022/widgets/loader/index.mjs +2 -0
  40. package/esm2022/widgets/loader/loader.component.mjs +36 -0
  41. package/esm2022/widgets/utility-info/utility-info.component.mjs +4 -4
  42. package/fesm2022/cuby-ui-core.mjs +1182 -234
  43. package/fesm2022/cuby-ui-core.mjs.map +1 -1
  44. package/package.json +3 -3
  45. package/utils/default-validators/create-default-validators.d.ts +1 -1
  46. package/utils/default-validators/index.d.ts +1 -1
  47. package/widgets/categories/components/category-item/category-item.component.d.ts +3 -3
  48. package/widgets/checklist-block/checklist-block.component.d.ts +20 -0
  49. package/widgets/checklist-block/checklist-block.options.d.ts +12 -0
  50. package/widgets/checklist-block/components/checklist-block-list/checklist-block-list.component.d.ts +27 -0
  51. package/widgets/checklist-block/components/checklist-block-list/index.d.ts +1 -0
  52. package/widgets/checklist-block/components/checklist-block-list-item-action-card/checklist-block-list-item-action-card.component.d.ts +30 -0
  53. package/widgets/checklist-block/components/checklist-block-list-item-action-card/index.d.ts +1 -0
  54. package/widgets/checklist-block/components/checklist-block-list-item-action-with-verification/checklist-block-list-item-action-with-verification.component.d.ts +11 -0
  55. package/widgets/checklist-block/components/checklist-block-list-item-action-with-verification/index.d.ts +1 -0
  56. package/widgets/checklist-block/components/checklist-block-list-item-action-without-verification/checklist-block-list-item-action-without-verification.component.d.ts +10 -0
  57. package/widgets/checklist-block/components/checklist-block-list-item-action-without-verification/index.d.ts +1 -0
  58. package/widgets/checklist-block/components/checklist-block-list-item-container/checklist-block-list-item-container.component.d.ts +41 -0
  59. package/widgets/checklist-block/components/checklist-block-list-item-container/checklist-block-list-item-container.options.d.ts +5 -0
  60. package/widgets/checklist-block/components/checklist-block-list-item-container/index.d.ts +1 -0
  61. package/widgets/checklist-block/components/checklist-block-list-item-evaluation/checklist-block-list-item-evaluation.component.d.ts +51 -0
  62. package/widgets/checklist-block/components/checklist-block-list-item-evaluation/checklist-block-list-item-evaluation.options.d.ts +14 -0
  63. package/widgets/checklist-block/components/checklist-block-list-item-evaluation/index.d.ts +2 -0
  64. package/widgets/checklist-block/components/checklist-block-list-item-evaluation-criteria/checklist-block-list-item-evaluation-criteria.component.d.ts +33 -0
  65. package/widgets/checklist-block/components/checklist-block-list-item-evaluation-criteria/checklist-block-list-item-evaluation-criteria.options.d.ts +4 -0
  66. package/widgets/checklist-block/components/checklist-block-list-item-evaluation-criteria/index.d.ts +1 -0
  67. package/widgets/checklist-block/components/checklist-block-title-control/checklist-block-title-control.component.d.ts +8 -0
  68. package/widgets/checklist-block/components/checklist-block-title-control/index.d.ts +1 -0
  69. package/widgets/checklist-block/components/index.d.ts +1 -0
  70. package/widgets/checklist-block/index.d.ts +1 -0
  71. package/widgets/checklist-block/services/checklist-block.service.d.ts +19 -0
  72. package/widgets/checklist-block/services/index.d.ts +1 -0
  73. package/widgets/delete-modal/delete-modal.component.d.ts +13 -0
  74. package/widgets/delete-modal/delete-modal.options.d.ts +7 -0
  75. package/widgets/delete-modal/index.d.ts +2 -0
  76. package/widgets/index.d.ts +5 -1
  77. package/widgets/loader/index.d.ts +1 -0
  78. package/widgets/loader/loader.component.d.ts +20 -0
@@ -0,0 +1,39 @@
1
+ import { ChangeDetectionStrategy, Component, input } from '@angular/core';
2
+ import { ReactiveFormsModule } from '@angular/forms';
3
+ import { CuiContextMenuModule, CuiFormFieldModule, CuiHintModule, CuiInputModule, CuiLabelModule } from '../../../../components';
4
+ import { CuiTextFieldControllerModule } from '../../../../directives';
5
+ import { TranslocoDirective } from '@jsverse/transloco';
6
+ import { CuiGeneralControlErrorHintComponent } from '../../../../widgets';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "../../../../components/form-field/form-field.component";
9
+ import * as i2 from "../../../../components/input-text/input-text.component";
10
+ import * as i3 from "../../../../directives/text-field-controller/text-field-id.directive";
11
+ import * as i4 from "../../../../directives/text-field-controller/text-field-placeholder.directive";
12
+ import * as i5 from "../../../../directives/text-field-controller/text-field-is-error.directive";
13
+ import * as i6 from "../../../../components/label/label.component";
14
+ import * as i7 from "@angular/forms";
15
+ export class CuiChecklistBlockTitleControlComponent {
16
+ constructor() {
17
+ this.control = input.required();
18
+ }
19
+ get isTitleError() {
20
+ return this.control().invalid && this.control().dirty;
21
+ }
22
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiChecklistBlockTitleControlComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
23
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: CuiChecklistBlockTitleControlComponent, isStandalone: true, selector: "cui-checklist-block-title-control", inputs: { control: { classPropertyName: "control", publicName: "control", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "<ng-container *transloco=\"let t\">\r\n <cui-form-field>\r\n <label\r\n cuiLabel\r\n [isRequired]=\"true\"\r\n for=\"title\"\r\n >\r\n {{ t('TITLE') }}\r\n </label>\r\n <cui-input-text\r\n [formControl]=\"control()\"\r\n cuiTextFieldId=\"title\"\r\n [cuiTextFieldIsError]=\"isTitleError\"\r\n cuiTextFieldPlaceholder=\"{{ t('ADD_A_TITLE') }}...\"\r\n />\r\n <cui-general-control-error-hint [control]=\"control()\" />\r\n </cui-form-field>\r\n</ng-container>\r\n", dependencies: [{ kind: "ngmodule", type: CuiContextMenuModule }, { kind: "ngmodule", type: CuiFormFieldModule }, { kind: "component", type: i1.CuiFormFieldComponent, selector: "cui-form-field" }, { kind: "ngmodule", type: CuiHintModule }, { kind: "ngmodule", type: CuiInputModule }, { kind: "component", type: i2.CuiInputTextComponent, selector: "cui-input-text" }, { kind: "directive", type: i3.CuiTextFieldIdDirective, selector: "[cuiTextFieldId]", inputs: ["cuiTextFieldId"] }, { kind: "directive", type: i4.CuiTextFieldPlaceholderDirective, selector: "[cuiTextFieldPlaceholder]", inputs: ["cuiTextFieldPlaceholder"] }, { kind: "directive", type: i5.CuiTextFieldIsErrorDirective, selector: "[cuiTextFieldIsError]", inputs: ["cuiTextFieldIsError"] }, { kind: "ngmodule", type: CuiLabelModule }, { kind: "component", type: i6.CuiLabelComponent, selector: "label[cuiLabel]", inputs: ["isRequired"] }, { kind: "ngmodule", type: CuiTextFieldControllerModule }, { kind: "component", type: CuiGeneralControlErrorHintComponent, selector: "cui-general-control-error-hint", inputs: ["control", "isVisible"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
24
+ }
25
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiChecklistBlockTitleControlComponent, decorators: [{
26
+ type: Component,
27
+ args: [{ selector: 'cui-checklist-block-title-control', imports: [
28
+ CuiContextMenuModule,
29
+ CuiFormFieldModule,
30
+ CuiHintModule,
31
+ CuiInputModule,
32
+ CuiLabelModule,
33
+ CuiTextFieldControllerModule,
34
+ CuiGeneralControlErrorHintComponent,
35
+ ReactiveFormsModule,
36
+ TranslocoDirective
37
+ ], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *transloco=\"let t\">\r\n <cui-form-field>\r\n <label\r\n cuiLabel\r\n [isRequired]=\"true\"\r\n for=\"title\"\r\n >\r\n {{ t('TITLE') }}\r\n </label>\r\n <cui-input-text\r\n [formControl]=\"control()\"\r\n cuiTextFieldId=\"title\"\r\n [cuiTextFieldIsError]=\"isTitleError\"\r\n cuiTextFieldPlaceholder=\"{{ t('ADD_A_TITLE') }}...\"\r\n />\r\n <cui-general-control-error-hint [control]=\"control()\" />\r\n </cui-form-field>\r\n</ng-container>\r\n" }]
38
+ }] });
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tsaXN0LWJsb2NrLXRpdGxlLWNvbnRyb2wuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS93aWRnZXRzL2NoZWNrbGlzdC1ibG9jay9jb21wb25lbnRzL2NoZWNrbGlzdC1ibG9jay10aXRsZS1jb250cm9sL2NoZWNrbGlzdC1ibG9jay10aXRsZS1jb250cm9sLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvd2lkZ2V0cy9jaGVja2xpc3QtYmxvY2svY29tcG9uZW50cy9jaGVja2xpc3QtYmxvY2stdGl0bGUtY29udHJvbC9jaGVja2xpc3QtYmxvY2stdGl0bGUtY29udHJvbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyRCxPQUFPLEVBQ0gsb0JBQW9CLEVBQ3BCLGtCQUFrQixFQUNsQixhQUFhLEVBQ2IsY0FBYyxFQUNkLGNBQWMsRUFDakIsTUFBTSx3QkFBd0IsQ0FBQztBQUNoQyxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN0RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUV4RCxPQUFPLEVBQUUsbUNBQW1DLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7Ozs7Ozs7O0FBbUIxRSxNQUFNLE9BQU8sc0NBQXNDO0lBakJuRDtRQWtCb0IsWUFBTyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQWUsQ0FBQztLQUszRDtJQUhHLElBQWMsWUFBWTtRQUN0QixPQUFPLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxPQUFPLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLEtBQUssQ0FBQztJQUMxRCxDQUFDOytHQUxRLHNDQUFzQzttR0FBdEMsc0NBQXNDLHNPQ2hDbkQsdWxCQWtCQSwyQ0RBUSxvQkFBb0IsOEJBQ3BCLGtCQUFrQixpSEFDbEIsYUFBYSw4QkFDYixjQUFjLG9mQUNkLGNBQWMsc0lBQ2QsNEJBQTRCLCtCQUM1QixtQ0FBbUMsNEdBQ25DLG1CQUFtQiwwVEFDbkIsa0JBQWtCOzs0RkFNYixzQ0FBc0M7a0JBakJsRCxTQUFTOytCQUNJLG1DQUFtQyxXQUNwQzt3QkFDTCxvQkFBb0I7d0JBQ3BCLGtCQUFrQjt3QkFDbEIsYUFBYTt3QkFDYixjQUFjO3dCQUNkLGNBQWM7d0JBQ2QsNEJBQTRCO3dCQUM1QixtQ0FBbUM7d0JBQ25DLG1CQUFtQjt3QkFDbkIsa0JBQWtCO3FCQUNyQixjQUNXLElBQUksbUJBRUMsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB0eXBlIHsgRm9ybUNvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7XHJcbiAgICBDdWlDb250ZXh0TWVudU1vZHVsZSxcclxuICAgIEN1aUZvcm1GaWVsZE1vZHVsZSxcclxuICAgIEN1aUhpbnRNb2R1bGUsXHJcbiAgICBDdWlJbnB1dE1vZHVsZSxcclxuICAgIEN1aUxhYmVsTW9kdWxlXHJcbn0gZnJvbSAnLi4vLi4vLi4vLi4vY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IEN1aVRleHRGaWVsZENvbnRyb2xsZXJNb2R1bGUgfSBmcm9tICcuLi8uLi8uLi8uLi9kaXJlY3RpdmVzJztcclxuaW1wb3J0IHsgVHJhbnNsb2NvRGlyZWN0aXZlIH0gZnJvbSAnQGpzdmVyc2UvdHJhbnNsb2NvJztcclxuXHJcbmltcG9ydCB7IEN1aUdlbmVyYWxDb250cm9sRXJyb3JIaW50Q29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vLi4vd2lkZ2V0cyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnY3VpLWNoZWNrbGlzdC1ibG9jay10aXRsZS1jb250cm9sJyxcclxuICAgIGltcG9ydHM6IFtcclxuICAgICAgICBDdWlDb250ZXh0TWVudU1vZHVsZSxcclxuICAgICAgICBDdWlGb3JtRmllbGRNb2R1bGUsXHJcbiAgICAgICAgQ3VpSGludE1vZHVsZSxcclxuICAgICAgICBDdWlJbnB1dE1vZHVsZSxcclxuICAgICAgICBDdWlMYWJlbE1vZHVsZSxcclxuICAgICAgICBDdWlUZXh0RmllbGRDb250cm9sbGVyTW9kdWxlLFxyXG4gICAgICAgIEN1aUdlbmVyYWxDb250cm9sRXJyb3JIaW50Q29tcG9uZW50LFxyXG4gICAgICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICAgICAgVHJhbnNsb2NvRGlyZWN0aXZlXHJcbiAgICBdLFxyXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9jaGVja2xpc3QtYmxvY2stdGl0bGUtY29udHJvbC5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ3VpQ2hlY2tsaXN0QmxvY2tUaXRsZUNvbnRyb2xDb21wb25lbnQge1xyXG4gICAgcHVibGljIHJlYWRvbmx5IGNvbnRyb2wgPSBpbnB1dC5yZXF1aXJlZDxGb3JtQ29udHJvbD4oKTtcclxuXHJcbiAgICBwcm90ZWN0ZWQgZ2V0IGlzVGl0bGVFcnJvcigpOiBib29sZWFuIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5jb250cm9sKCkuaW52YWxpZCAmJiB0aGlzLmNvbnRyb2woKS5kaXJ0eTtcclxuICAgIH1cclxufVxyXG4iLCI8bmctY29udGFpbmVyICp0cmFuc2xvY289XCJsZXQgdFwiPlxyXG4gICAgPGN1aS1mb3JtLWZpZWxkPlxyXG4gICAgICAgIDxsYWJlbFxyXG4gICAgICAgICAgICBjdWlMYWJlbFxyXG4gICAgICAgICAgICBbaXNSZXF1aXJlZF09XCJ0cnVlXCJcclxuICAgICAgICAgICAgZm9yPVwidGl0bGVcIlxyXG4gICAgICAgID5cclxuICAgICAgICAgICAge3sgdCgnVElUTEUnKSB9fVxyXG4gICAgICAgIDwvbGFiZWw+XHJcbiAgICAgICAgPGN1aS1pbnB1dC10ZXh0XHJcbiAgICAgICAgICAgIFtmb3JtQ29udHJvbF09XCJjb250cm9sKClcIlxyXG4gICAgICAgICAgICBjdWlUZXh0RmllbGRJZD1cInRpdGxlXCJcclxuICAgICAgICAgICAgW2N1aVRleHRGaWVsZElzRXJyb3JdPVwiaXNUaXRsZUVycm9yXCJcclxuICAgICAgICAgICAgY3VpVGV4dEZpZWxkUGxhY2Vob2xkZXI9XCJ7eyB0KCdBRERfQV9USVRMRScpIH19Li4uXCJcclxuICAgICAgICAvPlxyXG4gICAgICAgIDxjdWktZ2VuZXJhbC1jb250cm9sLWVycm9yLWhpbnQgW2NvbnRyb2xdPVwiY29udHJvbCgpXCIgLz5cclxuICAgIDwvY3VpLWZvcm0tZmllbGQ+XHJcbjwvbmctY29udGFpbmVyPlxyXG4iXX0=
@@ -0,0 +1,2 @@
1
+ export { CuiChecklistBlockTitleControlComponent } from './checklist-block-title-control.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvY2hlY2tsaXN0LWJsb2NrL2NvbXBvbmVudHMvY2hlY2tsaXN0LWJsb2NrLXRpdGxlLWNvbnRyb2wvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHNDQUFzQyxFQUFFLE1BQU0sMkNBQTJDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBDdWlDaGVja2xpc3RCbG9ja1RpdGxlQ29udHJvbENvbXBvbmVudCB9IGZyb20gJy4vY2hlY2tsaXN0LWJsb2NrLXRpdGxlLWNvbnRyb2wuY29tcG9uZW50JztcclxuIl19
@@ -0,0 +1,2 @@
1
+ export { CuiChecklistBlockListComponent } from './checklist-block-list';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvY2hlY2tsaXN0LWJsb2NrL2NvbXBvbmVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sd0JBQXdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBDdWlDaGVja2xpc3RCbG9ja0xpc3RDb21wb25lbnQgfSBmcm9tICcuL2NoZWNrbGlzdC1ibG9jay1saXN0JztcclxuIl19
@@ -0,0 +1,2 @@
1
+ export { CuiChecklistBlockComponent } from './checklist-block.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvY2hlY2tsaXN0LWJsb2NrL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLDZCQUE2QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQ3VpQ2hlY2tsaXN0QmxvY2tDb21wb25lbnQgfSBmcm9tICcuL2NoZWNrbGlzdC1ibG9jay5jb21wb25lbnQnO1xyXG4iXX0=
@@ -0,0 +1,50 @@
1
+ import { Injectable, signal } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class CuiCheckListBlockService {
4
+ constructor() {
5
+ this.checkListItemsSignal = signal(null);
6
+ this.componentIdSignal = signal(null);
7
+ this.isDragAvailableSignal = signal(false);
8
+ this.checkListItems = this.checkListItemsSignal.asReadonly();
9
+ this.componentId = this.componentIdSignal.asReadonly();
10
+ this.isDragAvailable = this.isDragAvailableSignal.asReadonly();
11
+ }
12
+ setCheckListItems(checkListItems) {
13
+ this.checkListItemsSignal.set(checkListItems);
14
+ }
15
+ addCheckListItem(checkListItem) {
16
+ this.checkListItemsSignal.update((value) => (value ? [...value, checkListItem] : [checkListItem]));
17
+ }
18
+ updateCheckListItem(updatedCheckListItem) {
19
+ if (!this.checkListItemsSignal()) {
20
+ return;
21
+ }
22
+ this.checkListItemsSignal.update((value) => {
23
+ const updateCheckListItemIndex = value.findIndex((checkListItem) => checkListItem.id === updatedCheckListItem.id);
24
+ value[updateCheckListItemIndex] = updatedCheckListItem;
25
+ return [...value];
26
+ });
27
+ }
28
+ deleteCheckListItem(id) {
29
+ if (!this.checkListItemsSignal()) {
30
+ return;
31
+ }
32
+ this.checkListItemsSignal.update((value) => {
33
+ const deletedItemIndex = value.findIndex((checklistItem) => checklistItem.id === id);
34
+ value.splice(deletedItemIndex, 1);
35
+ return [...value];
36
+ });
37
+ }
38
+ setComponentId(id) {
39
+ this.componentIdSignal.set(id);
40
+ }
41
+ toggleDragPermission(isDragButtonVisible) {
42
+ this.isDragAvailableSignal.set(isDragButtonVisible);
43
+ }
44
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiCheckListBlockService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
45
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiCheckListBlockService }); }
46
+ }
47
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiCheckListBlockService, decorators: [{
48
+ type: Injectable
49
+ }] });
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tsaXN0LWJsb2NrLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvY2hlY2tsaXN0LWJsb2NrL3NlcnZpY2VzL2NoZWNrbGlzdC1ibG9jay5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUtuRCxNQUFNLE9BQU8sd0JBQXdCO0lBRHJDO1FBRXFCLHlCQUFvQixHQUNqQyxNQUFNLENBQWlFLElBQUksQ0FBQyxDQUFDO1FBQ2hFLHNCQUFpQixHQUFHLE1BQU0sQ0FBc0IsSUFBSSxDQUFDLENBQUM7UUFDdEQsMEJBQXFCLEdBQUcsTUFBTSxDQUFVLEtBQUssQ0FBQyxDQUFDO1FBRWhELG1CQUFjLEdBQUcsSUFBSSxDQUFDLG9CQUFvQixDQUFDLFVBQVUsRUFBRSxDQUFDO1FBQ3hELGdCQUFXLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLFVBQVUsRUFBRSxDQUFDO1FBQ2xELG9CQUFlLEdBQUcsSUFBSSxDQUFDLHFCQUFxQixDQUFDLFVBQVUsRUFBRSxDQUFDO0tBK0M3RTtJQTdDVSxpQkFBaUIsQ0FBQyxjQUFpRTtRQUN0RixJQUFJLENBQUMsb0JBQW9CLENBQUMsR0FBRyxDQUFDLGNBQWMsQ0FBQyxDQUFDO0lBQ2xELENBQUM7SUFFTSxnQkFBZ0IsQ0FBQyxhQUE4RDtRQUNsRixJQUFJLENBQUMsb0JBQW9CLENBQUMsTUFBTSxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssRUFBRSxhQUFhLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDdkcsQ0FBQztJQUVNLG1CQUFtQixDQUFDLG9CQUFxRTtRQUM1RixJQUFJLENBQUMsSUFBSSxDQUFDLG9CQUFvQixFQUFFLEVBQUUsQ0FBQztZQUMvQixPQUFPO1FBQ1gsQ0FBQztRQUVELElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxNQUFNLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUN2QyxNQUFNLHdCQUF3QixHQUFHLEtBQU0sQ0FBQyxTQUFTLENBQzdDLENBQUMsYUFBYSxFQUFFLEVBQUUsQ0FBQyxhQUFhLENBQUMsRUFBRSxLQUFLLG9CQUFvQixDQUFDLEVBQUUsQ0FDbEUsQ0FBQztZQUVGLEtBQU0sQ0FBQyx3QkFBd0IsQ0FBQyxHQUFHLG9CQUFvQixDQUFDO1lBRXhELE9BQU8sQ0FBQyxHQUFHLEtBQU0sQ0FBQyxDQUFDO1FBQ3ZCLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVNLG1CQUFtQixDQUFDLEVBQVU7UUFDakMsSUFBSSxDQUFDLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxFQUFFLENBQUM7WUFDL0IsT0FBTztRQUNYLENBQUM7UUFFRCxJQUFJLENBQUMsb0JBQW9CLENBQUMsTUFBTSxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDdkMsTUFBTSxnQkFBZ0IsR0FBRyxLQUFNLENBQUMsU0FBUyxDQUFDLENBQUMsYUFBYSxFQUFFLEVBQUUsQ0FBQyxhQUFhLENBQUMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO1lBRXRGLEtBQU0sQ0FBQyxNQUFNLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFFbkMsT0FBTyxDQUFDLEdBQUcsS0FBTSxDQUFDLENBQUM7UUFDdkIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRU0sY0FBYyxDQUFDLEVBQVU7UUFDNUIsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRU0sb0JBQW9CLENBQUMsbUJBQTRCO1FBQ3BELElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxHQUFHLENBQUMsbUJBQW1CLENBQUMsQ0FBQztJQUN4RCxDQUFDOytHQXREUSx3QkFBd0I7bUhBQXhCLHdCQUF3Qjs7NEZBQXhCLHdCQUF3QjtrQkFEcEMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIHNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgdHlwZSB7IEN1aU51bGxhYmxlIH0gZnJvbSAnQGN1YnktdWkvY2RrJztcclxuaW1wb3J0IHsgTm9kZUNoZWNrTGlzdEl0ZW0sIE5vZGVDaGVja0xpc3RJdGVtQ29udGVudFR5cGUgfSBmcm9tICdAY3VieS11aS9hcGknO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgQ3VpQ2hlY2tMaXN0QmxvY2tTZXJ2aWNlIHtcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgY2hlY2tMaXN0SXRlbXNTaWduYWwgPVxyXG4gICAgICAgIHNpZ25hbDxDdWlOdWxsYWJsZTxOb2RlQ2hlY2tMaXN0SXRlbTxOb2RlQ2hlY2tMaXN0SXRlbUNvbnRlbnRUeXBlPltdPj4obnVsbCk7XHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IGNvbXBvbmVudElkU2lnbmFsID0gc2lnbmFsPEN1aU51bGxhYmxlPHN0cmluZz4+KG51bGwpO1xyXG4gICAgcHJpdmF0ZSByZWFkb25seSBpc0RyYWdBdmFpbGFibGVTaWduYWwgPSBzaWduYWw8Ym9vbGVhbj4oZmFsc2UpO1xyXG5cclxuICAgIHB1YmxpYyByZWFkb25seSBjaGVja0xpc3RJdGVtcyA9IHRoaXMuY2hlY2tMaXN0SXRlbXNTaWduYWwuYXNSZWFkb25seSgpO1xyXG4gICAgcHVibGljIHJlYWRvbmx5IGNvbXBvbmVudElkID0gdGhpcy5jb21wb25lbnRJZFNpZ25hbC5hc1JlYWRvbmx5KCk7XHJcbiAgICBwdWJsaWMgcmVhZG9ubHkgaXNEcmFnQXZhaWxhYmxlID0gdGhpcy5pc0RyYWdBdmFpbGFibGVTaWduYWwuYXNSZWFkb25seSgpO1xyXG5cclxuICAgIHB1YmxpYyBzZXRDaGVja0xpc3RJdGVtcyhjaGVja0xpc3RJdGVtczogTm9kZUNoZWNrTGlzdEl0ZW08Tm9kZUNoZWNrTGlzdEl0ZW1Db250ZW50VHlwZT5bXSk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuY2hlY2tMaXN0SXRlbXNTaWduYWwuc2V0KGNoZWNrTGlzdEl0ZW1zKTtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgYWRkQ2hlY2tMaXN0SXRlbShjaGVja0xpc3RJdGVtOiBOb2RlQ2hlY2tMaXN0SXRlbTxOb2RlQ2hlY2tMaXN0SXRlbUNvbnRlbnRUeXBlPik6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuY2hlY2tMaXN0SXRlbXNTaWduYWwudXBkYXRlKCh2YWx1ZSkgPT4gKHZhbHVlID8gWy4uLnZhbHVlLCBjaGVja0xpc3RJdGVtXSA6IFtjaGVja0xpc3RJdGVtXSkpO1xyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyB1cGRhdGVDaGVja0xpc3RJdGVtKHVwZGF0ZWRDaGVja0xpc3RJdGVtOiBOb2RlQ2hlY2tMaXN0SXRlbTxOb2RlQ2hlY2tMaXN0SXRlbUNvbnRlbnRUeXBlPik6IHZvaWQge1xyXG4gICAgICAgIGlmICghdGhpcy5jaGVja0xpc3RJdGVtc1NpZ25hbCgpKSB7XHJcbiAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHRoaXMuY2hlY2tMaXN0SXRlbXNTaWduYWwudXBkYXRlKCh2YWx1ZSkgPT4ge1xyXG4gICAgICAgICAgICBjb25zdCB1cGRhdGVDaGVja0xpc3RJdGVtSW5kZXggPSB2YWx1ZSEuZmluZEluZGV4KFxyXG4gICAgICAgICAgICAgICAgKGNoZWNrTGlzdEl0ZW0pID0+IGNoZWNrTGlzdEl0ZW0uaWQgPT09IHVwZGF0ZWRDaGVja0xpc3RJdGVtLmlkXHJcbiAgICAgICAgICAgICk7XHJcblxyXG4gICAgICAgICAgICB2YWx1ZSFbdXBkYXRlQ2hlY2tMaXN0SXRlbUluZGV4XSA9IHVwZGF0ZWRDaGVja0xpc3RJdGVtO1xyXG5cclxuICAgICAgICAgICAgcmV0dXJuIFsuLi52YWx1ZSFdO1xyXG4gICAgICAgIH0pO1xyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyBkZWxldGVDaGVja0xpc3RJdGVtKGlkOiBzdHJpbmcpOiB2b2lkIHtcclxuICAgICAgICBpZiAoIXRoaXMuY2hlY2tMaXN0SXRlbXNTaWduYWwoKSkge1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICB0aGlzLmNoZWNrTGlzdEl0ZW1zU2lnbmFsLnVwZGF0ZSgodmFsdWUpID0+IHtcclxuICAgICAgICAgICAgY29uc3QgZGVsZXRlZEl0ZW1JbmRleCA9IHZhbHVlIS5maW5kSW5kZXgoKGNoZWNrbGlzdEl0ZW0pID0+IGNoZWNrbGlzdEl0ZW0uaWQgPT09IGlkKTtcclxuXHJcbiAgICAgICAgICAgIHZhbHVlIS5zcGxpY2UoZGVsZXRlZEl0ZW1JbmRleCwgMSk7XHJcblxyXG4gICAgICAgICAgICByZXR1cm4gWy4uLnZhbHVlIV07XHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIHNldENvbXBvbmVudElkKGlkOiBzdHJpbmcpOiB2b2lkIHtcclxuICAgICAgICB0aGlzLmNvbXBvbmVudElkU2lnbmFsLnNldChpZCk7XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIHRvZ2dsZURyYWdQZXJtaXNzaW9uKGlzRHJhZ0J1dHRvblZpc2libGU6IGJvb2xlYW4pOiB2b2lkIHtcclxuICAgICAgICB0aGlzLmlzRHJhZ0F2YWlsYWJsZVNpZ25hbC5zZXQoaXNEcmFnQnV0dG9uVmlzaWJsZSk7XHJcbiAgICB9XHJcbn1cclxuIl19
@@ -0,0 +1,2 @@
1
+ export { CuiCheckListBlockService } from './checklist-block.service';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvY2hlY2tsaXN0LWJsb2NrL3NlcnZpY2VzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQ3VpQ2hlY2tMaXN0QmxvY2tTZXJ2aWNlIH0gZnJvbSAnLi9jaGVja2xpc3QtYmxvY2suc2VydmljZSc7XHJcbiJdfQ==
@@ -0,0 +1,39 @@
1
+ import { ChangeDetectionStrategy, Component, inject, signal } from '@angular/core';
2
+ import { TranslocoModule } from '@jsverse/transloco';
3
+ import { finalize } from 'rxjs';
4
+ import { CuiTooltip, } from '../../directives';
5
+ import { CUI_DIALOG_CONTEXT, CuiButtonModule } from '../../components';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../../components/button/button.component";
8
+ import * as i2 from "@jsverse/transloco";
9
+ import * as i3 from "../../directives/tooltip/tooltip.directive";
10
+ export class CuiDeleteModalComponent {
11
+ constructor() {
12
+ this.context = inject(CUI_DIALOG_CONTEXT);
13
+ this.data = this.context.data;
14
+ this.title = this.data.title;
15
+ this.content = this.data.content;
16
+ this.isLoading = signal(false);
17
+ this.isDisabled = this.data.isDisabled ?? false;
18
+ }
19
+ onDelete() {
20
+ if (!this.data.delete) {
21
+ return;
22
+ }
23
+ this.isLoading.set(true);
24
+ this.data
25
+ .delete()
26
+ .pipe(finalize(() => this.isLoading.set(false)))
27
+ .subscribe(() => this.context.completeWith());
28
+ }
29
+ onCancel() {
30
+ this.context.completeWith({ canceled: true });
31
+ }
32
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiDeleteModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
33
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CuiDeleteModalComponent, isStandalone: true, selector: "cui-delete-modal", ngImport: i0, template: "<div\r\n *transloco=\"let t\"\r\n class=\"wrapper\"\r\n>\r\n <div class=\"content\">\r\n <div class=\"header\">\r\n <h3 class=\"title\">{{ t(title) }}</h3>\r\n <button\r\n type=\"button\"\r\n cuiButton\r\n icon=\"cuiIconX\"\r\n appearance=\"ghost\"\r\n [disabled]=\"isLoading()\"\r\n class=\"close-btn\"\r\n (click)=\"onCancel()\"\r\n ></button>\r\n </div>\r\n <div class=\"info\">\r\n @for (text of content; track text) {\r\n <p [innerHTML]=\"t(text)\"></p>\r\n }\r\n </div>\r\n </div>\r\n\r\n <div class=\"footer\">\r\n <button\r\n type=\"button\"\r\n cuiButton\r\n (click)=\"onCancel()\"\r\n [disabled]=\"isLoading()\"\r\n appearance=\"secondary\"\r\n >\r\n {{ t('CANCEL') }}\r\n </button>\r\n <button\r\n type=\"button\"\r\n cuiButton\r\n [isLoaderShown]=\"isLoading()\"\r\n [disabled]=\"isDisabled\"\r\n [cuiTooltip]=\"isDisabled && t('IN_DEVELOPMENT')\"\r\n appearance=\"destructive\"\r\n (click)=\"onDelete()\"\r\n >\r\n {{ t('YES_DELETE') }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".wrapper{display:flex;flex-direction:column;gap:24px;padding:23px;border-radius:12px;width:400px}.header{display:flex;gap:8px;justify-content:space-between}.content{display:flex;flex-direction:column;gap:12px}.title{font-weight:500;font-size:18px;line-height:28px}.info{display:flex;flex-direction:column;gap:16px;font-weight:400;font-size:14px;line-height:20px}.footer{display:flex;gap:12px;justify-content:flex-end}.close-btn{margin:-8px}\n"], dependencies: [{ kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: i1.CuiButtonComponent, selector: "button[cuiButton], a[cuiButton]", inputs: ["shape", "disabled", "isLoaderShown", "icon", "iconRight", "appearance", "size"] }, { kind: "ngmodule", type: TranslocoModule }, { kind: "directive", type: i2.TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "directive", type: i3.CuiTooltipDirective, selector: "[cuiTooltip]:not(ng-container):not(ng-template)", inputs: ["cuiTooltipContext", "cuiTooltipAppearance", "cuiTooltip"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
34
+ }
35
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiDeleteModalComponent, decorators: [{
36
+ type: Component,
37
+ args: [{ selector: 'cui-delete-modal', imports: [CuiButtonModule, TranslocoModule, CuiTooltip], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\r\n *transloco=\"let t\"\r\n class=\"wrapper\"\r\n>\r\n <div class=\"content\">\r\n <div class=\"header\">\r\n <h3 class=\"title\">{{ t(title) }}</h3>\r\n <button\r\n type=\"button\"\r\n cuiButton\r\n icon=\"cuiIconX\"\r\n appearance=\"ghost\"\r\n [disabled]=\"isLoading()\"\r\n class=\"close-btn\"\r\n (click)=\"onCancel()\"\r\n ></button>\r\n </div>\r\n <div class=\"info\">\r\n @for (text of content; track text) {\r\n <p [innerHTML]=\"t(text)\"></p>\r\n }\r\n </div>\r\n </div>\r\n\r\n <div class=\"footer\">\r\n <button\r\n type=\"button\"\r\n cuiButton\r\n (click)=\"onCancel()\"\r\n [disabled]=\"isLoading()\"\r\n appearance=\"secondary\"\r\n >\r\n {{ t('CANCEL') }}\r\n </button>\r\n <button\r\n type=\"button\"\r\n cuiButton\r\n [isLoaderShown]=\"isLoading()\"\r\n [disabled]=\"isDisabled\"\r\n [cuiTooltip]=\"isDisabled && t('IN_DEVELOPMENT')\"\r\n appearance=\"destructive\"\r\n (click)=\"onDelete()\"\r\n >\r\n {{ t('YES_DELETE') }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".wrapper{display:flex;flex-direction:column;gap:24px;padding:23px;border-radius:12px;width:400px}.header{display:flex;gap:8px;justify-content:space-between}.content{display:flex;flex-direction:column;gap:12px}.title{font-weight:500;font-size:18px;line-height:28px}.info{display:flex;flex-direction:column;gap:16px;font-weight:400;font-size:14px;line-height:20px}.footer{display:flex;gap:12px;justify-content:flex-end}.close-btn{margin:-8px}\n"] }]
38
+ }] });
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVsZXRlLW1vZGFsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvd2lkZ2V0cy9kZWxldGUtbW9kYWwvZGVsZXRlLW1vZGFsLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvd2lkZ2V0cy9kZWxldGUtbW9kYWwvZGVsZXRlLW1vZGFsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDckQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUVoQyxPQUFPLEVBQUUsVUFBVSxHQUFHLE1BQU0sa0JBQWtCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLGVBQWUsRUFBeUIsTUFBTSxrQkFBa0IsQ0FBQzs7Ozs7QUFXOUYsTUFBTSxPQUFPLHVCQUF1QjtJQVJwQztRQVNxQixZQUFPLEdBQUcsTUFBTSxDQUF3QyxrQkFBa0IsQ0FBQyxDQUFDO1FBRTVFLFNBQUksR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQztRQUV2QixVQUFLLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUM7UUFDeEIsWUFBTyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDO1FBQzVCLGNBQVMsR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDMUIsZUFBVSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxJQUFJLEtBQUssQ0FBQztLQWlCakU7SUFmYSxRQUFRO1FBQ2QsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDcEIsT0FBTztRQUNYLENBQUM7UUFFRCxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6QixJQUFJLENBQUMsSUFBSTthQUNKLE1BQU0sRUFBRTthQUNSLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQzthQUMvQyxTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLEVBQUUsQ0FBQyxDQUFDO0lBQ3RELENBQUM7SUFFUyxRQUFRO1FBQ2QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLENBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNsRCxDQUFDOytHQXhCUSx1QkFBdUI7bUdBQXZCLHVCQUF1Qiw0RUNoQnBDLCszQ0ErQ0EsbWZEckNjLGVBQWUsME5BQUUsZUFBZTs7NEZBTWpDLHVCQUF1QjtrQkFSbkMsU0FBUzsrQkFDSSxrQkFBa0IsV0FDbkIsQ0FBQyxlQUFlLEVBQUUsZUFBZSxFQUFFLFVBQVUsQ0FBQyxjQUMzQyxJQUFJLG1CQUdDLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbmplY3QsIHNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUcmFuc2xvY29Nb2R1bGUgfSBmcm9tICdAanN2ZXJzZS90cmFuc2xvY28nO1xyXG5pbXBvcnQgeyBmaW5hbGl6ZSB9IGZyb20gJ3J4anMnO1xyXG5cclxuaW1wb3J0IHsgQ3VpVG9vbHRpcCwgfSBmcm9tICcuLi8uLi9kaXJlY3RpdmVzJztcclxuaW1wb3J0IHsgQ1VJX0RJQUxPR19DT05URVhULCBDdWlCdXR0b25Nb2R1bGUsIHR5cGUgQ3VpRGlhbG9nQ29udGV4dCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgdHlwZSB7IEN1aURpYWxvZ0RlbGV0ZURhdGEgfSBmcm9tICcuL2RlbGV0ZS1tb2RhbC5vcHRpb25zJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdjdWktZGVsZXRlLW1vZGFsJyxcclxuICAgIGltcG9ydHM6IFtDdWlCdXR0b25Nb2R1bGUsIFRyYW5zbG9jb01vZHVsZSwgQ3VpVG9vbHRpcF0sXHJcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2RlbGV0ZS1tb2RhbC5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi9kZWxldGUtbW9kYWwuY29tcG9uZW50LnNjc3MnXSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDdWlEZWxldGVNb2RhbENvbXBvbmVudCB7XHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IGNvbnRleHQgPSBpbmplY3Q8Q3VpRGlhbG9nQ29udGV4dDxDdWlEaWFsb2dEZWxldGVEYXRhPj4oQ1VJX0RJQUxPR19DT05URVhUKTtcclxuXHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IGRhdGEgPSB0aGlzLmNvbnRleHQuZGF0YTtcclxuXHJcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgdGl0bGUgPSB0aGlzLmRhdGEudGl0bGU7XHJcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgY29udGVudCA9IHRoaXMuZGF0YS5jb250ZW50O1xyXG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IGlzTG9hZGluZyA9IHNpZ25hbChmYWxzZSk7XHJcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgaXNEaXNhYmxlZCA9IHRoaXMuZGF0YS5pc0Rpc2FibGVkID8/IGZhbHNlO1xyXG5cclxuICAgIHByb3RlY3RlZCBvbkRlbGV0ZSgpOiB2b2lkIHtcclxuICAgICAgICBpZiAoIXRoaXMuZGF0YS5kZWxldGUpIHtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgdGhpcy5pc0xvYWRpbmcuc2V0KHRydWUpO1xyXG4gICAgICAgIHRoaXMuZGF0YVxyXG4gICAgICAgICAgICAuZGVsZXRlKClcclxuICAgICAgICAgICAgLnBpcGUoZmluYWxpemUoKCkgPT4gdGhpcy5pc0xvYWRpbmcuc2V0KGZhbHNlKSkpXHJcbiAgICAgICAgICAgIC5zdWJzY3JpYmUoKCkgPT4gdGhpcy5jb250ZXh0LmNvbXBsZXRlV2l0aCgpKTtcclxuICAgIH1cclxuXHJcbiAgICBwcm90ZWN0ZWQgb25DYW5jZWwoKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5jb250ZXh0LmNvbXBsZXRlV2l0aCh7IGNhbmNlbGVkOiB0cnVlIH0pO1xyXG4gICAgfVxyXG59XHJcbiIsIjxkaXZcclxuICAgICp0cmFuc2xvY289XCJsZXQgdFwiXHJcbiAgICBjbGFzcz1cIndyYXBwZXJcIlxyXG4+XHJcbiAgICA8ZGl2IGNsYXNzPVwiY29udGVudFwiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJoZWFkZXJcIj5cclxuICAgICAgICAgICAgPGgzIGNsYXNzPVwidGl0bGVcIj57eyB0KHRpdGxlKSB9fTwvaDM+XHJcbiAgICAgICAgICAgIDxidXR0b25cclxuICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxyXG4gICAgICAgICAgICAgICAgY3VpQnV0dG9uXHJcbiAgICAgICAgICAgICAgICBpY29uPVwiY3VpSWNvblhcIlxyXG4gICAgICAgICAgICAgICAgYXBwZWFyYW5jZT1cImdob3N0XCJcclxuICAgICAgICAgICAgICAgIFtkaXNhYmxlZF09XCJpc0xvYWRpbmcoKVwiXHJcbiAgICAgICAgICAgICAgICBjbGFzcz1cImNsb3NlLWJ0blwiXHJcbiAgICAgICAgICAgICAgICAoY2xpY2spPVwib25DYW5jZWwoKVwiXHJcbiAgICAgICAgICAgID48L2J1dHRvbj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiaW5mb1wiPlxyXG4gICAgICAgICAgICBAZm9yICh0ZXh0IG9mIGNvbnRlbnQ7IHRyYWNrIHRleHQpIHtcclxuICAgICAgICAgICAgICAgIDxwIFtpbm5lckhUTUxdPVwidCh0ZXh0KVwiPjwvcD5cclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcblxyXG4gICAgPGRpdiBjbGFzcz1cImZvb3RlclwiPlxyXG4gICAgICAgIDxidXR0b25cclxuICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXHJcbiAgICAgICAgICAgIGN1aUJ1dHRvblxyXG4gICAgICAgICAgICAoY2xpY2spPVwib25DYW5jZWwoKVwiXHJcbiAgICAgICAgICAgIFtkaXNhYmxlZF09XCJpc0xvYWRpbmcoKVwiXHJcbiAgICAgICAgICAgIGFwcGVhcmFuY2U9XCJzZWNvbmRhcnlcIlxyXG4gICAgICAgID5cclxuICAgICAgICAgICAge3sgdCgnQ0FOQ0VMJykgfX1cclxuICAgICAgICA8L2J1dHRvbj5cclxuICAgICAgICA8YnV0dG9uXHJcbiAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxyXG4gICAgICAgICAgICBjdWlCdXR0b25cclxuICAgICAgICAgICAgW2lzTG9hZGVyU2hvd25dPVwiaXNMb2FkaW5nKClcIlxyXG4gICAgICAgICAgICBbZGlzYWJsZWRdPVwiaXNEaXNhYmxlZFwiXHJcbiAgICAgICAgICAgIFtjdWlUb29sdGlwXT1cImlzRGlzYWJsZWQgJiYgdCgnSU5fREVWRUxPUE1FTlQnKVwiXHJcbiAgICAgICAgICAgIGFwcGVhcmFuY2U9XCJkZXN0cnVjdGl2ZVwiXHJcbiAgICAgICAgICAgIChjbGljayk9XCJvbkRlbGV0ZSgpXCJcclxuICAgICAgICA+XHJcbiAgICAgICAgICAgIHt7IHQoJ1lFU19ERUxFVEUnKSB9fVxyXG4gICAgICAgIDwvYnV0dG9uPlxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PlxyXG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVsZXRlLW1vZGFsLm9wdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvZGVsZXRlLW1vZGFsL2RlbGV0ZS1tb2RhbC5vcHRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ3VpRGlhbG9nRGVsZXRlRGF0YSB7XHJcbiAgICByZWFkb25seSB0aXRsZTogc3RyaW5nO1xyXG4gICAgcmVhZG9ubHkgY29udGVudDogc3RyaW5nW107XHJcbiAgICByZWFkb25seSBpc0Rpc2FibGVkPzogYm9vbGVhbjtcclxuICAgIHJlYWRvbmx5IGRlbGV0ZTogKCkgPT4gT2JzZXJ2YWJsZTx2b2lkPjtcclxufVxyXG4iXX0=
@@ -0,0 +1,2 @@
1
+ export { CuiDeleteModalComponent } from './delete-modal.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvZGVsZXRlLW1vZGFsL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQ3VpRGVsZXRlTW9kYWxDb21wb25lbnQgfSBmcm9tICcuL2RlbGV0ZS1tb2RhbC5jb21wb25lbnQnO1xyXG5leHBvcnQgeyBDdWlEaWFsb2dEZWxldGVEYXRhIH0gZnJvbSAnLi9kZWxldGUtbW9kYWwub3B0aW9ucyc7XHJcbiJdfQ==
@@ -1,3 +1,7 @@
1
+ export { CuiLoaderComponent } from './loader';
2
+ export { CuiDeleteModalComponent } from './delete-modal';
3
+ export { CuiCategoriesComponent } from './categories';
1
4
  export { CuiUtilityInfoComponent } from './utility-info';
2
- export { CuiCategoriesComponent, CuiSelectedCategoryService } from './categories';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDekQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLDBCQUEwQixFQUFFLE1BQU0sY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQ3VpVXRpbGl0eUluZm9Db21wb25lbnQgfSBmcm9tICcuL3V0aWxpdHktaW5mbyc7XHJcbmV4cG9ydCB7IEN1aUNhdGVnb3JpZXNDb21wb25lbnQsIEN1aVNlbGVjdGVkQ2F0ZWdvcnlTZXJ2aWNlIH0gZnJvbSAnLi9jYXRlZ29yaWVzJztcclxuIl19
5
+ export { CuiChecklistBlockComponent } from './checklist-block';
6
+ export { CuiGeneralControlErrorHintComponent } from './general-control-error-hint';
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQzlDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUN0RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUMvRCxPQUFPLEVBQUUsbUNBQW1DLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IEN1aUxvYWRlckNvbXBvbmVudCB9IGZyb20gJy4vbG9hZGVyJztcclxuZXhwb3J0IHsgQ3VpRGVsZXRlTW9kYWxDb21wb25lbnQgfSBmcm9tICcuL2RlbGV0ZS1tb2RhbCc7XHJcbmV4cG9ydCB7IEN1aUNhdGVnb3JpZXNDb21wb25lbnQgfSBmcm9tICcuL2NhdGVnb3JpZXMnO1xyXG5leHBvcnQgeyBDdWlVdGlsaXR5SW5mb0NvbXBvbmVudCB9IGZyb20gJy4vdXRpbGl0eS1pbmZvJztcclxuZXhwb3J0IHsgQ3VpQ2hlY2tsaXN0QmxvY2tDb21wb25lbnQgfSBmcm9tICcuL2NoZWNrbGlzdC1ibG9jayc7XHJcbmV4cG9ydCB7IEN1aUdlbmVyYWxDb250cm9sRXJyb3JIaW50Q29tcG9uZW50IH0gZnJvbSAnLi9nZW5lcmFsLWNvbnRyb2wtZXJyb3ItaGludCc7XHJcbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export { CuiLoaderComponent } from './loader.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvbG9hZGVyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQ3VpTG9hZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9sb2FkZXIuY29tcG9uZW50JztcclxuIl19
@@ -0,0 +1,36 @@
1
+ import { ChangeDetectionStrategy, Component, computed, inject } from '@angular/core';
2
+ import { TranslocoService } from '@jsverse/transloco';
3
+ import { CuiSvgModule } from '../../components';
4
+ import { CuiLoaderService, CuiLoadingState } from '../../services';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "../../components/svg/svg.component";
7
+ export class CuiLoaderComponent {
8
+ constructor() {
9
+ this.loaderService = inject(CuiLoaderService);
10
+ this.translocoService = inject(TranslocoService);
11
+ this.state = CuiLoadingState;
12
+ this.LoaderString = {
13
+ [CuiLoadingState.LOADING]: `${this.translocoService.translate('SAVING')}...`,
14
+ [CuiLoadingState.COMPLETED]: this.translocoService.translate('SAVED'),
15
+ [CuiLoadingState.INITIAL]: ''
16
+ };
17
+ this.LoaderIcon = {
18
+ [CuiLoadingState.LOADING]: 'cuiIconRefreshCcw',
19
+ [CuiLoadingState.COMPLETED]: 'cuiIconCheck',
20
+ [CuiLoadingState.INITIAL]: ''
21
+ };
22
+ this.loaderState = this.loaderService.loaderState;
23
+ this.loaderString = computed(() => this.LoaderString[this.loaderState()]);
24
+ this.loaderIcon = computed(() => this.LoaderIcon[this.loaderState()]);
25
+ }
26
+ ngOnDestroy() {
27
+ this.loaderService.reset();
28
+ }
29
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiLoaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
30
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CuiLoaderComponent, isStandalone: true, selector: "cui-loader", ngImport: i0, template: "@if (loaderState() !== state.INITIAL) {\r\n <cui-svg\r\n [icon]=\"loaderIcon()\"\r\n color=\"var(--cui-base-500)\"\r\n [class.icon_loading]=\"loaderState() === state.LOADING\"\r\n />\r\n <span>{{ loaderString() }}</span>\r\n}\r\n", styles: [":host{padding:6px 8px;font-weight:500;font-size:12px;line-height:14px;display:flex;align-items:center;gap:6px;color:var(--cui-base-500)}.icon_loading{animation:spin 1s ease-in-out infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}\n"], dependencies: [{ kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i1.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
31
+ }
32
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiLoaderComponent, decorators: [{
33
+ type: Component,
34
+ args: [{ selector: 'cui-loader', imports: [CuiSvgModule], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (loaderState() !== state.INITIAL) {\r\n <cui-svg\r\n [icon]=\"loaderIcon()\"\r\n color=\"var(--cui-base-500)\"\r\n [class.icon_loading]=\"loaderState() === state.LOADING\"\r\n />\r\n <span>{{ loaderString() }}</span>\r\n}\r\n", styles: [":host{padding:6px 8px;font-weight:500;font-size:12px;line-height:14px;display:flex;align-items:center;gap:6px;color:var(--cui-base-500)}.icon_loading{animation:spin 1s ease-in-out infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}\n"] }]
35
+ }] });
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvd2lkZ2V0cy9sb2FkZXIvbG9hZGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvd2lkZ2V0cy9sb2FkZXIvbG9hZGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVyRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUV0RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDaEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLGVBQWUsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7QUFVbkUsTUFBTSxPQUFPLGtCQUFrQjtJQVIvQjtRQVNtQixrQkFBYSxHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQ3pDLHFCQUFnQixHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBRTFDLFVBQUssR0FBRyxlQUFlLENBQUM7UUFDeEIsaUJBQVksR0FBb0M7WUFDakUsQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLEVBQUUsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxLQUFLO1lBQzVFLENBQUMsZUFBZSxDQUFDLFNBQVMsQ0FBQyxFQUFFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDO1lBQ3JFLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxFQUFFLEVBQUU7U0FDOUIsQ0FBQztRQUNpQixlQUFVLEdBQW9DO1lBQy9ELENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxFQUFFLG1CQUFtQjtZQUM5QyxDQUFDLGVBQWUsQ0FBQyxTQUFTLENBQUMsRUFBRSxjQUFjO1lBQzNDLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxFQUFFLEVBQUU7U0FDOUIsQ0FBQztRQUVpQixnQkFBVyxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsV0FBVyxDQUFDO1FBQzdDLGlCQUFZLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNyRSxlQUFVLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUMsQ0FBQztLQUtyRjtJQUhRLFdBQVc7UUFDaEIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUM3QixDQUFDOytHQXRCVSxrQkFBa0I7bUdBQWxCLGtCQUFrQixzRUNoQi9CLHFRQVFBLDZUREVZLFlBQVk7OzRGQU1YLGtCQUFrQjtrQkFSOUIsU0FBUzsrQkFDRSxZQUFZLFdBQ2IsQ0FBQyxZQUFZLENBQUMsY0FDWCxJQUFJLG1CQUdDLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBjb21wdXRlZCwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBUcmFuc2xvY29TZXJ2aWNlIH0gZnJvbSAnQGpzdmVyc2UvdHJhbnNsb2NvJztcclxuXHJcbmltcG9ydCB7IEN1aVN2Z01vZHVsZSB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBDdWlMb2FkZXJTZXJ2aWNlLCBDdWlMb2FkaW5nU3RhdGUgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2N1aS1sb2FkZXInLFxyXG4gIGltcG9ydHM6IFtDdWlTdmdNb2R1bGVdLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2xvYWRlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vbG9hZGVyLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcclxufSlcclxuZXhwb3J0IGNsYXNzIEN1aUxvYWRlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XHJcbiAgcHJpdmF0ZSByZWFkb25seSBsb2FkZXJTZXJ2aWNlID0gaW5qZWN0KEN1aUxvYWRlclNlcnZpY2UpO1xyXG4gIHByaXZhdGUgcmVhZG9ubHkgdHJhbnNsb2NvU2VydmljZSA9IGluamVjdChUcmFuc2xvY29TZXJ2aWNlKTtcclxuXHJcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IHN0YXRlID0gQ3VpTG9hZGluZ1N0YXRlO1xyXG4gIHByb3RlY3RlZCByZWFkb25seSBMb2FkZXJTdHJpbmc6IFJlY29yZDxDdWlMb2FkaW5nU3RhdGUsIHN0cmluZz4gPSB7XHJcbiAgICBbQ3VpTG9hZGluZ1N0YXRlLkxPQURJTkddOiBgJHt0aGlzLnRyYW5zbG9jb1NlcnZpY2UudHJhbnNsYXRlKCdTQVZJTkcnKX0uLi5gLFxyXG4gICAgW0N1aUxvYWRpbmdTdGF0ZS5DT01QTEVURURdOiB0aGlzLnRyYW5zbG9jb1NlcnZpY2UudHJhbnNsYXRlKCdTQVZFRCcpLFxyXG4gICAgW0N1aUxvYWRpbmdTdGF0ZS5JTklUSUFMXTogJydcclxuICB9O1xyXG4gIHByb3RlY3RlZCByZWFkb25seSBMb2FkZXJJY29uOiBSZWNvcmQ8Q3VpTG9hZGluZ1N0YXRlLCBzdHJpbmc+ID0ge1xyXG4gICAgW0N1aUxvYWRpbmdTdGF0ZS5MT0FESU5HXTogJ2N1aUljb25SZWZyZXNoQ2N3JyxcclxuICAgIFtDdWlMb2FkaW5nU3RhdGUuQ09NUExFVEVEXTogJ2N1aUljb25DaGVjaycsXHJcbiAgICBbQ3VpTG9hZGluZ1N0YXRlLklOSVRJQUxdOiAnJ1xyXG4gIH07XHJcblxyXG4gIHByb3RlY3RlZCByZWFkb25seSBsb2FkZXJTdGF0ZSA9IHRoaXMubG9hZGVyU2VydmljZS5sb2FkZXJTdGF0ZTtcclxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgbG9hZGVyU3RyaW5nID0gY29tcHV0ZWQoKCkgPT4gdGhpcy5Mb2FkZXJTdHJpbmdbdGhpcy5sb2FkZXJTdGF0ZSgpXSk7XHJcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IGxvYWRlckljb24gPSBjb21wdXRlZCgoKSA9PiB0aGlzLkxvYWRlckljb25bdGhpcy5sb2FkZXJTdGF0ZSgpXSk7XHJcblxyXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgIHRoaXMubG9hZGVyU2VydmljZS5yZXNldCgpO1xyXG4gIH1cclxufVxyXG4iLCJAaWYgKGxvYWRlclN0YXRlKCkgIT09IHN0YXRlLklOSVRJQUwpIHtcclxuICAgIDxjdWktc3ZnXHJcbiAgICAgICAgW2ljb25dPVwibG9hZGVySWNvbigpXCJcclxuICAgICAgICBjb2xvcj1cInZhcigtLWN1aS1iYXNlLTUwMClcIlxyXG4gICAgICAgIFtjbGFzcy5pY29uX2xvYWRpbmddPVwibG9hZGVyU3RhdGUoKSA9PT0gc3RhdGUuTE9BRElOR1wiXHJcbiAgICAvPlxyXG4gICAgPHNwYW4+e3sgbG9hZGVyU3RyaW5nKCkgfX08L3NwYW4+XHJcbn1cclxuIl19
@@ -8,7 +8,7 @@ import { debounceTime, map, pairwise, startWith } from 'rxjs';
8
8
  import { CuiAccordionModule, CuiAlertService, CuiButtonModule, CuiFormFieldModule, CuiHintModule, CuiInputModule, CuiLabelModule } from '../../components';
9
9
  import { CuiTooltip } from '../../directives';
10
10
  import { CuiEditorBlockComponent } from '../../editor';
11
- import { createDefaultValidators } from '../../utils';
11
+ import { cuiCreateDefaultValidators } from '../../utils';
12
12
  import { CuiGeneralControlErrorHintComponent } from '../general-control-error-hint';
13
13
  import * as i0 from "@angular/core";
14
14
  import * as i1 from "../../components/button/button.component";
@@ -41,8 +41,8 @@ export class CuiUtilityInfoComponent {
41
41
  this.titleId = this.cuiIdService.generate();
42
42
  this.descriptionId = this.cuiIdService.generate();
43
43
  this.form = this.formBuilder.group({
44
- title: this.formBuilder.control('', createDefaultValidators({ asyncDelay: this.CONTROL_DELAY })),
45
- description: this.formBuilder.control('', createDefaultValidators({ asyncDelay: this.CONTROL_DELAY }))
44
+ title: this.formBuilder.control('', cuiCreateDefaultValidators({ asyncDelay: this.CONTROL_DELAY })),
45
+ description: this.formBuilder.control('', cuiCreateDefaultValidators({ asyncDelay: this.CONTROL_DELAY }))
46
46
  });
47
47
  this.isDescriptionModalOpen = signal(false);
48
48
  this.isDescriptionEmpty = signal(false);
@@ -243,4 +243,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
243
243
  CuiTooltip
244
244
  ], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *transloco=\"let t\">\r\n <section class=\"content\">\r\n <cui-form-field>\r\n <label cuiLabel [isRequired]=\"true\" [for]=\"titleId\">\r\n {{ t('TITLE') }}\r\n </label>\r\n <cui-input-text\r\n [cuiTextFieldId]=\"titleId\"\r\n [cuiTextFieldPlaceholder]=\"t('ADD_TITLE')\"\r\n [cuiTextFieldIsError]=\"isTitleError\"\r\n [formControl]=\"form.controls.title\"\r\n />\r\n @if (isTitleError) {\r\n <cui-general-control-error-hint [control]=\"form.controls.title\" [isVisible]=\"true\" />\r\n }\r\n </cui-form-field>\r\n <cui-form-field>\r\n <label cuiLabel [isRequired]=\"true\" [for]=\"descriptionId\">\r\n {{ t('SHORT_DESCRIPTION') }}\r\n </label>\r\n <cui-input-text\r\n [cuiTextFieldId]=\"descriptionId\"\r\n cuiTextFieldPlaceholder=\"{{t('SHORT_DESCRIPTION')}}...\"\r\n [cuiTextFieldIsError]=\"isDescriptionError\"\r\n [formControl]=\"form.controls.description\"\r\n />\r\n @if (isDescriptionError) {\r\n <cui-general-control-error-hint [control]=\"form.controls.description\" [isVisible]=\"true\" />\r\n }\r\n </cui-form-field>\r\n <section class=\"file\">\r\n <span class=\"title\">{{ t('THUMBNAIL') }}</span>\r\n <div class=\"content__upload\">\r\n <div class=\"content__upload-file\">\r\n @if (thumbnail()?.name; as fileId) {\r\n <div class=\"image\">\r\n <span class=\"image__name\">{{ thumbnail()?.name }}</span>\r\n <!-- TODO: ngSrc -->\r\n <img class=\"image__view\" [src]=\"thumbnailUrl()\" height=\"120\" width=\"184\" alt=\"Thumbnail\" />\r\n </div>\r\n }\r\n <button type=\"button\" cuiButton appearance=\"outlined-gray\" size=\"xxs\" icon=\"cuiIconUpload\"\r\n (click)=\"onSelectFile()\">\r\n {{ uploadButtonName() }}\r\n </button>\r\n @if (thumbnail()?.name) {\r\n <button class=\"content__remove-button\" cuiButton appearance=\"link\" size=\"sm\" type=\"button\"\r\n (click)=\"onRemoveThumbnail()\">\r\n {{ t('REMOVE') }}\r\n </button>\r\n }\r\n <span class=\"content__accepted\">\r\n {{ t('ACCEPTED') }}: JPG, JPEG, PNG, MP4 {{ t('UP_TO') }} 20MB\r\n </span>\r\n </div>\r\n </div>\r\n </section>\r\n @if (editorId(); as editorId) {\r\n <cui-editor-block\r\n [title]=\"form.controls.title.value || title()\"\r\n [config]=\"config()\"\r\n [editorId]=\"editorId\"\r\n [required]=\"true\"\r\n (editorEmpty)=\"onEditorEmpty($event)\"\r\n ></cui-editor-block>\r\n }\r\n </section>\r\n</ng-container>\r\n", styles: ["::ng-deep cui-dialog:has(.instruction-description-modal){inset:0;margin:auto;transform:none!important}:host{display:block}.title{font-weight:500;font-size:14px;line-height:20px;display:flex;gap:2px}.title_required{color:var(--cui-danger)}.content{display:flex;flex-direction:column;gap:16px;padding:16px 24px}.content__upload{padding:12px 16px;border-radius:8px;border:1px solid var(--cui-base-200);background:var(--cui-base-10)}.content__accepted{color:var(--cui-base-500)}.content__upload-file{display:flex;align-items:center;gap:8px}.content__upload-file input[type=file]{display:none}.content__remove-button ::ng-deep .c-content{color:var(--cui-danger)!important}.file{display:flex;flex-direction:column;gap:4px}.description_invalid{border:1px solid var(--cui-danger)}.image{position:relative;display:inline-block}.image__view{border-radius:8px;object-fit:cover}.image__name{position:absolute;top:6px;left:14px;color:var(--cui-base-0);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:170px;z-index:1}.image:after{content:\"\";position:absolute;top:0;left:0;width:100%;height:100%;background-color:#0003;z-index:0;pointer-events:none;border-radius:8px}.button-save{margin-left:auto}.instruction-description-modal{text-transform:none}.empty{padding:16px;color:var(--cui-base-500);text-align:center}\n"] }]
245
245
  }], ctorParameters: () => [] });
246
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utility-info.component.js","sourceRoot":"","sources":["../../../../../projects/core/widgets/utility-info/utility-info.component.ts","../../../../../projects/core/widgets/utility-info/utility-info.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    computed,\r\n    DestroyRef,\r\n    effect,\r\n    forwardRef,\r\n    inject,\r\n    input,\r\n    output,\r\n    signal\r\n} from '@angular/core';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport { NonNullableFormBuilder, ReactiveFormsModule } from '@angular/forms';\r\nimport { CuiFrameApiService, FragmentType, ResourceFragment } from '@cuby-ui/api';\r\nimport { CuiIdService, type CuiNullable } from '@cuby-ui/cdk';\r\nimport { TranslocoDirective, TranslocoService } from '@jsverse/transloco';\r\nimport { debounceTime, map, pairwise, startWith } from 'rxjs';\r\n\r\nimport {\r\n    CuiAccordionModule,\r\n    CuiAlertService,\r\n    CuiButtonModule,\r\n    CuiFormFieldModule,\r\n    CuiHintModule,\r\n    CuiInputModule,\r\n    CuiLabelModule\r\n} from '../../components';\r\nimport { CuiTooltip } from '../../directives';\r\nimport { CuiEditorBlockComponent, CuiEditorConfig } from '../../editor';\r\nimport { createDefaultValidators } from '../../utils';\r\nimport { CuiGeneralControlErrorHintComponent } from '../general-control-error-hint';\r\nimport { CuiUtilityFormGroup, CuiUtilityFormValues } from './utility-info.options';\r\n\r\n@Component({\r\n    selector: 'cui-utility-info',\r\n    imports: [\r\n        CuiAccordionModule,\r\n        CuiButtonModule,\r\n        CuiFormFieldModule,\r\n        CuiHintModule,\r\n        CuiInputModule,\r\n        CuiLabelModule,\r\n        forwardRef(() => CuiEditorBlockComponent),\r\n        CuiGeneralControlErrorHintComponent,\r\n        ReactiveFormsModule,\r\n        TranslocoDirective,\r\n        CuiTooltip\r\n    ],\r\n    standalone: true,\r\n    templateUrl: './utility-info.component.html',\r\n    styleUrl: './utility-info.component.scss',\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class CuiUtilityInfoComponent {\r\n    private readonly destroy = inject(DestroyRef);\r\n    private readonly formBuilder = inject(NonNullableFormBuilder);\r\n    private readonly translocoService = inject(TranslocoService);\r\n    private readonly frameApiService = inject(CuiFrameApiService);\r\n    private readonly cuiAlertService = inject(CuiAlertService);\r\n    private readonly cuiIdService = inject(CuiIdService);\r\n\r\n    protected readonly CONTROL_DELAY = 500;\r\n    protected readonly MAX_FILE_SIZE = 20971520;\r\n\r\n    protected readonly titleId = this.cuiIdService.generate();\r\n    protected readonly descriptionId = this.cuiIdService.generate();\r\n    protected readonly form = this.formBuilder.group<CuiUtilityFormGroup>({\r\n        title: this.formBuilder.control('', createDefaultValidators({ asyncDelay: this.CONTROL_DELAY })),\r\n        description: this.formBuilder.control('', createDefaultValidators({ asyncDelay: this.CONTROL_DELAY }))\r\n    });\r\n    protected readonly isDescriptionModalOpen = signal(false);\r\n    protected readonly isDescriptionEmpty = signal(false);\r\n    protected readonly editorId = signal<CuiNullable<string>>(null);\r\n    protected readonly thumbnail = signal<CuiNullable<ResourceFragment>>(null);\r\n    protected readonly thumbnailUrl = computed(() => {\r\n        const thumbnail = this.thumbnail();\r\n\r\n        if (thumbnail?.resource) {\r\n            return thumbnail.resource;\r\n        }\r\n\r\n        return this.baseResourceUrl() + thumbnail!.fileId!;\r\n    });\r\n    protected readonly uploadButtonName = computed(() => {\r\n        const thumbnail = this.thumbnail();\r\n\r\n        if (thumbnail?.name) {\r\n            return this.translocoService.translate('REPLACE_FILE');\r\n        }\r\n\r\n        return this.translocoService.translate('UPLOAD_FILE');\r\n    });\r\n\r\n    protected heading: CuiNullable<string> = null;\r\n\r\n    protected get controls(): CuiUtilityFormGroup {\r\n        return this.form.controls;\r\n    }\r\n\r\n    protected get isTitleError(): boolean {\r\n        return this.controls.title.invalid && this.controls.title.dirty;\r\n    }\r\n\r\n    protected get isDescriptionError(): boolean {\r\n        return this.controls.description.invalid && this.controls.description.dirty;\r\n    }\r\n\r\n    public readonly title = input.required<string>();\r\n    public readonly framerId = input.required<string>();\r\n    public readonly baseResourceUrl = input.required<string>();\r\n    public readonly config = input.required<CuiEditorConfig>();\r\n\r\n    public readonly formChanged = output<Partial<CuiUtilityFormValues>>();\r\n    public readonly isFormValidChanged = output<boolean>();\r\n\r\n    constructor() {\r\n        this.initUtilityEffect();\r\n    }\r\n\r\n    protected onSelectFile(): void {\r\n        const input = document.createElement('input');\r\n        input.type = 'file';\r\n        input.accept = 'image/jpg, image/jpeg, image/png, video/mp4';\r\n\r\n        input.onchange = (): void => {\r\n            const files = input.files;\r\n\r\n            if (!files?.length) {\r\n                return;\r\n            }\r\n\r\n            this.getFile(files);\r\n        };\r\n\r\n        input.click();\r\n    }\r\n\r\n    protected onEditorEmpty(isEmpty: boolean): void {\r\n        this.isDescriptionEmpty.set(isEmpty);\r\n        this.isFormValidChanged.emit(this.checkFormValidation());\r\n    }\r\n\r\n    protected onRemoveThumbnail(): void {\r\n        const frameId = this.framerId();\r\n        const fragmentId = this.thumbnail()?.id;\r\n\r\n        if (!frameId || !fragmentId) {\r\n            return;\r\n        }\r\n\r\n        this.frameApiService.deleteResource(frameId, fragmentId).subscribe(() => {\r\n            this.thumbnail.update((prev) => ({ ...prev!, fileId: null, name: null, resource: null }));\r\n        });\r\n    }\r\n\r\n    protected onToggleDescriptionModal(): void {\r\n        this.isDescriptionModalOpen.update((prev) => !prev);\r\n    }\r\n\r\n    private initUtilityEffect(): void {\r\n        const effectRef = effect(() => {\r\n            const title = this.title();\r\n\r\n            if (!title) {\r\n                return;\r\n            }\r\n\r\n            this.initTitleSubscriptions();\r\n            this.initFrameFragments();\r\n            effectRef.destroy();\r\n        });\r\n    }\r\n\r\n    private initTitleSubscriptions(): void {\r\n        this.form.patchValue({ title: this.title() });\r\n\r\n        this.form.statusChanges\r\n            .pipe(takeUntilDestroyed(this.destroy))\r\n            .subscribe(() => this.isFormValidChanged.emit(this.checkFormValidation()));\r\n\r\n        this.form.valueChanges\r\n            .pipe(\r\n                takeUntilDestroyed(this.destroy),\r\n                startWith(this.form.value),\r\n                pairwise(),\r\n                debounceTime(this.CONTROL_DELAY),\r\n                map(([prev, current]) => this.compareFormValues([prev, current]))\r\n            )\r\n            .subscribe((value) => {\r\n                this.formChanged.emit(value);\r\n            });\r\n    }\r\n\r\n    private initFrameFragments(): void {\r\n        const frameId = this.framerId();\r\n\r\n        if (!frameId) {\r\n            return;\r\n        }\r\n\r\n        this.frameApiService.getFrame(frameId).subscribe((frame) => {\r\n            frame.fragments.forEach((fragment) => {\r\n                if (fragment.type === FragmentType.jText) {\r\n                    this.editorId.set(fragment?.id);\r\n                }\r\n\r\n                if (fragment.type === FragmentType.resourceFile) {\r\n                    this.setResourceFile(fragment as ResourceFragment);\r\n                }\r\n            });\r\n        });\r\n    }\r\n\r\n    private compareFormValues([prevGroup, currentGruop]: Partial<CuiUtilityFormValues>[]): Partial<CuiUtilityFormValues> {\r\n        const keys = Object.keys(currentGruop) as (keyof CuiUtilityFormGroup)[];\r\n        const changedFields: Record<string, unknown> = {};\r\n\r\n        keys.forEach((key) => {\r\n            const prev = prevGroup[key];\r\n            const current = currentGruop[key];\r\n\r\n            if (prev === current) {\r\n                return;\r\n            }\r\n\r\n            changedFields[key] = current;\r\n        });\r\n\r\n        return changedFields;\r\n    }\r\n\r\n    private setResourceFile(resource: ResourceFragment): void {\r\n        const url = this.baseResourceUrl() + resource.fileId!;\r\n\r\n        this.thumbnail.set(resource);\r\n\r\n        if (!url || resource?.name?.split('.').pop() !== 'mp4') {\r\n            return;\r\n        }\r\n\r\n        this.getCaptureFromVideo(url);\r\n    }\r\n\r\n    private getFile(files: FileList): void {\r\n        const file = files.item(0);\r\n\r\n        if (!file) {\r\n            return;\r\n        }\r\n\r\n        if (file.size > this.MAX_FILE_SIZE) {\r\n            this.cuiAlertService\r\n                .open(this.translocoService.translate('INVALID_FILE_SIZE'), {\r\n                    status: 'error'\r\n                })\r\n                .subscribe();\r\n\r\n            return;\r\n        }\r\n\r\n        const isVideo = file.name.split('.').at(-1) === 'mp4';\r\n        const url = URL.createObjectURL(file);\r\n\r\n        if (isVideo) {\r\n            this.getCaptureFromVideo(url, file);\r\n        } else {\r\n            this.thumbnail.update((prev) => ({ ...prev!, name: file.name, resource: url }));\r\n        }\r\n\r\n        this.uploadFile(file);\r\n    }\r\n\r\n    private uploadFile(file: File): void {\r\n        const frameId = this.framerId();\r\n        const fragmentId = this.thumbnail()?.id;\r\n\r\n        if (!frameId || !fragmentId) {\r\n            return;\r\n        }\r\n\r\n        const formData = new FormData();\r\n        formData.append('resource', file);\r\n\r\n        this.frameApiService.uploadResource(formData, frameId, fragmentId).subscribe();\r\n    }\r\n\r\n    private getCaptureFromVideo(url: string, file?: File): void {\r\n        const canvas = document.createElement('canvas') as HTMLCanvasElement;\r\n        const video = document.createElement('video') as HTMLVideoElement;\r\n\r\n        video.src = url;\r\n        video.currentTime = 1;\r\n        canvas.width = 184;\r\n        canvas.height = 120;\r\n\r\n        video.onloadeddata = (): void => {\r\n            const context = canvas.getContext('2d');\r\n\r\n            if (!context) {\r\n                return;\r\n            }\r\n\r\n            context.drawImage(video, 0, 0, canvas.width, canvas.height);\r\n\r\n            canvas.toBlob((blob) => {\r\n                if (!blob) {\r\n                    return;\r\n                }\r\n\r\n                const videoCaptureUrl = URL.createObjectURL(blob);\r\n                this.thumbnail.update((prev) => ({\r\n                    ...prev!,\r\n                    name: (file?.name || prev?.name)!,\r\n                    resource: videoCaptureUrl\r\n                }));\r\n            });\r\n        };\r\n\r\n        video.load();\r\n    }\r\n\r\n    private checkFormValidation(): boolean {\r\n        console.log(this.isDescriptionEmpty(), this.form.invalid);\r\n        return !this.isDescriptionEmpty() && !this.form.invalid;\r\n    }\r\n}\r\n","<ng-container *transloco=\"let t\">\r\n  <section class=\"content\">\r\n    <cui-form-field>\r\n        <label cuiLabel [isRequired]=\"true\" [for]=\"titleId\">\r\n            {{ t('TITLE') }}\r\n        </label>\r\n        <cui-input-text\r\n            [cuiTextFieldId]=\"titleId\"\r\n            [cuiTextFieldPlaceholder]=\"t('ADD_TITLE')\"\r\n            [cuiTextFieldIsError]=\"isTitleError\"\r\n            [formControl]=\"form.controls.title\"\r\n        />\r\n        @if (isTitleError) {\r\n            <cui-general-control-error-hint [control]=\"form.controls.title\" [isVisible]=\"true\" />\r\n        }\r\n    </cui-form-field>\r\n    <cui-form-field>\r\n        <label cuiLabel [isRequired]=\"true\" [for]=\"descriptionId\">\r\n            {{ t('SHORT_DESCRIPTION') }}\r\n        </label>\r\n         <cui-input-text\r\n            [cuiTextFieldId]=\"descriptionId\"\r\n            cuiTextFieldPlaceholder=\"{{t('SHORT_DESCRIPTION')}}...\"\r\n            [cuiTextFieldIsError]=\"isDescriptionError\"\r\n            [formControl]=\"form.controls.description\"\r\n        />\r\n        @if (isDescriptionError) {\r\n            <cui-general-control-error-hint [control]=\"form.controls.description\" [isVisible]=\"true\" />\r\n        }\r\n    </cui-form-field>\r\n    <section class=\"file\">\r\n      <span class=\"title\">{{ t('THUMBNAIL') }}</span>\r\n      <div class=\"content__upload\">\r\n        <div class=\"content__upload-file\">\r\n          @if (thumbnail()?.name; as fileId) {\r\n          <div class=\"image\">\r\n            <span class=\"image__name\">{{ thumbnail()?.name }}</span>\r\n            <!-- TODO: ngSrc -->\r\n            <img class=\"image__view\" [src]=\"thumbnailUrl()\" height=\"120\" width=\"184\" alt=\"Thumbnail\" />\r\n          </div>\r\n          }\r\n          <button type=\"button\" cuiButton appearance=\"outlined-gray\" size=\"xxs\" icon=\"cuiIconUpload\"\r\n            (click)=\"onSelectFile()\">\r\n            {{ uploadButtonName() }}\r\n          </button>\r\n          @if (thumbnail()?.name) {\r\n          <button class=\"content__remove-button\" cuiButton appearance=\"link\" size=\"sm\" type=\"button\"\r\n            (click)=\"onRemoveThumbnail()\">\r\n            {{ t('REMOVE') }}\r\n          </button>\r\n          }\r\n          <span class=\"content__accepted\">\r\n            {{ t('ACCEPTED') }}: JPG, JPEG, PNG, MP4 {{ t('UP_TO') }} 20MB\r\n          </span>\r\n        </div>\r\n      </div>\r\n    </section>\r\n    @if (editorId(); as editorId) {\r\n        <cui-editor-block\r\n            [title]=\"form.controls.title.value || title()\"\r\n            [config]=\"config()\"\r\n            [editorId]=\"editorId\"\r\n            [required]=\"true\"\r\n            (editorEmpty)=\"onEditorEmpty($event)\"\r\n        ></cui-editor-block>\r\n    }\r\n  </section>\r\n</ng-container>\r\n"]}
246
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utility-info.component.js","sourceRoot":"","sources":["../../../../../projects/core/widgets/utility-info/utility-info.component.ts","../../../../../projects/core/widgets/utility-info/utility-info.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    computed,\r\n    DestroyRef,\r\n    effect,\r\n    forwardRef,\r\n    inject,\r\n    input,\r\n    output,\r\n    signal\r\n} from '@angular/core';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport { NonNullableFormBuilder, ReactiveFormsModule } from '@angular/forms';\r\nimport { CuiFrameApiService, FragmentType, ResourceFragment } from '@cuby-ui/api';\r\nimport { CuiIdService, type CuiNullable } from '@cuby-ui/cdk';\r\nimport { TranslocoDirective, TranslocoService } from '@jsverse/transloco';\r\nimport { debounceTime, map, pairwise, startWith } from 'rxjs';\r\n\r\nimport {\r\n    CuiAccordionModule,\r\n    CuiAlertService,\r\n    CuiButtonModule,\r\n    CuiFormFieldModule,\r\n    CuiHintModule,\r\n    CuiInputModule,\r\n    CuiLabelModule\r\n} from '../../components';\r\nimport { CuiTooltip } from '../../directives';\r\nimport { CuiEditorBlockComponent, CuiEditorConfig } from '../../editor';\r\nimport { cuiCreateDefaultValidators } from '../../utils';\r\nimport { CuiGeneralControlErrorHintComponent } from '../general-control-error-hint';\r\nimport { CuiUtilityFormGroup, CuiUtilityFormValues } from './utility-info.options';\r\n\r\n@Component({\r\n    selector: 'cui-utility-info',\r\n    imports: [\r\n        CuiAccordionModule,\r\n        CuiButtonModule,\r\n        CuiFormFieldModule,\r\n        CuiHintModule,\r\n        CuiInputModule,\r\n        CuiLabelModule,\r\n        forwardRef(() => CuiEditorBlockComponent),\r\n        CuiGeneralControlErrorHintComponent,\r\n        ReactiveFormsModule,\r\n        TranslocoDirective,\r\n        CuiTooltip\r\n    ],\r\n    standalone: true,\r\n    templateUrl: './utility-info.component.html',\r\n    styleUrl: './utility-info.component.scss',\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class CuiUtilityInfoComponent {\r\n    private readonly destroy = inject(DestroyRef);\r\n    private readonly formBuilder = inject(NonNullableFormBuilder);\r\n    private readonly translocoService = inject(TranslocoService);\r\n    private readonly frameApiService = inject(CuiFrameApiService);\r\n    private readonly cuiAlertService = inject(CuiAlertService);\r\n    private readonly cuiIdService = inject(CuiIdService);\r\n\r\n    protected readonly CONTROL_DELAY = 500;\r\n    protected readonly MAX_FILE_SIZE = 20971520;\r\n\r\n    protected readonly titleId = this.cuiIdService.generate();\r\n    protected readonly descriptionId = this.cuiIdService.generate();\r\n    protected readonly form = this.formBuilder.group<CuiUtilityFormGroup>({\r\n        title: this.formBuilder.control('', cuiCreateDefaultValidators({ asyncDelay: this.CONTROL_DELAY })),\r\n        description: this.formBuilder.control('', cuiCreateDefaultValidators({ asyncDelay: this.CONTROL_DELAY }))\r\n    });\r\n    protected readonly isDescriptionModalOpen = signal(false);\r\n    protected readonly isDescriptionEmpty = signal(false);\r\n    protected readonly editorId = signal<CuiNullable<string>>(null);\r\n    protected readonly thumbnail = signal<CuiNullable<ResourceFragment>>(null);\r\n    protected readonly thumbnailUrl = computed(() => {\r\n        const thumbnail = this.thumbnail();\r\n\r\n        if (thumbnail?.resource) {\r\n            return thumbnail.resource;\r\n        }\r\n\r\n        return this.baseResourceUrl() + thumbnail!.fileId!;\r\n    });\r\n    protected readonly uploadButtonName = computed(() => {\r\n        const thumbnail = this.thumbnail();\r\n\r\n        if (thumbnail?.name) {\r\n            return this.translocoService.translate('REPLACE_FILE');\r\n        }\r\n\r\n        return this.translocoService.translate('UPLOAD_FILE');\r\n    });\r\n\r\n    protected heading: CuiNullable<string> = null;\r\n\r\n    protected get controls(): CuiUtilityFormGroup {\r\n        return this.form.controls;\r\n    }\r\n\r\n    protected get isTitleError(): boolean {\r\n        return this.controls.title.invalid && this.controls.title.dirty;\r\n    }\r\n\r\n    protected get isDescriptionError(): boolean {\r\n        return this.controls.description.invalid && this.controls.description.dirty;\r\n    }\r\n\r\n    public readonly title = input.required<string>();\r\n    public readonly framerId = input.required<string>();\r\n    public readonly baseResourceUrl = input.required<string>();\r\n    public readonly config = input.required<CuiEditorConfig>();\r\n\r\n    public readonly formChanged = output<Partial<CuiUtilityFormValues>>();\r\n    public readonly isFormValidChanged = output<boolean>();\r\n\r\n    constructor() {\r\n        this.initUtilityEffect();\r\n    }\r\n\r\n    protected onSelectFile(): void {\r\n        const input = document.createElement('input');\r\n        input.type = 'file';\r\n        input.accept = 'image/jpg, image/jpeg, image/png, video/mp4';\r\n\r\n        input.onchange = (): void => {\r\n            const files = input.files;\r\n\r\n            if (!files?.length) {\r\n                return;\r\n            }\r\n\r\n            this.getFile(files);\r\n        };\r\n\r\n        input.click();\r\n    }\r\n\r\n    protected onEditorEmpty(isEmpty: boolean): void {\r\n        this.isDescriptionEmpty.set(isEmpty);\r\n        this.isFormValidChanged.emit(this.checkFormValidation());\r\n    }\r\n\r\n    protected onRemoveThumbnail(): void {\r\n        const frameId = this.framerId();\r\n        const fragmentId = this.thumbnail()?.id;\r\n\r\n        if (!frameId || !fragmentId) {\r\n            return;\r\n        }\r\n\r\n        this.frameApiService.deleteResource(frameId, fragmentId).subscribe(() => {\r\n            this.thumbnail.update((prev) => ({ ...prev!, fileId: null, name: null, resource: null }));\r\n        });\r\n    }\r\n\r\n    protected onToggleDescriptionModal(): void {\r\n        this.isDescriptionModalOpen.update((prev) => !prev);\r\n    }\r\n\r\n    private initUtilityEffect(): void {\r\n        const effectRef = effect(() => {\r\n            const title = this.title();\r\n\r\n            if (!title) {\r\n                return;\r\n            }\r\n\r\n            this.initTitleSubscriptions();\r\n            this.initFrameFragments();\r\n            effectRef.destroy();\r\n        });\r\n    }\r\n\r\n    private initTitleSubscriptions(): void {\r\n        this.form.patchValue({ title: this.title() });\r\n\r\n        this.form.statusChanges\r\n            .pipe(takeUntilDestroyed(this.destroy))\r\n            .subscribe(() => this.isFormValidChanged.emit(this.checkFormValidation()));\r\n\r\n        this.form.valueChanges\r\n            .pipe(\r\n                takeUntilDestroyed(this.destroy),\r\n                startWith(this.form.value),\r\n                pairwise(),\r\n                debounceTime(this.CONTROL_DELAY),\r\n                map(([prev, current]) => this.compareFormValues([prev, current]))\r\n            )\r\n            .subscribe((value) => {\r\n                this.formChanged.emit(value);\r\n            });\r\n    }\r\n\r\n    private initFrameFragments(): void {\r\n        const frameId = this.framerId();\r\n\r\n        if (!frameId) {\r\n            return;\r\n        }\r\n\r\n        this.frameApiService.getFrame(frameId).subscribe((frame) => {\r\n            frame.fragments.forEach((fragment) => {\r\n                if (fragment.type === FragmentType.jText) {\r\n                    this.editorId.set(fragment?.id);\r\n                }\r\n\r\n                if (fragment.type === FragmentType.resourceFile) {\r\n                    this.setResourceFile(fragment as ResourceFragment);\r\n                }\r\n            });\r\n        });\r\n    }\r\n\r\n    private compareFormValues([prevGroup, currentGruop]: Partial<CuiUtilityFormValues>[]): Partial<CuiUtilityFormValues> {\r\n        const keys = Object.keys(currentGruop) as (keyof CuiUtilityFormGroup)[];\r\n        const changedFields: Record<string, unknown> = {};\r\n\r\n        keys.forEach((key) => {\r\n            const prev = prevGroup[key];\r\n            const current = currentGruop[key];\r\n\r\n            if (prev === current) {\r\n                return;\r\n            }\r\n\r\n            changedFields[key] = current;\r\n        });\r\n\r\n        return changedFields;\r\n    }\r\n\r\n    private setResourceFile(resource: ResourceFragment): void {\r\n        const url = this.baseResourceUrl() + resource.fileId!;\r\n\r\n        this.thumbnail.set(resource);\r\n\r\n        if (!url || resource?.name?.split('.').pop() !== 'mp4') {\r\n            return;\r\n        }\r\n\r\n        this.getCaptureFromVideo(url);\r\n    }\r\n\r\n    private getFile(files: FileList): void {\r\n        const file = files.item(0);\r\n\r\n        if (!file) {\r\n            return;\r\n        }\r\n\r\n        if (file.size > this.MAX_FILE_SIZE) {\r\n            this.cuiAlertService\r\n                .open(this.translocoService.translate('INVALID_FILE_SIZE'), {\r\n                    status: 'error'\r\n                })\r\n                .subscribe();\r\n\r\n            return;\r\n        }\r\n\r\n        const isVideo = file.name.split('.').at(-1) === 'mp4';\r\n        const url = URL.createObjectURL(file);\r\n\r\n        if (isVideo) {\r\n            this.getCaptureFromVideo(url, file);\r\n        } else {\r\n            this.thumbnail.update((prev) => ({ ...prev!, name: file.name, resource: url }));\r\n        }\r\n\r\n        this.uploadFile(file);\r\n    }\r\n\r\n    private uploadFile(file: File): void {\r\n        const frameId = this.framerId();\r\n        const fragmentId = this.thumbnail()?.id;\r\n\r\n        if (!frameId || !fragmentId) {\r\n            return;\r\n        }\r\n\r\n        const formData = new FormData();\r\n        formData.append('resource', file);\r\n\r\n        this.frameApiService.uploadResource(formData, frameId, fragmentId).subscribe();\r\n    }\r\n\r\n    private getCaptureFromVideo(url: string, file?: File): void {\r\n        const canvas = document.createElement('canvas') as HTMLCanvasElement;\r\n        const video = document.createElement('video') as HTMLVideoElement;\r\n\r\n        video.src = url;\r\n        video.currentTime = 1;\r\n        canvas.width = 184;\r\n        canvas.height = 120;\r\n\r\n        video.onloadeddata = (): void => {\r\n            const context = canvas.getContext('2d');\r\n\r\n            if (!context) {\r\n                return;\r\n            }\r\n\r\n            context.drawImage(video, 0, 0, canvas.width, canvas.height);\r\n\r\n            canvas.toBlob((blob) => {\r\n                if (!blob) {\r\n                    return;\r\n                }\r\n\r\n                const videoCaptureUrl = URL.createObjectURL(blob);\r\n                this.thumbnail.update((prev) => ({\r\n                    ...prev!,\r\n                    name: (file?.name || prev?.name)!,\r\n                    resource: videoCaptureUrl\r\n                }));\r\n            });\r\n        };\r\n\r\n        video.load();\r\n    }\r\n\r\n    private checkFormValidation(): boolean {\r\n        console.log(this.isDescriptionEmpty(), this.form.invalid);\r\n        return !this.isDescriptionEmpty() && !this.form.invalid;\r\n    }\r\n}\r\n","<ng-container *transloco=\"let t\">\r\n  <section class=\"content\">\r\n    <cui-form-field>\r\n        <label cuiLabel [isRequired]=\"true\" [for]=\"titleId\">\r\n            {{ t('TITLE') }}\r\n        </label>\r\n        <cui-input-text\r\n            [cuiTextFieldId]=\"titleId\"\r\n            [cuiTextFieldPlaceholder]=\"t('ADD_TITLE')\"\r\n            [cuiTextFieldIsError]=\"isTitleError\"\r\n            [formControl]=\"form.controls.title\"\r\n        />\r\n        @if (isTitleError) {\r\n            <cui-general-control-error-hint [control]=\"form.controls.title\" [isVisible]=\"true\" />\r\n        }\r\n    </cui-form-field>\r\n    <cui-form-field>\r\n        <label cuiLabel [isRequired]=\"true\" [for]=\"descriptionId\">\r\n            {{ t('SHORT_DESCRIPTION') }}\r\n        </label>\r\n         <cui-input-text\r\n            [cuiTextFieldId]=\"descriptionId\"\r\n            cuiTextFieldPlaceholder=\"{{t('SHORT_DESCRIPTION')}}...\"\r\n            [cuiTextFieldIsError]=\"isDescriptionError\"\r\n            [formControl]=\"form.controls.description\"\r\n        />\r\n        @if (isDescriptionError) {\r\n            <cui-general-control-error-hint [control]=\"form.controls.description\" [isVisible]=\"true\" />\r\n        }\r\n    </cui-form-field>\r\n    <section class=\"file\">\r\n      <span class=\"title\">{{ t('THUMBNAIL') }}</span>\r\n      <div class=\"content__upload\">\r\n        <div class=\"content__upload-file\">\r\n          @if (thumbnail()?.name; as fileId) {\r\n          <div class=\"image\">\r\n            <span class=\"image__name\">{{ thumbnail()?.name }}</span>\r\n            <!-- TODO: ngSrc -->\r\n            <img class=\"image__view\" [src]=\"thumbnailUrl()\" height=\"120\" width=\"184\" alt=\"Thumbnail\" />\r\n          </div>\r\n          }\r\n          <button type=\"button\" cuiButton appearance=\"outlined-gray\" size=\"xxs\" icon=\"cuiIconUpload\"\r\n            (click)=\"onSelectFile()\">\r\n            {{ uploadButtonName() }}\r\n          </button>\r\n          @if (thumbnail()?.name) {\r\n          <button class=\"content__remove-button\" cuiButton appearance=\"link\" size=\"sm\" type=\"button\"\r\n            (click)=\"onRemoveThumbnail()\">\r\n            {{ t('REMOVE') }}\r\n          </button>\r\n          }\r\n          <span class=\"content__accepted\">\r\n            {{ t('ACCEPTED') }}: JPG, JPEG, PNG, MP4 {{ t('UP_TO') }} 20MB\r\n          </span>\r\n        </div>\r\n      </div>\r\n    </section>\r\n    @if (editorId(); as editorId) {\r\n        <cui-editor-block\r\n            [title]=\"form.controls.title.value || title()\"\r\n            [config]=\"config()\"\r\n            [editorId]=\"editorId\"\r\n            [required]=\"true\"\r\n            (editorEmpty)=\"onEditorEmpty($event)\"\r\n        ></cui-editor-block>\r\n    }\r\n  </section>\r\n</ng-container>\r\n"]}