@cuby-ui/core 0.0.455 → 0.0.457

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.
@@ -42,7 +42,7 @@ export class ModalDividedSectionComponent {
42
42
  this.selectedStorageObject.set(this.storageObjects()?.[0]);
43
43
  }
44
44
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ModalDividedSectionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
45
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: ModalDividedSectionComponent, isStandalone: true, selector: "cui-modal-divided-section", inputs: { storageElementTypeName: { classPropertyName: "storageElementTypeName", publicName: "storageElementTypeName", isSignal: true, isRequired: true, transformFunction: null }, storageObjects: { classPropertyName: "storageObjects", publicName: "storageObjects", isSignal: true, isRequired: true, transformFunction: null }, environmentUrlForResources: { classPropertyName: "environmentUrlForResources", publicName: "environmentUrlForResources", isSignal: true, isRequired: false, transformFunction: null }, environmentUrlForInstruction: { classPropertyName: "environmentUrlForInstruction", publicName: "environmentUrlForInstruction", isSignal: true, isRequired: false, transformFunction: null }, context: { classPropertyName: "context", publicName: "context", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<ng-container *transloco=\"let t\">\n @if (storageObjects(); as storageObjects) {\n @if (storageObjects.length) {\n <div class=\"block block_left\">\n <ul class=\"list\">\n @for (storageObject of storageObjects; track storageObject.id) {\n @if (storageObject.storageElement; as storageElement) {\n <li>\n <button\n type=\"button\"\n [title]=\"storageElement.title\"\n cuiCardWrapper\n [isSelected]=\"selectedStorageObject()?.id === storageObject.id\"\n (click)=\"onSelect(storageObject)\"\n >\n <div class=\"button__content\">\n @switch (storageElementTypeName()) {\n @case ('CRITERIA') {\n <cui-letter-box\n letter=\"c\"\n backgroundColor=\"var(--cui-violet-400)\"\n />\n }\n @case ('INSTRUCTION') {\n <cui-svg\n icon=\"cuiIconFileText\"\n color=\"var(--cui-base-500)\"\n />\n }\n }\n <span class=\"button__text\">{{ storageElement.title }}</span>\n </div>\n </button>\n </li>\n }\n }\n </ul>\n </div>\n <div class=\"block block_right\">\n @if (selectedStorageObject()?.storageElement; as selectedStorageElement) {\n <header class=\"header\">{{ selectedStorageElement.title }}</header>\n <cui-utility-info-readonly\n [framerId]=\"selectedFramerId()!\"\n [environmentUrlForResources]=\"environmentUrlForResources()\"\n [environmentUrlForInstruction]=\"environmentUrlForInstruction()\"\n class=\"utility-info\"\n />\n }\n </div>\n } @else {\n <cui-empty-state [subtitle]=\"t(emptyStateSubtitle())\" />\n }\n }\n</ng-container>\n", styles: [":host{display:contents}.block{overflow:auto;flex:1}.block_left{padding:15px 16px 16px 24px}.block_right{display:flex;flex-direction:column;border-left:1px solid var(--cui-base-200)}.list{display:flex;flex-direction:column;gap:8px}.button__content{display:flex;gap:8px}.button__text{max-width:482px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header{padding:11px 24px 11px 15px;font-weight:500;font-size:16px;line-height:24px}.utility-info{padding-right:24px}\n"], dependencies: [{ kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i1.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "component", type: CuiEmptyStateComponent, selector: "cui-empty-state, [cuiEmptyState]", inputs: ["title", "subtitle"] }, { kind: "component", type: CuiLetterBoxComponent, selector: "cui-letter-box", inputs: ["letter", "backgroundColor", "size", "shape"] }, { kind: "component", type: CuiCardWrapperComponent, selector: "cui-card-wrapper, [cuiCardWrapper]", inputs: ["withBorder", "isSelected"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "component", type: UtilityInfoReadonlyComponent, selector: "cui-utility-info-readonly", inputs: ["environmentUrlForResources", "environmentUrlForInstruction", "framerId", "element"] }] }); }
45
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: ModalDividedSectionComponent, isStandalone: true, selector: "cui-modal-divided-section", inputs: { storageElementTypeName: { classPropertyName: "storageElementTypeName", publicName: "storageElementTypeName", isSignal: true, isRequired: true, transformFunction: null }, storageObjects: { classPropertyName: "storageObjects", publicName: "storageObjects", isSignal: true, isRequired: true, transformFunction: null }, environmentUrlForResources: { classPropertyName: "environmentUrlForResources", publicName: "environmentUrlForResources", isSignal: true, isRequired: false, transformFunction: null }, environmentUrlForInstruction: { classPropertyName: "environmentUrlForInstruction", publicName: "environmentUrlForInstruction", isSignal: true, isRequired: false, transformFunction: null }, context: { classPropertyName: "context", publicName: "context", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<ng-container *transloco=\"let t\">\n @if (storageObjects(); as storageObjects) {\n @if (storageObjects.length) {\n <div class=\"block block_left\">\n <ul class=\"list\">\n @for (storageObject of storageObjects; track storageObject.id) {\n @if (storageObject.storageElement; as storageElement) {\n <li>\n <button\n type=\"button\"\n [title]=\"storageElement.title\"\n cuiCardWrapper\n [isSelected]=\"selectedStorageObject()?.id === storageObject.id\"\n (click)=\"onSelect(storageObject)\"\n >\n <div class=\"button__content\">\n @switch (storageElementTypeName()) {\n @case ('CRITERIA') {\n <cui-letter-box\n letter=\"c\"\n backgroundColor=\"var(--cui-violet-400)\"\n />\n }\n @case ('INSTRUCTION') {\n <cui-svg\n icon=\"cuiIconFileText\"\n color=\"var(--cui-base-500)\"\n />\n }\n }\n <span class=\"button__text\">{{ storageElement.title }}</span>\n </div>\n </button>\n </li>\n }\n }\n </ul>\n </div>\n <div class=\"block block_right\">\n @if (selectedStorageObject()?.storageElement; as selectedStorageElement) {\n <header class=\"header\">{{ selectedStorageElement.title }}</header>\n <cui-utility-info-readonly\n [framerId]=\"selectedFramerId()!\"\n [environmentUrlForResources]=\"environmentUrlForResources()\"\n [environmentUrlForInstruction]=\"environmentUrlForInstruction()\"\n class=\"utility-info\"\n />\n }\n </div>\n } @else {\n <cui-empty-state [subtitle]=\"t(emptyStateSubtitle())\" />\n }\n }\n</ng-container>\n", styles: [":host{display:contents}.block{overflow:auto;flex:1}.block_left{padding:15px 16px 16px 24px}.block_right{display:flex;flex-direction:column;border-left:1px solid var(--cui-base-200)}.list{display:flex;flex-direction:column;gap:8px}.button__content{display:flex;gap:8px}.button__text{max-width:482px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header{padding:11px 24px 11px 15px;font-weight:500;font-size:16px;line-height:24px}.utility-info{padding-right:24px}\n"], dependencies: [{ kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i1.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "component", type: CuiEmptyStateComponent, selector: "cui-empty-state, [cuiEmptyState]", inputs: ["title", "subtitle"] }, { kind: "component", type: CuiLetterBoxComponent, selector: "cui-letter-box", inputs: ["letter", "backgroundColor", "size", "shape"] }, { kind: "component", type: CuiCardWrapperComponent, selector: "cui-card-wrapper, [cuiCardWrapper]", inputs: ["withBorder", "isSelected"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "component", type: UtilityInfoReadonlyComponent, selector: "cui-utility-info-readonly", inputs: ["environmentUrlForResources", "environmentUrlForInstruction", "framerId", "element"] }] }); }
46
46
  }
47
47
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ModalDividedSectionComponent, decorators: [{
48
48
  type: Component,
@@ -53,6 +53,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
53
53
  CuiCardWrapperComponent,
54
54
  TranslocoDirective,
55
55
  UtilityInfoReadonlyComponent
56
- ], template: "<ng-container *transloco=\"let t\">\n @if (storageObjects(); as storageObjects) {\n @if (storageObjects.length) {\n <div class=\"block block_left\">\n <ul class=\"list\">\n @for (storageObject of storageObjects; track storageObject.id) {\n @if (storageObject.storageElement; as storageElement) {\n <li>\n <button\n type=\"button\"\n [title]=\"storageElement.title\"\n cuiCardWrapper\n [isSelected]=\"selectedStorageObject()?.id === storageObject.id\"\n (click)=\"onSelect(storageObject)\"\n >\n <div class=\"button__content\">\n @switch (storageElementTypeName()) {\n @case ('CRITERIA') {\n <cui-letter-box\n letter=\"c\"\n backgroundColor=\"var(--cui-violet-400)\"\n />\n }\n @case ('INSTRUCTION') {\n <cui-svg\n icon=\"cuiIconFileText\"\n color=\"var(--cui-base-500)\"\n />\n }\n }\n <span class=\"button__text\">{{ storageElement.title }}</span>\n </div>\n </button>\n </li>\n }\n }\n </ul>\n </div>\n <div class=\"block block_right\">\n @if (selectedStorageObject()?.storageElement; as selectedStorageElement) {\n <header class=\"header\">{{ selectedStorageElement.title }}</header>\n <cui-utility-info-readonly\n [framerId]=\"selectedFramerId()!\"\n [environmentUrlForResources]=\"environmentUrlForResources()\"\n [environmentUrlForInstruction]=\"environmentUrlForInstruction()\"\n class=\"utility-info\"\n />\n }\n </div>\n } @else {\n <cui-empty-state [subtitle]=\"t(emptyStateSubtitle())\" />\n }\n }\n</ng-container>\n", styles: [":host{display:contents}.block{overflow:auto;flex:1}.block_left{padding:15px 16px 16px 24px}.block_right{display:flex;flex-direction:column;border-left:1px solid var(--cui-base-200)}.list{display:flex;flex-direction:column;gap:8px}.button__content{display:flex;gap:8px}.button__text{max-width:482px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header{padding:11px 24px 11px 15px;font-weight:500;font-size:16px;line-height:24px}.utility-info{padding-right:24px}\n"] }]
56
+ ], template: "<ng-container *transloco=\"let t\">\n @if (storageObjects(); as storageObjects) {\n @if (storageObjects.length) {\n <div class=\"block block_left\">\n <ul class=\"list\">\n @for (storageObject of storageObjects; track storageObject.id) {\n @if (storageObject.storageElement; as storageElement) {\n <li>\n <button\n type=\"button\"\n [title]=\"storageElement.title\"\n cuiCardWrapper\n [isSelected]=\"selectedStorageObject()?.id === storageObject.id\"\n (click)=\"onSelect(storageObject)\"\n >\n <div class=\"button__content\">\n @switch (storageElementTypeName()) {\n @case ('CRITERIA') {\n <cui-letter-box\n letter=\"c\"\n backgroundColor=\"var(--cui-violet-400)\"\n />\n }\n @case ('INSTRUCTION') {\n <cui-svg\n icon=\"cuiIconFileText\"\n color=\"var(--cui-base-500)\"\n />\n }\n }\n <span class=\"button__text\">{{ storageElement.title }}</span>\n </div>\n </button>\n </li>\n }\n }\n </ul>\n </div>\n <div class=\"block block_right\">\n @if (selectedStorageObject()?.storageElement; as selectedStorageElement) {\n <header class=\"header\">{{ selectedStorageElement.title }}</header>\n <cui-utility-info-readonly\n [framerId]=\"selectedFramerId()!\"\n [environmentUrlForResources]=\"environmentUrlForResources()\"\n [environmentUrlForInstruction]=\"environmentUrlForInstruction()\"\n class=\"utility-info\"\n />\n }\n </div>\n } @else {\n <cui-empty-state [subtitle]=\"t(emptyStateSubtitle())\" />\n }\n }\n</ng-container>\n", styles: [":host{display:contents}.block{overflow:auto;flex:1}.block_left{padding:15px 16px 16px 24px}.block_right{display:flex;flex-direction:column;border-left:1px solid var(--cui-base-200)}.list{display:flex;flex-direction:column;gap:8px}.button__content{display:flex;gap:8px}.button__text{max-width:482px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header{padding:11px 24px 11px 15px;font-weight:500;font-size:16px;line-height:24px}.utility-info{padding-right:24px}\n"] }]
57
57
  }] });
