@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,133 @@
1
+ import { ChangeDetectionStrategy, Component, computed, DestroyRef, effect, inject, input, output, signal } from '@angular/core';
2
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
3
+ import { NonNullableFormBuilder, ReactiveFormsModule } from '@angular/forms';
4
+ import { TranslocoDirective } from '@jsverse/transloco';
5
+ import { CuiCheckboxModule, CuiFormFieldModule, CuiLabelModule, CuiRadioModule, CuiSelectModule, CuiTextareaModule, CuiToggleModule } from '../../../../components';
6
+ import { CuiTextFieldControllerModule } from '../../../../directives';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "../../../../components/checkbox/checkbox.component";
9
+ import * as i2 from "../../../../components/label/label.component";
10
+ import * as i3 from "../../../../components/radio/radio.component";
11
+ import * as i4 from "../../../../components/toggle/toggle.component";
12
+ import * as i5 from "@angular/forms";
13
+ export class CuiCheckListBlockListItemActionCardComponent {
14
+ get photoGroup() {
15
+ return this.actionForm.get('photo');
16
+ }
17
+ get commentGroup() {
18
+ return this.actionForm.get('comment');
19
+ }
20
+ constructor() {
21
+ this.destroyRef = inject(DestroyRef);
22
+ this.nonNullableFormBuilder = inject(NonNullableFormBuilder);
23
+ this.purposeType = input();
24
+ this.isConsiderationNeeded = input(false);
25
+ this.actionInfo = input.required();
26
+ this.consideredCorrectChanged = output();
27
+ this.checkListActionChanged = output();
28
+ this._actionInfo = signal(null);
29
+ this.attachmentPhotoAction = computed(() => this.actionInfo().actions.find((contentAction) => contentAction.contentActionType === 'ATTACHMENT_PHOTO'));
30
+ this.textAreaAction = computed(() => this.actionInfo().actions.find((contentAction) => contentAction.contentActionType === 'TEXT_AREA'));
31
+ this.isConsideredCorrectControl = this.nonNullableFormBuilder.control({
32
+ value: false,
33
+ disabled: false
34
+ });
35
+ effect(() => {
36
+ this._actionInfo.set(this.actionInfo());
37
+ if (!this.purposeType() || !this.isConsiderationNeeded()) {
38
+ return;
39
+ }
40
+ this.isConsideredCorrectControl.setValue(this.actionInfo().considerCorrect, { emitEvent: false });
41
+ }, { allowSignalWrites: true });
42
+ }
43
+ ngOnInit() {
44
+ this.initActionForm();
45
+ }
46
+ initActionForm() {
47
+ this.actionForm = this.nonNullableFormBuilder.group({
48
+ photo: this.nonNullableFormBuilder.group({
49
+ isEnable: this.attachmentPhotoAction().isEnable,
50
+ isRequired: {
51
+ value: this.attachmentPhotoAction().isRequired,
52
+ disabled: !this.attachmentPhotoAction().isEnable
53
+ }
54
+ }),
55
+ comment: this.nonNullableFormBuilder.group({
56
+ isEnable: this.textAreaAction().isEnable,
57
+ isRequired: {
58
+ value: this.textAreaAction().isRequired,
59
+ disabled: !this.textAreaAction().isEnable
60
+ }
61
+ })
62
+ });
63
+ this.initActionFormSegmentsSubscriptions();
64
+ if (!this.isConsiderationNeeded()) {
65
+ return;
66
+ }
67
+ this.isConsideredCorrectControl.setValue(this.actionInfo().considerCorrect, { emitEvent: false });
68
+ }
69
+ initActionFormSegmentsSubscriptions() {
70
+ this.isConsideredCorrectControlSubscription();
71
+ this.initPhotoGroupSubscription();
72
+ this.initCommentGroupSubscription();
73
+ }
74
+ isConsideredCorrectControlSubscription() {
75
+ this.isConsideredCorrectControl.valueChanges
76
+ .pipe(takeUntilDestroyed(this.destroyRef))
77
+ .subscribe(() => this.consideredCorrectChanged.emit(this._actionInfo().id));
78
+ }
79
+ initPhotoGroupSubscription() {
80
+ this.photoGroup.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((value) => {
81
+ if (!value.isEnable) {
82
+ this.photoGroup.get('isRequired')?.setValue(false, { emitEvent: false });
83
+ this.photoGroup.get('isRequired')?.disable({ emitEvent: false });
84
+ this.checkListActionChanged.emit({
85
+ id: this.attachmentPhotoAction().id,
86
+ ...this.photoGroup.getRawValue()
87
+ });
88
+ return;
89
+ }
90
+ this.photoGroup.get('isRequired')?.enable({ emitEvent: false });
91
+ this.checkListActionChanged.emit({
92
+ id: this.attachmentPhotoAction().id,
93
+ ...this.photoGroup.value
94
+ });
95
+ });
96
+ }
97
+ initCommentGroupSubscription() {
98
+ this.commentGroup.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((value) => {
99
+ if (!value.isEnable) {
100
+ this.commentGroup.get('isRequired')?.setValue(false, { emitEvent: false });
101
+ this.commentGroup.get('isRequired')?.disable({ emitEvent: false });
102
+ this.checkListActionChanged.emit({
103
+ id: this.textAreaAction().id,
104
+ ...this.commentGroup.getRawValue()
105
+ });
106
+ return;
107
+ }
108
+ this.commentGroup.get('isRequired')?.enable({ emitEvent: false });
109
+ this.checkListActionChanged.emit({
110
+ id: this.textAreaAction().id,
111
+ ...this.commentGroup.value
112
+ });
113
+ });
114
+ }
115
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiCheckListBlockListItemActionCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
116
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CuiCheckListBlockListItemActionCardComponent, isStandalone: true, selector: "cui-checklist-block-list-item-action-card", inputs: { purposeType: { classPropertyName: "purposeType", publicName: "purposeType", isSignal: true, isRequired: false, transformFunction: null }, isConsiderationNeeded: { classPropertyName: "isConsiderationNeeded", publicName: "isConsiderationNeeded", isSignal: true, isRequired: false, transformFunction: null }, actionInfo: { classPropertyName: "actionInfo", publicName: "actionInfo", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { consideredCorrectChanged: "consideredCorrectChanged", checkListActionChanged: "checkListActionChanged" }, ngImport: i0, template: "<ng-container *transloco=\"let t\">\r\n <div\r\n class=\"card\"\r\n [formGroup]=\"actionForm\"\r\n >\r\n <div class=\"title-container\">\r\n <span class=\"title\">{{ actionInfo().title }}</span>\r\n @if (isConsiderationNeeded()) {\r\n <label\r\n cuiLabel\r\n class=\"title__input\"\r\n >\r\n <input\r\n cuiRadio\r\n type=\"radio\"\r\n [checked]=\"actionInfo().considerCorrect\"\r\n [formControl]=\"isConsideredCorrectControl\"\r\n [value]=\"true\"\r\n />\r\n {{ t('CONSIDER_CORRECT') }}\r\n </label>\r\n }\r\n </div>\r\n <div class=\"blocks\">\r\n <div\r\n class=\"block-card\"\r\n [formGroup]=\"photoGroup\"\r\n >\r\n <label cuiLabel>\r\n <input\r\n cuiCheckbox\r\n type=\"checkbox\"\r\n formControlName=\"isEnable\"\r\n />\r\n {{ t('PHOTO') }}\r\n </label>\r\n <label cuiLabel>\r\n <input\r\n cuiToggle\r\n type=\"checkbox\"\r\n formControlName=\"isRequired\"\r\n />\r\n {{ t('REQUIRED') }}\r\n </label>\r\n </div>\r\n <div\r\n class=\"block-card\"\r\n [formGroup]=\"commentGroup\"\r\n >\r\n <label cuiLabel>\r\n <input\r\n cuiCheckbox\r\n type=\"checkbox\"\r\n formControlName=\"isEnable\"\r\n />\r\n {{ t('COMMENT') }}\r\n </label>\r\n <label cuiLabel>\r\n <input\r\n cuiToggle\r\n type=\"checkbox\"\r\n formControlName=\"isRequired\"\r\n />\r\n {{ t('REQUIRED') }}\r\n </label>\r\n </div>\r\n </div>\r\n </div>\r\n</ng-container>\r\n", styles: [":host{flex:1}.card{padding:11px;display:flex;flex-direction:column;gap:10px;border:1px solid var(--cui-base-200);border-radius:8px}.title-container{display:flex;flex-direction:row;gap:8px;justify-content:space-between;align-items:center}.title{font-weight:500;font-size:14px;line-height:20px}.title__input{font-weight:400;font-size:14px;line-height:20px}.blocks{display:flex;flex-direction:column;gap:8px}.block-card{padding:13px 11px;display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid var(--cui-base-200);border-radius:8px}.block-card_multiple-lines{flex-direction:column;align-items:unset}.block-card__checkboxes-container{padding:13px 8px;display:flex;gap:12px}\n"], dependencies: [{ kind: "ngmodule", type: CuiCheckboxModule }, { kind: "component", type: i1.CuiCheckboxComponent, selector: "input[type=\"checkbox\"][cuiCheckbox]" }, { kind: "ngmodule", type: CuiFormFieldModule }, { kind: "ngmodule", type: CuiLabelModule }, { kind: "component", type: i2.CuiLabelComponent, selector: "label[cuiLabel]", inputs: ["isRequired"] }, { kind: "ngmodule", type: CuiRadioModule }, { kind: "component", type: i3.CuiRadioComponent, selector: "input[type=\"radio\"][cuiRadio]" }, { kind: "ngmodule", type: CuiSelectModule }, { kind: "ngmodule", type: CuiTextareaModule }, { kind: "ngmodule", type: CuiTextFieldControllerModule }, { kind: "ngmodule", type: CuiToggleModule }, { kind: "component", type: i4.CuiToggleComponent, selector: "input[type=\"checkbox\"][cuiToggle]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i5.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: i5.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i5.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i5.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
117
+ }
118
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiCheckListBlockListItemActionCardComponent, decorators: [{
119
+ type: Component,
120
+ args: [{ selector: 'cui-checklist-block-list-item-action-card', imports: [
121
+ CuiCheckboxModule,
122
+ CuiFormFieldModule,
123
+ CuiLabelModule,
124
+ CuiRadioModule,
125
+ CuiSelectModule,
126
+ CuiTextareaModule,
127
+ CuiTextFieldControllerModule,
128
+ CuiToggleModule,
129
+ ReactiveFormsModule,
130
+ TranslocoDirective
131
+ ], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *transloco=\"let t\">\r\n <div\r\n class=\"card\"\r\n [formGroup]=\"actionForm\"\r\n >\r\n <div class=\"title-container\">\r\n <span class=\"title\">{{ actionInfo().title }}</span>\r\n @if (isConsiderationNeeded()) {\r\n <label\r\n cuiLabel\r\n class=\"title__input\"\r\n >\r\n <input\r\n cuiRadio\r\n type=\"radio\"\r\n [checked]=\"actionInfo().considerCorrect\"\r\n [formControl]=\"isConsideredCorrectControl\"\r\n [value]=\"true\"\r\n />\r\n {{ t('CONSIDER_CORRECT') }}\r\n </label>\r\n }\r\n </div>\r\n <div class=\"blocks\">\r\n <div\r\n class=\"block-card\"\r\n [formGroup]=\"photoGroup\"\r\n >\r\n <label cuiLabel>\r\n <input\r\n cuiCheckbox\r\n type=\"checkbox\"\r\n formControlName=\"isEnable\"\r\n />\r\n {{ t('PHOTO') }}\r\n </label>\r\n <label cuiLabel>\r\n <input\r\n cuiToggle\r\n type=\"checkbox\"\r\n formControlName=\"isRequired\"\r\n />\r\n {{ t('REQUIRED') }}\r\n </label>\r\n </div>\r\n <div\r\n class=\"block-card\"\r\n [formGroup]=\"commentGroup\"\r\n >\r\n <label cuiLabel>\r\n <input\r\n cuiCheckbox\r\n type=\"checkbox\"\r\n formControlName=\"isEnable\"\r\n />\r\n {{ t('COMMENT') }}\r\n </label>\r\n <label cuiLabel>\r\n <input\r\n cuiToggle\r\n type=\"checkbox\"\r\n formControlName=\"isRequired\"\r\n />\r\n {{ t('REQUIRED') }}\r\n </label>\r\n </div>\r\n </div>\r\n </div>\r\n</ng-container>\r\n", styles: [":host{flex:1}.card{padding:11px;display:flex;flex-direction:column;gap:10px;border:1px solid var(--cui-base-200);border-radius:8px}.title-container{display:flex;flex-direction:row;gap:8px;justify-content:space-between;align-items:center}.title{font-weight:500;font-size:14px;line-height:20px}.title__input{font-weight:400;font-size:14px;line-height:20px}.blocks{display:flex;flex-direction:column;gap:8px}.block-card{padding:13px 11px;display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid var(--cui-base-200);border-radius:8px}.block-card_multiple-lines{flex-direction:column;align-items:unset}.block-card__checkboxes-container{padding:13px 8px;display:flex;gap:12px}\n"] }]
132
+ }], ctorParameters: () => [] });
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checklist-block-list-item-action-card.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/widgets/checklist-block/components/checklist-block-list-item-action-card/checklist-block-list-item-action-card.component.ts","../../../../../../../projects/core/widgets/checklist-block/components/checklist-block-list-item-action-card/checklist-block-list-item-action-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import type { OnInit } from '@angular/core';\r\nimport {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    computed,\r\n    DestroyRef,\r\n    effect,\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 type { FormGroup } from '@angular/forms';\r\nimport { NonNullableFormBuilder, ReactiveFormsModule } from '@angular/forms';\r\nimport type { CuiNullable } from '@cuby-ui/cdk';\r\nimport { NodeCheckListActionItemContent, NodeCheckListItemContentAction } from '@cuby-ui/api';\r\nimport { TranslocoDirective } from '@jsverse/transloco';\r\n\r\nimport {\r\n    CuiCheckboxModule,\r\n    CuiFormFieldModule,\r\n    CuiLabelModule,\r\n    CuiRadioModule,\r\n    CuiSelectModule,\r\n    CuiTextareaModule,\r\n    CuiToggleModule\r\n} from '../../../../components';\r\nimport { CuiTextFieldControllerModule } from '../../../../directives';\r\n\r\n@Component({\r\n    selector: 'cui-checklist-block-list-item-action-card',\r\n    imports: [\r\n        CuiCheckboxModule,\r\n        CuiFormFieldModule,\r\n        CuiLabelModule,\r\n        CuiRadioModule,\r\n        CuiSelectModule,\r\n        CuiTextareaModule,\r\n        CuiTextFieldControllerModule,\r\n        CuiToggleModule,\r\n        ReactiveFormsModule,\r\n        TranslocoDirective\r\n    ],\r\n    standalone: true,\r\n    templateUrl: './checklist-block-list-item-action-card.component.html',\r\n    styleUrl: './checklist-block-list-item-action-card.component.scss',\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class CuiCheckListBlockListItemActionCardComponent implements OnInit {\r\n    private readonly destroyRef = inject(DestroyRef);\r\n    private readonly nonNullableFormBuilder = inject(NonNullableFormBuilder);\r\n\r\n    public actionForm!: FormGroup;\r\n\r\n    public readonly purposeType = input<string>();\r\n    public readonly isConsiderationNeeded = input<boolean>(false);\r\n    public readonly actionInfo = input.required<NodeCheckListActionItemContent>();\r\n\r\n    public readonly consideredCorrectChanged = output<string>();\r\n    public readonly checkListActionChanged = output<NodeCheckListItemContentAction>();\r\n\r\n    protected readonly _actionInfo = signal<CuiNullable<NodeCheckListActionItemContent>>(null);\r\n    protected readonly attachmentPhotoAction = computed<NodeCheckListItemContentAction>(\r\n        () => this.actionInfo().actions.find((contentAction) => contentAction.contentActionType === 'ATTACHMENT_PHOTO')!\r\n    );\r\n    protected readonly textAreaAction = computed<NodeCheckListItemContentAction>(\r\n        () => this.actionInfo().actions.find((contentAction) => contentAction.contentActionType === 'TEXT_AREA')!\r\n    );\r\n\r\n    protected readonly isConsideredCorrectControl = this.nonNullableFormBuilder.control({\r\n        value: false,\r\n        disabled: false\r\n    });\r\n\r\n    protected get photoGroup(): FormGroup {\r\n        return this.actionForm.get('photo') as FormGroup;\r\n    }\r\n\r\n    protected get commentGroup(): FormGroup {\r\n        return this.actionForm.get('comment') as FormGroup;\r\n    }\r\n\r\n    constructor() {\r\n        effect(() => {\r\n            this._actionInfo.set(this.actionInfo());\r\n\r\n            if (!this.purposeType() || !this.isConsiderationNeeded()) {\r\n                return;\r\n            }\r\n\r\n            this.isConsideredCorrectControl.setValue(this.actionInfo().considerCorrect, { emitEvent: false });\r\n        }, { allowSignalWrites: true });\r\n    }\r\n\r\n    public ngOnInit(): void {\r\n        this.initActionForm();\r\n    }\r\n\r\n    private initActionForm(): void {\r\n        this.actionForm = this.nonNullableFormBuilder.group({\r\n            photo: this.nonNullableFormBuilder.group({\r\n                isEnable: this.attachmentPhotoAction().isEnable,\r\n                isRequired: {\r\n                    value: this.attachmentPhotoAction().isRequired,\r\n                    disabled: !this.attachmentPhotoAction().isEnable\r\n                }\r\n            }),\r\n            comment: this.nonNullableFormBuilder.group({\r\n                isEnable: this.textAreaAction().isEnable,\r\n                isRequired: {\r\n                    value: this.textAreaAction().isRequired,\r\n                    disabled: !this.textAreaAction().isEnable\r\n                }\r\n            })\r\n        });\r\n\r\n        this.initActionFormSegmentsSubscriptions();\r\n\r\n        if (!this.isConsiderationNeeded()) {\r\n            return;\r\n        }\r\n\r\n        this.isConsideredCorrectControl.setValue(this.actionInfo().considerCorrect, { emitEvent: false });\r\n    }\r\n\r\n    private initActionFormSegmentsSubscriptions(): void {\r\n        this.isConsideredCorrectControlSubscription();\r\n        this.initPhotoGroupSubscription();\r\n        this.initCommentGroupSubscription();\r\n    }\r\n\r\n    private isConsideredCorrectControlSubscription(): void {\r\n        this.isConsideredCorrectControl.valueChanges\r\n            .pipe(takeUntilDestroyed(this.destroyRef))\r\n            .subscribe(() => this.consideredCorrectChanged.emit(this._actionInfo()!.id));\r\n    }\r\n\r\n    private initPhotoGroupSubscription(): void {\r\n        this.photoGroup.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((value) => {\r\n            if (!value.isEnable) {\r\n                this.photoGroup.get('isRequired')?.setValue(false, { emitEvent: false });\r\n                this.photoGroup.get('isRequired')?.disable({ emitEvent: false });\r\n                this.checkListActionChanged.emit({\r\n                    id: this.attachmentPhotoAction().id,\r\n                    ...this.photoGroup.getRawValue()\r\n                });\r\n\r\n                return;\r\n            }\r\n\r\n            this.photoGroup.get('isRequired')?.enable({ emitEvent: false });\r\n            this.checkListActionChanged.emit({\r\n                id: this.attachmentPhotoAction().id,\r\n                ...this.photoGroup.value\r\n            });\r\n        });\r\n    }\r\n\r\n    private initCommentGroupSubscription(): void {\r\n        this.commentGroup.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((value) => {\r\n            if (!value.isEnable) {\r\n                this.commentGroup.get('isRequired')?.setValue(false, { emitEvent: false });\r\n                this.commentGroup.get('isRequired')?.disable({ emitEvent: false });\r\n                this.checkListActionChanged.emit({\r\n                    id: this.textAreaAction().id,\r\n                    ...this.commentGroup.getRawValue()\r\n                });\r\n\r\n                return;\r\n            }\r\n\r\n            this.commentGroup.get('isRequired')?.enable({ emitEvent: false });\r\n            this.checkListActionChanged.emit({\r\n                id: this.textAreaAction().id,\r\n                ...this.commentGroup.value\r\n            });\r\n        });\r\n    }\r\n}\r\n","<ng-container *transloco=\"let t\">\r\n    <div\r\n        class=\"card\"\r\n        [formGroup]=\"actionForm\"\r\n    >\r\n        <div class=\"title-container\">\r\n            <span class=\"title\">{{ actionInfo().title }}</span>\r\n            @if (isConsiderationNeeded()) {\r\n                <label\r\n                    cuiLabel\r\n                    class=\"title__input\"\r\n                >\r\n                    <input\r\n                        cuiRadio\r\n                        type=\"radio\"\r\n                        [checked]=\"actionInfo().considerCorrect\"\r\n                        [formControl]=\"isConsideredCorrectControl\"\r\n                        [value]=\"true\"\r\n                    />\r\n                    {{ t('CONSIDER_CORRECT') }}\r\n                </label>\r\n            }\r\n        </div>\r\n        <div class=\"blocks\">\r\n            <div\r\n                class=\"block-card\"\r\n                [formGroup]=\"photoGroup\"\r\n            >\r\n                <label cuiLabel>\r\n                    <input\r\n                        cuiCheckbox\r\n                        type=\"checkbox\"\r\n                        formControlName=\"isEnable\"\r\n                    />\r\n                    {{ t('PHOTO') }}\r\n                </label>\r\n                <label cuiLabel>\r\n                    <input\r\n                        cuiToggle\r\n                        type=\"checkbox\"\r\n                        formControlName=\"isRequired\"\r\n                    />\r\n                    {{ t('REQUIRED') }}\r\n                </label>\r\n            </div>\r\n            <div\r\n                class=\"block-card\"\r\n                [formGroup]=\"commentGroup\"\r\n            >\r\n                <label cuiLabel>\r\n                    <input\r\n                        cuiCheckbox\r\n                        type=\"checkbox\"\r\n                        formControlName=\"isEnable\"\r\n                    />\r\n                    {{ t('COMMENT') }}\r\n                </label>\r\n                <label cuiLabel>\r\n                    <input\r\n                        cuiToggle\r\n                        type=\"checkbox\"\r\n                        formControlName=\"isRequired\"\r\n                    />\r\n                    {{ t('REQUIRED') }}\r\n                </label>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</ng-container>\r\n"]}
@@ -0,0 +1,2 @@
1
+ export { CuiCheckListBlockListItemActionCardComponent } from './checklist-block-list-item-action-card.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvY2hlY2tsaXN0LWJsb2NrL2NvbXBvbmVudHMvY2hlY2tsaXN0LWJsb2NrLWxpc3QtaXRlbS1hY3Rpb24tY2FyZC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsNENBQTRDLEVBQUUsTUFBTSxtREFBbUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IEN1aUNoZWNrTGlzdEJsb2NrTGlzdEl0ZW1BY3Rpb25DYXJkQ29tcG9uZW50IH0gZnJvbSAnLi9jaGVja2xpc3QtYmxvY2stbGlzdC1pdGVtLWFjdGlvbi1jYXJkLmNvbXBvbmVudCc7XHJcbiJdfQ==
@@ -0,0 +1,45 @@
1
+ import { UpperCasePipe } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, inject, input } from '@angular/core';
3
+ import { CuiLetDirective } from '@cuby-ui/cdk';
4
+ import { TranslocoDirective } from '@jsverse/transloco';
5
+ import { CuiNodeChecklistApiService } from '@cuby-ui/api';
6
+ import { CuiCheckListBlockListItemActionCardComponent } from '../checklist-block-list-item-action-card';
7
+ import { CuiCheckListBlockService } from '../../services';
8
+ import * as i0 from "@angular/core";
9
+ export class CuiCheckListBlockListItemActionWithVerificationComponent {
10
+ constructor() {
11
+ this.nodeCheckListApiService = inject(CuiNodeChecklistApiService);
12
+ this.checkListBlockService = inject(CuiCheckListBlockService);
13
+ this.checkListItem = input.required();
14
+ }
15
+ onConsiderCorrectChanged(actionId, purposeType) {
16
+ const requestData = {
17
+ nodeCheckListId: this.checkListItem().id,
18
+ assigneePurposeType: purposeType,
19
+ actionId
20
+ };
21
+ this.nodeCheckListApiService
22
+ .updateNodeCheckListItemIsConsideredCorrect(requestData)
23
+ .subscribe((checkListItem) => this.checkListBlockService.updateCheckListItem(checkListItem));
24
+ }
25
+ onCheckListActionChanged(actionContent, actionId, purposeType) {
26
+ const requestData = {
27
+ nodeCheckListId: this.checkListItem().id,
28
+ assigneePurposeType: purposeType,
29
+ actionId,
30
+ contentId: actionContent.id,
31
+ isEnable: actionContent.isEnable,
32
+ isRequired: actionContent.isRequired
33
+ };
34
+ this.nodeCheckListApiService
35
+ .updateNodeCheckListItemActionContent(requestData)
36
+ .subscribe((checkListItem) => this.checkListBlockService.updateCheckListItem(checkListItem));
37
+ }
38
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiCheckListBlockListItemActionWithVerificationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
39
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: CuiCheckListBlockListItemActionWithVerificationComponent, isStandalone: true, selector: "cui-checklist-block-list-item-action-with-verification", inputs: { checkListItem: { classPropertyName: "checkListItem", publicName: "checkListItem", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "<ng-container *transloco=\"let t\">\r\n <ng-container *cuiLet=\"checkListItem().content as checkListItemContent\">\r\n <div class=\"action\">\r\n <div class=\"action__header action__assignee-header\">\r\n {{ t('CONDITIONAL_LOGIC_FOR_ASSIGNEE') | uppercase }}\r\n </div>\r\n <div class=\"action__content\">\r\n <div class=\"cards-container\">\r\n <cui-checklist-block-list-item-action-card\r\n [purposeType]=\"'ASSIGN'\"\r\n [actionInfo]=\"checkListItemContent.actionsAssignee![0]\"\r\n [isConsiderationNeeded]=\"true\"\r\n (consideredCorrectChanged)=\"onConsiderCorrectChanged($event, 'ASSIGN')\"\r\n (checkListActionChanged)=\"\r\n onCheckListActionChanged($event, checkListItemContent.actionsAssignee![0].id, 'ASSIGN')\r\n \"\r\n />\r\n <cui-checklist-block-list-item-action-card\r\n [purposeType]=\"'ASSIGN'\"\r\n [actionInfo]=\"checkListItemContent.actionsAssignee![1]\"\r\n [isConsiderationNeeded]=\"true\"\r\n (consideredCorrectChanged)=\"onConsiderCorrectChanged($event, 'ASSIGN')\"\r\n (checkListActionChanged)=\"\r\n onCheckListActionChanged($event, checkListItemContent.actionsAssignee![1].id, 'ASSIGN')\r\n \"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"action\">\r\n <div class=\"action__header action__approver-header\">\r\n {{ t('CONDITIONAL_LOGIC_FOR_APPROVER') | uppercase }}\r\n </div>\r\n <div class=\"action__content\">\r\n <div class=\"cards-container\">\r\n <cui-checklist-block-list-item-action-card\r\n [purposeType]=\"'APPROVE'\"\r\n [actionInfo]=\"checkListItemContent.actionsApprove![0]\"\r\n (consideredCorrectChanged)=\"onConsiderCorrectChanged($event, 'APPROVE')\"\r\n (checkListActionChanged)=\"\r\n onCheckListActionChanged($event, checkListItemContent.actionsApprove![0].id, 'APPROVE')\r\n \"\r\n />\r\n <cui-checklist-block-list-item-action-card\r\n [purposeType]=\"'APPROVE'\"\r\n [actionInfo]=\"checkListItemContent.actionsApprove![1]\"\r\n (consideredCorrectChanged)=\"onConsiderCorrectChanged($event, 'APPROVE')\"\r\n (checkListActionChanged)=\"\r\n onCheckListActionChanged($event, checkListItemContent.actionsApprove![1].id, 'APPROVE')\r\n \"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</ng-container>\r\n", styles: [":host{padding-right:15px;padding-left:15px;padding-bottom:15px;display:flex;flex-direction:column;gap:16px;border-radius:inherit}.action{display:flex;flex-direction:column;border:1px solid var(--cui-base-200);border-radius:8px}.action__content{padding:15px;display:flex;flex-direction:column;border-radius:8px;background:var(--cui-base-0);gap:16px}.action__header{font-weight:400;font-size:12px;line-height:14px;padding:15px 19px 15.5px;display:flex;align-items:center;justify-content:space-between;gap:8px;color:var(--cui-base-900);border-bottom:.5px solid var(--cui-base-200);border-radius:8px 8px 0 0}.action__assignee-header{background:var(--cui-badge-warning-bg)}.action__approver-header{background:var(--cui-badge-violet-bg)}.action__estimated-time{display:flex;flex-direction:column;gap:4px}.action__input{padding:11px 13px;border-radius:8px;border:1px solid var(--cui-base-200);background:var(--cui-gray-10);outline:none}.action__input:focus-within{box-shadow:0 0 0 2px var(--cui-blue-100);border-color:var(--cui-blue-600)}.cards-container{display:flex;flex-direction:row;justify-items:center;gap:16px}\n"], dependencies: [{ kind: "component", type: CuiCheckListBlockListItemActionCardComponent, selector: "cui-checklist-block-list-item-action-card", inputs: ["purposeType", "isConsiderationNeeded", "actionInfo"], outputs: ["consideredCorrectChanged", "checkListActionChanged"] }, { kind: "directive", type: CuiLetDirective, selector: "[cuiLet]", inputs: ["cuiLet"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "pipe", type: UpperCasePipe, name: "uppercase" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
40
+ }
41
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiCheckListBlockListItemActionWithVerificationComponent, decorators: [{
42
+ type: Component,
43
+ args: [{ selector: 'cui-checklist-block-list-item-action-with-verification', imports: [CuiCheckListBlockListItemActionCardComponent, CuiLetDirective, TranslocoDirective, UpperCasePipe], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *transloco=\"let t\">\r\n <ng-container *cuiLet=\"checkListItem().content as checkListItemContent\">\r\n <div class=\"action\">\r\n <div class=\"action__header action__assignee-header\">\r\n {{ t('CONDITIONAL_LOGIC_FOR_ASSIGNEE') | uppercase }}\r\n </div>\r\n <div class=\"action__content\">\r\n <div class=\"cards-container\">\r\n <cui-checklist-block-list-item-action-card\r\n [purposeType]=\"'ASSIGN'\"\r\n [actionInfo]=\"checkListItemContent.actionsAssignee![0]\"\r\n [isConsiderationNeeded]=\"true\"\r\n (consideredCorrectChanged)=\"onConsiderCorrectChanged($event, 'ASSIGN')\"\r\n (checkListActionChanged)=\"\r\n onCheckListActionChanged($event, checkListItemContent.actionsAssignee![0].id, 'ASSIGN')\r\n \"\r\n />\r\n <cui-checklist-block-list-item-action-card\r\n [purposeType]=\"'ASSIGN'\"\r\n [actionInfo]=\"checkListItemContent.actionsAssignee![1]\"\r\n [isConsiderationNeeded]=\"true\"\r\n (consideredCorrectChanged)=\"onConsiderCorrectChanged($event, 'ASSIGN')\"\r\n (checkListActionChanged)=\"\r\n onCheckListActionChanged($event, checkListItemContent.actionsAssignee![1].id, 'ASSIGN')\r\n \"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"action\">\r\n <div class=\"action__header action__approver-header\">\r\n {{ t('CONDITIONAL_LOGIC_FOR_APPROVER') | uppercase }}\r\n </div>\r\n <div class=\"action__content\">\r\n <div class=\"cards-container\">\r\n <cui-checklist-block-list-item-action-card\r\n [purposeType]=\"'APPROVE'\"\r\n [actionInfo]=\"checkListItemContent.actionsApprove![0]\"\r\n (consideredCorrectChanged)=\"onConsiderCorrectChanged($event, 'APPROVE')\"\r\n (checkListActionChanged)=\"\r\n onCheckListActionChanged($event, checkListItemContent.actionsApprove![0].id, 'APPROVE')\r\n \"\r\n />\r\n <cui-checklist-block-list-item-action-card\r\n [purposeType]=\"'APPROVE'\"\r\n [actionInfo]=\"checkListItemContent.actionsApprove![1]\"\r\n (consideredCorrectChanged)=\"onConsiderCorrectChanged($event, 'APPROVE')\"\r\n (checkListActionChanged)=\"\r\n onCheckListActionChanged($event, checkListItemContent.actionsApprove![1].id, 'APPROVE')\r\n \"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</ng-container>\r\n", styles: [":host{padding-right:15px;padding-left:15px;padding-bottom:15px;display:flex;flex-direction:column;gap:16px;border-radius:inherit}.action{display:flex;flex-direction:column;border:1px solid var(--cui-base-200);border-radius:8px}.action__content{padding:15px;display:flex;flex-direction:column;border-radius:8px;background:var(--cui-base-0);gap:16px}.action__header{font-weight:400;font-size:12px;line-height:14px;padding:15px 19px 15.5px;display:flex;align-items:center;justify-content:space-between;gap:8px;color:var(--cui-base-900);border-bottom:.5px solid var(--cui-base-200);border-radius:8px 8px 0 0}.action__assignee-header{background:var(--cui-badge-warning-bg)}.action__approver-header{background:var(--cui-badge-violet-bg)}.action__estimated-time{display:flex;flex-direction:column;gap:4px}.action__input{padding:11px 13px;border-radius:8px;border:1px solid var(--cui-base-200);background:var(--cui-gray-10);outline:none}.action__input:focus-within{box-shadow:0 0 0 2px var(--cui-blue-100);border-color:var(--cui-blue-600)}.cards-container{display:flex;flex-direction:row;justify-items:center;gap:16px}\n"] }]
44
+ }] });
45
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checklist-block-list-item-action-with-verification.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/widgets/checklist-block/components/checklist-block-list-item-action-with-verification/checklist-block-list-item-action-with-verification.component.ts","../../../../../../../projects/core/widgets/checklist-block/components/checklist-block-list-item-action-with-verification/checklist-block-list-item-action-with-verification.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAClF,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,0BAA0B,EAAqF,MAAM,cAAc,CAAC;AAE7I,OAAO,EAAE,4CAA4C,EAAE,MAAM,0CAA0C,CAAC;AACxG,OAAO,EAAE,wBAAwB,EAAE,MAAM,gBAAgB,CAAC;;AAU1D,MAAM,OAAO,wDAAwD;IARrE;QASqB,4BAAuB,GAAG,MAAM,CAAC,0BAA0B,CAAC,CAAC;QACtE,0BAAqB,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAC;QAEjD,kBAAa,GAAG,KAAK,CAAC,QAAQ,EAAqD,CAAC;KAgCvG;IA9Ba,wBAAwB,CAAC,QAAgB,EAAE,WAAmB;QACpE,MAAM,WAAW,GAAG;YAChB,eAAe,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,EAAE;YACxC,mBAAmB,EAAE,WAAW;YAChC,QAAQ;SACX,CAAC;QAEF,IAAI,CAAC,uBAAuB;aACvB,0CAA0C,CAAC,WAAW,CAAC;aACvD,SAAS,CAAC,CAAC,aAAa,EAAE,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,mBAAmB,CAAC,aAAa,CAAC,CAAC,CAAC;IACrG,CAAC;IAES,wBAAwB,CAC9B,aAA6C,EAC7C,QAAgB,EAChB,WAAmB;QAEnB,MAAM,WAAW,GAAG;YAChB,eAAe,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,EAAE;YACxC,mBAAmB,EAAE,WAAW;YAChC,QAAQ;YACR,SAAS,EAAE,aAAa,CAAC,EAAE;YAC3B,QAAQ,EAAE,aAAa,CAAC,QAAQ;YAChC,UAAU,EAAE,aAAa,CAAC,UAAU;SACvC,CAAC;QAEF,IAAI,CAAC,uBAAuB;aACvB,oCAAoC,CAAC,WAAW,CAAC;aACjD,SAAS,CAAC,CAAC,aAAa,EAAE,EAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,mBAAmB,CAAC,aAAa,CAAC,CAAC,CAAC;IACrG,CAAC;+GAnCQ,wDAAwD;mGAAxD,wDAAwD,6QCjBrE,qlGAwDA,kpCD7Cc,4CAA4C,uNAAE,eAAe,yEAAE,kBAAkB,2LAAE,aAAa;;4FAMjG,wDAAwD;kBARpE,SAAS;+BACI,wDAAwD,WACzD,CAAC,4CAA4C,EAAE,eAAe,EAAE,kBAAkB,EAAE,aAAa,CAAC,cAC/F,IAAI,mBAGC,uBAAuB,CAAC,MAAM","sourcesContent":["import { UpperCasePipe } from '@angular/common';\r\nimport { ChangeDetectionStrategy, Component, inject, input } from '@angular/core';\r\nimport { CuiLetDirective } from '@cuby-ui/cdk';\r\nimport { TranslocoDirective } from '@jsverse/transloco';\r\nimport { CuiNodeChecklistApiService, NodeCheckListActionItemContent, NodeCheckListItem, NodeCheckListItemContentAction } from '@cuby-ui/api';\r\n\r\nimport { CuiCheckListBlockListItemActionCardComponent } from '../checklist-block-list-item-action-card';\r\nimport { CuiCheckListBlockService } from '../../services';\r\n\r\n@Component({\r\n    selector: 'cui-checklist-block-list-item-action-with-verification',\r\n    imports: [CuiCheckListBlockListItemActionCardComponent, CuiLetDirective, TranslocoDirective, UpperCasePipe],\r\n    standalone: true,\r\n    templateUrl: './checklist-block-list-item-action-with-verification.component.html',\r\n    styleUrl: './checklist-block-list-item-action-with-verification.component.scss',\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class CuiCheckListBlockListItemActionWithVerificationComponent {\r\n    private readonly nodeCheckListApiService = inject(CuiNodeChecklistApiService);\r\n    private checkListBlockService = inject(CuiCheckListBlockService);\r\n\r\n    public readonly checkListItem = input.required<NodeCheckListItem<NodeCheckListActionItemContent>>();\r\n\r\n    protected onConsiderCorrectChanged(actionId: string, purposeType: string): void {\r\n        const requestData = {\r\n            nodeCheckListId: this.checkListItem().id,\r\n            assigneePurposeType: purposeType,\r\n            actionId\r\n        };\r\n\r\n        this.nodeCheckListApiService\r\n            .updateNodeCheckListItemIsConsideredCorrect(requestData)\r\n            .subscribe((checkListItem) => this.checkListBlockService.updateCheckListItem(checkListItem));\r\n    }\r\n\r\n    protected onCheckListActionChanged(\r\n        actionContent: NodeCheckListItemContentAction,\r\n        actionId: string,\r\n        purposeType: string\r\n    ): void {\r\n        const requestData = {\r\n            nodeCheckListId: this.checkListItem().id,\r\n            assigneePurposeType: purposeType,\r\n            actionId,\r\n            contentId: actionContent.id,\r\n            isEnable: actionContent.isEnable,\r\n            isRequired: actionContent.isRequired\r\n        };\r\n\r\n        this.nodeCheckListApiService\r\n            .updateNodeCheckListItemActionContent(requestData)\r\n            .subscribe((checkListItem) => this.checkListBlockService.updateCheckListItem(checkListItem));\r\n    }\r\n}\r\n","<ng-container *transloco=\"let t\">\r\n    <ng-container *cuiLet=\"checkListItem().content as checkListItemContent\">\r\n        <div class=\"action\">\r\n            <div class=\"action__header action__assignee-header\">\r\n                {{ t('CONDITIONAL_LOGIC_FOR_ASSIGNEE') | uppercase }}\r\n            </div>\r\n            <div class=\"action__content\">\r\n                <div class=\"cards-container\">\r\n                    <cui-checklist-block-list-item-action-card\r\n                        [purposeType]=\"'ASSIGN'\"\r\n                        [actionInfo]=\"checkListItemContent.actionsAssignee![0]\"\r\n                        [isConsiderationNeeded]=\"true\"\r\n                        (consideredCorrectChanged)=\"onConsiderCorrectChanged($event, 'ASSIGN')\"\r\n                        (checkListActionChanged)=\"\r\n                            onCheckListActionChanged($event, checkListItemContent.actionsAssignee![0].id, 'ASSIGN')\r\n                        \"\r\n                    />\r\n                    <cui-checklist-block-list-item-action-card\r\n                        [purposeType]=\"'ASSIGN'\"\r\n                        [actionInfo]=\"checkListItemContent.actionsAssignee![1]\"\r\n                        [isConsiderationNeeded]=\"true\"\r\n                        (consideredCorrectChanged)=\"onConsiderCorrectChanged($event, 'ASSIGN')\"\r\n                        (checkListActionChanged)=\"\r\n                            onCheckListActionChanged($event, checkListItemContent.actionsAssignee![1].id, 'ASSIGN')\r\n                        \"\r\n                    />\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div class=\"action\">\r\n            <div class=\"action__header action__approver-header\">\r\n                {{ t('CONDITIONAL_LOGIC_FOR_APPROVER') | uppercase }}\r\n            </div>\r\n            <div class=\"action__content\">\r\n                <div class=\"cards-container\">\r\n                    <cui-checklist-block-list-item-action-card\r\n                        [purposeType]=\"'APPROVE'\"\r\n                        [actionInfo]=\"checkListItemContent.actionsApprove![0]\"\r\n                        (consideredCorrectChanged)=\"onConsiderCorrectChanged($event, 'APPROVE')\"\r\n                        (checkListActionChanged)=\"\r\n                            onCheckListActionChanged($event, checkListItemContent.actionsApprove![0].id, 'APPROVE')\r\n                        \"\r\n                    />\r\n                    <cui-checklist-block-list-item-action-card\r\n                        [purposeType]=\"'APPROVE'\"\r\n                        [actionInfo]=\"checkListItemContent.actionsApprove![1]\"\r\n                        (consideredCorrectChanged)=\"onConsiderCorrectChanged($event, 'APPROVE')\"\r\n                        (checkListActionChanged)=\"\r\n                            onCheckListActionChanged($event, checkListItemContent.actionsApprove![1].id, 'APPROVE')\r\n                        \"\r\n                    />\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </ng-container>\r\n</ng-container>\r\n"]}
@@ -0,0 +1,2 @@
1
+ export { CuiCheckListBlockListItemActionWithVerificationComponent } from './checklist-block-list-item-action-with-verification.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvY2hlY2tsaXN0LWJsb2NrL2NvbXBvbmVudHMvY2hlY2tsaXN0LWJsb2NrLWxpc3QtaXRlbS1hY3Rpb24td2l0aC12ZXJpZmljYXRpb24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHdEQUF3RCxFQUFFLE1BQU0sZ0VBQWdFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBDdWlDaGVja0xpc3RCbG9ja0xpc3RJdGVtQWN0aW9uV2l0aFZlcmlmaWNhdGlvbkNvbXBvbmVudCB9IGZyb20gJy4vY2hlY2tsaXN0LWJsb2NrLWxpc3QtaXRlbS1hY3Rpb24td2l0aC12ZXJpZmljYXRpb24uY29tcG9uZW50JztcclxuIl19
@@ -0,0 +1,35 @@
1
+ import { UpperCasePipe } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, inject, input } from '@angular/core';
3
+ import { CuiLetDirective } from '@cuby-ui/cdk';
4
+ import { TranslocoDirective } from '@jsverse/transloco';
5
+ import { CuiNodeChecklistApiService } from '@cuby-ui/api';
6
+ import { CuiCheckListBlockListItemActionCardComponent } from '../checklist-block-list-item-action-card';
7
+ import { CuiCheckListBlockService } from '../../services';
8
+ import * as i0 from "@angular/core";
9
+ export class CuiCheckListBlockListItemActionWithoutVerificationComponent {
10
+ constructor() {
11
+ this.nodeCheckListApiService = inject(CuiNodeChecklistApiService);
12
+ this.checkListBlockService = inject(CuiCheckListBlockService);
13
+ this.checkListItem = input.required();
14
+ }
15
+ onCheckListActionChanged(actionContent, actionId) {
16
+ const requestData = {
17
+ nodeCheckListId: this.checkListItem().id,
18
+ assigneePurposeType: 'ASSIGN',
19
+ actionId,
20
+ contentId: actionContent.id,
21
+ isEnable: actionContent.isEnable,
22
+ isRequired: actionContent.isRequired
23
+ };
24
+ this.nodeCheckListApiService
25
+ .updateNodeCheckListItemActionContent(requestData)
26
+ .subscribe((checkListItem) => this.checkListBlockService.updateCheckListItem(checkListItem));
27
+ }
28
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiCheckListBlockListItemActionWithoutVerificationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
29
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: CuiCheckListBlockListItemActionWithoutVerificationComponent, isStandalone: true, selector: "cui-checklist-block-list-item-action-without-verification", inputs: { checkListItem: { classPropertyName: "checkListItem", publicName: "checkListItem", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "<ng-container *transloco=\"let t\">\r\n <ng-container *cuiLet=\"checkListItem().content as checkListItemContent\">\r\n <div class=\"action\">\r\n <div class=\"action__header\">\r\n {{ t('CONDITIONAL_LOGIC') | uppercase }}\r\n </div>\r\n <div class=\"action__content\">\r\n <div class=\"cards-container\">\r\n <cui-checklist-block-list-item-action-card\r\n [actionInfo]=\"checkListItemContent.actionsAssignee![0]\"\r\n (checkListActionChanged)=\"\r\n onCheckListActionChanged($event, checkListItemContent.actionsAssignee![0].id)\r\n \"\r\n />\r\n <cui-checklist-block-list-item-action-card\r\n [actionInfo]=\"checkListItemContent.actionsAssignee![1]\"\r\n (checkListActionChanged)=\"\r\n onCheckListActionChanged($event, checkListItemContent.actionsAssignee![1].id)\r\n \"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</ng-container>\r\n", styles: [":host{padding-right:15px;padding-left:15px;padding-bottom:15px;border-radius:inherit}.action{display:flex;flex-direction:column;border:1px solid var(--cui-base-200);border-radius:8px}.action__content{padding:15px;display:flex;flex-direction:column;border-radius:8px;background:var(--cui-base-0);gap:16px}.action__header{font-weight:400;font-size:12px;line-height:14px;padding:15px 19px 15.5px;display:flex;align-items:center;justify-content:space-between;gap:8px;color:var(--cui-base-900);border-bottom:.5px solid var(--cui-base-200);border-radius:8px 8px 0 0}.cards-container{display:flex;flex-direction:row;justify-items:center;gap:16px}\n"], dependencies: [{ kind: "component", type: CuiCheckListBlockListItemActionCardComponent, selector: "cui-checklist-block-list-item-action-card", inputs: ["purposeType", "isConsiderationNeeded", "actionInfo"], outputs: ["consideredCorrectChanged", "checkListActionChanged"] }, { kind: "directive", type: CuiLetDirective, selector: "[cuiLet]", inputs: ["cuiLet"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "pipe", type: UpperCasePipe, name: "uppercase" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
30
+ }
31
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiCheckListBlockListItemActionWithoutVerificationComponent, decorators: [{
32
+ type: Component,
33
+ args: [{ selector: 'cui-checklist-block-list-item-action-without-verification', imports: [CuiCheckListBlockListItemActionCardComponent, CuiLetDirective, TranslocoDirective, UpperCasePipe], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *transloco=\"let t\">\r\n <ng-container *cuiLet=\"checkListItem().content as checkListItemContent\">\r\n <div class=\"action\">\r\n <div class=\"action__header\">\r\n {{ t('CONDITIONAL_LOGIC') | uppercase }}\r\n </div>\r\n <div class=\"action__content\">\r\n <div class=\"cards-container\">\r\n <cui-checklist-block-list-item-action-card\r\n [actionInfo]=\"checkListItemContent.actionsAssignee![0]\"\r\n (checkListActionChanged)=\"\r\n onCheckListActionChanged($event, checkListItemContent.actionsAssignee![0].id)\r\n \"\r\n />\r\n <cui-checklist-block-list-item-action-card\r\n [actionInfo]=\"checkListItemContent.actionsAssignee![1]\"\r\n (checkListActionChanged)=\"\r\n onCheckListActionChanged($event, checkListItemContent.actionsAssignee![1].id)\r\n \"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</ng-container>\r\n", styles: [":host{padding-right:15px;padding-left:15px;padding-bottom:15px;border-radius:inherit}.action{display:flex;flex-direction:column;border:1px solid var(--cui-base-200);border-radius:8px}.action__content{padding:15px;display:flex;flex-direction:column;border-radius:8px;background:var(--cui-base-0);gap:16px}.action__header{font-weight:400;font-size:12px;line-height:14px;padding:15px 19px 15.5px;display:flex;align-items:center;justify-content:space-between;gap:8px;color:var(--cui-base-900);border-bottom:.5px solid var(--cui-base-200);border-radius:8px 8px 0 0}.cards-container{display:flex;flex-direction:row;justify-items:center;gap:16px}\n"] }]
34
+ }] });
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tsaXN0LWJsb2NrLWxpc3QtaXRlbS1hY3Rpb24td2l0aG91dC12ZXJpZmljYXRpb24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS93aWRnZXRzL2NoZWNrbGlzdC1ibG9jay9jb21wb25lbnRzL2NoZWNrbGlzdC1ibG9jay1saXN0LWl0ZW0tYWN0aW9uLXdpdGhvdXQtdmVyaWZpY2F0aW9uL2NoZWNrbGlzdC1ibG9jay1saXN0LWl0ZW0tYWN0aW9uLXdpdGhvdXQtdmVyaWZpY2F0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvd2lkZ2V0cy9jaGVja2xpc3QtYmxvY2svY29tcG9uZW50cy9jaGVja2xpc3QtYmxvY2stbGlzdC1pdGVtLWFjdGlvbi13aXRob3V0LXZlcmlmaWNhdGlvbi9jaGVja2xpc3QtYmxvY2stbGlzdC1pdGVtLWFjdGlvbi13aXRob3V0LXZlcmlmaWNhdGlvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDaEQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDL0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDeEQsT0FBTyxFQUFFLDBCQUEwQixFQUFxRixNQUFNLGNBQWMsQ0FBQztBQUU3SSxPQUFPLEVBQUUsNENBQTRDLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUN4RyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFVMUQsTUFBTSxPQUFPLDJEQUEyRDtJQVJ4RTtRQVNxQiw0QkFBdUIsR0FBRyxNQUFNLENBQUMsMEJBQTBCLENBQUMsQ0FBQztRQUN0RSwwQkFBcUIsR0FBRyxNQUFNLENBQUMsd0JBQXdCLENBQUMsQ0FBQztRQUVqRCxrQkFBYSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQXFELENBQUM7S0FnQnZHO0lBZGEsd0JBQXdCLENBQUMsYUFBNkMsRUFBRSxRQUFnQjtRQUM5RixNQUFNLFdBQVcsR0FBRztZQUNoQixlQUFlLEVBQUUsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDLEVBQUU7WUFDeEMsbUJBQW1CLEVBQUUsUUFBUTtZQUM3QixRQUFRO1lBQ1IsU0FBUyxFQUFFLGFBQWEsQ0FBQyxFQUFFO1lBQzNCLFFBQVEsRUFBRSxhQUFhLENBQUMsUUFBUTtZQUNoQyxVQUFVLEVBQUUsYUFBYSxDQUFDLFVBQVU7U0FDdkMsQ0FBQztRQUVGLElBQUksQ0FBQyx1QkFBdUI7YUFDdkIsb0NBQW9DLENBQUMsV0FBVyxDQUFDO2FBQ2pELFNBQVMsQ0FBQyxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLG1CQUFtQixDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUM7SUFDckcsQ0FBQzsrR0FuQlEsMkRBQTJEO21HQUEzRCwyREFBMkQsZ1JDakJ4RSxpdENBeUJBLDJyQkRkYyw0Q0FBNEMsdU5BQUUsZUFBZSx5RUFBRSxrQkFBa0IsMkxBQUUsYUFBYTs7NEZBTWpHLDJEQUEyRDtrQkFSdkUsU0FBUzsrQkFDSSwyREFBMkQsV0FDNUQsQ0FBQyw0Q0FBNEMsRUFBRSxlQUFlLEVBQUUsa0JBQWtCLEVBQUUsYUFBYSxDQUFDLGNBQy9GLElBQUksbUJBR0MsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVwcGVyQ2FzZVBpcGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbmplY3QsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEN1aUxldERpcmVjdGl2ZSB9IGZyb20gJ0BjdWJ5LXVpL2Nkayc7XHJcbmltcG9ydCB7IFRyYW5zbG9jb0RpcmVjdGl2ZSB9IGZyb20gJ0Bqc3ZlcnNlL3RyYW5zbG9jbyc7XHJcbmltcG9ydCB7IEN1aU5vZGVDaGVja2xpc3RBcGlTZXJ2aWNlLCBOb2RlQ2hlY2tMaXN0QWN0aW9uSXRlbUNvbnRlbnQsIE5vZGVDaGVja0xpc3RJdGVtLCBOb2RlQ2hlY2tMaXN0SXRlbUNvbnRlbnRBY3Rpb24gfSBmcm9tICdAY3VieS11aS9hcGknO1xyXG5cclxuaW1wb3J0IHsgQ3VpQ2hlY2tMaXN0QmxvY2tMaXN0SXRlbUFjdGlvbkNhcmRDb21wb25lbnQgfSBmcm9tICcuLi9jaGVja2xpc3QtYmxvY2stbGlzdC1pdGVtLWFjdGlvbi1jYXJkJztcclxuaW1wb3J0IHsgQ3VpQ2hlY2tMaXN0QmxvY2tTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2N1aS1jaGVja2xpc3QtYmxvY2stbGlzdC1pdGVtLWFjdGlvbi13aXRob3V0LXZlcmlmaWNhdGlvbicsXHJcbiAgICBpbXBvcnRzOiBbQ3VpQ2hlY2tMaXN0QmxvY2tMaXN0SXRlbUFjdGlvbkNhcmRDb21wb25lbnQsIEN1aUxldERpcmVjdGl2ZSwgVHJhbnNsb2NvRGlyZWN0aXZlLCBVcHBlckNhc2VQaXBlXSxcclxuICAgIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vY2hlY2tsaXN0LWJsb2NrLWxpc3QtaXRlbS1hY3Rpb24td2l0aG91dC12ZXJpZmljYXRpb24uY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmw6ICcuL2NoZWNrbGlzdC1ibG9jay1saXN0LWl0ZW0tYWN0aW9uLXdpdGhvdXQtdmVyaWZpY2F0aW9uLmNvbXBvbmVudC5zY3NzJyxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDdWlDaGVja0xpc3RCbG9ja0xpc3RJdGVtQWN0aW9uV2l0aG91dFZlcmlmaWNhdGlvbkNvbXBvbmVudCB7XHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IG5vZGVDaGVja0xpc3RBcGlTZXJ2aWNlID0gaW5qZWN0KEN1aU5vZGVDaGVja2xpc3RBcGlTZXJ2aWNlKTtcclxuICAgIHByaXZhdGUgY2hlY2tMaXN0QmxvY2tTZXJ2aWNlID0gaW5qZWN0KEN1aUNoZWNrTGlzdEJsb2NrU2VydmljZSk7XHJcblxyXG4gICAgcHVibGljIHJlYWRvbmx5IGNoZWNrTGlzdEl0ZW0gPSBpbnB1dC5yZXF1aXJlZDxOb2RlQ2hlY2tMaXN0SXRlbTxOb2RlQ2hlY2tMaXN0QWN0aW9uSXRlbUNvbnRlbnQ+PigpO1xyXG5cclxuICAgIHByb3RlY3RlZCBvbkNoZWNrTGlzdEFjdGlvbkNoYW5nZWQoYWN0aW9uQ29udGVudDogTm9kZUNoZWNrTGlzdEl0ZW1Db250ZW50QWN0aW9uLCBhY3Rpb25JZDogc3RyaW5nKTogdm9pZCB7XHJcbiAgICAgICAgY29uc3QgcmVxdWVzdERhdGEgPSB7XHJcbiAgICAgICAgICAgIG5vZGVDaGVja0xpc3RJZDogdGhpcy5jaGVja0xpc3RJdGVtKCkuaWQsXHJcbiAgICAgICAgICAgIGFzc2lnbmVlUHVycG9zZVR5cGU6ICdBU1NJR04nLFxyXG4gICAgICAgICAgICBhY3Rpb25JZCxcclxuICAgICAgICAgICAgY29udGVudElkOiBhY3Rpb25Db250ZW50LmlkLFxyXG4gICAgICAgICAgICBpc0VuYWJsZTogYWN0aW9uQ29udGVudC5pc0VuYWJsZSxcclxuICAgICAgICAgICAgaXNSZXF1aXJlZDogYWN0aW9uQ29udGVudC5pc1JlcXVpcmVkXHJcbiAgICAgICAgfTtcclxuXHJcbiAgICAgICAgdGhpcy5ub2RlQ2hlY2tMaXN0QXBpU2VydmljZVxyXG4gICAgICAgICAgICAudXBkYXRlTm9kZUNoZWNrTGlzdEl0ZW1BY3Rpb25Db250ZW50KHJlcXVlc3REYXRhKVxyXG4gICAgICAgICAgICAuc3Vic2NyaWJlKChjaGVja0xpc3RJdGVtKSA9PiB0aGlzLmNoZWNrTGlzdEJsb2NrU2VydmljZS51cGRhdGVDaGVja0xpc3RJdGVtKGNoZWNrTGlzdEl0ZW0pKTtcclxuICAgIH1cclxufVxyXG4iLCI8bmctY29udGFpbmVyICp0cmFuc2xvY289XCJsZXQgdFwiPlxyXG4gICAgPG5nLWNvbnRhaW5lciAqY3VpTGV0PVwiY2hlY2tMaXN0SXRlbSgpLmNvbnRlbnQgYXMgY2hlY2tMaXN0SXRlbUNvbnRlbnRcIj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiYWN0aW9uXCI+XHJcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJhY3Rpb25fX2hlYWRlclwiPlxyXG4gICAgICAgICAgICAgICAge3sgdCgnQ09ORElUSU9OQUxfTE9HSUMnKSB8IHVwcGVyY2FzZSB9fVxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImFjdGlvbl9fY29udGVudFwiPlxyXG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNhcmRzLWNvbnRhaW5lclwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxjdWktY2hlY2tsaXN0LWJsb2NrLWxpc3QtaXRlbS1hY3Rpb24tY2FyZFxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbYWN0aW9uSW5mb109XCJjaGVja0xpc3RJdGVtQ29udGVudC5hY3Rpb25zQXNzaWduZWUhWzBdXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgKGNoZWNrTGlzdEFjdGlvbkNoYW5nZWQpPVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBvbkNoZWNrTGlzdEFjdGlvbkNoYW5nZWQoJGV2ZW50LCBjaGVja0xpc3RJdGVtQ29udGVudC5hY3Rpb25zQXNzaWduZWUhWzBdLmlkKVxyXG4gICAgICAgICAgICAgICAgICAgICAgICBcIlxyXG4gICAgICAgICAgICAgICAgICAgIC8+XHJcbiAgICAgICAgICAgICAgICAgICAgPGN1aS1jaGVja2xpc3QtYmxvY2stbGlzdC1pdGVtLWFjdGlvbi1jYXJkXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFthY3Rpb25JbmZvXT1cImNoZWNrTGlzdEl0ZW1Db250ZW50LmFjdGlvbnNBc3NpZ25lZSFbMV1cIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAoY2hlY2tMaXN0QWN0aW9uQ2hhbmdlZCk9XCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG9uQ2hlY2tMaXN0QWN0aW9uQ2hhbmdlZCgkZXZlbnQsIGNoZWNrTGlzdEl0ZW1Db250ZW50LmFjdGlvbnNBc3NpZ25lZSFbMV0uaWQpXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFwiXHJcbiAgICAgICAgICAgICAgICAgICAgLz5cclxuICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgIDwvbmctY29udGFpbmVyPlxyXG48L25nLWNvbnRhaW5lcj5cclxuIl19
@@ -0,0 +1,2 @@
1
+ export { CuiCheckListBlockListItemActionWithoutVerificationComponent } from './checklist-block-list-item-action-without-verification.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvY2hlY2tsaXN0LWJsb2NrL2NvbXBvbmVudHMvY2hlY2tsaXN0LWJsb2NrLWxpc3QtaXRlbS1hY3Rpb24td2l0aG91dC12ZXJpZmljYXRpb24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLDJEQUEyRCxFQUFFLE1BQU0sbUVBQW1FLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBDdWlDaGVja0xpc3RCbG9ja0xpc3RJdGVtQWN0aW9uV2l0aG91dFZlcmlmaWNhdGlvbkNvbXBvbmVudCB9IGZyb20gJy4vY2hlY2tsaXN0LWJsb2NrLWxpc3QtaXRlbS1hY3Rpb24td2l0aG91dC12ZXJpZmljYXRpb24uY29tcG9uZW50JztcclxuIl19
@@ -0,0 +1,152 @@
1
+ import { NgComponentOutlet } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, computed, DestroyRef, inject, input, signal } from '@angular/core';
3
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
+ import { NonNullableFormBuilder } from '@angular/forms';
5
+ import { CuiElementDirective, CuiLetDirective, CuiDragPointerDirective } from '@cuby-ui/cdk';
6
+ import { TranslocoDirective, TranslocoService } from '@jsverse/transloco';
7
+ import { debounceTime, distinctUntilChanged } from 'rxjs';
8
+ import { CuiTreeStructApiService, CuiNodeChecklistApiService } from '@cuby-ui/api';
9
+ import { CuiTooltip } from '../../../../directives';
10
+ import { CuiButtonModule, CuiContextMenuModule, CuiDialogService, CuiLabelModule, CuiSvgModule } from '../../../../components';
11
+ import { CuiCheckListBlockService } from '../../services/checklist-block.service';
12
+ import { CuiChecklistBlockTitleControlComponent } from '../checklist-block-title-control';
13
+ import { CuiEditorBlockComponent } from '../../../../editor';
14
+ import { CuiDeleteModalComponent } from '../../../../widgets';
15
+ import { cuiCreateDefaultValidators } from '../../../../utils';
16
+ import * as i0 from "@angular/core";
17
+ import * as i1 from "../../../../directives/tooltip/tooltip.directive";
18
+ import * as i2 from "../../../../components/button/button.component";
19
+ import * as i3 from "../../../../components/context-menu/context-menu.component";
20
+ import * as i4 from "../../../../components/svg/svg.component";
21
+ export class CuiChecklistBlockListItemContainerComponent {
22
+ constructor() {
23
+ this.destroyRef = inject(DestroyRef);
24
+ this.nonNullableFormBuilder = inject(NonNullableFormBuilder);
25
+ this.translocoService = inject(TranslocoService);
26
+ this.cuiDialogService = inject(CuiDialogService);
27
+ this.treeStructApiService = inject(CuiTreeStructApiService);
28
+ this.checkListBlockService = inject(CuiCheckListBlockService);
29
+ this.nodeCheckListApiService = inject(CuiNodeChecklistApiService);
30
+ this.DEFAULT_CONTROL_DELAY = 700;
31
+ this.isOpen = signal(false);
32
+ this.checkListBlockItem = input.required();
33
+ this.config = input.required();
34
+ this.index = input(0);
35
+ this.componentId = this.checkListBlockService.componentId;
36
+ this.rotate = computed(() => `rotate(${this.isOpen() ? '0deg' : '-90deg'})`);
37
+ this.headerText = computed(() => this.checkListItem().title ? this.checkListItem().title : this.translocoService.translate('UNTITLED'));
38
+ this.checkListItem = computed(() => this.checkListBlockItem().content);
39
+ this.checkListItemComponent = computed(() => this.checkListBlockItem().component);
40
+ this.checkListItemWithOptions = computed(() => ({
41
+ ...this.checkListItem(),
42
+ options: [
43
+ {
44
+ label: this.translocoService.translate('DUPLICATE'),
45
+ icon: 'cuiIconCopy'
46
+ },
47
+ {
48
+ label: this.translocoService.translate('DELETE'),
49
+ icon: 'cuiIconTrash',
50
+ color: 'var(--cui-danger)',
51
+ command: this.openDeleteChecklistNodeModal.bind(this)
52
+ }
53
+ ]
54
+ }));
55
+ this.headerBorderColor = computed(() => {
56
+ const checkListItem = this.checkListItem();
57
+ if (checkListItem.content.actionsApprove !== null) {
58
+ return 'var(--cui-violet-bg)';
59
+ }
60
+ if ('acceptanceCriteriaEvaluations' in checkListItem.content.actionsAssignee[0]) {
61
+ return 'var(--cui-cyan-bg)';
62
+ }
63
+ return null;
64
+ });
65
+ this.iconChecklistType = computed(() => {
66
+ const checkListItem = this.checkListItem();
67
+ if (checkListItem.content.actionsApprove !== null) {
68
+ return 'cuiIconUsersSm';
69
+ }
70
+ if ('acceptanceCriteriaEvaluations' in checkListItem.content.actionsAssignee[0]) {
71
+ return 'cuiIconChecklist';
72
+ }
73
+ return 'cuiIconUserSm';
74
+ });
75
+ this.titleControl = this.nonNullableFormBuilder.control({ value: '', disabled: true }, cuiCreateDefaultValidators());
76
+ }
77
+ get isTitleEmpty() {
78
+ return !this.titleControl.value;
79
+ }
80
+ get isTitleError() {
81
+ return this.titleControl.invalid && this.titleControl.dirty;
82
+ }
83
+ ngOnInit() {
84
+ this.initControls();
85
+ }
86
+ onRowToggle() {
87
+ this.isOpen.update((prev) => !prev);
88
+ }
89
+ onAllowDrag() {
90
+ this.checkListBlockService.toggleDragPermission(true);
91
+ }
92
+ onProhibitDrag() {
93
+ this.checkListBlockService.toggleDragPermission(false);
94
+ }
95
+ initControls() {
96
+ this.initTitleControlValue();
97
+ this.initTitleControlSubscription();
98
+ }
99
+ initTitleControlValue() {
100
+ this.titleControl.enable();
101
+ this.titleControl.setValue(this.checkListItem().title ? this.checkListItem().title : '');
102
+ }
103
+ initTitleControlSubscription() {
104
+ this.titleControl.valueChanges
105
+ .pipe(debounceTime(this.DEFAULT_CONTROL_DELAY), distinctUntilChanged(), takeUntilDestroyed(this.destroyRef))
106
+ .subscribe((titleValue) => {
107
+ if (this.titleControl.invalid) {
108
+ return;
109
+ }
110
+ this.nodeCheckListApiService
111
+ .updateNodeCheckListItemTitle(this.checkListItem().id, titleValue)
112
+ .subscribe(() => {
113
+ this.checkListBlockService.updateCheckListItem({
114
+ ...this.checkListItem(),
115
+ title: titleValue
116
+ });
117
+ });
118
+ });
119
+ }
120
+ openDeleteChecklistNodeModal() {
121
+ const content = ['THIS_ACTION_WILL_PERMANENTLY_DELETE_THE_ITEM_FROM_CHECKLIST'];
122
+ this.cuiDialogService
123
+ .open(CuiDeleteModalComponent, {
124
+ data: {
125
+ title: 'DELETE_EVALUATION_CHECKLIST_ITEM_QUESTION',
126
+ content,
127
+ delete: () => this.treeStructApiService.deleteTreeStructElement(this.componentId(), this.checkListItem().id)
128
+ }
129
+ })
130
+ .subscribe((data) => data?.canceled || this.checkListBlockService.deleteCheckListItem(this.checkListItem().id));
131
+ }
132
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiChecklistBlockListItemContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
133
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CuiChecklistBlockListItemContainerComponent, isStandalone: true, selector: "cui-checklist-block-list-item-container", inputs: { checkListBlockItem: { classPropertyName: "checkListBlockItem", publicName: "checkListBlockItem", isSignal: true, isRequired: true, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null }, index: { classPropertyName: "index", publicName: "index", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<ng-container *transloco=\"let t\">\r\n <ng-container *cuiLet=\"checkListItemWithOptions() as checkListItem\">\r\n <header\r\n class=\"header\"\r\n [style.border-left-color]=\"headerBorderColor()\"\r\n [class.header__opened]=\"isOpen()\"\r\n >\r\n <button\r\n class=\"icon-drag\"\r\n cuiButton\r\n cuiDragPointer\r\n type=\"button\"\r\n appearance=\"ghost\"\r\n size=\"xxs\"\r\n [icon]=\"'cuiIconDragHandleDots'\"\r\n (mouseenter)=\"onAllowDrag()\"\r\n (mouseleave)=\"onProhibitDrag()\"\r\n ></button>\r\n <button\r\n cuiButton\r\n type=\"button\"\r\n appearance=\"ghost\"\r\n size=\"xxs\"\r\n [style.transform]=\"rotate()\"\r\n icon=\"cuiIconCaretDownFillXxs\"\r\n (click)=\"onRowToggle()\"\r\n ></button>\r\n <cui-svg\r\n [icon]=\"iconChecklistType()\"\r\n color=\"var(--cui-base-500)\"\r\n />\r\n <div class=\"header__content\">\r\n <div class=\"header__numeration\">{{ index() }}.</div>\r\n <div class=\"header__text\">{{ headerText() }}</div>\r\n </div>\r\n @if (isTitleEmpty) {\r\n <cui-svg\r\n [cuiTooltip]=\"t('TITLE_IS_REQUIRED')\"\r\n icon=\"cuiIconAlertTriangle\"\r\n color=\"var(--cui-danger)\"\r\n class=\"icon\"\r\n />\r\n }\r\n <button\r\n #actionButton=\"elementRef\"\r\n cuiButton\r\n type=\"button\"\r\n cuiElement\r\n appearance=\"ghost\"\r\n size=\"xxs\"\r\n icon=\"cuiIconMoreVertical\"\r\n class=\"list__context-menu-button\"\r\n ></button>\r\n <cui-context-menu\r\n [items]=\"checkListItem.options\"\r\n [target]=\"actionButton.nativeElement\"\r\n />\r\n </header>\r\n @if (isOpen()) {\r\n <div class=\"info\">\r\n <cui-checklist-block-title-control [control]=\"titleControl\" />\r\n <cui-editor-block\r\n [config]=\"config()\"\r\n [editorId]=\"checkListItem.textContainerId!\"\r\n [title]=\"titleControl.value\"\r\n />\r\n </div>\r\n <ng-container\r\n [ngComponentOutlet]=\"checkListItemComponent()\"\r\n [ngComponentOutletInputs]=\"{\r\n checkListItem: checkListItem\r\n }\"\r\n />\r\n }\r\n </ng-container>\r\n</ng-container>\r\n", styles: [":host{display:flex;flex-direction:column;gap:16px;border-radius:inherit;background-color:var(--cui-base-0)}.header{padding-right:7px;padding-left:7px;display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:4px;background:var(--cui-base-0);border-radius:inherit;border-left:6px solid var(--cui-yellow-bg)}.header__content{display:flex;flex-direction:row;align-items:center;gap:8px;flex:1}.header__numeration{font-weight:600;font-size:13px;line-height:16px;padding-right:8px;padding-left:8px;display:flex;justify-content:center;align-items:center}.header__text{font-weight:500;font-size:14px;line-height:20px;padding-top:11px;padding-bottom:11px;flex:1;width:0;overflow:hidden;text-overflow:ellipsis;text-wrap:nowrap}.header__opened{background:var(--cui-badge-info-bg);border-bottom:.5px solid var(--cui-base-200);border-bottom-left-radius:0;border-bottom-right-radius:0}.header:hover{background:var(--cui-base-10)}.info{padding-right:15px;padding-left:15px;display:flex;flex-direction:column;gap:16px}.icon{padding:6px;width:max-content}\n"], dependencies: [{ kind: "directive", type: i1.CuiTooltipDirective, selector: "[cuiTooltip]:not(ng-container):not(ng-template)", inputs: ["cuiTooltipContext", "cuiTooltipAppearance", "cuiTooltip"] }, { kind: "component", type: CuiEditorBlockComponent, selector: "cui-editor-block", inputs: ["title", "editorId", "config", "required"], outputs: ["editorEmpty"] }, { kind: "component", type: CuiChecklistBlockTitleControlComponent, selector: "cui-checklist-block-title-control", inputs: ["control"] }, { kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: i2.CuiButtonComponent, selector: "button[cuiButton], a[cuiButton]", inputs: ["shape", "disabled", "isLoaderShown", "icon", "iconRight", "appearance", "size"] }, { kind: "ngmodule", type: CuiContextMenuModule }, { kind: "component", type: i3.CuiContextMenuComponent, selector: "cui-context-menu[items][target]", inputs: ["items", "target"] }, { kind: "directive", type: CuiElementDirective, selector: "[cuiElement]", exportAs: ["elementRef"] }, { kind: "ngmodule", type: CuiLabelModule }, { kind: "directive", type: CuiLetDirective, selector: "[cuiLet]", inputs: ["cuiLet"] }, { kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i4.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "directive", type: CuiDragPointerDirective, selector: "[cuiDragPointer]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
134
+ }
135
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiChecklistBlockListItemContainerComponent, decorators: [{
136
+ type: Component,
137
+ args: [{ selector: 'cui-checklist-block-list-item-container', imports: [
138
+ CuiTooltip,
139
+ CuiEditorBlockComponent,
140
+ CuiChecklistBlockTitleControlComponent,
141
+ CuiButtonModule,
142
+ CuiContextMenuModule,
143
+ CuiElementDirective,
144
+ CuiLabelModule,
145
+ CuiLetDirective,
146
+ CuiSvgModule,
147
+ NgComponentOutlet,
148
+ TranslocoDirective,
149
+ CuiDragPointerDirective
150
+ ], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *transloco=\"let t\">\r\n <ng-container *cuiLet=\"checkListItemWithOptions() as checkListItem\">\r\n <header\r\n class=\"header\"\r\n [style.border-left-color]=\"headerBorderColor()\"\r\n [class.header__opened]=\"isOpen()\"\r\n >\r\n <button\r\n class=\"icon-drag\"\r\n cuiButton\r\n cuiDragPointer\r\n type=\"button\"\r\n appearance=\"ghost\"\r\n size=\"xxs\"\r\n [icon]=\"'cuiIconDragHandleDots'\"\r\n (mouseenter)=\"onAllowDrag()\"\r\n (mouseleave)=\"onProhibitDrag()\"\r\n ></button>\r\n <button\r\n cuiButton\r\n type=\"button\"\r\n appearance=\"ghost\"\r\n size=\"xxs\"\r\n [style.transform]=\"rotate()\"\r\n icon=\"cuiIconCaretDownFillXxs\"\r\n (click)=\"onRowToggle()\"\r\n ></button>\r\n <cui-svg\r\n [icon]=\"iconChecklistType()\"\r\n color=\"var(--cui-base-500)\"\r\n />\r\n <div class=\"header__content\">\r\n <div class=\"header__numeration\">{{ index() }}.</div>\r\n <div class=\"header__text\">{{ headerText() }}</div>\r\n </div>\r\n @if (isTitleEmpty) {\r\n <cui-svg\r\n [cuiTooltip]=\"t('TITLE_IS_REQUIRED')\"\r\n icon=\"cuiIconAlertTriangle\"\r\n color=\"var(--cui-danger)\"\r\n class=\"icon\"\r\n />\r\n }\r\n <button\r\n #actionButton=\"elementRef\"\r\n cuiButton\r\n type=\"button\"\r\n cuiElement\r\n appearance=\"ghost\"\r\n size=\"xxs\"\r\n icon=\"cuiIconMoreVertical\"\r\n class=\"list__context-menu-button\"\r\n ></button>\r\n <cui-context-menu\r\n [items]=\"checkListItem.options\"\r\n [target]=\"actionButton.nativeElement\"\r\n />\r\n </header>\r\n @if (isOpen()) {\r\n <div class=\"info\">\r\n <cui-checklist-block-title-control [control]=\"titleControl\" />\r\n <cui-editor-block\r\n [config]=\"config()\"\r\n [editorId]=\"checkListItem.textContainerId!\"\r\n [title]=\"titleControl.value\"\r\n />\r\n </div>\r\n <ng-container\r\n [ngComponentOutlet]=\"checkListItemComponent()\"\r\n [ngComponentOutletInputs]=\"{\r\n checkListItem: checkListItem\r\n }\"\r\n />\r\n }\r\n </ng-container>\r\n</ng-container>\r\n", styles: [":host{display:flex;flex-direction:column;gap:16px;border-radius:inherit;background-color:var(--cui-base-0)}.header{padding-right:7px;padding-left:7px;display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:4px;background:var(--cui-base-0);border-radius:inherit;border-left:6px solid var(--cui-yellow-bg)}.header__content{display:flex;flex-direction:row;align-items:center;gap:8px;flex:1}.header__numeration{font-weight:600;font-size:13px;line-height:16px;padding-right:8px;padding-left:8px;display:flex;justify-content:center;align-items:center}.header__text{font-weight:500;font-size:14px;line-height:20px;padding-top:11px;padding-bottom:11px;flex:1;width:0;overflow:hidden;text-overflow:ellipsis;text-wrap:nowrap}.header__opened{background:var(--cui-badge-info-bg);border-bottom:.5px solid var(--cui-base-200);border-bottom-left-radius:0;border-bottom-right-radius:0}.header:hover{background:var(--cui-base-10)}.info{padding-right:15px;padding-left:15px;display:flex;flex-direction:column;gap:16px}.icon{padding:6px;width:max-content}\n"] }]
151
+ }] });
152
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checklist-block-list-item-container.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/widgets/checklist-block/components/checklist-block-list-item-container/checklist-block-list-item-container.component.ts","../../../../../../../projects/core/widgets/checklist-block/components/checklist-block-list-item-container/checklist-block-list-item-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgComponentOutlet } from '@angular/common';\r\nimport type { OnInit, Type } from '@angular/core';\r\nimport { ChangeDetectionStrategy, Component, computed, DestroyRef, inject, input, signal } from '@angular/core';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport { NonNullableFormBuilder } from '@angular/forms';\r\nimport { CuiElementDirective, CuiLetDirective, CuiDragPointerDirective } from '@cuby-ui/cdk';\r\nimport { TranslocoDirective, TranslocoService } from '@jsverse/transloco';\r\nimport { debounceTime, distinctUntilChanged } from 'rxjs';\r\nimport { CuiTreeStructApiService, CuiNodeChecklistApiService, NodeCheckListItem, NodeCheckListItemContentType } from '@cuby-ui/api';\r\n\r\nimport type { CuiCheckListBlockItem } from '../../checklist-block.options';\r\nimport { CuiTooltip } from '../../../../directives';\r\nimport { CuiButtonModule, CuiContextMenuModule, CuiDialogService, CuiLabelModule, CuiSvgModule } from '../../../../components';\r\nimport { CuiCheckListBlockService } from '../../services/checklist-block.service';\r\nimport { CuiChecklistBlockTitleControlComponent } from '../checklist-block-title-control';\r\nimport { CuiNodeCheckListItemWithOption } from './checklist-block-list-item-container.options';\r\nimport { CuiEditorBlockComponent, CuiEditorConfig } from '../../../../editor';\r\nimport { CuiDeleteModalComponent } from '../../../../widgets';\r\nimport { cuiCreateDefaultValidators } from '../../../../utils';\r\n\r\n@Component({\r\n    selector: 'cui-checklist-block-list-item-container',\r\n    imports: [\r\n        CuiTooltip,\r\n        CuiEditorBlockComponent,\r\n        CuiChecklistBlockTitleControlComponent,\r\n        CuiButtonModule,\r\n        CuiContextMenuModule,\r\n        CuiElementDirective,\r\n        CuiLabelModule,\r\n        CuiLetDirective,\r\n        CuiSvgModule,\r\n        NgComponentOutlet,\r\n        TranslocoDirective,\r\n        CuiDragPointerDirective\r\n    ],\r\n    standalone: true,\r\n    templateUrl: './checklist-block-list-item-container.component.html',\r\n    styleUrl: './checklist-block-list-item-container.component.scss',\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class CuiChecklistBlockListItemContainerComponent implements OnInit {\r\n    private readonly destroyRef = inject(DestroyRef);\r\n    private readonly nonNullableFormBuilder = inject(NonNullableFormBuilder);\r\n    private readonly translocoService = inject(TranslocoService);\r\n    private readonly cuiDialogService = inject(CuiDialogService);\r\n    private readonly treeStructApiService = inject(CuiTreeStructApiService);\r\n    private readonly checkListBlockService = inject(CuiCheckListBlockService);\r\n    private readonly nodeCheckListApiService = inject(CuiNodeChecklistApiService);\r\n\r\n    protected readonly DEFAULT_CONTROL_DELAY = 700;\r\n\r\n    protected readonly isOpen = signal(false);\r\n\r\n    public readonly checkListBlockItem = input.required<CuiCheckListBlockItem>();\r\n    public readonly config = input.required<CuiEditorConfig>();\r\n    public readonly index = input<number>(0);\r\n\r\n    protected readonly componentId = this.checkListBlockService.componentId;\r\n    protected readonly rotate = computed(() => `rotate(${this.isOpen() ? '0deg' : '-90deg'})`);\r\n    protected readonly headerText = computed(() =>\r\n        this.checkListItem().title ? this.checkListItem().title : this.translocoService.translate('UNTITLED')\r\n    );\r\n    protected readonly checkListItem = computed<NodeCheckListItem<NodeCheckListItemContentType>>(\r\n        () => this.checkListBlockItem().content\r\n    );\r\n    protected readonly checkListItemComponent = computed<Type<unknown>>(() => this.checkListBlockItem().component);\r\n    protected readonly checkListItemWithOptions = computed<CuiNodeCheckListItemWithOption<NodeCheckListItemContentType>>(\r\n        () => ({\r\n            ...this.checkListItem(),\r\n            options: [\r\n                {\r\n                    label: this.translocoService.translate('DUPLICATE'),\r\n                    icon: 'cuiIconCopy'\r\n                },\r\n                {\r\n                    label: this.translocoService.translate('DELETE'),\r\n                    icon: 'cuiIconTrash',\r\n                    color: 'var(--cui-danger)',\r\n                    command: this.openDeleteChecklistNodeModal.bind(this)\r\n                }\r\n            ]\r\n        })\r\n    );\r\n    protected readonly headerBorderColor = computed(() => {\r\n        const checkListItem = this.checkListItem();\r\n\r\n        if (checkListItem.content.actionsApprove !== null) {\r\n            return 'var(--cui-violet-bg)';\r\n        }\r\n\r\n        if ('acceptanceCriteriaEvaluations' in checkListItem.content.actionsAssignee![0]) {\r\n            return 'var(--cui-cyan-bg)';\r\n        }\r\n\r\n        return null;\r\n    });\r\n    protected readonly iconChecklistType = computed(() => {\r\n        const checkListItem = this.checkListItem();\r\n\r\n        if (checkListItem.content.actionsApprove !== null) {\r\n            return 'cuiIconUsersSm';\r\n        }\r\n\r\n        if ('acceptanceCriteriaEvaluations' in checkListItem.content.actionsAssignee![0]) {\r\n            return 'cuiIconChecklist';\r\n        }\r\n\r\n        return 'cuiIconUserSm';\r\n    });\r\n\r\n    protected readonly titleControl = this.nonNullableFormBuilder.control(\r\n        { value: '', disabled: true },\r\n        cuiCreateDefaultValidators()\r\n    );\r\n\r\n    protected get isTitleEmpty(): boolean {\r\n        return !this.titleControl.value;\r\n    }\r\n\r\n    protected get isTitleError(): boolean {\r\n        return this.titleControl.invalid && this.titleControl.dirty;\r\n    }\r\n\r\n    public ngOnInit(): void {\r\n        this.initControls();\r\n    }\r\n\r\n    protected onRowToggle(): void {\r\n        this.isOpen.update((prev) => !prev);\r\n    }\r\n\r\n    protected onAllowDrag(): void {\r\n        this.checkListBlockService.toggleDragPermission(true);\r\n    }\r\n\r\n    protected onProhibitDrag(): void {\r\n        this.checkListBlockService.toggleDragPermission(false);\r\n    }\r\n\r\n    private initControls(): void {\r\n        this.initTitleControlValue();\r\n        this.initTitleControlSubscription();\r\n    }\r\n\r\n    private initTitleControlValue(): void {\r\n        this.titleControl.enable();\r\n        this.titleControl.setValue(this.checkListItem().title ? this.checkListItem().title : '');\r\n    }\r\n\r\n    private initTitleControlSubscription(): void {\r\n        this.titleControl.valueChanges\r\n            .pipe(debounceTime(this.DEFAULT_CONTROL_DELAY), distinctUntilChanged(), takeUntilDestroyed(this.destroyRef))\r\n            .subscribe((titleValue) => {\r\n                if (this.titleControl.invalid) {\r\n                    return;\r\n                }\r\n\r\n                this.nodeCheckListApiService\r\n                    .updateNodeCheckListItemTitle(this.checkListItem().id, titleValue)\r\n                    .subscribe(() => {\r\n                        this.checkListBlockService.updateCheckListItem({\r\n                            ...this.checkListItem(),\r\n                            title: titleValue\r\n                        });\r\n                    });\r\n            });\r\n    }\r\n\r\n    private openDeleteChecklistNodeModal(): void {\r\n        const content = ['THIS_ACTION_WILL_PERMANENTLY_DELETE_THE_ITEM_FROM_CHECKLIST'];\r\n\r\n        this.cuiDialogService\r\n            .open(CuiDeleteModalComponent, {\r\n                data: {\r\n                    title: 'DELETE_EVALUATION_CHECKLIST_ITEM_QUESTION',\r\n                    content,\r\n                    delete: () =>\r\n                        this.treeStructApiService.deleteTreeStructElement(this.componentId()!, this.checkListItem().id)\r\n                }\r\n            })\r\n            .subscribe(\r\n                (data) => data?.canceled || this.checkListBlockService.deleteCheckListItem(this.checkListItem().id)\r\n            );\r\n    }\r\n}\r\n","<ng-container *transloco=\"let t\">\r\n    <ng-container *cuiLet=\"checkListItemWithOptions() as checkListItem\">\r\n        <header\r\n            class=\"header\"\r\n            [style.border-left-color]=\"headerBorderColor()\"\r\n            [class.header__opened]=\"isOpen()\"\r\n        >\r\n            <button\r\n                class=\"icon-drag\"\r\n                cuiButton\r\n                cuiDragPointer\r\n                type=\"button\"\r\n                appearance=\"ghost\"\r\n                size=\"xxs\"\r\n                [icon]=\"'cuiIconDragHandleDots'\"\r\n                (mouseenter)=\"onAllowDrag()\"\r\n                (mouseleave)=\"onProhibitDrag()\"\r\n            ></button>\r\n            <button\r\n                cuiButton\r\n                type=\"button\"\r\n                appearance=\"ghost\"\r\n                size=\"xxs\"\r\n                [style.transform]=\"rotate()\"\r\n                icon=\"cuiIconCaretDownFillXxs\"\r\n                (click)=\"onRowToggle()\"\r\n            ></button>\r\n            <cui-svg\r\n                [icon]=\"iconChecklistType()\"\r\n                color=\"var(--cui-base-500)\"\r\n            />\r\n            <div class=\"header__content\">\r\n                <div class=\"header__numeration\">{{ index() }}.</div>\r\n                <div class=\"header__text\">{{ headerText() }}</div>\r\n            </div>\r\n            @if (isTitleEmpty) {\r\n                <cui-svg\r\n                    [cuiTooltip]=\"t('TITLE_IS_REQUIRED')\"\r\n                    icon=\"cuiIconAlertTriangle\"\r\n                    color=\"var(--cui-danger)\"\r\n                    class=\"icon\"\r\n                />\r\n            }\r\n            <button\r\n                #actionButton=\"elementRef\"\r\n                cuiButton\r\n                type=\"button\"\r\n                cuiElement\r\n                appearance=\"ghost\"\r\n                size=\"xxs\"\r\n                icon=\"cuiIconMoreVertical\"\r\n                class=\"list__context-menu-button\"\r\n            ></button>\r\n            <cui-context-menu\r\n                [items]=\"checkListItem.options\"\r\n                [target]=\"actionButton.nativeElement\"\r\n            />\r\n        </header>\r\n        @if (isOpen()) {\r\n            <div class=\"info\">\r\n                <cui-checklist-block-title-control [control]=\"titleControl\" />\r\n                <cui-editor-block\r\n                    [config]=\"config()\"\r\n                    [editorId]=\"checkListItem.textContainerId!\"\r\n                    [title]=\"titleControl.value\"\r\n                />\r\n            </div>\r\n            <ng-container\r\n                [ngComponentOutlet]=\"checkListItemComponent()\"\r\n                [ngComponentOutletInputs]=\"{\r\n                    checkListItem: checkListItem\r\n                }\"\r\n            />\r\n        }\r\n    </ng-container>\r\n</ng-container>\r\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tsaXN0LWJsb2NrLWxpc3QtaXRlbS1jb250YWluZXIub3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvd2lkZ2V0cy9jaGVja2xpc3QtYmxvY2svY29tcG9uZW50cy9jaGVja2xpc3QtYmxvY2stbGlzdC1pdGVtLWNvbnRhaW5lci9jaGVja2xpc3QtYmxvY2stbGlzdC1pdGVtLWNvbnRhaW5lci5vcHRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOb2RlQ2hlY2tMaXN0SXRlbSB9IGZyb20gXCJAY3VieS11aS9hcGlcIjtcclxuXHJcbmltcG9ydCB7IEN1aUNvbnRleHRNZW51SXRlbSB9IGZyb20gXCIuLi8uLi8uLi8uLi9pbnRlcmZhY2VzXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEN1aU5vZGVDaGVja0xpc3RJdGVtV2l0aE9wdGlvbjxUPiBleHRlbmRzIE5vZGVDaGVja0xpc3RJdGVtPFQ+IHtcclxuICAgIHJlYWRvbmx5IG9wdGlvbnM6IEN1aUNvbnRleHRNZW51SXRlbVtdO1xyXG59XHJcbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export { CuiChecklistBlockListItemContainerComponent } from './checklist-block-list-item-container.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvY2hlY2tsaXN0LWJsb2NrL2NvbXBvbmVudHMvY2hlY2tsaXN0LWJsb2NrLWxpc3QtaXRlbS1jb250YWluZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLDJDQUEyQyxFQUFFLE1BQU0saURBQWlELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBDdWlDaGVja2xpc3RCbG9ja0xpc3RJdGVtQ29udGFpbmVyQ29tcG9uZW50IH0gZnJvbSAnLi9jaGVja2xpc3QtYmxvY2stbGlzdC1pdGVtLWNvbnRhaW5lci5jb21wb25lbnQnO1xyXG4iXX0=