@cuby-ui/core 0.0.361 → 0.0.363

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.
@@ -33,6 +33,7 @@ export class CuiButtonComponent {
33
33
  }
34
34
  set appearance(appearance) {
35
35
  this._appearance = appearance;
36
+ this.changeIconColor();
36
37
  }
37
38
  get theme() {
38
39
  return this._theme;
@@ -129,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
129
130
  type: ViewChild,
130
131
  args: ['content']
131
132
  }] } });
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/button/button.component.ts","../../../../../projects/core/components/button/button.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    HostBinding,\n    inject,\n    Input,\n    OnInit,\n    ViewChild\n} from '@angular/core';\nimport type { CuiIcon } from '@cuby-ui/icons';\n\nimport { CUI_BUTTON_OPTIONS, CuiButtonAppearance, CuiButtonOptions, CuiButtonSize, CuiButtonTheme } from './button.options';\n\n@Component({\n    selector: 'button[cuiButton], a[cuiButton]',\n    templateUrl: './button.template.html',\n    styleUrls: ['./styles/index.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiButtonComponent implements CuiButtonOptions, OnInit {\n    private readonly changeDetectorRef = inject(ChangeDetectorRef);\n    private readonly cuiButtonOptions = inject(CUI_BUTTON_OPTIONS);\n\n    private readonly ICON_XS_SIZES = ['xxs', 'xxxs'];\n    protected readonly COLOR_BASE_500 = 'var(--cui-base-500)';\n    protected readonly BUTTON_ICONS_COLOR_BASE_500: CuiButtonAppearance[] = [\n        'secondary',\n        'outlined',\n        'outlined-gray',\n        'ghost'\n    ];\n\n    protected _theme = this.cuiButtonOptions.theme;\n    protected _appearance = this.cuiButtonOptions.appearance;\n    protected _size = this.cuiButtonOptions.size;\n\n    protected iconColor = this.getIconColor(this._appearance);\n    protected iconDimensions = {\n        width: 20,\n        height: 20\n    };\n\n    @Input()\n    @HostBinding('attr.data-shape')\n    public shape = this.cuiButtonOptions.shape;\n\n    @Input()\n    @HostBinding('class._disabled')\n    public disabled = false;\n\n    @Input()\n    @HostBinding('class._loading')\n    public isLoaderShown = false;\n\n    @Input()\n    public icon?: CuiIcon | string;\n\n    @Input()\n    public iconRight?: CuiIcon | string;\n\n    @Input()\n    @HostBinding('attr.data-appearance')\n    public get appearance(): CuiButtonAppearance {\n        return this._appearance;\n    }\n\n    public set appearance(appearance: CuiButtonAppearance) {\n        this._appearance = appearance;\n    }\n\n    @Input()\n    @HostBinding('attr.data-theme')\n    public get theme(): CuiButtonTheme {\n        return this._theme;\n    }\n\n    public set theme(theme: CuiButtonTheme) {\n        this._theme = theme;\n\n        this.changeIconColor();\n    }\n\n    @Input()\n    @HostBinding('attr.data-size')\n    public get size(): CuiButtonSize {\n        return this._size;\n    }\n\n    public set size(size: CuiButtonSize) {\n        this._size = size;\n\n        if (this.ICON_XS_SIZES.includes(size)) {\n            this.iconDimensions = {\n                width: 16,\n                height: 16\n            };\n\n            return;\n        }\n\n        this.iconDimensions = {\n            width: 20,\n            height: 20\n        };\n    }\n\n    @HostBinding('class._only-icon')\n    protected containsOnlyIcon = false;\n\n    @HostBinding('disabled')\n    protected get isDisabled(): boolean {\n        return this.disabled || this.isLoaderShown;\n    }\n\n    @ViewChild('content')\n    protected content!: ElementRef<HTMLSpanElement>;\n\n    public ngOnInit(): void {\n        this.initIconColor();\n    }\n\n    private initIconColor(): void {\n        this.changeIconColor();\n    }\n\n    private changeIconColor(): void {\n        Promise.resolve().then(() => {\n            this.iconColor = this.getIconColor(this._appearance);\n\n            this.changeDetectorRef.markForCheck();\n        });\n    }\n\n    private getIconColor(appearance: CuiButtonOptions['appearance']): string {\n        if (this.BUTTON_ICONS_COLOR_BASE_500.includes(appearance)) {\n            return this.COLOR_BASE_500;\n        }\n\n        return 'currentColor';\n    }\n}\n","<span\n  class=\"c-wrapper\"\n  [class.c-wrapper_invisible]=\"isLoaderShown\"\n>\n  <cui-svg\n    *ngIf=\"icon\"\n    [icon]=\"icon\"\n    [width]=\"iconDimensions.width\"\n    [height]=\"iconDimensions.height\"\n    [color]=\"iconColor\"\n  ></cui-svg>\n  <span\n    #content\n    class=\"c-content\"\n  ><ng-content></ng-content></span>\n  <cui-svg\n    *ngIf=\"iconRight\"\n    [icon]=\"iconRight\"\n    [width]=\"iconDimensions.width\"\n    [height]=\"iconDimensions.height\"\n    [color]=\"iconColor\"\n  ></cui-svg>\n</span>\n<cui-svg\n  *ngIf=\"isLoaderShown\"\n  icon=\"cuiIconLoading\"\n  [color]=\"iconColor\"\n  class=\"c-loader\"\n></cui-svg>\n"]}
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/button/button.component.ts","../../../../../projects/core/components/button/button.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    HostBinding,\n    inject,\n    Input,\n    OnInit,\n    ViewChild\n} from '@angular/core';\nimport type { CuiIcon } from '@cuby-ui/icons';\n\nimport { CUI_BUTTON_OPTIONS, CuiButtonAppearance, CuiButtonOptions, CuiButtonSize, CuiButtonTheme } from './button.options';\n\n@Component({\n    selector: 'button[cuiButton], a[cuiButton]',\n    templateUrl: './button.template.html',\n    styleUrls: ['./styles/index.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiButtonComponent implements CuiButtonOptions, OnInit {\n    private readonly changeDetectorRef = inject(ChangeDetectorRef);\n    private readonly cuiButtonOptions = inject(CUI_BUTTON_OPTIONS);\n\n    private readonly ICON_XS_SIZES = ['xxs', 'xxxs'];\n    protected readonly COLOR_BASE_500 = 'var(--cui-base-500)';\n    protected readonly BUTTON_ICONS_COLOR_BASE_500: CuiButtonAppearance[] = [\n        'secondary',\n        'outlined',\n        'outlined-gray',\n        'ghost'\n    ];\n\n    protected _theme = this.cuiButtonOptions.theme;\n    protected _appearance = this.cuiButtonOptions.appearance;\n    protected _size = this.cuiButtonOptions.size;\n\n    protected iconColor = this.getIconColor(this._appearance);\n    protected iconDimensions = {\n        width: 20,\n        height: 20\n    };\n\n    @Input()\n    @HostBinding('attr.data-shape')\n    public shape = this.cuiButtonOptions.shape;\n\n    @Input()\n    @HostBinding('class._disabled')\n    public disabled = false;\n\n    @Input()\n    @HostBinding('class._loading')\n    public isLoaderShown = false;\n\n    @Input()\n    public icon?: CuiIcon | string;\n\n    @Input()\n    public iconRight?: CuiIcon | string;\n\n    @Input()\n    @HostBinding('attr.data-appearance')\n    public get appearance(): CuiButtonAppearance {\n        return this._appearance;\n    }\n\n    public set appearance(appearance: CuiButtonAppearance) {\n        this._appearance = appearance;\n\n        this.changeIconColor();\n    }\n\n    @Input()\n    @HostBinding('attr.data-theme')\n    public get theme(): CuiButtonTheme {\n        return this._theme;\n    }\n\n    public set theme(theme: CuiButtonTheme) {\n        this._theme = theme;\n\n        this.changeIconColor();\n    }\n\n    @Input()\n    @HostBinding('attr.data-size')\n    public get size(): CuiButtonSize {\n        return this._size;\n    }\n\n    public set size(size: CuiButtonSize) {\n        this._size = size;\n\n        if (this.ICON_XS_SIZES.includes(size)) {\n            this.iconDimensions = {\n                width: 16,\n                height: 16\n            };\n\n            return;\n        }\n\n        this.iconDimensions = {\n            width: 20,\n            height: 20\n        };\n    }\n\n    @HostBinding('class._only-icon')\n    protected containsOnlyIcon = false;\n\n    @HostBinding('disabled')\n    protected get isDisabled(): boolean {\n        return this.disabled || this.isLoaderShown;\n    }\n\n    @ViewChild('content')\n    protected content!: ElementRef<HTMLSpanElement>;\n\n    public ngOnInit(): void {\n        this.initIconColor();\n    }\n\n    private initIconColor(): void {\n        this.changeIconColor();\n    }\n\n    private changeIconColor(): void {\n        Promise.resolve().then(() => {\n            this.iconColor = this.getIconColor(this._appearance);\n\n            this.changeDetectorRef.markForCheck();\n        });\n    }\n\n    private getIconColor(appearance: CuiButtonOptions['appearance']): string {\n        if (this.BUTTON_ICONS_COLOR_BASE_500.includes(appearance)) {\n            return this.COLOR_BASE_500;\n        }\n\n        return 'currentColor';\n    }\n}\n","<span\n  class=\"c-wrapper\"\n  [class.c-wrapper_invisible]=\"isLoaderShown\"\n>\n  <cui-svg\n    *ngIf=\"icon\"\n    [icon]=\"icon\"\n    [width]=\"iconDimensions.width\"\n    [height]=\"iconDimensions.height\"\n    [color]=\"iconColor\"\n  ></cui-svg>\n  <span\n    #content\n    class=\"c-content\"\n  ><ng-content></ng-content></span>\n  <cui-svg\n    *ngIf=\"iconRight\"\n    [icon]=\"iconRight\"\n    [width]=\"iconDimensions.width\"\n    [height]=\"iconDimensions.height\"\n    [color]=\"iconColor\"\n  ></cui-svg>\n</span>\n<cui-svg\n  *ngIf=\"isLoaderShown\"\n  icon=\"cuiIconLoading\"\n  [color]=\"iconColor\"\n  class=\"c-loader\"\n></cui-svg>\n"]}
@@ -41,7 +41,15 @@ export class CuiStorageListItemComponent {
41
41
  });
42
42
  }
43
43
  setChildren(storage) {
44
- if (this.isLoadingChildren || !this.areContentOpened() || this.storageChildren().length) {
44
+ const storageChildren = storage.children;
45
+ if (!storageChildren.length) {
46
+ this.storageChildren.set([]);
47
+ }
48
+ if (this.isLoadingChildren || !this.areContentOpened()) {
49
+ return;
50
+ }
51
+ if (typeof storageChildren[0] !== 'string') {
52
+ this.storageChildren.set(storageChildren);
45
53
  return;
46
54
  }
47
55
  this.isLoadingChildren = true;
@@ -51,7 +59,16 @@ export class CuiStorageListItemComponent {
51
59
  .subscribe((response) => this.storageChildren.set(response));
52
60
  }
53
61
  setElements(storage) {
54
- if (this.isLoadingElements || this.storageElements().length) {
62
+ const storageElements = storage.elements;
63
+ if (this.isLoadingElements) {
64
+ return;
65
+ }
66
+ if (!storageElements?.length) {
67
+ this.storageElements.set([]);
68
+ return;
69
+ }
70
+ if (this.storageElements.length) {
71
+ this.storageElements.set(storageElements);
55
72
  return;
56
73
  }
57
74
  this.isLoadingElements = true;
@@ -67,4 +84,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
67
84
  type: Component,
68
85
  args: [{ selector: 'li[cuiStorageListItem]', imports: [CuiLetDirective, CuiSvgModule, NgTemplateOutlet, forwardRef(() => CuiStorageListComponent)], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *cuiLet=\"storage() as storage\">\n <div class=\"wrapper\">\n <ng-template #openCloseButton>\n @if (hasContent()) {\n <button\n type=\"button\"\n class=\"button\"\n (click)=\"onToggleChildren($event)\"\n >\n <cui-svg\n [icon]=\"openCloseButtonIcon()\"\n color=\"var(--cui-base-500)\"\n />\n </button>\n }\n </ng-template>\n\n @if (itemSlot(); as item) {\n <ng-container\n *ngTemplateOutlet=\"\n item;\n context: {\n $implicit: storage,\n openCloseButton,\n areContentOpened: areContentOpened(),\n hasContent: hasContent()\n }\n \"\n />\n }\n\n <div\n class=\"content\"\n [class.content_hidden]=\"!areContentOpened()\"\n >\n <div class=\"lists\">\n @if (storageChildren().length) {\n <cui-storage-list\n [storages]=\"storageChildren()\"\n [elementSlot]=\"elementSlot()\"\n [itemSlot]=\"itemSlot()\"\n />\n }\n @if (storageElements().length && elementSlot()) {\n <ul class=\"list\">\n @for (element of storageElements(); track element.id) {\n <li class=\"item\">\n <ng-container\n *ngTemplateOutlet=\"\n elementSlot()!;\n context: { $implicit: element, storage: storage }\n \"\n />\n </li>\n }\n </ul>\n }\n </div>\n </div>\n </div>\n</ng-container>\n", styles: [".button{padding:2px;display:flex;border-radius:4px}@media (hover: hover){.button:hover{background:var(--cui-base-200)}}.button :active{background:var(--cui-base-200)}.icon{padding:2px}.wrapper{display:flex;flex-direction:column;gap:8px}.content{padding-left:20px}.content_hidden{display:none}.lists{display:flex;flex-direction:column;gap:8px;position:relative}.lists>*{z-index:1}.lists:has(>:nth-child(2)):before{content:\"\";position:absolute;top:0;bottom:0;left:8px;width:1px;background:var(--cui-base-200)}.list{display:flex;flex-direction:column;gap:8px}.item{position:relative}.item:not(:last-child):before{content:\"\";position:absolute;top:0;left:8px;bottom:-8px;z-index:-1;width:1px;background:var(--cui-base-200)}\n"] }]
69
86
  }], ctorParameters: () => [] });
70
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"storage-list-item.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/widgets/storage-list/components/storage-list-item/storage-list-item.component.ts","../../../../../../../projects/core/widgets/storage-list/components/storage-list-item/storage-list-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport type { TemplateRef } from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    effect,\n    forwardRef,\n    inject,\n    input,\n    signal,\n    untracked\n} from '@angular/core';\nimport { CuiLetDirective } from '@cuby-ui/cdk';\nimport type { CuiIcon } from '@cuby-ui/icons';\nimport { finalize } from 'rxjs';\n\nimport { CuiSvgModule } from '../../../../components/svg';\nimport { CuiStorageListComponent } from '../..';\nimport type { CuiStorage, CuiStorageBase } from '../../storage-list.options';\nimport { CUI_STORAGE_LIST_SERVICE_TOKEN } from '../../storage-list.options';\n\n@Component({\n    selector: 'li[cuiStorageListItem]',\n    imports: [CuiLetDirective, CuiSvgModule, NgTemplateOutlet, forwardRef(() => CuiStorageListComponent)],\n    templateUrl: './storage-list-item.component.html',\n    styleUrl: './storage-list-item.component.scss',\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiStorageListItemComponent<T = CuiStorageBase> {\n    private readonly storageListService = inject(CUI_STORAGE_LIST_SERVICE_TOKEN);\n\n    private isLoadingChildren = false;\n    private isLoadingElements = false;\n\n    protected readonly storageChildren = signal<CuiStorage[]>([]);\n    protected readonly storageElements = signal<CuiStorageBase[]>([]);\n    protected readonly areContentOpened = signal(false);\n    protected readonly openCloseButtonIcon = computed<CuiIcon>(() =>\n        this.areContentOpened() ? 'cuiIconChevronDown' : 'cuiIconChevronRight'\n    );\n    protected readonly hasContent = computed(\n        () => this.storage().children.length || this.storageChildren().length || this.storageElements().length\n    );\n\n    public readonly storage = input.required<CuiStorage<T>>();\n    public readonly elementSlot = input<TemplateRef<unknown>>();\n    public readonly itemSlot = input<TemplateRef<unknown>>();\n\n    constructor() {\n        this.initStorageChildrenEffect();\n        this.initStorageElementsEffect();\n    }\n\n    protected onToggleChildren(event: MouseEvent): void {\n        event.preventDefault();\n\n        this.areContentOpened.update((prevAreChildrenOpened) => !prevAreChildrenOpened);\n    }\n\n    private initStorageChildrenEffect(): void {\n        effect(() => {\n            const storage = this.storage() as CuiStorage<CuiStorageBase>;\n\n            this.areContentOpened();\n            untracked(this.setChildren.bind(this, storage));\n        });\n    }\n\n    private initStorageElementsEffect(): void {\n        effect(() => {\n            const storage = this.storage() as CuiStorage<CuiStorageBase>;\n\n            untracked(this.setElements.bind(this, storage));\n        });\n    }\n\n    private setChildren(storage: CuiStorage<CuiStorageBase>): void {\n        if (this.isLoadingChildren || !this.areContentOpened() || this.storageChildren().length) {\n            return;\n        }\n\n        this.isLoadingChildren = true;\n        this.storageListService\n            .getChildren?.(storage, this.storageChildren())\n            .pipe(finalize(() => (this.isLoadingChildren = false)))\n            .subscribe((response) => this.storageChildren.set(response));\n    }\n\n    private setElements(storage: CuiStorage<CuiStorageBase>): void {\n        if (this.isLoadingElements || this.storageElements().length) {\n            return;\n        }\n\n        this.isLoadingElements = true;\n        this.storageListService\n            .getElements?.(storage, this.storageElements())\n            .pipe(finalize(() => (this.isLoadingElements = false)))\n            .subscribe((response) => this.storageElements.set(response));\n    }\n}\n","<ng-container *cuiLet=\"storage() as storage\">\n    <div class=\"wrapper\">\n        <ng-template #openCloseButton>\n            @if (hasContent()) {\n                <button\n                    type=\"button\"\n                    class=\"button\"\n                    (click)=\"onToggleChildren($event)\"\n                >\n                    <cui-svg\n                        [icon]=\"openCloseButtonIcon()\"\n                        color=\"var(--cui-base-500)\"\n                    />\n                </button>\n            }\n        </ng-template>\n\n        @if (itemSlot(); as item) {\n            <ng-container\n                *ngTemplateOutlet=\"\n                    item;\n                    context: {\n                        $implicit: storage,\n                        openCloseButton,\n                        areContentOpened: areContentOpened(),\n                        hasContent: hasContent()\n                    }\n                \"\n            />\n        }\n\n        <div\n            class=\"content\"\n            [class.content_hidden]=\"!areContentOpened()\"\n        >\n            <div class=\"lists\">\n                @if (storageChildren().length) {\n                    <cui-storage-list\n                        [storages]=\"storageChildren()\"\n                        [elementSlot]=\"elementSlot()\"\n                        [itemSlot]=\"itemSlot()\"\n                    />\n                }\n                @if (storageElements().length && elementSlot()) {\n                    <ul class=\"list\">\n                        @for (element of storageElements(); track element.id) {\n                            <li class=\"item\">\n                                <ng-container\n                                    *ngTemplateOutlet=\"\n                                        elementSlot()!;\n                                        context: { $implicit: element, storage: storage }\n                                    \"\n                                />\n                            </li>\n                        }\n                    </ul>\n                }\n            </div>\n        </div>\n    </div>\n</ng-container>\n"]}
87
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"storage-list-item.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/widgets/storage-list/components/storage-list-item/storage-list-item.component.ts","../../../../../../../projects/core/widgets/storage-list/components/storage-list-item/storage-list-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport type { TemplateRef } from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    effect,\n    forwardRef,\n    inject,\n    input,\n    signal,\n    untracked\n} from '@angular/core';\nimport { CuiLetDirective } from '@cuby-ui/cdk';\nimport type { CuiIcon } from '@cuby-ui/icons';\nimport { finalize } from 'rxjs';\n\nimport { CuiSvgModule } from '../../../../components/svg';\nimport { CuiStorageListComponent } from '../..';\nimport type { CuiStorage, CuiStorageBase } from '../../storage-list.options';\nimport { CUI_STORAGE_LIST_SERVICE_TOKEN } from '../../storage-list.options';\n\n@Component({\n    selector: 'li[cuiStorageListItem]',\n    imports: [CuiLetDirective, CuiSvgModule, NgTemplateOutlet, forwardRef(() => CuiStorageListComponent)],\n    templateUrl: './storage-list-item.component.html',\n    styleUrl: './storage-list-item.component.scss',\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiStorageListItemComponent<T = CuiStorageBase> {\n    private readonly storageListService = inject(CUI_STORAGE_LIST_SERVICE_TOKEN);\n\n    private isLoadingChildren = false;\n    private isLoadingElements = false;\n\n    protected readonly storageChildren = signal<CuiStorage[]>([]);\n    protected readonly storageElements = signal<CuiStorageBase[]>([]);\n    protected readonly areContentOpened = signal(false);\n    protected readonly openCloseButtonIcon = computed<CuiIcon>(() =>\n        this.areContentOpened() ? 'cuiIconChevronDown' : 'cuiIconChevronRight'\n    );\n    protected readonly hasContent = computed(\n        () => this.storage().children.length || this.storageChildren().length || this.storageElements().length\n    );\n\n    public readonly storage = input.required<CuiStorage<T>>();\n    public readonly elementSlot = input<TemplateRef<unknown>>();\n    public readonly itemSlot = input<TemplateRef<unknown>>();\n\n    constructor() {\n        this.initStorageChildrenEffect();\n        this.initStorageElementsEffect();\n    }\n\n    protected onToggleChildren(event: MouseEvent): void {\n        event.preventDefault();\n\n        this.areContentOpened.update((prevAreChildrenOpened) => !prevAreChildrenOpened);\n    }\n\n    private initStorageChildrenEffect(): void {\n        effect(() => {\n            const storage = this.storage() as CuiStorage<CuiStorageBase>;\n\n            this.areContentOpened();\n            untracked(this.setChildren.bind(this, storage));\n        });\n    }\n\n    private initStorageElementsEffect(): void {\n        effect(() => {\n            const storage = this.storage() as CuiStorage<CuiStorageBase>;\n\n            untracked(this.setElements.bind(this, storage));\n        });\n    }\n\n    private setChildren(storage: CuiStorage<CuiStorageBase>): void {\n        const storageChildren = storage.children;\n\n        if (!storageChildren.length) {\n            this.storageChildren.set([]);\n        }\n\n        if (this.isLoadingChildren || !this.areContentOpened()) {\n            return;\n        }\n\n        if (typeof storageChildren[0] !== 'string') {\n            this.storageChildren.set(storageChildren as CuiStorage[]);\n\n            return;\n        }\n\n        this.isLoadingChildren = true;\n        this.storageListService\n            .getChildren?.(storage, this.storageChildren())\n            .pipe(finalize(() => (this.isLoadingChildren = false)))\n            .subscribe((response) => this.storageChildren.set(response));\n    }\n\n    private setElements(storage: CuiStorage<CuiStorageBase>): void {\n        const storageElements = storage.elements;\n\n        if (this.isLoadingElements) {\n            return;\n        }\n\n        if (!storageElements?.length) {\n            this.storageElements.set([]);\n\n            return;\n        }\n\n        if (this.storageElements.length) {\n            this.storageElements.set(storageElements);\n\n            return;\n        }\n\n        this.isLoadingElements = true;\n        this.storageListService\n            .getElements?.(storage, this.storageElements())\n            .pipe(finalize(() => (this.isLoadingElements = false)))\n            .subscribe((response) => this.storageElements.set(response));\n    }\n}\n","<ng-container *cuiLet=\"storage() as storage\">\n    <div class=\"wrapper\">\n        <ng-template #openCloseButton>\n            @if (hasContent()) {\n                <button\n                    type=\"button\"\n                    class=\"button\"\n                    (click)=\"onToggleChildren($event)\"\n                >\n                    <cui-svg\n                        [icon]=\"openCloseButtonIcon()\"\n                        color=\"var(--cui-base-500)\"\n                    />\n                </button>\n            }\n        </ng-template>\n\n        @if (itemSlot(); as item) {\n            <ng-container\n                *ngTemplateOutlet=\"\n                    item;\n                    context: {\n                        $implicit: storage,\n                        openCloseButton,\n                        areContentOpened: areContentOpened(),\n                        hasContent: hasContent()\n                    }\n                \"\n            />\n        }\n\n        <div\n            class=\"content\"\n            [class.content_hidden]=\"!areContentOpened()\"\n        >\n            <div class=\"lists\">\n                @if (storageChildren().length) {\n                    <cui-storage-list\n                        [storages]=\"storageChildren()\"\n                        [elementSlot]=\"elementSlot()\"\n                        [itemSlot]=\"itemSlot()\"\n                    />\n                }\n                @if (storageElements().length && elementSlot()) {\n                    <ul class=\"list\">\n                        @for (element of storageElements(); track element.id) {\n                            <li class=\"item\">\n                                <ng-container\n                                    *ngTemplateOutlet=\"\n                                        elementSlot()!;\n                                        context: { $implicit: element, storage: storage }\n                                    \"\n                                />\n                            </li>\n                        }\n                    </ul>\n                }\n            </div>\n        </div>\n    </div>\n</ng-container>\n"]}
@@ -177,6 +177,7 @@ class CuiButtonComponent {
177
177
  }