58
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-divided-section.component.js","sourceRoot":"","sources":["../../../../../../projects/core/widgets/ui/modal-divided-section/modal-divided-section.component.ts","../../../../../../projects/core/widgets/ui/modal-divided-section/modal-divided-section.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAS3E,OAAO,EACH,uBAAuB,EACvB,sBAAsB,EACtB,qBAAqB,EACrB,YAAY,EACf,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,4BAA4B,EAAE,MAAM,0BAA0B,CAAC;;;AAgBxE,MAAM,OAAO,4BAA4B;IAdzC;QAeuB,sBAAiB,GAAoB;YACpD,QAAQ,EAAE,qBAAqB;YAC/B,WAAW,EAAE,cAAc;SAC9B,CAAC;QACiB,kBAAa,GAAgB;YAC5C,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAE,KAAmB,CAAC,iBAAiB;YAC3D,WAAW,EAAE,CAAC,KAAK,EAAE,EAAE,CAAE,KAAqB,CAAC,mBAAmB;SACrE,CAAC;QAEiB,0BAAqB,GAAG,MAAM,CAAoC,IAAI,CAAC,CAAC;QACxE,qBAAgB,GAAG,QAAQ,CAAC,GAAG,EAAE;YAChD,MAAM,qBAAqB,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAE3D,IAAI,CAAC,qBAAqB,EAAE,CAAC;gBACzB,OAAO;YACX,CAAC;YAED,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC,CAAC,qBAAqB,CAAC,cAAc,CAAC,CAAC;QACnG,CAAC,CAAC,CAAC;QAEgB,uBAAkB,GAAG,QAAQ,CAC5C,GAAG,EAAE,CAAC,MAAM,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC,cAAc,CAClF,CAAC;QAEc,2BAAsB,GAAG,KAAK,CAAC,QAAQ,EAAiC,CAAC;QACzE,mBAAc,GAAG,KAAK,CAAC,QAAQ,EAA0B,CAAC;QAC1D,+BAA0B,GAAG,KAAK,EAAU,CAAC;QAC7C,iCAA4B,GAAG,KAAK,EAAU,CAAC;QAC/C,YAAO,GAAG,KAAK,EAAiB,CAAC;KAiBpD;IAfU,QAAQ;QACX,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACrC,CAAC;IAES,QAAQ,CAAC,oBAA0C;QACzD,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC;IACzD,CAAC;IAEO,yBAAyB;QAC7B,IAAG,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,EAAC,CAAC;YAC9B,OAAM;QACV,CAAC;QAED,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/D,CAAC;+GA7CQ,4BAA4B;mGAA5B,4BAA4B,+4BChCzC,6gGAsDA,ohBDhCQ,YAAY,wKACZ,sBAAsB,4GACtB,qBAAqB,mHACrB,uBAAuB,qHACvB,kBAAkB,gMAClB,4BAA4B;;4FAKvB,4BAA4B;kBAdxC,SAAS;+BACI,2BAA2B,cACzB,IAAI,WACP;wBACL,YAAY;wBACZ,sBAAsB;wBACtB,qBAAqB;wBACrB,uBAAuB;wBACvB,kBAAkB;wBAClB,4BAA4B;qBAC/B","sourcesContent":["import { Component, computed, input, OnInit, signal } from '@angular/core';\nimport { Criterion, CuiApiContext, Instruction } from '@cuby-ui/api';\nimport { CuiNullable } from '@cuby-ui/cdk';\nimport {\n    EmptyStateTitle,\n    GetFramerId,\n    SectionStorageElementTypeName,\n    SectionStorageObject\n} from './modal-divided-section.interfaces';\nimport {\n    CuiCardWrapperComponent,\n    CuiEmptyStateComponent,\n    CuiLetterBoxComponent,\n    CuiSvgModule\n} from '../../../components';\nimport { TranslocoDirective } from '@jsverse/transloco';\nimport { UtilityInfoReadonlyComponent } from '../utility-info-readonly';\n\n@Component({\n    selector: 'cui-modal-divided-section',\n    standalone: true,\n    imports: [\n        CuiSvgModule,\n        CuiEmptyStateComponent,\n        CuiLetterBoxComponent,\n        CuiCardWrapperComponent,\n        TranslocoDirective,\n        UtilityInfoReadonlyComponent\n    ],\n    templateUrl: './modal-divided-section.component.html',\n    styleUrl: './modal-divided-section.component.scss'\n})\nexport class ModalDividedSectionComponent implements OnInit {\n    protected readonly EMPTY_STATE_TITLE: EmptyStateTitle = {\n        CRITERIA: 'ACCEPTANCE_CRITERIA',\n        INSTRUCTION: 'INSTRUCTIONS'\n    };\n    protected readonly GET_FRAMER_ID: GetFramerId = {\n        CRITERIA: (value) => (value as Criterion).framerCriterionId,\n        INSTRUCTION: (value) => (value as Instruction).framerInstructionId\n    };\n\n    protected readonly selectedStorageObject = signal<CuiNullable<SectionStorageObject>>(null);\n    protected readonly selectedFramerId = computed(() => {\n        const selectedStorageObject = this.selectedStorageObject();\n\n        if (!selectedStorageObject) {\n            return;\n        }\n\n        return this.GET_FRAMER_ID[this.storageElementTypeName()](selectedStorageObject.storageElement);\n    });\n\n    protected readonly emptyStateSubtitle = computed(\n        () => `NO_${this.EMPTY_STATE_TITLE[this.storageElementTypeName()]}_TO_VIEW_YET`\n    );\n\n    public readonly storageElementTypeName = input.required<SectionStorageElementTypeName>();\n    public readonly storageObjects = input.required<SectionStorageObject[]>();\n    public readonly environmentUrlForResources = input<string>();\n    public readonly environmentUrlForInstruction = input<string>();\n    public readonly context = input<CuiApiContext>();\n\n    public ngOnInit(): void {\n        this.initSelectedStorageObject();\n    }\n\n    protected onSelect(sectionStorageObject: SectionStorageObject): void {\n        this.selectedStorageObject.set(sectionStorageObject);\n    }\n\n    private initSelectedStorageObject(): void {\n        if(!this.storageObjects().length){\n            return\n        }\n\n        this.selectedStorageObject.set(this.storageObjects()?.[0]);\n    }\n}\n","<ng-container *transloco=\"let t\">\n        @if (storageObjects(); as storageObjects) {\n            @if (storageObjects.length) {\n                <div class=\"block block_left\">\n                    <ul class=\"list\">\n                        @for (storageObject of storageObjects; track storageObject.id) {\n                            @if (storageObject.storageElement; as storageElement) {\n                                <li>\n                                    <button\n                                        type=\"button\"\n                                        [title]=\"storageElement.title\"\n                                        cuiCardWrapper\n                                        [isSelected]=\"selectedStorageObject()?.id === storageObject.id\"\n                                        (click)=\"onSelect(storageObject)\"\n                                    >\n                                        <div class=\"button__content\">\n                                            @switch (storageElementTypeName()) {\n                                                @case ('CRITERIA') {\n                                                    <cui-letter-box\n                                                        letter=\"c\"\n                                                        backgroundColor=\"var(--cui-violet-400)\"\n                                                    />\n                                                }\n                                                @case ('INSTRUCTION') {\n                                                    <cui-svg\n                                                        icon=\"cuiIconFileText\"\n                                                        color=\"var(--cui-base-500)\"\n                                                    />\n                                                }\n                                            }\n                                            <span class=\"button__text\">{{ storageElement.title }}</span>\n                                        </div>\n                                    </button>\n                                </li>\n                            }\n                        }\n                    </ul>\n                </div>\n                <div class=\"block block_right\">\n                    @if (selectedStorageObject()?.storageElement; as selectedStorageElement) {\n                        <header class=\"header\">{{ selectedStorageElement.title }}</header>\n                        <cui-utility-info-readonly\n                            [framerId]=\"selectedFramerId()!\"\n                            [environmentUrlForResources]=\"environmentUrlForResources()\"\n                            [environmentUrlForInstruction]=\"environmentUrlForInstruction()\"\n                            class=\"utility-info\"\n                        />\n                    }\n                </div>\n            } @else {\n                <cui-empty-state [subtitle]=\"t(emptyStateSubtitle())\" />\n            }\n        }\n</ng-container>\n"]}
58
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-divided-section.component.js","sourceRoot":"","sources":["../../../../../../projects/core/widgets/ui/modal-divided-section/modal-divided-section.component.ts","../../../../../../projects/core/widgets/ui/modal-divided-section/modal-divided-section.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAS3E,OAAO,EACH,uBAAuB,EACvB,sBAAsB,EACtB,qBAAqB,EACrB,YAAY,EACf,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,4BAA4B,EAAE,MAAM,0BAA0B,CAAC;;;AAgBxE,MAAM,OAAO,4BAA4B;IAdzC;QAeuB,sBAAiB,GAAoB;YACpD,QAAQ,EAAE,qBAAqB;YAC/B,WAAW,EAAE,cAAc;SAC9B,CAAC;QACiB,kBAAa,GAAgB;YAC5C,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAE,KAAmB,CAAC,iBAAiB;YAC3D,WAAW,EAAE,CAAC,KAAK,EAAE,EAAE,CAAE,KAAqB,CAAC,mBAAmB;SACrE,CAAC;QAEiB,0BAAqB,GAAG,MAAM,CAAoC,IAAI,CAAC,CAAC;QACxE,qBAAgB,GAAG,QAAQ,CAAC,GAAG,EAAE;YAChD,MAAM,qBAAqB,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAE3D,IAAI,CAAC,qBAAqB,EAAE,CAAC;gBACzB,OAAO;YACX,CAAC;YAED,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC,CAAC,qBAAqB,CAAC,cAAc,CAAC,CAAC;QACnG,CAAC,CAAC,CAAC;QAEgB,uBAAkB,GAAG,QAAQ,CAC5C,GAAG,EAAE,CAAC,MAAM,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC,cAAc,CAClF,CAAC;QAEc,2BAAsB,GAAG,KAAK,CAAC,QAAQ,EAAiC,CAAC;QACzE,mBAAc,GAAG,KAAK,CAAC,QAAQ,EAA0B,CAAC;QAC1D,+BAA0B,GAAG,KAAK,EAAU,CAAC;QAC7C,iCAA4B,GAAG,KAAK,EAAU,CAAC;QAC/C,YAAO,GAAG,KAAK,EAAiB,CAAC;KAiBpD;IAfU,QAAQ;QACX,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACrC,CAAC;IAES,QAAQ,CAAC,oBAA0C;QACzD,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC;IACzD,CAAC;IAEO,yBAAyB;QAC7B,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,EAAE,CAAC;YAChC,OAAO;QACX,CAAC;QAED,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/D,CAAC;+GA7CQ,4BAA4B;mGAA5B,4BAA4B,+4BChCzC,6zFAsDA,ohBDhCQ,YAAY,wKACZ,sBAAsB,4GACtB,qBAAqB,mHACrB,uBAAuB,qHACvB,kBAAkB,gMAClB,4BAA4B;;4FAKvB,4BAA4B;kBAdxC,SAAS;+BACI,2BAA2B,cACzB,IAAI,WACP;wBACL,YAAY;wBACZ,sBAAsB;wBACtB,qBAAqB;wBACrB,uBAAuB;wBACvB,kBAAkB;wBAClB,4BAA4B;qBAC/B","sourcesContent":["import { Component, computed, input, OnInit, signal } from '@angular/core';\nimport { Criterion, CuiApiContext, Instruction } from '@cuby-ui/api';\nimport { CuiNullable } from '@cuby-ui/cdk';\nimport {\n    EmptyStateTitle,\n    GetFramerId,\n    SectionStorageElementTypeName,\n    SectionStorageObject\n} from './modal-divided-section.interfaces';\nimport {\n    CuiCardWrapperComponent,\n    CuiEmptyStateComponent,\n    CuiLetterBoxComponent,\n    CuiSvgModule\n} from '../../../components';\nimport { TranslocoDirective } from '@jsverse/transloco';\nimport { UtilityInfoReadonlyComponent } from '../utility-info-readonly';\n\n@Component({\n    selector: 'cui-modal-divided-section',\n    standalone: true,\n    imports: [\n        CuiSvgModule,\n        CuiEmptyStateComponent,\n        CuiLetterBoxComponent,\n        CuiCardWrapperComponent,\n        TranslocoDirective,\n        UtilityInfoReadonlyComponent\n    ],\n    templateUrl: './modal-divided-section.component.html',\n    styleUrl: './modal-divided-section.component.scss'\n})\nexport class ModalDividedSectionComponent implements OnInit {\n    protected readonly EMPTY_STATE_TITLE: EmptyStateTitle = {\n        CRITERIA: 'ACCEPTANCE_CRITERIA',\n        INSTRUCTION: 'INSTRUCTIONS'\n    };\n    protected readonly GET_FRAMER_ID: GetFramerId = {\n        CRITERIA: (value) => (value as Criterion).framerCriterionId,\n        INSTRUCTION: (value) => (value as Instruction).framerInstructionId\n    };\n\n    protected readonly selectedStorageObject = signal<CuiNullable<SectionStorageObject>>(null);\n    protected readonly selectedFramerId = computed(() => {\n        const selectedStorageObject = this.selectedStorageObject();\n\n        if (!selectedStorageObject) {\n            return;\n        }\n\n        return this.GET_FRAMER_ID[this.storageElementTypeName()](selectedStorageObject.storageElement);\n    });\n\n    protected readonly emptyStateSubtitle = computed(\n        () => `NO_${this.EMPTY_STATE_TITLE[this.storageElementTypeName()]}_TO_VIEW_YET`\n    );\n\n    public readonly storageElementTypeName = input.required<SectionStorageElementTypeName>();\n    public readonly storageObjects = input.required<SectionStorageObject[]>();\n    public readonly environmentUrlForResources = input<string>();\n    public readonly environmentUrlForInstruction = input<string>();\n    public readonly context = input<CuiApiContext>();\n\n    public ngOnInit(): void {\n        this.initSelectedStorageObject();\n    }\n\n    protected onSelect(sectionStorageObject: SectionStorageObject): void {\n        this.selectedStorageObject.set(sectionStorageObject);\n    }\n\n    private initSelectedStorageObject(): void {\n        if (!this.storageObjects().length) {\n            return;\n        }\n\n        this.selectedStorageObject.set(this.storageObjects()?.[0]);\n    }\n}\n","<ng-container *transloco=\"let t\">\n    @if (storageObjects(); as storageObjects) {\n        @if (storageObjects.length) {\n            <div class=\"block block_left\">\n                <ul class=\"list\">\n                    @for (storageObject of storageObjects; track storageObject.id) {\n                        @if (storageObject.storageElement; as storageElement) {\n                            <li>\n                                <button\n                                    type=\"button\"\n                                    [title]=\"storageElement.title\"\n                                    cuiCardWrapper\n                                    [isSelected]=\"selectedStorageObject()?.id === storageObject.id\"\n                                    (click)=\"onSelect(storageObject)\"\n                                >\n                                    <div class=\"button__content\">\n                                        @switch (storageElementTypeName()) {\n                                            @case ('CRITERIA') {\n                                                <cui-letter-box\n                                                    letter=\"c\"\n                                                    backgroundColor=\"var(--cui-violet-400)\"\n                                                />\n                                            }\n                                            @case ('INSTRUCTION') {\n                                                <cui-svg\n                                                    icon=\"cuiIconFileText\"\n                                                    color=\"var(--cui-base-500)\"\n                                                />\n                                            }\n                                        }\n                                        <span class=\"button__text\">{{ storageElement.title }}</span>\n                                    </div>\n                                </button>\n                            </li>\n                        }\n                    }\n                </ul>\n            </div>\n            <div class=\"block block_right\">\n                @if (selectedStorageObject()?.storageElement; as selectedStorageElement) {\n                    <header class=\"header\">{{ selectedStorageElement.title }}</header>\n                    <cui-utility-info-readonly\n                        [framerId]=\"selectedFramerId()!\"\n                        [environmentUrlForResources]=\"environmentUrlForResources()\"\n                        [environmentUrlForInstruction]=\"environmentUrlForInstruction()\"\n                        class=\"utility-info\"\n                    />\n                }\n            </div>\n        } @else {\n            <cui-empty-state [subtitle]=\"t(emptyStateSubtitle())\" />\n        }\n    }\n</ng-container>\n"]}
@@ -8,7 +8,7 @@ export class ModalInstructionsTabComponent {
8
8
  this.utilityId = input.required();
9
9
  this.environmentUrlForInstruction = input.required();
10
10
  this.context = input.required();
11
- this.storageObjectInstructions = signal([]);
11
+ this.storageObjectInstructions = signal(null);
12
12
  }
