@cuby-ui/core 0.0.339 → 0.0.341

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 (31) hide show
  1. package/components/badge/badge.component.d.ts +1 -1
  2. package/components/button/button.component.d.ts +12 -12
  3. package/components/button/button.options.d.ts +9 -4
  4. package/esm2022/components/accordion/accordion-item/accordion-item.component.mjs +1 -1
  5. package/esm2022/components/banner/banner.component.mjs +1 -1
  6. package/esm2022/components/button/button.component.mjs +16 -26
  7. package/esm2022/components/button/button.options.mjs +3 -2
  8. package/esm2022/components/dialog/dialog-header/dialog-header.component.mjs +1 -1
  9. package/esm2022/editor/components/editor-tool-modal/editor-tool-modal.component.mjs +1 -1
  10. package/esm2022/editor/components/editor-tooltip/editor-tooltip.component.mjs +2 -2
  11. package/esm2022/editor/components/marker-modal/marker-modal.component.mjs +2 -2
  12. package/esm2022/editor/components/marker-select/marker-select.component.mjs +2 -2
  13. package/esm2022/editor/widgets/editor-block/editor-block.component.mjs +2 -2
  14. package/esm2022/editor/widgets/editor-modal/editor-modal.component.mjs +2 -2
  15. package/esm2022/types/button-theme.mjs +2 -0
  16. package/esm2022/types/index.mjs +2 -1
  17. package/esm2022/widgets/categories/categories.component.mjs +2 -2
  18. package/esm2022/widgets/categories/components/category-item/category-item.component.mjs +2 -2
  19. package/esm2022/widgets/checklist-block/checklist-block.component.mjs +2 -2
  20. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-container/checklist-block-list-item-container.component.mjs +2 -2
  21. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-evaluation/checklist-block-list-item-evaluation.component.mjs +2 -2
  22. package/esm2022/widgets/checklist-block/components/checklist-block-list-item-evaluation-criteria/checklist-block-list-item-evaluation-criteria.component.mjs +2 -2
  23. package/esm2022/widgets/delete-modal/delete-modal.component.mjs +2 -2
  24. package/esm2022/widgets/utility-modal/components/readonly-utility-modal/readonly-utility-modal.component.mjs +2 -2
  25. package/esm2022/widgets/utility-modal/components/utility-modal-create/utility-modal-create.component.mjs +2 -2
  26. package/fesm2022/cuby-ui-core.mjs +38 -46
  27. package/fesm2022/cuby-ui-core.mjs.map +1 -1
  28. package/package.json +4 -4
  29. package/styles/theme.scss +1 -8
  30. package/types/button-theme.d.ts +5 -0
  31. package/types/index.d.ts +1 -0
@@ -46,10 +46,10 @@ export class CuiUtilityModalCreateComponent {
46
46
  this.utilityModalService.deleteUtility(utility).subscribe();
47
47
  }