178
178
  set appearance(appearance) {
179
179
  this._appearance = appearance;
180
+ this.changeIconColor();
180
181
  }
181
182
  get theme() {
182
183
  return this._theme;
@@ -10264,7 +10265,15 @@ class CuiStorageListItemComponent {
10264
10265
  });
10265
10266
  }
10266
10267
  setChildren(storage) {
10267
- if (this.isLoadingChildren || !this.areContentOpened() || this.storageChildren().length) {
10268
+ const storageChildren = storage.children;
10269
+ if (!storageChildren.length) {
10270
+ this.storageChildren.set([]);
10271
+ }
10272
+ if (this.isLoadingChildren || !this.areContentOpened()) {
10273
+ return;
10274
+ }
10275
+ if (typeof storageChildren[0] !== 'string') {
10276
+ this.storageChildren.set(storageChildren);
10268
10277
  return;
10269
10278
  }
10270
10279
  this.isLoadingChildren = true;
@@ -10274,7 +10283,16 @@ class CuiStorageListItemComponent {
10274
10283
  .subscribe((response) => this.storageChildren.set(response));
10275
10284
  }
10276
10285
  setElements(storage) {
10277
- if (this.isLoadingElements || this.storageElements().length) {
10286
+ const storageElements = storage.elements;
10287
+ if (this.isLoadingElements) {
10288
+ return;
10289
+ }
10290
+ if (!storageElements?.length) {
10291
+ this.storageElements.set([]);
10292
+ return;
10293
+ }
10294
+ if (this.storageElements.length) {
10295
+ this.storageElements.set(storageElements);
10278
10296
  return;
10279
10297
  }
10280
10298
  this.isLoadingElements = true;