13
13
  ngOnInit() {
14
14
  this.initInstructions();
@@ -28,4 +28,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
28
28
  type: Component,
29
29
  args: [{ imports: [ModalDividedSectionComponent], changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "@if (storageObjectInstructions(); as storageObjectInstructions) {\n <cui-modal-divided-section\n storageElementTypeName=\"INSTRUCTION\"\n [context]=\"context()\"\n [environmentUrlForInstruction]=\"environmentUrlForInstruction()\"\n [storageObjects]=\"storageObjectInstructions\"\n />\n}\n", styles: [":host{display:flex;height:100%}\n"] }]
30
30
  }] });
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtaW5zdHJ1Y3Rpb25zLXRhYi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvdWkvbW9kYWwtaW5zdHJ1Y3Rpb25zLXRhYi9tb2RhbC1pbnN0cnVjdGlvbnMtdGFiLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvd2lkZ2V0cy91aS9tb2RhbC1pbnN0cnVjdGlvbnMtdGFiL21vZGFsLWluc3RydWN0aW9ucy10YWIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRixPQUFPLEVBR0gsaUJBQWlCLEVBR3BCLE1BQU0sY0FBYyxDQUFDO0FBRXRCLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLDBCQUEwQixDQUFDOztBQVN4RSxNQUFNLE9BQU8sNkJBQTZCO0lBUDFDO1FBUXFCLHNCQUFpQixHQUFHLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1FBRS9DLGNBQVMsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFVLENBQUM7UUFDckMsaUNBQTRCLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBQ3hELFlBQU8sR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFpQixDQUFDO1FBQ3ZDLDhCQUF5QixHQUFHLE1BQU0sQ0FBMEMsRUFBRSxDQUFDLENBQUM7S0FxQnRHO0lBbkJVLFFBQVE7UUFDWCxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBRU8sZ0JBQWdCO1FBQ3BCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDbkUsTUFBTSxnQ0FBZ0MsR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDLElBQUksQ0FDNUQsQ0FBQyxnQkFBZ0IsRUFBRSxFQUFFLENBQUMsZ0JBQWdCLENBQUMsYUFBYSwyREFBc0MsQ0FDNUMsQ0FBQztZQUVuRCxJQUFJLENBQUMseUJBQXlCLENBQUMsR0FBRyxDQUM5QixnQ0FBZ0M7Z0JBQzVCLENBQUMsQ0FBQyxnQ0FBZ0MsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUMxQyxDQUFDLHFCQUFxQixFQUFFLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQyxXQUFXLENBQy9EO2dCQUNILENBQUMsQ0FBQyxFQUFFLENBQ1gsQ0FBQztRQUNOLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQzsrR0ExQlEsNkJBQTZCO21HQUE3Qiw2QkFBNkIsZ2hCQ25CMUMsb1VBUUEsMkZES2MsNEJBQTRCOzs0RkFNN0IsNkJBQTZCO2tCQVB6QyxTQUFTOzhCQUNHLENBQUMsNEJBQTRCLENBQUMsbUJBR3RCLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbmplY3QsIGlucHV0LCBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gICAgQ3VpQXBpQ29udGV4dCxcbiAgICBTdG9yYWdlT2JqZWN0SW5zdHJ1Y3Rpb24sXG4gICAgVXRpbGl0eUFwaVNlcnZpY2UsXG4gICAgVXRpbGl0eUNvbXBvbmVudFR5cGUsXG4gICAgVXRpbGl0eUNvbXBvbmVudFdpdGhJbnN0cnVjdGlvbnNcbn0gZnJvbSAnQGN1YnktdWkvYXBpJztcbmltcG9ydCB0eXBlIHsgQ3VpTnVsbGFibGUgfSBmcm9tICdAY3VieS11aS9jZGsnO1xuaW1wb3J0IHsgTW9kYWxEaXZpZGVkU2VjdGlvbkNvbXBvbmVudCB9IGZyb20gJy4uL21vZGFsLWRpdmlkZWQtc2VjdGlvbic7XG5cbkBDb21wb25lbnQoe1xuICAgIGltcG9ydHM6IFtNb2RhbERpdmlkZWRTZWN0aW9uQ29tcG9uZW50XSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vbW9kYWwtaW5zdHJ1Y3Rpb25zLXRhYi5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmw6ICcuL21vZGFsLWluc3RydWN0aW9ucy10YWIuY29tcG9uZW50LnNjc3MnLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgTW9kYWxJbnN0cnVjdGlvbnNUYWJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgdXRpbGl0eUFwaVNlcnZpY2UgPSBpbmplY3QoVXRpbGl0eUFwaVNlcnZpY2UpO1xuXG4gICAgcHVibGljIHJlYWRvbmx5IHV0aWxpdHlJZCA9IGlucHV0LnJlcXVpcmVkPHN0cmluZz4oKTtcbiAgICBwdWJsaWMgcmVhZG9ubHkgZW52aXJvbm1lbnRVcmxGb3JJbnN0cnVjdGlvbiA9IGlucHV0LnJlcXVpcmVkPHN0cmluZz4oKTtcbiAgICBwdWJsaWMgcmVhZG9ubHkgY29udGV4dCA9IGlucHV0LnJlcXVpcmVkPEN1aUFwaUNvbnRleHQ+KCk7XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IHN0b3JhZ2VPYmplY3RJbnN0cnVjdGlvbnMgPSBzaWduYWw8Q3VpTnVsbGFibGU8U3RvcmFnZU9iamVjdEluc3RydWN0aW9uW10+PihbXSk7XG5cbiAgICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaW5pdEluc3RydWN0aW9ucygpO1xuICAgIH1cblxuICAgIHByaXZhdGUgaW5pdEluc3RydWN0aW9ucygpOiB2b2lkIHtcbiAgICAgICAgdGhpcy51dGlsaXR5QXBpU2VydmljZS5nZXRCeUlkKHRoaXMudXRpbGl0eUlkKCkpLnN1YnNjcmliZSgodXRpbGl0eSkgPT4ge1xuICAgICAgICAgICAgY29uc3QgdXRpbGl0eUNvbXBvbmVudFdpdGhJbnN0cnVjdGlvbnMgPSB1dGlsaXR5LmNvbXBvbmVudHMuZmluZChcbiAgICAgICAgICAgICAgICAodXRpbGl0eUNvbXBvbmVudCkgPT4gdXRpbGl0eUNvbXBvbmVudC5jb21wb25lbnRUeXBlID09PSBVdGlsaXR5Q29tcG9uZW50VHlwZS5JbnN0cnVjdGlvbnNcbiAgICAgICAgICAgICkgYXMgQ3VpTnVsbGFibGU8VXRpbGl0eUNvbXBvbmVudFdpdGhJbnN0cnVjdGlvbnM+O1xuXG4gICAgICAgICAgICB0aGlzLnN0b3JhZ2VPYmplY3RJbnN0cnVjdGlvbnMuc2V0KFxuICAgICAgICAgICAgICAgIHV0aWxpdHlDb21wb25lbnRXaXRoSW5zdHJ1Y3Rpb25zXG4gICAgICAgICAgICAgICAgICAgID8gdXRpbGl0eUNvbXBvbmVudFdpdGhJbnN0cnVjdGlvbnMuc3RydWN0dXJlLm1hcChcbiAgICAgICAgICAgICAgICAgICAgICAgICAgKGxpc3RPYmplY3RJbnN0cnVjdGlvbikgPT4gbGlzdE9iamVjdEluc3RydWN0aW9uLmluc3RydWN0aW9uXG4gICAgICAgICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgICAgICAgICA6IFtdXG4gICAgICAgICAgICApO1xuICAgICAgICB9KTtcbiAgICB9XG59XG4iLCJAaWYgKHN0b3JhZ2VPYmplY3RJbnN0cnVjdGlvbnMoKTsgYXMgc3RvcmFnZU9iamVjdEluc3RydWN0aW9ucykge1xuICAgIDxjdWktbW9kYWwtZGl2aWRlZC1zZWN0aW9uXG4gICAgICAgIHN0b3JhZ2VFbGVtZW50VHlwZU5hbWU9XCJJTlNUUlVDVElPTlwiXG4gICAgICAgIFtjb250ZXh0XT1cImNvbnRleHQoKVwiXG4gICAgICAgIFtlbnZpcm9ubWVudFVybEZvckluc3RydWN0aW9uXT1cImVudmlyb25tZW50VXJsRm9ySW5zdHJ1Y3Rpb24oKVwiXG4gICAgICAgIFtzdG9yYWdlT2JqZWN0c109XCJzdG9yYWdlT2JqZWN0SW5zdHJ1Y3Rpb25zXCJcbiAgICAvPlxufVxuIl19
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtaW5zdHJ1Y3Rpb25zLXRhYi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvdWkvbW9kYWwtaW5zdHJ1Y3Rpb25zLXRhYi9tb2RhbC1pbnN0cnVjdGlvbnMtdGFiLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvd2lkZ2V0cy91aS9tb2RhbC1pbnN0cnVjdGlvbnMtdGFiL21vZGFsLWluc3RydWN0aW9ucy10YWIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRixPQUFPLEVBR0gsaUJBQWlCLEVBR3BCLE1BQU0sY0FBYyxDQUFDO0FBRXRCLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLDBCQUEwQixDQUFDOztBQVN4RSxNQUFNLE9BQU8sNkJBQTZCO0lBUDFDO1FBUXFCLHNCQUFpQixHQUFHLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1FBRS9DLGNBQVMsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFVLENBQUM7UUFDckMsaUNBQTRCLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBQ3hELFlBQU8sR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFpQixDQUFDO1FBQ3ZDLDhCQUF5QixHQUFHLE1BQU0sQ0FBMEMsSUFBSSxDQUFDLENBQUM7S0FxQnhHO0lBbkJVLFFBQVE7UUFDWCxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBRU8sZ0JBQWdCO1FBQ3BCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDbkUsTUFBTSxnQ0FBZ0MsR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDLElBQUksQ0FDNUQsQ0FBQyxnQkFBZ0IsRUFBRSxFQUFFLENBQUMsZ0JBQWdCLENBQUMsYUFBYSwyREFBc0MsQ0FDNUMsQ0FBQztZQUVuRCxJQUFJLENBQUMseUJBQXlCLENBQUMsR0FBRyxDQUM5QixnQ0FBZ0M7Z0JBQzVCLENBQUMsQ0FBQyxnQ0FBZ0MsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUMxQyxDQUFDLHFCQUFxQixFQUFFLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQyxXQUFXLENBQy9EO2dCQUNILENBQUMsQ0FBQyxFQUFFLENBQ1gsQ0FBQztRQUNOLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQzsrR0ExQlEsNkJBQTZCO21HQUE3Qiw2QkFBNkIsZ2hCQ25CMUMsb1VBUUEsMkZES2MsNEJBQTRCOzs0RkFNN0IsNkJBQTZCO2tCQVB6QyxTQUFTOzhCQUNHLENBQUMsNEJBQTRCLENBQUMsbUJBR3RCLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbmplY3QsIGlucHV0LCBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gICAgQ3VpQXBpQ29udGV4dCxcbiAgICBTdG9yYWdlT2JqZWN0SW5zdHJ1Y3Rpb24sXG4gICAgVXRpbGl0eUFwaVNlcnZpY2UsXG4gICAgVXRpbGl0eUNvbXBvbmVudFR5cGUsXG4gICAgVXRpbGl0eUNvbXBvbmVudFdpdGhJbnN0cnVjdGlvbnNcbn0gZnJvbSAnQGN1YnktdWkvYXBpJztcbmltcG9ydCB0eXBlIHsgQ3VpTnVsbGFibGUgfSBmcm9tICdAY3VieS11aS9jZGsnO1xuaW1wb3J0IHsgTW9kYWxEaXZpZGVkU2VjdGlvbkNvbXBvbmVudCB9IGZyb20gJy4uL21vZGFsLWRpdmlkZWQtc2VjdGlvbic7XG5cbkBDb21wb25lbnQoe1xuICAgIGltcG9ydHM6IFtNb2RhbERpdmlkZWRTZWN0aW9uQ29tcG9uZW50XSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vbW9kYWwtaW5zdHJ1Y3Rpb25zLXRhYi5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmw6ICcuL21vZGFsLWluc3RydWN0aW9ucy10YWIuY29tcG9uZW50LnNjc3MnLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgTW9kYWxJbnN0cnVjdGlvbnNUYWJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgdXRpbGl0eUFwaVNlcnZpY2UgPSBpbmplY3QoVXRpbGl0eUFwaVNlcnZpY2UpO1xuXG4gICAgcHVibGljIHJlYWRvbmx5IHV0aWxpdHlJZCA9IGlucHV0LnJlcXVpcmVkPHN0cmluZz4oKTtcbiAgICBwdWJsaWMgcmVhZG9ubHkgZW52aXJvbm1lbnRVcmxGb3JJbnN0cnVjdGlvbiA9IGlucHV0LnJlcXVpcmVkPHN0cmluZz4oKTtcbiAgICBwdWJsaWMgcmVhZG9ubHkgY29udGV4dCA9IGlucHV0LnJlcXVpcmVkPEN1aUFwaUNvbnRleHQ+KCk7XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IHN0b3JhZ2VPYmplY3RJbnN0cnVjdGlvbnMgPSBzaWduYWw8Q3VpTnVsbGFibGU8U3RvcmFnZU9iamVjdEluc3RydWN0aW9uW10+PihudWxsKTtcblxuICAgIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pbml0SW5zdHJ1Y3Rpb25zKCk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBpbml0SW5zdHJ1Y3Rpb25zKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnV0aWxpdHlBcGlTZXJ2aWNlLmdldEJ5SWQodGhpcy51dGlsaXR5SWQoKSkuc3Vic2NyaWJlKCh1dGlsaXR5KSA9PiB7XG4gICAgICAgICAgICBjb25zdCB1dGlsaXR5Q29tcG9uZW50V2l0aEluc3RydWN0aW9ucyA9IHV0aWxpdHkuY29tcG9uZW50cy5maW5kKFxuICAgICAgICAgICAgICAgICh1dGlsaXR5Q29tcG9uZW50KSA9PiB1dGlsaXR5Q29tcG9uZW50LmNvbXBvbmVudFR5cGUgPT09IFV0aWxpdHlDb21wb25lbnRUeXBlLkluc3RydWN0aW9uc1xuICAgICAgICAgICAgKSBhcyBDdWlOdWxsYWJsZTxVdGlsaXR5Q29tcG9uZW50V2l0aEluc3RydWN0aW9ucz47XG5cbiAgICAgICAgICAgIHRoaXMuc3RvcmFnZU9iamVjdEluc3RydWN0aW9ucy5zZXQoXG4gICAgICAgICAgICAgICAgdXRpbGl0eUNvbXBvbmVudFdpdGhJbnN0cnVjdGlvbnNcbiAgICAgICAgICAgICAgICAgICAgPyB1dGlsaXR5Q29tcG9uZW50V2l0aEluc3RydWN0aW9ucy5zdHJ1Y3R1cmUubWFwKFxuICAgICAgICAgICAgICAgICAgICAgICAgICAobGlzdE9iamVjdEluc3RydWN0aW9uKSA9PiBsaXN0T2JqZWN0SW5zdHJ1Y3Rpb24uaW5zdHJ1Y3Rpb25cbiAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgIDogW11cbiAgICAgICAgICAgICk7XG4gICAgICAgIH0pO1xuICAgIH1cbn1cbiIsIkBpZiAoc3RvcmFnZU9iamVjdEluc3RydWN0aW9ucygpOyBhcyBzdG9yYWdlT2JqZWN0SW5zdHJ1Y3Rpb25zKSB7XG4gICAgPGN1aS1tb2RhbC1kaXZpZGVkLXNlY3Rpb25cbiAgICAgICAgc3RvcmFnZUVsZW1lbnRUeXBlTmFtZT1cIklOU1RSVUNUSU9OXCJcbiAgICAgICAgW2NvbnRleHRdPVwiY29udGV4dCgpXCJcbiAgICAgICAgW2Vudmlyb25tZW50VXJsRm9ySW5zdHJ1Y3Rpb25dPVwiZW52aXJvbm1lbnRVcmxGb3JJbnN0cnVjdGlvbigpXCJcbiAgICAgICAgW3N0b3JhZ2VPYmplY3RzXT1cInN0b3JhZ2VPYmplY3RJbnN0cnVjdGlvbnNcIlxuICAgIC8+XG59XG4iXX0=
@@ -1,8 +1,8 @@
1
1
  import { Component, computed, inject, input, signal, viewChild } from '@angular/core';