48
48
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiUtilityModalCreateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
49
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CuiUtilityModalCreateComponent, isStandalone: true, selector: "cui-utility-modal-create", inputs: { initialUtility: { classPropertyName: "initialUtility", publicName: "initialUtility", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "<div\n class=\"wrapper\"\n *transloco=\"let t\"\n>\n <header class=\"header\">\n <ng-container [ngTemplateOutlet]=\"header\" />\n\n <div class=\"header__content\">\n <cui-loader />\n\n <div class=\"actions\">\n @if (!initialUtility()) {\n <button\n type=\"button\"\n cuiButton\n appearance=\"secondary\"\n (click)=\"onCancel()\"\n >\n {{ t('CANCEL') }}\n </button>\n }\n\n <button\n type=\"button\"\n cuiButton\n [disabled]=\"!isFormValid()\"\n appearance=\"action-violet\"\n (click)=\"onSave()\"\n >\n {{ t('DONE') }}\n </button>\n </div>\n </div>\n </header>\n\n <ng-content />\n</div>\n", styles: [".header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px}.header__content{display:flex;gap:8px}.actions{display:flex;gap:16px}\n"], dependencies: [{ kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: i1.CuiButtonComponent, selector: "button[cuiButton], a[cuiButton]", inputs: ["shape", "disabled", "isLoaderShown", "icon", "iconRight", "appearance", "size"] }, { kind: "component", type: CuiLoaderComponent, selector: "cui-loader" }, { kind: "ngmodule", type: CuiSvgModule }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
49
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CuiUtilityModalCreateComponent, isStandalone: true, selector: "cui-utility-modal-create", inputs: { initialUtility: { classPropertyName: "initialUtility", publicName: "initialUtility", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "<div\n class=\"wrapper\"\n *transloco=\"let t\"\n>\n <header class=\"header\">\n <ng-container [ngTemplateOutlet]=\"header\" />\n\n <div class=\"header__content\">\n <cui-loader />\n\n <div class=\"actions\">\n @if (!initialUtility()) {\n <button\n type=\"button\"\n cuiButton\n appearance=\"secondary\"\n (click)=\"onCancel()\"\n >\n {{ t('CANCEL') }}\n </button>\n }\n\n <button\n type=\"button\"\n cuiButton\n [disabled]=\"!isFormValid()\"\n appearance=\"action-violet\"\n (click)=\"onSave()\"\n >\n {{ t('DONE') }}\n </button>\n </div>\n </div>\n </header>\n\n <ng-content />\n</div>\n", styles: [".header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px}.header__content{display:flex;gap:8px}.actions{display:flex;gap:16px}\n"], dependencies: [{ kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: i1.CuiButtonComponent, selector: "button[cuiButton], a[cuiButton]", inputs: ["shape", "disabled", "isLoaderShown", "icon", "iconRight", "appearance", "theme", "size"] }, { kind: "component", type: CuiLoaderComponent, selector: "cui-loader" }, { kind: "ngmodule", type: CuiSvgModule }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
50
50
  }
51
51
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CuiUtilityModalCreateComponent, decorators: [{
52
52
  type: Component,
53
53
  args: [{ selector: 'cui-utility-modal-create', imports: [CuiButtonModule, CuiLoaderComponent, CuiSvgModule, NgTemplateOutlet, TranslocoDirective], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"wrapper\"\n *transloco=\"let t\"\n>\n <header class=\"header\">\n <ng-container [ngTemplateOutlet]=\"header\" />\n\n <div class=\"header__content\">\n <cui-loader />\n\n <div class=\"actions\">\n @if (!initialUtility()) {\n <button\n type=\"button\"\n cuiButton\n appearance=\"secondary\"\n (click)=\"onCancel()\"\n >\n {{ t('CANCEL') }}\n </button>\n }\n\n <button\n type=\"button\"\n cuiButton\n [disabled]=\"!isFormValid()\"\n appearance=\"action-violet\"\n (click)=\"onSave()\"\n >\n {{ t('DONE') }}\n </button>\n </div>\n </div>\n </header>\n\n <ng-content />\n</div>\n", styles: [".header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px}.header__content{display:flex;gap:8px}.actions{display:flex;gap:16px}\n"] }]
54
54
  }] });
55
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utility-modal-create.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/widgets/utility-modal/components/utility-modal-create/utility-modal-create.component.ts","../../../../../../../projects/core/widgets/utility-modal/components/utility-modal-create/utility-modal-create.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport type { OnDestroy, OnInit } from '@angular/core';\nimport { ChangeDetectionStrategy, Component, computed, inject, input, signal } from '@angular/core';\nimport { TranslocoDirective } from '@jsverse/transloco';\nimport type { StorageObject } from '@cuby-ui/api';\nimport { CUI_WINDOW } from '@cuby-ui/cdk';\n\nimport { CUI_DIALOG_CONTEXT, CuiButtonModule, CuiSvgModule } from '../../../../components';\nimport { CuiLoaderComponent } from '../../../loader';\nimport { UTILITY_MODAL_SERVICE_TOKEN, UtilityElement } from \"../../utility-modal.options\";\n\n@Component({\n    selector: 'cui-utility-modal-create',\n    imports: [CuiButtonModule, CuiLoaderComponent, CuiSvgModule, NgTemplateOutlet, TranslocoDirective],\n    standalone: true,\n    templateUrl: './utility-modal-create.component.html',\n    styleUrl: './utility-modal-create.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiUtilityModalCreateComponent implements OnInit, OnDestroy {\n    private readonly window = inject(CUI_WINDOW);\n    private readonly cuiDialogContext = inject(CUI_DIALOG_CONTEXT);\n    private readonly utilityModalService = inject(UTILITY_MODAL_SERVICE_TOKEN);\n\n    private readonly prevUtility = this.cuiDialogContext.data.utility;\n\n    protected readonly editorResourceUrl = this.cuiDialogContext.data.editorResourceUrl;\n    protected readonly tools = this.cuiDialogContext.data.tools;\n    protected readonly header = this.cuiDialogContext.data.header;\n\n    private readonly _utility = computed(() => signal(this.initialUtility()));\n\n    protected readonly isFormValid = signal(false);\n    protected readonly utility = computed(() => this._utility()());\n\n    public readonly initialUtility = input.required<StorageObject<UtilityElement>>();\n\n    public ngOnInit(): void {\n        this.initWindowUnloadEvent();\n    }\n\n    public ngOnDestroy(): void {\n        this.window.onbeforeunload = null;\n    }\n\n    protected onSave(): void {\n        this.cuiDialogContext.completeWith(\n            this.initialUtility() ? { prevId: this.prevUtility.id, ...this.utility() } : this.utility()\n        );\n    }\n\n    protected onCancel(): void {\n        this.destroyUtility();\n\n        const returnedValue = this.initialUtility() ? this.utility() : null;\n\n        this.cuiDialogContext.completeWith(returnedValue);\n    }\n\n    private initWindowUnloadEvent(): void {\n        this.window.onbeforeunload = (): void => this.destroyUtility();\n    }\n\n    private destroyUtility(): void {\n        const utility = this.utility();\n\n        if (!utility || this.initialUtility()) {\n            return;\n        }\n\n        this.utilityModalService.deleteUtility(utility).subscribe();\n    }\n}\n","<div\n    class=\"wrapper\"\n    *transloco=\"let t\"\n>\n    <header class=\"header\">\n        <ng-container [ngTemplateOutlet]=\"header\" />\n\n        <div class=\"header__content\">\n            <cui-loader />\n\n            <div class=\"actions\">\n                @if (!initialUtility()) {\n                    <button\n                        type=\"button\"\n                        cuiButton\n                        appearance=\"secondary\"\n                        (click)=\"onCancel()\"\n                    >\n                        {{ t('CANCEL') }}\n                    </button>\n                }\n\n                <button\n                    type=\"button\"\n                    cuiButton\n                    [disabled]=\"!isFormValid()\"\n                    appearance=\"action-violet\"\n                    (click)=\"onSave()\"\n                >\n                    {{ t('DONE') }}\n                </button>\n            </div>\n        </div>\n    </header>\n\n    <ng-content />\n</div>\n"]}
55
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utility-modal-create.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/widgets/utility-modal/components/utility-modal-create/utility-modal-create.component.ts","../../../../../../../projects/core/widgets/utility-modal/components/utility-modal-create/utility-modal-create.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport type { OnDestroy, OnInit } from '@angular/core';\nimport { ChangeDetectionStrategy, Component, computed, inject, input, signal } from '@angular/core';\nimport { TranslocoDirective } from '@jsverse/transloco';\nimport type { StorageObject } from '@cuby-ui/api';\nimport { CUI_WINDOW } from '@cuby-ui/cdk';\n\nimport { CUI_DIALOG_CONTEXT, CuiButtonModule, CuiSvgModule } from '../../../../components';\nimport { CuiLoaderComponent } from '../../../loader';\nimport { UTILITY_MODAL_SERVICE_TOKEN, UtilityElement } from \"../../utility-modal.options\";\n\n@Component({\n    selector: 'cui-utility-modal-create',\n    imports: [CuiButtonModule, CuiLoaderComponent, CuiSvgModule, NgTemplateOutlet, TranslocoDirective],\n    standalone: true,\n    templateUrl: './utility-modal-create.component.html',\n    styleUrl: './utility-modal-create.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiUtilityModalCreateComponent implements OnInit, OnDestroy {\n    private readonly window = inject(CUI_WINDOW);\n    private readonly cuiDialogContext = inject(CUI_DIALOG_CONTEXT);\n    private readonly utilityModalService = inject(UTILITY_MODAL_SERVICE_TOKEN);\n\n    private readonly prevUtility = this.cuiDialogContext.data.utility;\n\n    protected readonly editorResourceUrl = this.cuiDialogContext.data.editorResourceUrl;\n    protected readonly tools = this.cuiDialogContext.data.tools;\n    protected readonly header = this.cuiDialogContext.data.header;\n\n    private readonly _utility = computed(() => signal(this.initialUtility()));\n\n    protected readonly isFormValid = signal(false);\n    protected readonly utility = computed(() => this._utility()());\n\n    public readonly initialUtility = input.required<StorageObject<UtilityElement>>();\n\n    public ngOnInit(): void {\n        this.initWindowUnloadEvent();\n    }\n\n    public ngOnDestroy(): void {\n        this.window.onbeforeunload = null;\n    }\n\n    protected onSave(): void {\n        this.cuiDialogContext.completeWith(\n            this.initialUtility() ? { prevId: this.prevUtility.id, ...this.utility() } : this.utility()\n        );\n    }\n\n    protected onCancel(): void {\n        this.destroyUtility();\n\n        const returnedValue = this.initialUtility() ? this.utility() : null;\n\n        this.cuiDialogContext.completeWith(returnedValue);\n    }\n\n    private initWindowUnloadEvent(): void {\n        this.window.onbeforeunload = (): void => this.destroyUtility();\n    }\n\n    private destroyUtility(): void {\n        const utility = this.utility();\n\n        if (!utility || this.initialUtility()) {\n            return;\n        }\n\n        this.utilityModalService.deleteUtility(utility).subscribe();\n    }\n}\n","<div\n    class=\"wrapper\"\n    *transloco=\"let t\"\n>\n    <header class=\"header\">\n        <ng-container [ngTemplateOutlet]=\"header\" />\n\n        <div class=\"header__content\">\n            <cui-loader />\n\n            <div class=\"actions\">\n                @if (!initialUtility()) {\n                    <button\n                        type=\"button\"\n                        cuiButton\n                        appearance=\"secondary\"\n                        (click)=\"onCancel()\"\n                    >\n                        {{ t('CANCEL') }}\n                    </button>\n                }\n\n                <button\n                    type=\"button\"\n                    cuiButton\n                    [disabled]=\"!isFormValid()\"\n                    appearance=\"action-violet\"\n                    (click)=\"onSave()\"\n                >\n                    {{ t('DONE') }}\n                </button>\n            </div>\n        </div>\n    </header>\n\n    <ng-content />\n</div>\n"]}