2
2
  import { CUI_DIALOG_CONTEXT, CuiLetterBoxComponent } from '../../../components';
3
- import { CuiEditorComponent } from '../../../editor';
3
+ import { createEditorTools, CuiEditorComponent } from '../../../editor';
4
4
  import { CuiTime } from '@cuby-ui/cdk';
5
- import { CuiJobApiService, JobType, SHARED_CONSTRUCTION_HTTP_OPTIONS, SHARED_INSTRUCTION_HTTP_OPTIONS } from '@cuby-ui/api';
5
+ import { CuiJobApiService, JobType, SHARED_INSTRUCTION_HTTP_OPTIONS } from '@cuby-ui/api';
6
6
  import { ModalInfoTabComponent } from '../modal-info-tab';
7
7
  import { ModalResourcesTabComponent } from '../modal-resources-tab';
8
8
  import { ModalInstructionsTabComponent } from '../modal-instructions-tab';
@@ -16,14 +16,17 @@ export class ModalOperationPartComponent {
16
16
  constructor() {
17
17
  this.context = inject(CUI_DIALOG_CONTEXT);
18
18
  this.jobApiService = inject(CuiJobApiService);
19
- this.editorConfig = { readOnly: true, requestOptions: SHARED_CONSTRUCTION_HTTP_OPTIONS };
20
19
  this.tabs = signal([]);
21
20
  this.ptFormat = computed(() => CuiTime.fromPT(this.storageObjectOperation().storageElement.estimatedTime).toString('HH:MM:SS'));
22
- this.storageObjectOperation = input.required();
21
+ this.editorConfig = computed(() => ({
22
+ readOnly: true,
23
+ tools: createEditorTools(this.environmentUrlForResources())
24
+ }));
23
25
  this.isInserted = input(false);
24
26
  this.containerId = input();
25
27
  this.quantumId = input();
26
28
  this.jobId = input();
29
+ this.storageObjectOperation = input.required();
27
30
  this.environmentUrlForResources = input.required();
28
31
  this.environmentUrlForInstruction = input.required();
29
32
  this.estimatedTime = viewChild.required('estimatedTime');
@@ -96,7 +99,7 @@ export class ModalOperationPartComponent {
96
99
  ]);
97
100
  }
98
101
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ModalOperationPartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
99
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: ModalOperationPartComponent, isStandalone: true, selector: "cui-modal-operation-part", inputs: { storageObjectOperation: { classPropertyName: "storageObjectOperation", publicName: "storageObjectOperation", isSignal: true, isRequired: true, transformFunction: null }, isInserted: { classPropertyName: "isInserted", publicName: "isInserted", isSignal: true, isRequired: false, transformFunction: null }, containerId: { classPropertyName: "containerId", publicName: "containerId", isSignal: true, isRequired: false, transformFunction: null }, quantumId: { classPropertyName: "quantumId", publicName: "quantumId", isSignal: true, isRequired: false, transformFunction: null }, jobId: { classPropertyName: "jobId", publicName: "jobId", isSignal: true, isRequired: false, transformFunction: null }, environmentUrlForResources: { classPropertyName: "environmentUrlForResources", publicName: "environmentUrlForResources", isSignal: true, isRequired: true, transformFunction: null }, environmentUrlForInstruction: { classPropertyName: "environmentUrlForInstruction", publicName: "environmentUrlForInstruction", isSignal: true, isRequired: true, transformFunction: null } }, viewQueries: [{ propertyName: "estimatedTime", first: true, predicate: ["estimatedTime"], descendants: true, isSignal: true }, { propertyName: "editor", first: true, predicate: ["editor"], descendants: true, isSignal: true }], ngImport: i0, template: "@if (storageObjectOperation().storageElement; as operation) {\n <ng-container *transloco=\"let t\">\n <cui-modal-header\n [heading]=\"operation.title\"\n [isInserted]=\"isInserted()\"\n >\n <cui-letter-box\n cuiModalHeaderIcon\n letter=\"o\"\n backgroundColor=\"var(--cui-success)\"\n />\n\n @if (isInserted()) {\n <cui-modal-header-inserted-buttons\n cuiModalHeaderButtons\n (unbindClicked)=\"onUnbindOperation()\"\n />\n }\n </cui-modal-header>\n\n @if (tabs().length) {\n <cui-modal-header-tabs [tabs]=\"tabs()\" />\n }\n </ng-container>\n\n <ng-template #estimatedTime>\n {{ ptFormat() }}\n </ng-template>\n\n <ng-template #editor>\n <cui-editor\n [editorApiId]=\"operation.textContainerId\"\n [config]=\"editorConfig\"\n />\n </ng-template>\n}\n", styles: [":host{display:contents}\n"], dependencies: [{ kind: "component", type: CuiLetterBoxComponent, selector: "cui-letter-box", inputs: ["letter", "backgroundColor", "size", "shape"] }, { kind: "component", type: CuiEditorComponent, selector: "cui-editor", inputs: ["editorApiId", "config", "requestSize"], outputs: ["editorEmpty"] }, { kind: "component", type: ModalHeaderTabsComponent, selector: "cui-modal-header-tabs", inputs: ["tabs", "selectedIndex"] }, { kind: "component", type: ModalHeaderInsertedButtonsComponent, selector: "cui-modal-header-inserted-buttons", outputs: ["unbindClicked"] }, { kind: "component", type: ModalHeaderComponent, selector: "cui-modal-header", inputs: ["heading", "isInserted"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }] }); }
102
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: ModalOperationPartComponent, isStandalone: true, selector: "cui-modal-operation-part", inputs: { isInserted: { classPropertyName: "isInserted", publicName: "isInserted", isSignal: true, isRequired: false, transformFunction: null }, containerId: { classPropertyName: "containerId", publicName: "containerId", isSignal: true, isRequired: false, transformFunction: null }, quantumId: { classPropertyName: "quantumId", publicName: "quantumId", isSignal: true, isRequired: false, transformFunction: null }, jobId: { classPropertyName: "jobId", publicName: "jobId", isSignal: true, isRequired: false, transformFunction: null }, storageObjectOperation: { classPropertyName: "storageObjectOperation", publicName: "storageObjectOperation", isSignal: true, isRequired: true, transformFunction: null }, environmentUrlForResources: { classPropertyName: "environmentUrlForResources", publicName: "environmentUrlForResources", isSignal: true, isRequired: true, transformFunction: null }, environmentUrlForInstruction: { classPropertyName: "environmentUrlForInstruction", publicName: "environmentUrlForInstruction", isSignal: true, isRequired: true, transformFunction: null } }, viewQueries: [{ propertyName: "estimatedTime", first: true, predicate: ["estimatedTime"], descendants: true, isSignal: true }, { propertyName: "editor", first: true, predicate: ["editor"], descendants: true, isSignal: true }], ngImport: i0, template: "@if (storageObjectOperation().storageElement; as operation) {\n <ng-container *transloco=\"let t\">\n <cui-modal-header\n [heading]=\"operation.title\"\n [isInserted]=\"isInserted()\"\n >\n <cui-letter-box\n cuiModalHeaderIcon\n letter=\"o\"\n backgroundColor=\"var(--cui-success)\"\n />\n\n @if (isInserted()) {\n <cui-modal-header-inserted-buttons\n cuiModalHeaderButtons\n (unbindClicked)=\"onUnbindOperation()\"\n />\n }\n </cui-modal-header>\n\n @if (tabs().length) {\n <cui-modal-header-tabs [tabs]=\"tabs()\" />\n }\n </ng-container>\n\n <ng-template #estimatedTime>\n {{ ptFormat() }}\n </ng-template>\n\n <ng-template #editor>\n <cui-editor\n [editorApiId]=\"operation.textContainerId\"\n [config]=\"editorConfig()\"\n />\n </ng-template>\n}\n", styles: [":host{display:contents}\n"], dependencies: [{ kind: "component", type: CuiLetterBoxComponent, selector: "cui-letter-box", inputs: ["letter", "backgroundColor", "size", "shape"] }, { kind: "component", type: CuiEditorComponent, selector: "cui-editor", inputs: ["editorApiId", "config", "requestSize"], outputs: ["editorEmpty"] }, { kind: "component", type: ModalHeaderTabsComponent, selector: "cui-modal-header-tabs", inputs: ["tabs", "selectedIndex"] }, { kind: "component", type: ModalHeaderInsertedButtonsComponent, selector: "cui-modal-header-inserted-buttons", outputs: ["unbindClicked"] }, { kind: "component", type: ModalHeaderComponent, selector: "cui-modal-header", inputs: ["heading", "isInserted"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }] }); }
100
103
  }
101
104
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ModalOperationPartComponent, decorators: [{
102
105
  type: Component,
@@ -110,6 +113,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
110
113
  ModalHeaderTabsComponent,
111
114
  ModalHeaderComponent,
112
115
  TranslocoDirective
113
- ], template: "@if (storageObjectOperation().storageElement; as operation) {\n <ng-container *transloco=\"let t\">\n <cui-modal-header\n [heading]=\"operation.title\"\n [isInserted]=\"isInserted()\"\n >\n <cui-letter-box\n cuiModalHeaderIcon\n letter=\"o\"\n backgroundColor=\"var(--cui-success)\"\n />\n\n @if (isInserted()) {\n <cui-modal-header-inserted-buttons\n cuiModalHeaderButtons\n (unbindClicked)=\"onUnbindOperation()\"\n />\n }\n </cui-modal-header>\n\n @if (tabs().length) {\n <cui-modal-header-tabs [tabs]=\"tabs()\" />\n }\n </ng-container>\n\n <ng-template #estimatedTime>\n {{ ptFormat() }}\n </ng-template>\n\n <ng-template #editor>\n <cui-editor\n [editorApiId]=\"operation.textContainerId\"\n [config]=\"editorConfig\"\n />\n </ng-template>\n}\n", styles: [":host{display:contents}\n"] }]
116
+ ], template: "@if (storageObjectOperation().storageElement; as operation) {\n <ng-container *transloco=\"let t\">\n <cui-modal-header\n [heading]=\"operation.title\"\n [isInserted]=\"isInserted()\"\n >\n <cui-letter-box\n cuiModalHeaderIcon\n letter=\"o\"\n backgroundColor=\"var(--cui-success)\"\n />\n\n @if (isInserted()) {\n <cui-modal-header-inserted-buttons\n cuiModalHeaderButtons\n (unbindClicked)=\"onUnbindOperation()\"\n />\n }\n </cui-modal-header>\n\n @if (tabs().length) {\n <cui-modal-header-tabs [tabs]=\"tabs()\" />\n }\n </ng-container>\n\n <ng-template #estimatedTime>\n {{ ptFormat() }}\n </ng-template>\n\n <ng-template #editor>\n <cui-editor\n [editorApiId]=\"operation.textContainerId\"\n [config]=\"editorConfig()\"\n />\n </ng-template>\n}\n", styles: [":host{display:contents}\n"] }]
114
117
  }] });
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-operation-part.component.js","sourceRoot":"","sources":["../../../../../../projects/core/widgets/ui/modal-operation-part/modal-operation-part.component.ts","../../../../../../projects/core/widgets/ui/modal-operation-part/modal-operation-part.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, computed, inject, input, signal, TemplateRef, viewChild } from '@angular/core';\nimport { CUI_DIALOG_CONTEXT, CuiDialogContext, CuiLetterBoxComponent } from '../../../components';\nimport { CuiEditorComponent, CuiEditorConfig } from '../../../editor';\nimport { CuiNullable, CuiTime } from '@cuby-ui/cdk';\nimport {\n    CuiJobApiService,\n    JobType,\n    ModalHeaderTab,\n    Operation,\n    SHARED_CONSTRUCTION_HTTP_OPTIONS,\n    SHARED_INSTRUCTION_HTTP_OPTIONS,\n    StorageObject\n} from '@cuby-ui/api';\nimport { ModalInfoTabComponent } from '../modal-info-tab';\nimport { ModalResourcesTabComponent } from '../modal-resources-tab';\nimport { ModalInstructionsTabComponent } from '../modal-instructions-tab';\nimport { ModalHeaderTabsComponent } from '../modal-header-tabs';\nimport { ModalHeaderInsertedButtonsComponent } from '../modal-header-inserted-buttons';\nimport { ModalCriteriaTabComponent } from '../modal-criteria-tab';\nimport { TranslocoDirective } from '@jsverse/transloco';\nimport { ModalHeaderComponent } from '../modal-header';\n\n@Component({\n    selector: 'cui-modal-operation-part',\n    standalone: true,\n    imports: [\n        CuiLetterBoxComponent,\n        CuiEditorComponent,\n        ModalHeaderTabsComponent,\n        ModalHeaderInsertedButtonsComponent,\n        ModalHeaderTabsComponent,\n        ModalHeaderTabsComponent,\n        ModalHeaderTabsComponent,\n        ModalHeaderComponent,\n        TranslocoDirective\n    ],\n    templateUrl: './modal-operation-part.component.html',\n    styleUrl: './modal-operation-part.component.scss'\n})\nexport class ModalOperationPartComponent implements AfterViewInit {\n    private readonly context = inject<CuiDialogContext>(CUI_DIALOG_CONTEXT);\n    private readonly jobApiService = inject(CuiJobApiService);\n\n    protected editorConfig: CuiEditorConfig = { readOnly: true, requestOptions: SHARED_CONSTRUCTION_HTTP_OPTIONS };\n\n    protected readonly tabs = signal<ModalHeaderTab[]>([]);\n    protected readonly ptFormat = computed(() =>\n        CuiTime.fromPT(this.storageObjectOperation().storageElement.estimatedTime).toString('HH:MM:SS')\n    );\n\n    public readonly storageObjectOperation = input.required<StorageObject<Operation>>();\n    public readonly isInserted = input(false);\n    public readonly containerId = input<CuiNullable<string>>();\n    public readonly quantumId = input<CuiNullable<string>>();\n    public readonly jobId = input<CuiNullable<string>>();\n    public readonly environmentUrlForResources = input.required<string>();\n    public readonly environmentUrlForInstruction = input.required<string>();\n\n    protected readonly estimatedTime = viewChild.required('estimatedTime');\n\n    public readonly editor = viewChild.required<TemplateRef<unknown>>('editor');\n\n    public ngAfterViewInit() {\n        this.initSectionComponent();\n    }\n\n    protected onUnbindOperation(): void {\n        const containerId = this.containerId();\n        const operationId = this.storageObjectOperation().id;\n        const quantumId = this.quantumId();\n        const jobId = this.jobId();\n\n        if (!containerId) {\n            return;\n        }\n\n        if (!quantumId) {\n            const requestBody = {\n                jobId: jobId!,\n                pointerOperationsId: containerId,\n                selectOperation: operationId,\n                type: JobType.JobCorrective\n            };\n\n            this.jobApiService.unbindOperation(requestBody).subscribe((response) => {\n                this.context.completeWith(response);\n            });\n\n            return;\n        }\n\n        this.jobApiService\n            .unbindOperation({\n                jobId: jobId!,\n                pointerOperationsId: containerId,\n                selectOperation: operationId,\n                type: JobType.JobMain\n            })\n            .subscribe((response) => {\n                this.context.completeWith(response);\n            });\n    }\n\n    private initSectionComponent(): void {\n        const {\n            storageElement: { utilityId, acceptancesCriteria }\n        } = this.storageObjectOperation();\n\n        this.tabs.set([\n            {\n                title: 'INFO',\n                component: ModalInfoTabComponent,\n                inputs: { content: { ESTIMATED_TIME: this.estimatedTime(), DESCRIPTION: this.editor() } }\n            },\n            {\n                title: 'RESOURCES',\n                component: ModalResourcesTabComponent,\n                inputs: { utilityId }\n            },\n            {\n                title: 'INSTRUCTIONS',\n                component: ModalInstructionsTabComponent,\n                inputs: {\n                    utilityId,\n                    environmentUrlForInstruction: this.environmentUrlForInstruction(),\n                    context: SHARED_INSTRUCTION_HTTP_OPTIONS\n                }\n            },\n            {\n                title: 'CRITERIA',\n                component: ModalCriteriaTabComponent,\n                inputs: {\n                    acceptanceCriteriaContainerId: acceptancesCriteria,\n                    environmentUrlForResources: this.environmentUrlForResources()\n                }\n            }\n        ]);\n    }\n}\n","@if (storageObjectOperation().storageElement; as operation) {\n    <ng-container *transloco=\"let t\">\n        <cui-modal-header\n            [heading]=\"operation.title\"\n            [isInserted]=\"isInserted()\"\n        >\n            <cui-letter-box\n                cuiModalHeaderIcon\n                letter=\"o\"\n                backgroundColor=\"var(--cui-success)\"\n            />\n\n            @if (isInserted()) {\n                <cui-modal-header-inserted-buttons\n                    cuiModalHeaderButtons\n                    (unbindClicked)=\"onUnbindOperation()\"\n                />\n            }\n        </cui-modal-header>\n\n        @if (tabs().length) {\n            <cui-modal-header-tabs [tabs]=\"tabs()\" />\n        }\n    </ng-container>\n\n    <ng-template #estimatedTime>\n        {{ ptFormat() }}\n    </ng-template>\n\n    <ng-template #editor>\n        <cui-editor\n            [editorApiId]=\"operation.textContainerId\"\n            [config]=\"editorConfig\"\n        />\n    </ng-template>\n}\n"]}
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-operation-part.component.js","sourceRoot":"","sources":["../../../../../../projects/core/widgets/ui/modal-operation-part/modal-operation-part.component.ts","../../../../../../projects/core/widgets/ui/modal-operation-part/modal-operation-part.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAe,SAAS,EAAE,MAAM,eAAe,CAAC;AAClH,OAAO,EAAE,kBAAkB,EAAoB,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAClG,OAAO,EAAE,iBAAiB,EAAE,kBAAkB,EAAmB,MAAM,iBAAiB,CAAC;AACzF,OAAO,EAAe,OAAO,EAAE,MAAM,cAAc,CAAC;AACpD,OAAO,EACH,gBAAgB,EAChB,OAAO,EAGP,+BAA+B,EAElC,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,EAAE,0BAA0B,EAAE,MAAM,wBAAwB,CAAC;AACpE,OAAO,EAAE,6BAA6B,EAAE,MAAM,2BAA2B,CAAC;AAC1E,OAAO,EAAE,wBAAwB,EAAE,MAAM,sBAAsB,CAAC;AAChE,OAAO,EAAE,mCAAmC,EAAE,MAAM,kCAAkC,CAAC;AACvF,OAAO,EAAE,yBAAyB,EAAE,MAAM,uBAAuB,CAAC;AAClE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;;AAmBvD,MAAM,OAAO,2BAA2B;IAjBxC;QAkBqB,YAAO,GAAG,MAAM,CAAmB,kBAAkB,CAAC,CAAC;QACvD,kBAAa,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAEvC,SAAI,GAAG,MAAM,CAAmB,EAAE,CAAC,CAAC;QAEpC,aAAQ,GAAG,QAAQ,CAAC,GAAG,EAAE,CACxC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,CAClG,CAAC;QAEQ,iBAAY,GAAG,QAAQ,CAAkB,GAAG,EAAE,CAAC,CAAC;YACtD,QAAQ,EAAE,IAAI;YACd,KAAK,EAAE,iBAAiB,CAAC,IAAI,CAAC,0BAA0B,EAAE,CAAC;SAC9D,CAAC,CAAC,CAAC;QAEY,eAAU,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QAC1B,gBAAW,GAAG,KAAK,EAAuB,CAAC;QAC3C,cAAS,GAAG,KAAK,EAAuB,CAAC;QACzC,UAAK,GAAG,KAAK,EAAuB,CAAC;QAErC,2BAAsB,GAAG,KAAK,CAAC,QAAQ,EAA4B,CAAC;QACpE,+BAA0B,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC;QACtD,iCAA4B,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC;QAErD,kBAAa,GAAG,SAAS,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC;QACvD,WAAM,GAAG,SAAS,CAAC,QAAQ,CAAuB,QAAQ,CAAC,CAAC;KA8E/E;IA5EU,eAAe;QAClB,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAChC,CAAC;IAES,iBAAiB;QACvB,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QACvC,MAAM,WAAW,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC,EAAE,CAAC;QACrD,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QACnC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;QAE3B,IAAI,CAAC,WAAW,EAAE,CAAC;YACf,OAAO;QACX,CAAC;QAED,IAAI,CAAC,SAAS,EAAE,CAAC;YACb,MAAM,WAAW,GAAG;gBAChB,KAAK,EAAE,KAAM;gBACb,mBAAmB,EAAE,WAAW;gBAChC,eAAe,EAAE,WAAW;gBAC5B,IAAI,EAAE,OAAO,CAAC,aAAa;aAC9B,CAAC;YAEF,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;gBACnE,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;YACxC,CAAC,CAAC,CAAC;YAEH,OAAO;QACX,CAAC;QAED,IAAI,CAAC,aAAa;aACb,eAAe,CAAC;YACb,KAAK,EAAE,KAAM;YACb,mBAAmB,EAAE,WAAW;YAChC,eAAe,EAAE,WAAW;YAC5B,IAAI,EAAE,OAAO,CAAC,OAAO;SACxB,CAAC;aACD,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YACpB,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;IACX,CAAC;IAEO,oBAAoB;QACxB,MAAM,EACF,cAAc,EAAE,EAAE,SAAS,EAAE,mBAAmB,EAAE,EACrD,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAElC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;YACV;gBACI,KAAK,EAAE,MAAM;gBACb,SAAS,EAAE,qBAAqB;gBAChC,MAAM,EAAE,EAAE,OAAO,EAAE,EAAE,cAAc,EAAE,IAAI,CAAC,aAAa,EAAE,EAAE,WAAW,EAAE,IAAI,CAAC,MAAM,EAAE,EAAE,EAAE;aAC5F;YACD;gBACI,KAAK,EAAE,WAAW;gBAClB,SAAS,EAAE,0BAA0B;gBACrC,MAAM,EAAE,EAAE,SAAS,EAAE;aACxB;YACD;gBACI,KAAK,EAAE,cAAc;gBACrB,SAAS,EAAE,6BAA6B;gBACxC,MAAM,EAAE;oBACJ,SAAS;oBACT,4BAA4B,EAAE,IAAI,CAAC,4BAA4B,EAAE;oBACjE,OAAO,EAAE,+BAA+B;iBAC3C;aACJ;YACD;gBACI,KAAK,EAAE,UAAU;gBACjB,SAAS,EAAE,yBAAyB;gBACpC,MAAM,EAAE;oBACJ,6BAA6B,EAAE,mBAAmB;oBAClD,0BAA0B,EAAE,IAAI,CAAC,0BAA0B,EAAE;iBAChE;aACJ;SACJ,CAAC,CAAC;IACP,CAAC;+GAtGQ,2BAA2B;mGAA3B,2BAA2B,42CCtCxC,ghCAoCA,mFDXQ,qBAAqB,mHACrB,kBAAkB,mIAClB,wBAAwB,qGACxB,mCAAmC,0GAInC,oBAAoB,gGACpB,kBAAkB;;4FAKb,2BAA2B;kBAjBvC,SAAS;+BACI,0BAA0B,cACxB,IAAI,WACP;wBACL,qBAAqB;wBACrB,kBAAkB;wBAClB,wBAAwB;wBACxB,mCAAmC;wBACnC,wBAAwB;wBACxB,wBAAwB;wBACxB,wBAAwB;wBACxB,oBAAoB;wBACpB,kBAAkB;qBACrB","sourcesContent":["import { AfterViewInit, Component, computed, inject, input, signal, TemplateRef, viewChild } from '@angular/core';\nimport { CUI_DIALOG_CONTEXT, CuiDialogContext, CuiLetterBoxComponent } from '../../../components';\nimport { createEditorTools, CuiEditorComponent, CuiEditorConfig } from '../../../editor';\nimport { CuiNullable, CuiTime } from '@cuby-ui/cdk';\nimport {\n    CuiJobApiService,\n    JobType,\n    ModalHeaderTab,\n    Operation,\n    SHARED_INSTRUCTION_HTTP_OPTIONS,\n    StorageObject\n} from '@cuby-ui/api';\nimport { ModalInfoTabComponent } from '../modal-info-tab';\nimport { ModalResourcesTabComponent } from '../modal-resources-tab';\nimport { ModalInstructionsTabComponent } from '../modal-instructions-tab';\nimport { ModalHeaderTabsComponent } from '../modal-header-tabs';\nimport { ModalHeaderInsertedButtonsComponent } from '../modal-header-inserted-buttons';\nimport { ModalCriteriaTabComponent } from '../modal-criteria-tab';\nimport { TranslocoDirective } from '@jsverse/transloco';\nimport { ModalHeaderComponent } from '../modal-header';\n\n@Component({\n    selector: 'cui-modal-operation-part',\n    standalone: true,\n    imports: [\n        CuiLetterBoxComponent,\n        CuiEditorComponent,\n        ModalHeaderTabsComponent,\n        ModalHeaderInsertedButtonsComponent,\n        ModalHeaderTabsComponent,\n        ModalHeaderTabsComponent,\n        ModalHeaderTabsComponent,\n        ModalHeaderComponent,\n        TranslocoDirective\n    ],\n    templateUrl: './modal-operation-part.component.html',\n    styleUrl: './modal-operation-part.component.scss'\n})\nexport class ModalOperationPartComponent implements AfterViewInit {\n    private readonly context = inject<CuiDialogContext>(CUI_DIALOG_CONTEXT);\n    private readonly jobApiService = inject(CuiJobApiService);\n\n    protected readonly tabs = signal<ModalHeaderTab[]>([]);\n\n    protected readonly ptFormat = computed(() =>\n        CuiTime.fromPT(this.storageObjectOperation().storageElement.estimatedTime).toString('HH:MM:SS')\n    );\n\n    protected editorConfig = computed<CuiEditorConfig>(() => ({\n        readOnly: true,\n        tools: createEditorTools(this.environmentUrlForResources())\n    }));\n\n    public readonly isInserted = input(false);\n    public readonly containerId = input<CuiNullable<string>>();\n    public readonly quantumId = input<CuiNullable<string>>();\n    public readonly jobId = input<CuiNullable<string>>();\n\n    public readonly storageObjectOperation = input.required<StorageObject<Operation>>();\n    public readonly environmentUrlForResources = input.required<string>();\n    public readonly environmentUrlForInstruction = input.required<string>();\n\n    protected readonly estimatedTime = viewChild.required('estimatedTime');\n    public readonly editor = viewChild.required<TemplateRef<unknown>>('editor');\n\n    public ngAfterViewInit() {\n        this.initSectionComponent();\n    }\n\n    protected onUnbindOperation(): void {\n        const containerId = this.containerId();\n        const operationId = this.storageObjectOperation().id;\n        const quantumId = this.quantumId();\n        const jobId = this.jobId();\n\n        if (!containerId) {\n            return;\n        }\n\n        if (!quantumId) {\n            const requestBody = {\n                jobId: jobId!,\n                pointerOperationsId: containerId,\n                selectOperation: operationId,\n                type: JobType.JobCorrective\n            };\n\n            this.jobApiService.unbindOperation(requestBody).subscribe((response) => {\n                this.context.completeWith(response);\n            });\n\n            return;\n        }\n\n        this.jobApiService\n            .unbindOperation({\n                jobId: jobId!,\n                pointerOperationsId: containerId,\n                selectOperation: operationId,\n                type: JobType.JobMain\n            })\n            .subscribe((response) => {\n                this.context.completeWith(response);\n            });\n    }\n\n    private initSectionComponent(): void {\n        const {\n            storageElement: { utilityId, acceptancesCriteria }\n        } = this.storageObjectOperation();\n\n        this.tabs.set([\n            {\n                title: 'INFO',\n                component: ModalInfoTabComponent,\n                inputs: { content: { ESTIMATED_TIME: this.estimatedTime(), DESCRIPTION: this.editor() } }\n            },\n            {\n                title: 'RESOURCES',\n                component: ModalResourcesTabComponent,\n                inputs: { utilityId }\n            },\n            {\n                title: 'INSTRUCTIONS',\n                component: ModalInstructionsTabComponent,\n                inputs: {\n                    utilityId,\n                    environmentUrlForInstruction: this.environmentUrlForInstruction(),\n                    context: SHARED_INSTRUCTION_HTTP_OPTIONS\n                }\n            },\n            {\n                title: 'CRITERIA',\n                component: ModalCriteriaTabComponent,\n                inputs: {\n                    acceptanceCriteriaContainerId: acceptancesCriteria,\n                    environmentUrlForResources: this.environmentUrlForResources()\n                }\n            }\n        ]);\n    }\n}\n","@if (storageObjectOperation().storageElement; as operation) {\n    <ng-container *transloco=\"let t\">\n        <cui-modal-header\n            [heading]=\"operation.title\"\n            [isInserted]=\"isInserted()\"\n        >\n            <cui-letter-box\n                cuiModalHeaderIcon\n                letter=\"o\"\n                backgroundColor=\"var(--cui-success)\"\n            />\n\n            @if (isInserted()) {\n                <cui-modal-header-inserted-buttons\n                    cuiModalHeaderButtons\n                    (unbindClicked)=\"onUnbindOperation()\"\n                />\n            }\n        </cui-modal-header>\n\n        @if (tabs().length) {\n            <cui-modal-header-tabs [tabs]=\"tabs()\" />\n        }\n    </ng-container>\n\n    <ng-template #estimatedTime>\n        {{ ptFormat() }}\n    </ng-template>\n\n    <ng-template #editor>\n        <cui-editor\n            [editorApiId]=\"operation.textContainerId\"\n            [config]=\"editorConfig()\"\n        />\n    </ng-template>\n}\n"]}
@@ -10726,7 +10726,7 @@ class ModalDividedSectionComponent {
10726
10726
  this.selectedStorageObject.set(this.storageObjects()?.[0]);
10727
10727
  }
10728
10728
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ModalDividedSectionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
10729
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: ModalDividedSectionComponent, isStandalone: true, selector: "cui-modal-divided-section", inputs: { storageElementTypeName: { classPropertyName: "storageElementTypeName", publicName: "storageElementTypeName", isSignal: true, isRequired: true, transformFunction: null }, storageObjects: { classPropertyName: "storageObjects", publicName: "storageObjects", isSignal: true, isRequired: true, transformFunction: null }, environmentUrlForResources: { classPropertyName: "environmentUrlForResources", publicName: "environmentUrlForResources", isSignal: true, isRequired: false, transformFunction: null }, environmentUrlForInstruction: { classPropertyName: "environmentUrlForInstruction", publicName: "environmentUrlForInstruction", isSignal: true, isRequired: false, transformFunction: null }, context: { classPropertyName: "context", publicName: "context", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<ng-container *transloco=\"let t\">\n @if (storageObjects(); as storageObjects) {\n @if (storageObjects.length) {\n <div class=\"block block_left\">\n <ul class=\"list\">\n @for (storageObject of storageObjects; track storageObject.id) {\n @if (storageObject.storageElement; as storageElement) {\n <li>\n <button\n type=\"button\"\n [title]=\"storageElement.title\"\n cuiCardWrapper\n [isSelected]=\"selectedStorageObject()?.id === storageObject.id\"\n (click)=\"onSelect(storageObject)\"\n >\n <div class=\"button__content\">\n @switch (storageElementTypeName()) {\n @case ('CRITERIA') {\n <cui-letter-box\n letter=\"c\"\n backgroundColor=\"var(--cui-violet-400)\"\n />\n }\n @case ('INSTRUCTION') {\n <cui-svg\n icon=\"cuiIconFileText\"\n color=\"var(--cui-base-500)\"\n />\n }\n }\n <span class=\"button__text\">{{ storageElement.title }}</span>\n </div>\n </button>\n </li>\n }\n }\n </ul>\n </div>\n <div class=\"block block_right\">\n @if (selectedStorageObject()?.storageElement; as selectedStorageElement) {\n <header class=\"header\">{{ selectedStorageElement.title }}</header>\n <cui-utility-info-readonly\n [framerId]=\"selectedFramerId()!\"\n [environmentUrlForResources]=\"environmentUrlForResources()\"\n [environmentUrlForInstruction]=\"environmentUrlForInstruction()\"\n class=\"utility-info\"\n />\n }\n </div>\n } @else {\n <cui-empty-state [subtitle]=\"t(emptyStateSubtitle())\" />\n }\n }\n</ng-container>\n", styles: [":host{display:contents}.block{overflow:auto;flex:1}.block_left{padding:15px 16px 16px 24px}.block_right{display:flex;flex-direction:column;border-left:1px solid var(--cui-base-200)}.list{display:flex;flex-direction:column;gap:8px}.button__content{display:flex;gap:8px}.button__text{max-width:482px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header{padding:11px 24px 11px 15px;font-weight:500;font-size:16px;line-height:24px}.utility-info{padding-right:24px}\n"], dependencies: [{ kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "component", type: CuiEmptyStateComponent, selector: "cui-empty-state, [cuiEmptyState]", inputs: ["title", "subtitle"] }, { kind: "component", type: CuiLetterBoxComponent, selector: "cui-letter-box", inputs: ["letter", "backgroundColor", "size", "shape"] }, { kind: "component", type: CuiCardWrapperComponent, selector: "cui-card-wrapper, [cuiCardWrapper]", inputs: ["withBorder", "isSelected"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "component", type: UtilityInfoReadonlyComponent, selector: "cui-utility-info-readonly", inputs: ["environmentUrlForResources", "environmentUrlForInstruction", "framerId", "element"] }] }); }
10729
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: ModalDividedSectionComponent, isStandalone: true, selector: "cui-modal-divided-section", inputs: { storageElementTypeName: { classPropertyName: "storageElementTypeName", publicName: "storageElementTypeName", isSignal: true, isRequired: true, transformFunction: null }, storageObjects: { classPropertyName: "storageObjects", publicName: "storageObjects", isSignal: true, isRequired: true, transformFunction: null }, environmentUrlForResources: { classPropertyName: "environmentUrlForResources", publicName: "environmentUrlForResources", isSignal: true, isRequired: false, transformFunction: null }, environmentUrlForInstruction: { classPropertyName: "environmentUrlForInstruction", publicName: "environmentUrlForInstruction", isSignal: true, isRequired: false, transformFunction: null }, context: { classPropertyName: "context", publicName: "context", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<ng-container *transloco=\"let t\">\n @if (storageObjects(); as storageObjects) {\n @if (storageObjects.length) {\n <div class=\"block block_left\">\n <ul class=\"list\">\n @for (storageObject of storageObjects; track storageObject.id) {\n @if (storageObject.storageElement; as storageElement) {\n <li>\n <button\n type=\"button\"\n [title]=\"storageElement.title\"\n cuiCardWrapper\n [isSelected]=\"selectedStorageObject()?.id === storageObject.id\"\n (click)=\"onSelect(storageObject)\"\n >\n <div class=\"button__content\">\n @switch (storageElementTypeName()) {\n @case ('CRITERIA') {\n <cui-letter-box\n letter=\"c\"\n backgroundColor=\"var(--cui-violet-400)\"\n />\n }\n @case ('INSTRUCTION') {\n <cui-svg\n icon=\"cuiIconFileText\"\n color=\"var(--cui-base-500)\"\n />\n }\n }\n <span class=\"button__text\">{{ storageElement.title }}</span>\n </div>\n </button>\n </li>\n }\n }\n </ul>\n </div>\n <div class=\"block block_right\">\n @if (selectedStorageObject()?.storageElement; as selectedStorageElement) {\n <header class=\"header\">{{ selectedStorageElement.title }}</header>\n <cui-utility-info-readonly\n [framerId]=\"selectedFramerId()!\"\n [environmentUrlForResources]=\"environmentUrlForResources()\"\n [environmentUrlForInstruction]=\"environmentUrlForInstruction()\"\n class=\"utility-info\"\n />\n }\n </div>\n } @else {\n <cui-empty-state [subtitle]=\"t(emptyStateSubtitle())\" />\n }\n }\n</ng-container>\n", styles: [":host{display:contents}.block{overflow:auto;flex:1}.block_left{padding:15px 16px 16px 24px}.block_right{display:flex;flex-direction:column;border-left:1px solid var(--cui-base-200)}.list{display:flex;flex-direction:column;gap:8px}.button__content{display:flex;gap:8px}.button__text{max-width:482px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header{padding:11px 24px 11px 15px;font-weight:500;font-size:16px;line-height:24px}.utility-info{padding-right:24px}\n"], dependencies: [{ kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "component", type: CuiEmptyStateComponent, selector: "cui-empty-state, [cuiEmptyState]", inputs: ["title", "subtitle"] }, { kind: "component", type: CuiLetterBoxComponent, selector: "cui-letter-box", inputs: ["letter", "backgroundColor", "size", "shape"] }, { kind: "component", type: CuiCardWrapperComponent, selector: "cui-card-wrapper, [cuiCardWrapper]", inputs: ["withBorder", "isSelected"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "component", type: UtilityInfoReadonlyComponent, selector: "cui-utility-info-readonly", inputs: ["environmentUrlForResources", "environmentUrlForInstruction", "framerId", "element"] }] }); }
10730
10730
  }
10731
10731
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ModalDividedSectionComponent, decorators: [{
10732
10732
  type: Component,
@@ -10737,7 +10737,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
10737
10737
  CuiCardWrapperComponent,
10738
10738
  TranslocoDirective,
10739
10739
  UtilityInfoReadonlyComponent
10740
- ], template: "<ng-container *transloco=\"let t\">\n @if (storageObjects(); as storageObjects) {\n @if (storageObjects.length) {\n <div class=\"block block_left\">\n <ul class=\"list\">\n @for (storageObject of storageObjects; track storageObject.id) {\n @if (storageObject.storageElement; as storageElement) {\n <li>\n <button\n type=\"button\"\n [title]=\"storageElement.title\"\n cuiCardWrapper\n [isSelected]=\"selectedStorageObject()?.id === storageObject.id\"\n (click)=\"onSelect(storageObject)\"\n >\n <div class=\"button__content\">\n @switch (storageElementTypeName()) {\n @case ('CRITERIA') {\n <cui-letter-box\n letter=\"c\"\n backgroundColor=\"var(--cui-violet-400)\"\n />\n }\n @case ('INSTRUCTION') {\n <cui-svg\n icon=\"cuiIconFileText\"\n color=\"var(--cui-base-500)\"\n />\n }\n }\n <span class=\"button__text\">{{ storageElement.title }}</span>\n </div>\n </button>\n </li>\n }\n }\n </ul>\n </div>\n <div class=\"block block_right\">\n @if (selectedStorageObject()?.storageElement; as selectedStorageElement) {\n <header class=\"header\">{{ selectedStorageElement.title }}</header>\n <cui-utility-info-readonly\n [framerId]=\"selectedFramerId()!\"\n [environmentUrlForResources]=\"environmentUrlForResources()\"\n [environmentUrlForInstruction]=\"environmentUrlForInstruction()\"\n class=\"utility-info\"\n />\n }\n </div>\n } @else {\n <cui-empty-state [subtitle]=\"t(emptyStateSubtitle())\" />\n }\n }\n</ng-container>\n", styles: [":host{display:contents}.block{overflow:auto;flex:1}.block_left{padding:15px 16px 16px 24px}.block_right{display:flex;flex-direction:column;border-left:1px solid var(--cui-base-200)}.list{display:flex;flex-direction:column;gap:8px}.button__content{display:flex;gap:8px}.button__text{max-width:482px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header{padding:11px 24px 11px 15px;font-weight:500;font-size:16px;line-height:24px}.utility-info{padding-right:24px}\n"] }]
10740
+ ], template: "<ng-container *transloco=\"let t\">\n @if (storageObjects(); as storageObjects) {\n @if (storageObjects.length) {\n <div class=\"block block_left\">\n <ul class=\"list\">\n @for (storageObject of storageObjects; track storageObject.id) {\n @if (storageObject.storageElement; as storageElement) {\n <li>\n <button\n type=\"button\"\n [title]=\"storageElement.title\"\n cuiCardWrapper\n [isSelected]=\"selectedStorageObject()?.id === storageObject.id\"\n (click)=\"onSelect(storageObject)\"\n >\n <div class=\"button__content\">\n @switch (storageElementTypeName()) {\n @case ('CRITERIA') {\n <cui-letter-box\n letter=\"c\"\n backgroundColor=\"var(--cui-violet-400)\"\n />\n }\n @case ('INSTRUCTION') {\n <cui-svg\n icon=\"cuiIconFileText\"\n color=\"var(--cui-base-500)\"\n />\n }\n }\n <span class=\"button__text\">{{ storageElement.title }}</span>\n </div>\n </button>\n </li>\n }\n }\n </ul>\n </div>\n <div class=\"block block_right\">\n @if (selectedStorageObject()?.storageElement; as selectedStorageElement) {\n <header class=\"header\">{{ selectedStorageElement.title }}</header>\n <cui-utility-info-readonly\n [framerId]=\"selectedFramerId()!\"\n [environmentUrlForResources]=\"environmentUrlForResources()\"\n [environmentUrlForInstruction]=\"environmentUrlForInstruction()\"\n class=\"utility-info\"\n />\n }\n </div>\n } @else {\n <cui-empty-state [subtitle]=\"t(emptyStateSubtitle())\" />\n }\n }\n</ng-container>\n", styles: [":host{display:contents}.block{overflow:auto;flex:1}.block_left{padding:15px 16px 16px 24px}.block_right{display:flex;flex-direction:column;border-left:1px solid var(--cui-base-200)}.list{display:flex;flex-direction:column;gap:8px}.button__content{display:flex;gap:8px}.button__text{max-width:482px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header{padding:11px 24px 11px 15px;font-weight:500;font-size:16px;line-height:24px}.utility-info{padding-right:24px}\n"] }]
10741
10741
  }] });
10742
10742
 
10743
10743
  class ModalHeaderInsertedButtonsComponent {
@@ -11587,7 +11587,7 @@ class ModalInstructionsTabComponent {
11587
11587
  this.utilityId = input.required();
11588
11588
  this.environmentUrlForInstruction = input.required();
11589
11589
  this.context = input.required();
11590
- this.storageObjectInstructions = signal([]);
11590
+ this.storageObjectInstructions = signal(null);
11591
11591
  }
11592
11592
  ngOnInit() {
11593
11593
  this.initInstructions();
@@ -11666,14 +11666,17 @@ class ModalOperationPartComponent {
11666
11666
  constructor() {
11667
11667
  this.context = inject(CUI_DIALOG_CONTEXT);
11668
11668
  this.jobApiService = inject(CuiJobApiService);
11669
- this.editorConfig = { readOnly: true, requestOptions: SHARED_CONSTRUCTION_HTTP_OPTIONS };
11670
11669
  this.tabs = signal([]);
11671
11670
  this.ptFormat = computed(() => CuiTime.fromPT(this.storageObjectOperation().storageElement.estimatedTime).toString('HH:MM:SS'));
11672
- this.storageObjectOperation = input.required();
11671
+ this.editorConfig = computed(() => ({
11672
+ readOnly: true,
11673
+ tools: createEditorTools(this.environmentUrlForResources())
11674
+ }));
11673
11675
  this.isInserted = input(false);
11674
11676
  this.containerId = input();
11675
11677
  this.quantumId = input();
11676
11678
  this.jobId = input();
11679
+ this.storageObjectOperation = input.required();
11677
11680
  this.environmentUrlForResources = input.required();
11678
11681
  this.environmentUrlForInstruction = input.required();
11679
11682
  this.estimatedTime = viewChild.required('estimatedTime');
@@ -11746,7 +11749,7 @@ class ModalOperationPartComponent {
11746
11749
  ]);
11747
11750
  }
11748
11751
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ModalOperationPartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
11749
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: ModalOperationPartComponent, isStandalone: true, selector: "cui-modal-operation-part", inputs: { storageObjectOperation: { classPropertyName: "storageObjectOperation", publicName: "storageObjectOperation", isSignal: true, isRequired: true, transformFunction: null }, isInserted: { classPropertyName: "isInserted", publicName: "isInserted", isSignal: true, isRequired: false, transformFunction: null }, containerId: { classPropertyName: "containerId", publicName: "containerId", isSignal: true, isRequired: false, transformFunction: null }, quantumId: { classPropertyName: "quantumId", publicName: "quantumId", isSignal: true, isRequired: false, transformFunction: null }, jobId: { classPropertyName: "jobId", publicName: "jobId", isSignal: true, isRequired: false, transformFunction: null }, environmentUrlForResources: { classPropertyName: "environmentUrlForResources", publicName: "environmentUrlForResources", isSignal: true, isRequired: true, transformFunction: null }, environmentUrlForInstruction: { classPropertyName: "environmentUrlForInstruction", publicName: "environmentUrlForInstruction", isSignal: true, isRequired: true, transformFunction: null } }, viewQueries: [{ propertyName: "estimatedTime", first: true, predicate: ["estimatedTime"], descendants: true, isSignal: true }, { propertyName: "editor", first: true, predicate: ["editor"], descendants: true, isSignal: true }], ngImport: i0, template: "@if (storageObjectOperation().storageElement; as operation) {\n <ng-container *transloco=\"let t\">\n <cui-modal-header\n [heading]=\"operation.title\"\n [isInserted]=\"isInserted()\"\n >\n <cui-letter-box\n cuiModalHeaderIcon\n letter=\"o\"\n backgroundColor=\"var(--cui-success)\"\n />\n\n @if (isInserted()) {\n <cui-modal-header-inserted-buttons\n cuiModalHeaderButtons\n (unbindClicked)=\"onUnbindOperation()\"\n />\n }\n </cui-modal-header>\n\n @if (tabs().length) {\n <cui-modal-header-tabs [tabs]=\"tabs()\" />\n }\n </ng-container>\n\n <ng-template #estimatedTime>\n {{ ptFormat() }}\n </ng-template>\n\n <ng-template #editor>\n <cui-editor\n [editorApiId]=\"operation.textContainerId\"\n [config]=\"editorConfig\"\n />\n </ng-template>\n}\n", styles: [":host{display:contents}\n"], dependencies: [{ kind: "component", type: CuiLetterBoxComponent, selector: "cui-letter-box", inputs: ["letter", "backgroundColor", "size", "shape"] }, { kind: "component", type: CuiEditorComponent, selector: "cui-editor", inputs: ["editorApiId", "config", "requestSize"], outputs: ["editorEmpty"] }, { kind: "component", type: ModalHeaderTabsComponent, selector: "cui-modal-header-tabs", inputs: ["tabs", "selectedIndex"] }, { kind: "component", type: ModalHeaderInsertedButtonsComponent, selector: "cui-modal-header-inserted-buttons", outputs: ["unbindClicked"] }, { kind: "component", type: ModalHeaderComponent, selector: "cui-modal-header", inputs: ["heading", "isInserted"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }] }); }
11752
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: ModalOperationPartComponent, isStandalone: true, selector: "cui-modal-operation-part", inputs: { isInserted: { classPropertyName: "isInserted", publicName: "isInserted", isSignal: true, isRequired: false, transformFunction: null }, containerId: { classPropertyName: "containerId", publicName: "containerId", isSignal: true, isRequired: false, transformFunction: null }, quantumId: { classPropertyName: "quantumId", publicName: "quantumId", isSignal: true, isRequired: false, transformFunction: null }, jobId: { classPropertyName: "jobId", publicName: "jobId", isSignal: true, isRequired: false, transformFunction: null }, storageObjectOperation: { classPropertyName: "storageObjectOperation", publicName: "storageObjectOperation", isSignal: true, isRequired: true, transformFunction: null }, environmentUrlForResources: { classPropertyName: "environmentUrlForResources", publicName: "environmentUrlForResources", isSignal: true, isRequired: true, transformFunction: null }, environmentUrlForInstruction: { classPropertyName: "environmentUrlForInstruction", publicName: "environmentUrlForInstruction", isSignal: true, isRequired: true, transformFunction: null } }, viewQueries: [{ propertyName: "estimatedTime", first: true, predicate: ["estimatedTime"], descendants: true, isSignal: true }, { propertyName: "editor", first: true, predicate: ["editor"], descendants: true, isSignal: true }], ngImport: i0, template: "@if (storageObjectOperation().storageElement; as operation) {\n <ng-container *transloco=\"let t\">\n <cui-modal-header\n [heading]=\"operation.title\"\n [isInserted]=\"isInserted()\"\n >\n <cui-letter-box\n cuiModalHeaderIcon\n letter=\"o\"\n backgroundColor=\"var(--cui-success)\"\n />\n\n @if (isInserted()) {\n <cui-modal-header-inserted-buttons\n cuiModalHeaderButtons\n (unbindClicked)=\"onUnbindOperation()\"\n />\n }\n </cui-modal-header>\n\n @if (tabs().length) {\n <cui-modal-header-tabs [tabs]=\"tabs()\" />\n }\n </ng-container>\n\n <ng-template #estimatedTime>\n {{ ptFormat() }}\n </ng-template>\n\n <ng-template #editor>\n <cui-editor\n [editorApiId]=\"operation.textContainerId\"\n [config]=\"editorConfig()\"\n />\n </ng-template>\n}\n", styles: [":host{display:contents}\n"], dependencies: [{ kind: "component", type: CuiLetterBoxComponent, selector: "cui-letter-box", inputs: ["letter", "backgroundColor", "size", "shape"] }, { kind: "component", type: CuiEditorComponent, selector: "cui-editor", inputs: ["editorApiId", "config", "requestSize"], outputs: ["editorEmpty"] }, { kind: "component", type: ModalHeaderTabsComponent, selector: "cui-modal-header-tabs", inputs: ["tabs", "selectedIndex"] }, { kind: "component", type: ModalHeaderInsertedButtonsComponent, selector: "cui-modal-header-inserted-buttons", outputs: ["unbindClicked"] }, { kind: "component", type: ModalHeaderComponent, selector: "cui-modal-header", inputs: ["heading", "isInserted"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }] }); }
11750
11753
  }
11751
11754
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ModalOperationPartComponent, decorators: [{
11752
11755
  type: Component,
@@ -11760,7 +11763,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
11760
11763
  ModalHeaderTabsComponent,
11761
11764
  ModalHeaderComponent,
11762
11765
  TranslocoDirective
11763
- ], template: "@if (storageObjectOperation().storageElement; as operation) {\n <ng-container *transloco=\"let t\">\n <cui-modal-header\n [heading]=\"operation.title\"\n [isInserted]=\"isInserted()\"\n >\n <cui-letter-box\n cuiModalHeaderIcon\n letter=\"o\"\n backgroundColor=\"var(--cui-success)\"\n />\n\n @if (isInserted()) {\n <cui-modal-header-inserted-buttons\n cuiModalHeaderButtons\n (unbindClicked)=\"onUnbindOperation()\"\n />\n }\n </cui-modal-header>\n\n @if (tabs().length) {\n <cui-modal-header-tabs [tabs]=\"tabs()\" />\n }\n </ng-container>\n\n <ng-template #estimatedTime>\n {{ ptFormat() }}\n </ng-template>\n\n <ng-template #editor>\n <cui-editor\n [editorApiId]=\"operation.textContainerId\"\n [config]=\"editorConfig\"\n />\n </ng-template>\n}\n", styles: [":host{display:contents}\n"] }]
11766
+ ], template: "@if (storageObjectOperation().storageElement; as operation) {\n <ng-container *transloco=\"let t\">\n <cui-modal-header\n [heading]=\"operation.title\"\n [isInserted]=\"isInserted()\"\n >\n <cui-letter-box\n cuiModalHeaderIcon\n letter=\"o\"\n backgroundColor=\"var(--cui-success)\"\n />\n\n @if (isInserted()) {\n <cui-modal-header-inserted-buttons\n cuiModalHeaderButtons\n (unbindClicked)=\"onUnbindOperation()\"\n />\n }\n </cui-modal-header>\n\n @if (tabs().length) {\n <cui-modal-header-tabs [tabs]=\"tabs()\" />\n }\n </ng-container>\n\n <ng-template #estimatedTime>\n {{ ptFormat() }}\n </ng-template>\n\n <ng-template #editor>\n <cui-editor\n [editorApiId]=\"operation.textContainerId\"\n [config]=\"editorConfig()\"\n />\n </ng-template>\n}\n", styles: [":host{display:contents}\n"] }]
11764
11767
  }] });
11765
11768
 
11766
11769
  class RenderDynamicModalComponent {