@cuby-ui/core 0.0.466 → 0.0.468

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.
@@ -1,4 +1,9 @@
1
1
  export interface CuiFileResponseData {
2
+ readonly id: string;
3
+ readonly downloadUrl: string;
4
+ }
5
+ export interface CuiResourceFile {
6
+ readonly id: string;
2
7
  readonly success: number;
3
8
  readonly file: CuiFileData;
4
9
  }
@@ -1,6 +1,6 @@
1
1
  import type { API, BlockAPI, PasteConfig, ToolboxConfig } from '@editorjs/editorjs';
2
2
  import type { CuiAngularElement } from '../interfaces';
3
- import type { CuiVideoToolConfig, EditorVideoToolComponent, CuiVideoToolData } from '../components/editor-video-tool';
3
+ import type { CuiVideoToolConfig, CuiVideoToolData, EditorVideoToolComponent } from '../components/editor-video-tool';
4
4
  import type { CuiFileData } from '../interfaces/file-response-data';
5
5
  import { CuiFileUploader } from '../utils/file-uploader';
6
6
  export declare class CuiVideoTool {
@@ -1,4 +1,4 @@
1
- import type { CuiFileResponseData } from '../interfaces';
1
+ import type { CuiResourceFile } from '../interfaces';
2
2
  export declare enum CuiFileUploaderStatus {
3
3
  Loading = "loading",
4
4
  Completed = "completed"
@@ -10,7 +10,7 @@ export interface CuiFileUploaderConfig {
10
10
  readonly additionalRequestHeaders: HeadersInit;
11
11
  readonly load: (status: CuiFileUploaderStatus) => void;
12
12
  }
13
- export type OnUpload = (response: CuiFileResponseData, file?: File) => void;
13
+ export type OnUpload = (response: CuiResourceFile, file?: File) => void;
14
14
  export declare class CuiFileUploader {
15
15
  private readonly REQUEST_METHOD;
16
16
  private readonly config;
@@ -23,4 +23,5 @@ export declare class CuiFileUploader {
23
23
  getFile(files: FileList, fileSelected: (file: File) => void): void;
24
24
  uploadFile(file: File): void;
25
25
  uploadByUrl(url: string): void;
26
+ private convertToFileSuccessResponse;
26
27
  }
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1yZXNwb25zZS1kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9lZGl0b3IvaW50ZXJmYWNlcy9maWxlLXJlc3BvbnNlLWRhdGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQ3VpRmlsZVJlc3BvbnNlRGF0YSB7XHJcbiAgICByZWFkb25seSBzdWNjZXNzOiBudW1iZXI7XHJcbiAgICByZWFkb25seSBmaWxlOiBDdWlGaWxlRGF0YTtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBDdWlGaWxlRGF0YSB7XHJcbiAgICByZWFkb25seSB1cmw6IHN0cmluZztcclxuICAgIHJlYWRvbmx5IHNpemU/OiBudW1iZXI7XHJcbiAgICByZWFkb25seSBuYW1lPzogc3RyaW5nO1xyXG4gICAgcmVhZG9ubHkgZXh0ZW5zaW9uPzogc3RyaW5nO1xyXG59XHJcbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1yZXNwb25zZS1kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9lZGl0b3IvaW50ZXJmYWNlcy9maWxlLXJlc3BvbnNlLWRhdGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQ3VpRmlsZVJlc3BvbnNlRGF0YSB7XHJcbiAgICByZWFkb25seSBpZDogc3RyaW5nO1xyXG4gICAgcmVhZG9ubHkgZG93bmxvYWRVcmw6IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBDdWlSZXNvdXJjZUZpbGUge1xyXG4gICAgcmVhZG9ubHkgaWQ6IHN0cmluZztcclxuICAgIHJlYWRvbmx5IHN1Y2Nlc3M6IG51bWJlcjtcclxuICAgIHJlYWRvbmx5IGZpbGU6IEN1aUZpbGVEYXRhO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEN1aUZpbGVEYXRhIHtcclxuICAgIHJlYWRvbmx5IHVybDogc3RyaW5nO1xyXG4gICAgcmVhZG9ubHkgc2l6ZT86IG51bWJlcjtcclxuICAgIHJlYWRvbmx5IG5hbWU/OiBzdHJpbmc7XHJcbiAgICByZWFkb25seSBleHRlbnNpb24/OiBzdHJpbmc7XHJcbn1cclxuIl19
@@ -99,4 +99,4 @@ export class CuiAttachesTool {
99
99
  this.attachesTool.isLoading = false;
100
100
  }
101
101
  }
102
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attaches.tool.js","sourceRoot":"","sources":["../../../../../projects/core/editor/tools/attaches.tool.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CuiNullable } from '@cuby-ui/cdk';\r\nimport { CUI_ICONS } from '@cuby-ui/icons';\r\nimport type { API, BlockAPI, BlockToolConstructorOptions, ToolboxConfig } from '@editorjs/editorjs';\r\n\r\nimport type { CuiAngularElement, CuiFileData, CuiFileResponseData } from '../interfaces';\r\n\r\nimport type { EditorAttachesToolComponent } from '../components/editor-attaches-tool/editor-attaches-tool.component';\r\nimport type {\r\n    CuiAttachesToolConfig,\r\n    CuiAttachesToolData\r\n} from '../components/editor-attaches-tool/editor-attaches-tool.options';\r\nimport { EDITOR_ATTACHES_TOOL_SELECTOR } from '../components/editor-attaches-tool/editor-attaches-tool.options';\r\nimport { CuiFileUploader } from '../utils/file-uploader';\r\n\r\nexport class CuiAttachesTool {\r\n    private readonly abortController = new AbortController();\r\n    private readonly abortSignal = this.abortController.signal;\r\n\r\n    private attachesTool!: CuiAngularElement<EditorAttachesToolComponent>;\r\n    private selectedFile: CuiNullable<File> = null;\r\n\r\n    public api: API;\r\n    public config: CuiAttachesToolConfig;\r\n    public blockApi?: BlockAPI;\r\n    public readOnly: boolean;\r\n    public data: CuiAttachesToolData;\r\n    public uploader: CuiFileUploader;\r\n\r\n    public static get isReadOnlySupported(): boolean {\r\n        return true;\r\n    }\r\n\r\n    public static get toolbox(): ToolboxConfig {\r\n        return {\r\n            icon: CUI_ICONS.cuiIconPaperclipSm,\r\n            title: 'File'\r\n        };\r\n    }\r\n\r\n    constructor(options: { api: API }) {\r\n        const { api, readOnly, config, data, block } = options as BlockToolConstructorOptions<\r\n            CuiAttachesToolData,\r\n            CuiAttachesToolConfig\r\n        >;\r\n\r\n        this.blockApi = block;\r\n        this.api = api;\r\n        this.readOnly = readOnly;\r\n        this.config = {\r\n            field: config?.field ?? 'file',\r\n            types: config?.types ?? '*',\r\n            endpoint: config?.endpoint ?? '',\r\n            buttonContent: config?.buttonContent ?? this.api.i18n.t('Select a File'),\r\n            additionalRequestHeaders: config?.additionalRequestHeaders ?? {},\r\n            load: config?.load ?? (() => {}),\r\n            fileClicked: config?.fileClicked ?? (() => {})\r\n        };\r\n\r\n        this.uploader = new CuiFileUploader(this.config, this.onUpload.bind(this), this.uploadingFailed.bind(this));\r\n        this.data = data;\r\n    }\r\n\r\n    public appendCallback(): void {\r\n        this.selectFile();\r\n    }\r\n\r\n    public render(): HTMLElement {\r\n        this.attachesTool = document.createElement(\r\n            EDITOR_ATTACHES_TOOL_SELECTOR\r\n        ) as CuiAngularElement<EditorAttachesToolComponent>;\r\n\r\n        this.attachesTool.api = this.api;\r\n        this.attachesTool.file = this.data.file ?? '';\r\n        this.attachesTool.title = this.data.title ?? '';\r\n        this.attachesTool.readOnly = this.readOnly;\r\n        this.attachesTool.buttonContent = this.config.buttonContent;\r\n\r\n        this.attachesTool.addEventListener('fileSelected', this.selectFile, { signal: this.abortSignal });\r\n        this.attachesTool.addEventListener('fileClicked', this.clickFile, { signal: this.abortSignal });\r\n        this.attachesTool.addEventListener('captionChanged', this.changeCaption, { signal: this.abortSignal });\r\n\r\n        return this.attachesTool;\r\n    }\r\n\r\n    public save(): CuiAttachesToolData {\r\n        return this.data;\r\n    }\r\n\r\n    public removed(): void {\r\n        this.abortController.abort();\r\n    }\r\n\r\n    public changeCaption = (event: Event): void => {\r\n        const customEvent = event as CustomEvent;\r\n        const value = customEvent.detail;\r\n        this.data.title = value;\r\n\r\n        this.blockApi?.dispatchChange();\r\n    };\r\n\r\n    public selectFile = (): void => {\r\n        return this.uploader.selectFile({\r\n            fileSelected: (file) => {\r\n                this.attachesTool.isLoading = true;\r\n                this.selectedFile = file;\r\n\r\n                this.uploader.uploadFile(file);\r\n            }\r\n        });\r\n    };\r\n\r\n    public clickFile = (): void => {\r\n        this.config.fileClicked(this.data.file);\r\n    };\r\n\r\n    public set file(file: CuiFileData) {\r\n        this.data.title = file.name!;\r\n        this.data.file = {\r\n            name: file.name,\r\n            extension: file.name?.split('.').pop(),\r\n            size: file.size,\r\n            url: file.url\r\n        };\r\n        this.attachesTool.file = { ...this.data.file };\r\n        this.attachesTool.title = file.name!;\r\n    }\r\n\r\n    private onUpload(response: CuiFileResponseData): void {\r\n        if (!response.success || !response.file || !this.selectedFile) {\r\n            this.uploadingFailed();\r\n\r\n            return;\r\n        }\r\n\r\n        this.file = {\r\n            name: this.selectedFile.name,\r\n            extension: this.selectedFile.name.split('.').pop(),\r\n            size: this.selectedFile.size,\r\n            url: response.file.url\r\n        };\r\n        this.attachesTool.isLoading = false;\r\n    }\r\n\r\n    private uploadingFailed(): void {\r\n        this.attachesTool.file = undefined;\r\n        this.attachesTool.isLoading = false;\r\n    }\r\n}\r\n"]}
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attaches.tool.js","sourceRoot":"","sources":["../../../../../projects/core/editor/tools/attaches.tool.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CuiNullable } from '@cuby-ui/cdk';\r\nimport { CUI_ICONS } from '@cuby-ui/icons';\r\nimport type { API, BlockAPI, BlockToolConstructorOptions, ToolboxConfig } from '@editorjs/editorjs';\r\n\r\nimport type { CuiAngularElement, CuiFileData, CuiResourceFile } from '../interfaces';\r\n\r\nimport type { EditorAttachesToolComponent } from '../components/editor-attaches-tool/editor-attaches-tool.component';\r\nimport type {\r\n    CuiAttachesToolConfig,\r\n    CuiAttachesToolData\r\n} from '../components/editor-attaches-tool/editor-attaches-tool.options';\r\nimport { EDITOR_ATTACHES_TOOL_SELECTOR } from '../components/editor-attaches-tool/editor-attaches-tool.options';\r\nimport { CuiFileUploader } from '../utils/file-uploader';\r\n\r\nexport class CuiAttachesTool {\r\n    private readonly abortController = new AbortController();\r\n    private readonly abortSignal = this.abortController.signal;\r\n\r\n    private attachesTool!: CuiAngularElement<EditorAttachesToolComponent>;\r\n    private selectedFile: CuiNullable<File> = null;\r\n\r\n    public api: API;\r\n    public config: CuiAttachesToolConfig;\r\n    public blockApi?: BlockAPI;\r\n    public readOnly: boolean;\r\n    public data: CuiAttachesToolData;\r\n    public uploader: CuiFileUploader;\r\n\r\n    public static get isReadOnlySupported(): boolean {\r\n        return true;\r\n    }\r\n\r\n    public static get toolbox(): ToolboxConfig {\r\n        return {\r\n            icon: CUI_ICONS.cuiIconPaperclipSm,\r\n            title: 'File'\r\n        };\r\n    }\r\n\r\n    constructor(options: { api: API }) {\r\n        const { api, readOnly, config, data, block } = options as BlockToolConstructorOptions<\r\n            CuiAttachesToolData,\r\n            CuiAttachesToolConfig\r\n        >;\r\n\r\n        this.blockApi = block;\r\n        this.api = api;\r\n        this.readOnly = readOnly;\r\n        this.config = {\r\n            field: config?.field ?? 'file',\r\n            types: config?.types ?? '*',\r\n            endpoint: config?.endpoint ?? '',\r\n            buttonContent: config?.buttonContent ?? this.api.i18n.t('Select a File'),\r\n            additionalRequestHeaders: config?.additionalRequestHeaders ?? {},\r\n            load: config?.load ?? (() => { }),\r\n            fileClicked: config?.fileClicked ?? (() => { })\r\n        };\r\n\r\n        this.uploader = new CuiFileUploader(this.config, this.onUpload.bind(this), this.uploadingFailed.bind(this));\r\n        this.data = data;\r\n    }\r\n\r\n    public appendCallback(): void {\r\n        this.selectFile();\r\n    }\r\n\r\n    public render(): HTMLElement {\r\n        this.attachesTool = document.createElement(\r\n            EDITOR_ATTACHES_TOOL_SELECTOR\r\n        ) as CuiAngularElement<EditorAttachesToolComponent>;\r\n\r\n        this.attachesTool.api = this.api;\r\n        this.attachesTool.file = this.data.file ?? '';\r\n        this.attachesTool.title = this.data.title ?? '';\r\n        this.attachesTool.readOnly = this.readOnly;\r\n        this.attachesTool.buttonContent = this.config.buttonContent;\r\n\r\n        this.attachesTool.addEventListener('fileSelected', this.selectFile, { signal: this.abortSignal });\r\n        this.attachesTool.addEventListener('fileClicked', this.clickFile, { signal: this.abortSignal });\r\n        this.attachesTool.addEventListener('captionChanged', this.changeCaption, { signal: this.abortSignal });\r\n\r\n        return this.attachesTool;\r\n    }\r\n\r\n    public save(): CuiAttachesToolData {\r\n        return this.data;\r\n    }\r\n\r\n    public removed(): void {\r\n        this.abortController.abort();\r\n    }\r\n\r\n    public changeCaption = (event: Event): void => {\r\n        const customEvent = event as CustomEvent;\r\n        const value = customEvent.detail;\r\n        this.data.title = value;\r\n\r\n        this.blockApi?.dispatchChange();\r\n    };\r\n\r\n    public selectFile = (): void => {\r\n        return this.uploader.selectFile({\r\n            fileSelected: (file) => {\r\n                this.attachesTool.isLoading = true;\r\n                this.selectedFile = file;\r\n\r\n                this.uploader.uploadFile(file);\r\n            }\r\n        });\r\n    };\r\n\r\n    public clickFile = (): void => {\r\n        this.config.fileClicked(this.data.file);\r\n    };\r\n\r\n    public set file(file: CuiFileData) {\r\n        this.data.title = file.name!;\r\n        this.data.file = {\r\n            name: file.name,\r\n            extension: file.name?.split('.').pop(),\r\n            size: file.size,\r\n            url: file.url\r\n        };\r\n        this.attachesTool.file = { ...this.data.file };\r\n        this.attachesTool.title = file.name!;\r\n    }\r\n\r\n    private onUpload(response: CuiResourceFile): void {\r\n        if (!response.success || !response.file || !this.selectedFile) {\r\n            this.uploadingFailed();\r\n\r\n            return;\r\n        }\r\n\r\n        this.file = {\r\n            name: this.selectedFile.name,\r\n            extension: this.selectedFile.name.split('.').pop(),\r\n            size: this.selectedFile.size,\r\n            url: response.file.url\r\n        };\r\n        this.attachesTool.isLoading = false;\r\n    }\r\n\r\n    private uploadingFailed(): void {\r\n        this.attachesTool.file = undefined;\r\n        this.attachesTool.isLoading = false;\r\n    }\r\n}\r\n"]}
@@ -154,4 +154,4 @@ export class CuiImageTool {
154
154
  this.imageTool.tunes = { ...this.data.tunes };
155
155
  }
156
156
  }
157
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.tool.js","sourceRoot":"","sources":["../../../../../projects/core/editor/tools/image.tool.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CuiNullable } from '@cuby-ui/cdk';\r\nimport type { API, BlockAPI, BlockToolConstructorOptions, PasteConfig, ToolboxConfig } from '@editorjs/editorjs';\r\nimport type { TunesMenuConfig } from '@editorjs/editorjs/types/tools';\r\n\r\nimport { CuiFileUploader } from '../utils';\r\nimport { EditorImageToolComponent, EDITOR_IMAGE_TOOL_SELECTOR } from '../components/editor-image-tool';\r\nimport type { CuiImageToolConfig, CuiImageToolData, CuiImageTunes } from '../components/editor-image-tool';\r\nimport type { CuiFileData, CuiFileResponseData, CuiTune, CuiAngularElement } from '../interfaces';\r\n\r\nexport class CuiImageTool {\r\n    private selectedFile: CuiNullable<string | File> = null;\r\n    private get Tunes(): CuiTune[] {\r\n        return [\r\n            {\r\n                name: 'stretched',\r\n                title: 'Stretch image',\r\n                toggle: true\r\n            },\r\n            {\r\n                name: 'center',\r\n                title: 'Center image',\r\n                toggle: true\r\n            }\r\n        ];\r\n    }\r\n\r\n    public api: API;\r\n    public data: CuiImageToolData;\r\n    public config: CuiImageToolConfig;\r\n    public blockApi?: BlockAPI;\r\n    public readOnly: boolean;\r\n    public uploader: CuiFileUploader;\r\n    public imageTool!: CuiAngularElement<EditorImageToolComponent>;\r\n\r\n    public static get isReadOnlySupported(): boolean {\r\n        return true;\r\n    }\r\n\r\n    public static get toolbox(): ToolboxConfig {\r\n        return {\r\n            /* eslint-disable */\r\n            icon: `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n                <path d=\"M12.5013 4.1665H7.5013C5.66035 4.1665 4.16797 5.65889 4.16797 7.49984V12.4998C4.16797 14.3408 5.66035 15.8332 7.5013 15.8332H12.5013C14.3423 15.8332 15.8346 14.3408 15.8346 12.4998V7.49984C15.8346 5.65889 14.3423 4.1665 12.5013 4.1665Z\" stroke=\"#121315\" stroke-width=\"1.66667\"/>\r\n                <path d=\"M4.28125 12.7665L7.24033 9.63825C7.52263 9.33617 7.90546 9.1665 8.30463 9.1665C8.70377 9.1665 9.0866 9.33617 9.36893 9.63825L12.8208 13.3332M11.3154 11.7218L12.5092 10.444C12.7914 10.1419 13.1743 9.97217 13.5734 9.97217C13.9726 9.97217 14.3554 10.1419 14.6378 10.444L15.699 11.636\" stroke=\"#121315\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                <path d=\"M11.4805 7.77783H11.4879\" stroke=\"#121315\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n            </svg>`,\r\n            /* eslint-enable */\r\n            title: 'Image'\r\n        };\r\n    }\r\n\r\n    public static get pasteConfig(): PasteConfig {\r\n        return {\r\n            tags: [\r\n                {\r\n                    img: { src: true }\r\n                }\r\n            ],\r\n            files: {\r\n                mimeTypes: ['image/*']\r\n            }\r\n        };\r\n    }\r\n\r\n    constructor(options: { api: API }) {\r\n        const { api, readOnly, config, data, block } = options as BlockToolConstructorOptions<\r\n            CuiImageToolData,\r\n            Partial<CuiImageToolConfig>\r\n        >;\r\n\r\n        this.blockApi = block;\r\n        this.api = api;\r\n        this.readOnly = readOnly;\r\n        this.config = {\r\n            load: config?.load ?? (() => {}),\r\n            field: config?.field ?? 'image',\r\n            types: config?.types ?? 'image/*',\r\n            endpoint: config?.endpoint ?? '',\r\n            buttonContent: config?.buttonContent ?? this.api.i18n.t('Select an Image'),\r\n            additionalRequestHeaders: config?.additionalRequestHeaders || {}\r\n        };\r\n\r\n        this.uploader = new CuiFileUploader(this.config, this.onUpload.bind(this), this.uploadingFailed.bind(this));\r\n        this.data = data;\r\n        this.data.tunes = this.data.tunes || {};\r\n    }\r\n\r\n    public onSelectFile = (): void => {\r\n        return this.uploader.selectFile({\r\n            fileSelected: (file) => {\r\n                const url = URL.createObjectURL(file);\r\n\r\n                this.imageTool.preview = url;\r\n                this.imageTool.isLoading = true;\r\n                this.selectedFile = file;\r\n\r\n                this.uploader.uploadFile(file);\r\n            }\r\n        });\r\n    };\r\n\r\n    public async onPaste(event: CustomEvent): Promise<void> {\r\n        const actions = {\r\n            tag: this.pasteByTag.bind(this),\r\n            file: this.pasteByFile.bind(this)\r\n        };\r\n        const key = event.type as keyof typeof actions;\r\n\r\n        this.imageTool.isLoading = true;\r\n        actions[key](event);\r\n    }\r\n\r\n    private pasteByFile(event: CustomEvent): void {\r\n        const file = event.detail.file;\r\n        this.selectedFile = file;\r\n        this.uploader.uploadFile(file);\r\n    }\r\n\r\n    private pasteByTag(event: CustomEvent): void {\r\n        const file = event.detail.data.src;\r\n\r\n        this.selectedFile = file;\r\n        this.uploader.uploadByUrl(file);\r\n    }\r\n\r\n    public appendCallback(): void {\r\n        this.onSelectFile();\r\n    }\r\n\r\n    public render(): HTMLElement {\r\n        this.imageTool = document.createElement(\r\n            EDITOR_IMAGE_TOOL_SELECTOR\r\n        ) as CuiAngularElement<EditorImageToolComponent>;\r\n\r\n        this.imageTool.api = this.api;\r\n        this.imageTool.image = this.data.file?.url || '';\r\n        this.imageTool.caption = this.data.caption || '';\r\n        this.imageTool.tunes = this.data.tunes;\r\n        this.imageTool.readOnly = this.readOnly;\r\n        this.imageTool.buttonContent = this.config.buttonContent;\r\n\r\n        this.imageTool.addEventListener('fileSelected', this.onSelectFile);\r\n        this.imageTool.addEventListener('captionChanged', this.changeCaption.bind(this));\r\n\r\n        return this.imageTool;\r\n    }\r\n\r\n    public renderSettings(): TunesMenuConfig {\r\n        return this.Tunes.map((tune) => ({\r\n            icon: tune.icon,\r\n            label: this.api.i18n.t(tune.title),\r\n            name: tune.name,\r\n            toggle: tune.toggle,\r\n            isActive: this.data.tunes[tune.name as keyof CuiImageTunes],\r\n            onActivate: (): void => this.tuneToggled(tune.name as keyof CuiImageTunes)\r\n        }));\r\n    }\r\n\r\n    public save(): CuiImageToolData {\r\n        return this.data;\r\n    }\r\n\r\n    public removed(): void {\r\n        this.imageTool.removeEventListener('fileSelected', this.onSelectFile);\r\n        this.imageTool.removeEventListener('captionChanged', this.changeCaption);\r\n    }\r\n\r\n    public changeCaption(event: Event): void {\r\n        const customEvent = event as CustomEvent;\r\n        const value = customEvent.detail;\r\n        this.data.caption = value;\r\n\r\n        this.blockApi?.dispatchChange();\r\n    }\r\n\r\n    public set image(file: CuiFileData) {\r\n        this.data.file = file || {};\r\n\r\n        if (file && file.url) {\r\n            this.imageTool.image = file.url;\r\n        }\r\n    }\r\n\r\n    private onUpload(response: CuiFileResponseData): void {\r\n        if (!response.success || !response.file || !this.selectedFile) {\r\n            this.uploadingFailed();\r\n\r\n            return;\r\n        }\r\n\r\n        const url =\r\n            this.selectedFile instanceof File ? window.URL.createObjectURL(this.selectedFile) : this.selectedFile;\r\n\r\n        this.data.file = response.file;\r\n        this.imageTool.image = url;\r\n        this.imageTool.isLoading = false;\r\n    }\r\n\r\n    private uploadingFailed(): void {\r\n        this.imageTool.image = '';\r\n        this.imageTool.isLoading = false;\r\n    }\r\n\r\n    private tuneToggled(tuneName: keyof CuiImageTunes): void {\r\n        const value = !(this.data.tunes[tuneName] || false);\r\n\r\n        this.data.tunes[tuneName] = value;\r\n        this.imageTool.tunes = { ...this.data.tunes };\r\n    }\r\n}\r\n"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.tool.js","sourceRoot":"","sources":["../../../../../projects/core/editor/tools/image.tool.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CuiNullable } from '@cuby-ui/cdk';\r\nimport type { API, BlockAPI, BlockToolConstructorOptions, PasteConfig, ToolboxConfig } from '@editorjs/editorjs';\r\nimport type { TunesMenuConfig } from '@editorjs/editorjs/types/tools';\r\n\r\nimport { CuiFileUploader } from '../utils';\r\nimport { EditorImageToolComponent, EDITOR_IMAGE_TOOL_SELECTOR } from '../components/editor-image-tool';\r\nimport type { CuiImageToolConfig, CuiImageToolData, CuiImageTunes } from '../components/editor-image-tool';\r\nimport type { CuiFileData, CuiTune, CuiAngularElement, CuiResourceFile } from '../interfaces';\r\n\r\nexport class CuiImageTool {\r\n    private selectedFile: CuiNullable<string | File> = null;\r\n    private get Tunes(): CuiTune[] {\r\n        return [\r\n            {\r\n                name: 'stretched',\r\n                title: 'Stretch image',\r\n                toggle: true\r\n            },\r\n            {\r\n                name: 'center',\r\n                title: 'Center image',\r\n                toggle: true\r\n            }\r\n        ];\r\n    }\r\n\r\n    public api: API;\r\n    public data: CuiImageToolData;\r\n    public config: CuiImageToolConfig;\r\n    public blockApi?: BlockAPI;\r\n    public readOnly: boolean;\r\n    public uploader: CuiFileUploader;\r\n    public imageTool!: CuiAngularElement<EditorImageToolComponent>;\r\n\r\n    public static get isReadOnlySupported(): boolean {\r\n        return true;\r\n    }\r\n\r\n    public static get toolbox(): ToolboxConfig {\r\n        return {\r\n            /* eslint-disable */\r\n            icon: `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n                <path d=\"M12.5013 4.1665H7.5013C5.66035 4.1665 4.16797 5.65889 4.16797 7.49984V12.4998C4.16797 14.3408 5.66035 15.8332 7.5013 15.8332H12.5013C14.3423 15.8332 15.8346 14.3408 15.8346 12.4998V7.49984C15.8346 5.65889 14.3423 4.1665 12.5013 4.1665Z\" stroke=\"#121315\" stroke-width=\"1.66667\"/>\r\n                <path d=\"M4.28125 12.7665L7.24033 9.63825C7.52263 9.33617 7.90546 9.1665 8.30463 9.1665C8.70377 9.1665 9.0866 9.33617 9.36893 9.63825L12.8208 13.3332M11.3154 11.7218L12.5092 10.444C12.7914 10.1419 13.1743 9.97217 13.5734 9.97217C13.9726 9.97217 14.3554 10.1419 14.6378 10.444L15.699 11.636\" stroke=\"#121315\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n                <path d=\"M11.4805 7.77783H11.4879\" stroke=\"#121315\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n            </svg>`,\r\n            /* eslint-enable */\r\n            title: 'Image'\r\n        };\r\n    }\r\n\r\n    public static get pasteConfig(): PasteConfig {\r\n        return {\r\n            tags: [\r\n                {\r\n                    img: { src: true }\r\n                }\r\n            ],\r\n            files: {\r\n                mimeTypes: ['image/*']\r\n            }\r\n        };\r\n    }\r\n\r\n    constructor(options: { api: API }) {\r\n        const { api, readOnly, config, data, block } = options as BlockToolConstructorOptions<\r\n            CuiImageToolData,\r\n            Partial<CuiImageToolConfig>\r\n        >;\r\n\r\n        this.blockApi = block;\r\n        this.api = api;\r\n        this.readOnly = readOnly;\r\n        this.config = {\r\n            load: config?.load ?? (() => { }),\r\n            field: config?.field ?? 'image',\r\n            types: config?.types ?? 'image/*',\r\n            endpoint: config?.endpoint ?? '',\r\n            buttonContent: config?.buttonContent ?? this.api.i18n.t('Select an Image'),\r\n            additionalRequestHeaders: config?.additionalRequestHeaders || {}\r\n        };\r\n\r\n        this.uploader = new CuiFileUploader(this.config, this.onUpload.bind(this), this.uploadingFailed.bind(this));\r\n        this.data = data;\r\n        this.data.tunes = this.data.tunes || {};\r\n    }\r\n\r\n    public onSelectFile = (): void => {\r\n        return this.uploader.selectFile({\r\n            fileSelected: (file) => {\r\n                const url = URL.createObjectURL(file);\r\n\r\n                this.imageTool.preview = url;\r\n                this.imageTool.isLoading = true;\r\n                this.selectedFile = file;\r\n\r\n                this.uploader.uploadFile(file);\r\n            }\r\n        });\r\n    };\r\n\r\n    public async onPaste(event: CustomEvent): Promise<void> {\r\n        const actions = {\r\n            tag: this.pasteByTag.bind(this),\r\n            file: this.pasteByFile.bind(this)\r\n        };\r\n        const key = event.type as keyof typeof actions;\r\n\r\n        this.imageTool.isLoading = true;\r\n        actions[key](event);\r\n    }\r\n\r\n    private pasteByFile(event: CustomEvent): void {\r\n        const file = event.detail.file;\r\n        this.selectedFile = file;\r\n        this.uploader.uploadFile(file);\r\n    }\r\n\r\n    private pasteByTag(event: CustomEvent): void {\r\n        const file = event.detail.data.src;\r\n\r\n        this.selectedFile = file;\r\n        this.uploader.uploadByUrl(file);\r\n    }\r\n\r\n    public appendCallback(): void {\r\n        this.onSelectFile();\r\n    }\r\n\r\n    public render(): HTMLElement {\r\n        this.imageTool = document.createElement(\r\n            EDITOR_IMAGE_TOOL_SELECTOR\r\n        ) as CuiAngularElement<EditorImageToolComponent>;\r\n\r\n        this.imageTool.api = this.api;\r\n        this.imageTool.image = this.data.file?.url || '';\r\n        this.imageTool.caption = this.data.caption || '';\r\n        this.imageTool.tunes = this.data.tunes;\r\n        this.imageTool.readOnly = this.readOnly;\r\n        this.imageTool.buttonContent = this.config.buttonContent;\r\n\r\n        this.imageTool.addEventListener('fileSelected', this.onSelectFile);\r\n        this.imageTool.addEventListener('captionChanged', this.changeCaption.bind(this));\r\n\r\n        return this.imageTool;\r\n    }\r\n\r\n    public renderSettings(): TunesMenuConfig {\r\n        return this.Tunes.map((tune) => ({\r\n            icon: tune.icon,\r\n            label: this.api.i18n.t(tune.title),\r\n            name: tune.name,\r\n            toggle: tune.toggle,\r\n            isActive: this.data.tunes[tune.name as keyof CuiImageTunes],\r\n            onActivate: (): void => this.tuneToggled(tune.name as keyof CuiImageTunes)\r\n        }));\r\n    }\r\n\r\n    public save(): CuiImageToolData {\r\n        return this.data;\r\n    }\r\n\r\n    public removed(): void {\r\n        this.imageTool.removeEventListener('fileSelected', this.onSelectFile);\r\n        this.imageTool.removeEventListener('captionChanged', this.changeCaption);\r\n    }\r\n\r\n    public changeCaption(event: Event): void {\r\n        const customEvent = event as CustomEvent;\r\n        const value = customEvent.detail;\r\n        this.data.caption = value;\r\n\r\n        this.blockApi?.dispatchChange();\r\n    }\r\n\r\n    public set image(file: CuiFileData) {\r\n        this.data.file = file || {};\r\n\r\n        if (file && file.url) {\r\n            this.imageTool.image = file.url;\r\n        }\r\n    }\r\n\r\n    private onUpload(response: CuiResourceFile): void {\r\n        if (!response.success || !response.file || !this.selectedFile) {\r\n            this.uploadingFailed();\r\n\r\n            return;\r\n        }\r\n\r\n        const url =\r\n            this.selectedFile instanceof File ? window.URL.createObjectURL(this.selectedFile) : this.selectedFile;\r\n\r\n        this.data.file = response.file;\r\n        this.imageTool.image = url;\r\n        this.imageTool.isLoading = false;\r\n    }\r\n\r\n    private uploadingFailed(): void {\r\n        this.imageTool.image = '';\r\n        this.imageTool.isLoading = false;\r\n    }\r\n\r\n    private tuneToggled(tuneName: keyof CuiImageTunes): void {\r\n        const value = !(this.data.tunes[tuneName] || false);\r\n\r\n        this.data.tunes[tuneName] = value;\r\n        this.imageTool.tunes = { ...this.data.tunes };\r\n    }\r\n}\r\n"]}
@@ -129,4 +129,4 @@ export class CuiVideoTool {
129
129
  video.load();
130
130
  }
131
131
  }
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"video.tool.js","sourceRoot":"","sources":["../../../../../projects/core/editor/tools/video.tool.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CuiNullable } from '@cuby-ui/cdk';\r\nimport { CUI_ICONS } from '@cuby-ui/icons';\r\nimport type { API, BlockAPI, BlockToolConstructorOptions, PasteConfig, ToolboxConfig } from '@editorjs/editorjs';\r\n\r\nimport type { CuiAngularElement } from '../interfaces';\r\n\r\nimport type { CuiVideoToolConfig, EditorVideoToolComponent, CuiVideoToolData } from '../components/editor-video-tool';\r\nimport { EDITOR_VIDEO_TOOL_SELECTOR } from '../components/editor-video-tool/editor-video-tool.options';\r\nimport type { CuiFileData, CuiFileResponseData } from '../interfaces/file-response-data';\r\nimport { CuiFileUploader } from '../utils/file-uploader';\r\n\r\nexport class CuiVideoTool {\r\n    private selectedFile: CuiNullable<string | File> = null;\r\n\r\n    public static get isReadOnlySupported(): boolean {\r\n        return true;\r\n    }\r\n\r\n    public static get toolbox(): ToolboxConfig {\r\n        return {\r\n            icon: CUI_ICONS.cuiIconPlayCircle,\r\n            title: 'Video'\r\n        };\r\n    }\r\n\r\n    public static get pasteConfig(): PasteConfig {\r\n        return {\r\n            tags: ['video'],\r\n            patterns: {\r\n                video: /https?:\\/\\/\\S+\\.(mp4)$/i\r\n            },\r\n            files: {\r\n                mimeTypes: ['video/*']\r\n            }\r\n        };\r\n    }\r\n\r\n    public api: API;\r\n    public config: CuiVideoToolConfig;\r\n    public blockApi?: BlockAPI;\r\n    public readOnly: boolean;\r\n    public data: CuiVideoToolData;\r\n    public videoTool!: CuiAngularElement<EditorVideoToolComponent>;\r\n    public uploader: CuiFileUploader;\r\n\r\n    constructor(options: { api: API }) {\r\n        const { api, readOnly, config, data, block } = options as BlockToolConstructorOptions<\r\n            CuiVideoToolData,\r\n            CuiVideoToolConfig\r\n        >;\r\n\r\n        this.blockApi = block;\r\n        this.api = api;\r\n        this.readOnly = readOnly;\r\n        this.config = {\r\n            load: config?.load ?? (() => {}),\r\n            field: config?.field ?? 'video',\r\n            types: config?.types ?? 'video/*',\r\n            endpoint: config?.endpoint ?? '',\r\n            buttonContent: config?.buttonContent ?? this.api.i18n.t('Select a Video'),\r\n            additionalRequestHeaders: config?.additionalRequestHeaders ?? {}\r\n        };\r\n\r\n        this.uploader = new CuiFileUploader(this.config, this.onUpload.bind(this), this.uploadingFailed.bind(this));\r\n        this.data = data;\r\n    }\r\n\r\n    public onSelectFile = (): void => {\r\n        return this.uploader.selectFile({\r\n            fileSelected: (file) => {\r\n                const url = URL.createObjectURL(file);\r\n\r\n                this.getCaptureFromVideo(url);\r\n                this.videoTool.isLoading = true;\r\n                this.selectedFile = file;\r\n\r\n                this.uploader.uploadFile(file);\r\n            }\r\n        });\r\n    };\r\n\r\n    public async onPaste(event: CustomEvent): Promise<void> {\r\n        if (event.type !== 'file') {\r\n            return;\r\n        }\r\n\r\n        const file = event.detail.file;\r\n\r\n        this.videoTool.isLoading = true;\r\n        this.selectedFile = file;\r\n        this.uploader.uploadFile(file);\r\n    }\r\n\r\n    public appendCallback(): void {\r\n        this.onSelectFile();\r\n    }\r\n\r\n    public render(): HTMLElement {\r\n        this.videoTool = document.createElement(\r\n            EDITOR_VIDEO_TOOL_SELECTOR\r\n        ) as CuiAngularElement<EditorVideoToolComponent>;\r\n\r\n        this.videoTool.api = this.api;\r\n        this.videoTool.video = this.data.file?.url || '';\r\n        this.videoTool.caption = this.data.caption || '';\r\n        this.videoTool.readOnly = this.readOnly;\r\n        this.videoTool.buttonContent = this.config.buttonContent;\r\n\r\n        this.videoTool.addEventListener('fileSelected', this.onSelectFile);\r\n        this.videoTool.addEventListener('captionChanged', this.changeCaption.bind(this));\r\n\r\n        return this.videoTool;\r\n    }\r\n\r\n    public save(): CuiVideoToolData {\r\n        return this.data;\r\n    }\r\n\r\n    public removed(): void {\r\n        this.videoTool.removeEventListener('fileSelected', this.onSelectFile);\r\n        this.videoTool.removeEventListener('captionChanged', this.changeCaption);\r\n    }\r\n\r\n    public changeCaption(event: Event): void {\r\n        const customEvent = event as CustomEvent;\r\n        const value = customEvent.detail;\r\n        this.data.caption = value;\r\n\r\n        this.blockApi?.dispatchChange();\r\n    }\r\n\r\n    public set video(file: CuiFileData) {\r\n        this.data.file = file || {};\r\n\r\n        if (file && file.url) {\r\n            this.videoTool.video = file.url;\r\n        }\r\n    }\r\n\r\n    private onUpload(response: CuiFileResponseData): void {\r\n        if (!response.success || !response.file || !this.selectedFile) {\r\n            this.uploadingFailed();\r\n\r\n            return;\r\n        }\r\n\r\n        const url =\r\n            this.selectedFile instanceof File ? window.URL.createObjectURL(this.selectedFile) : this.selectedFile;\r\n\r\n        this.data.file = response.file;\r\n        this.videoTool.video = url;\r\n        this.videoTool.isLoading = false;\r\n    }\r\n\r\n    private uploadingFailed(): void {\r\n        this.videoTool.video = '';\r\n        this.videoTool.isLoading = false;\r\n    }\r\n\r\n    private getCaptureFromVideo(url: string): void {\r\n        const canvas = document.createElement('canvas') as HTMLCanvasElement;\r\n        const video = document.createElement('video') as HTMLVideoElement;\r\n\r\n        video.src = url;\r\n        video.currentTime = 1;\r\n        canvas.width = 120;\r\n        canvas.height = 120;\r\n\r\n        video.onloadeddata = (): void => {\r\n            const context = canvas.getContext('2d');\r\n\r\n            if (!context) {\r\n                return;\r\n            }\r\n\r\n            context.drawImage(video, 0, 0, canvas.width, canvas.height);\r\n\r\n            canvas.toBlob((blob) => {\r\n                if (!blob) {\r\n                    return;\r\n                }\r\n\r\n                this.videoTool.preview = URL.createObjectURL(blob);\r\n            });\r\n        };\r\n\r\n        video.load();\r\n    }\r\n}\r\n"]}
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"video.tool.js","sourceRoot":"","sources":["../../../../../projects/core/editor/tools/video.tool.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CuiNullable } from '@cuby-ui/cdk';\r\nimport { CUI_ICONS } from '@cuby-ui/icons';\r\nimport type { API, BlockAPI, BlockToolConstructorOptions, PasteConfig, ToolboxConfig } from '@editorjs/editorjs';\r\n\r\nimport type { CuiAngularElement } from '../interfaces';\r\n\r\nimport type { CuiVideoToolConfig, CuiVideoToolData, EditorVideoToolComponent } from '../components/editor-video-tool';\r\nimport { EDITOR_VIDEO_TOOL_SELECTOR } from '../components/editor-video-tool/editor-video-tool.options';\r\nimport type { CuiFileData, CuiResourceFile } from '../interfaces/file-response-data';\r\nimport { CuiFileUploader } from '../utils/file-uploader';\r\n\r\nexport class CuiVideoTool {\r\n    private selectedFile: CuiNullable<string | File> = null;\r\n\r\n    public static get isReadOnlySupported(): boolean {\r\n        return true;\r\n    }\r\n\r\n    public static get toolbox(): ToolboxConfig {\r\n        return {\r\n            icon: CUI_ICONS.cuiIconPlayCircle,\r\n            title: 'Video'\r\n        };\r\n    }\r\n\r\n    public static get pasteConfig(): PasteConfig {\r\n        return {\r\n            tags: ['video'],\r\n            patterns: {\r\n                video: /https?:\\/\\/\\S+\\.(mp4)$/i\r\n            },\r\n            files: {\r\n                mimeTypes: ['video/*']\r\n            }\r\n        };\r\n    }\r\n\r\n    public api: API;\r\n    public config: CuiVideoToolConfig;\r\n    public blockApi?: BlockAPI;\r\n    public readOnly: boolean;\r\n    public data: CuiVideoToolData;\r\n    public videoTool!: CuiAngularElement<EditorVideoToolComponent>;\r\n    public uploader: CuiFileUploader;\r\n\r\n    constructor(options: { api: API }) {\r\n        const { api, readOnly, config, data, block } = options as BlockToolConstructorOptions<\r\n            CuiVideoToolData,\r\n            CuiVideoToolConfig\r\n        >;\r\n\r\n        this.blockApi = block;\r\n        this.api = api;\r\n        this.readOnly = readOnly;\r\n        this.config = {\r\n            load: config?.load ?? (() => { }),\r\n            field: config?.field ?? 'video',\r\n            types: config?.types ?? 'video/*',\r\n            endpoint: config?.endpoint ?? '',\r\n            buttonContent: config?.buttonContent ?? this.api.i18n.t('Select a Video'),\r\n            additionalRequestHeaders: config?.additionalRequestHeaders ?? {}\r\n        };\r\n\r\n        this.uploader = new CuiFileUploader(this.config, this.onUpload.bind(this), this.uploadingFailed.bind(this));\r\n        this.data = data;\r\n    }\r\n\r\n    public onSelectFile = (): void => {\r\n        return this.uploader.selectFile({\r\n            fileSelected: (file) => {\r\n                const url = URL.createObjectURL(file);\r\n\r\n                this.getCaptureFromVideo(url);\r\n                this.videoTool.isLoading = true;\r\n                this.selectedFile = file;\r\n\r\n                this.uploader.uploadFile(file);\r\n            }\r\n        });\r\n    };\r\n\r\n    public async onPaste(event: CustomEvent): Promise<void> {\r\n        if (event.type !== 'file') {\r\n            return;\r\n        }\r\n\r\n        const file = event.detail.file;\r\n\r\n        this.videoTool.isLoading = true;\r\n        this.selectedFile = file;\r\n        this.uploader.uploadFile(file);\r\n    }\r\n\r\n    public appendCallback(): void {\r\n        this.onSelectFile();\r\n    }\r\n\r\n    public render(): HTMLElement {\r\n        this.videoTool = document.createElement(\r\n            EDITOR_VIDEO_TOOL_SELECTOR\r\n        ) as CuiAngularElement<EditorVideoToolComponent>;\r\n\r\n        this.videoTool.api = this.api;\r\n        this.videoTool.video = this.data.file?.url || '';\r\n        this.videoTool.caption = this.data.caption || '';\r\n        this.videoTool.readOnly = this.readOnly;\r\n        this.videoTool.buttonContent = this.config.buttonContent;\r\n\r\n        this.videoTool.addEventListener('fileSelected', this.onSelectFile);\r\n        this.videoTool.addEventListener('captionChanged', this.changeCaption.bind(this));\r\n\r\n        return this.videoTool;\r\n    }\r\n\r\n    public save(): CuiVideoToolData {\r\n        return this.data;\r\n    }\r\n\r\n    public removed(): void {\r\n        this.videoTool.removeEventListener('fileSelected', this.onSelectFile);\r\n        this.videoTool.removeEventListener('captionChanged', this.changeCaption);\r\n    }\r\n\r\n    public changeCaption(event: Event): void {\r\n        const customEvent = event as CustomEvent;\r\n        const value = customEvent.detail;\r\n        this.data.caption = value;\r\n\r\n        this.blockApi?.dispatchChange();\r\n    }\r\n\r\n    public set video(file: CuiFileData) {\r\n        this.data.file = file || {};\r\n\r\n        if (file && file.url) {\r\n            this.videoTool.video = file.url;\r\n        }\r\n    }\r\n\r\n    private onUpload(response: CuiResourceFile): void {\r\n        if (!response.success || !response.file || !this.selectedFile) {\r\n            this.uploadingFailed();\r\n\r\n            return;\r\n        }\r\n\r\n        const url =\r\n            this.selectedFile instanceof File ? window.URL.createObjectURL(this.selectedFile) : this.selectedFile;\r\n\r\n        this.data.file = response.file;\r\n        this.videoTool.video = url;\r\n        this.videoTool.isLoading = false;\r\n    }\r\n\r\n    private uploadingFailed(): void {\r\n        this.videoTool.video = '';\r\n        this.videoTool.isLoading = false;\r\n    }\r\n\r\n    private getCaptureFromVideo(url: string): void {\r\n        const canvas = document.createElement('canvas') as HTMLCanvasElement;\r\n        const video = document.createElement('video') as HTMLVideoElement;\r\n\r\n        video.src = url;\r\n        video.currentTime = 1;\r\n        canvas.width = 120;\r\n        canvas.height = 120;\r\n\r\n        video.onloadeddata = (): void => {\r\n            const context = canvas.getContext('2d');\r\n\r\n            if (!context) {\r\n                return;\r\n            }\r\n\r\n            context.drawImage(video, 0, 0, canvas.width, canvas.height);\r\n\r\n            canvas.toBlob((blob) => {\r\n                if (!blob) {\r\n                    return;\r\n                }\r\n\r\n                this.videoTool.preview = URL.createObjectURL(blob);\r\n            });\r\n        };\r\n\r\n        video.load();\r\n    }\r\n}\r\n"]}
@@ -46,12 +46,15 @@ export class CuiFileUploader {
46
46
  });
47
47
  upload
48
48
  .then((response) => response.json())
49
- .then((response) => this.onUpload(response, file))
49
+ .then((response) => this.onUpload(this.convertToFileSuccessResponse(response), file))
50
50
  .catch(() => this.onError())
51
51
  .finally(() => this.config.load(CuiFileUploaderStatus.Completed));
52
52
  }
53
53
  uploadByUrl(url) {
54
- this.onUpload({ success: 1, file: { url } });
54
+ this.onUpload({ id: crypto.randomUUID(), success: 1, file: { url } });
55
+ }
56
+ convertToFileSuccessResponse(response) {
57
+ return { id: response.id, success: 1, file: { url: response.downloadUrl } };
55
58
  }
56
59
  }
57
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvZWRpdG9yL3V0aWxzL2ZpbGUtdXBsb2FkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFOLElBQVkscUJBR1g7QUFIRCxXQUFZLHFCQUFxQjtJQUM3Qiw0Q0FBbUIsQ0FBQTtJQUNuQixnREFBdUIsQ0FBQTtBQUMzQixDQUFDLEVBSFcscUJBQXFCLEtBQXJCLHFCQUFxQixRQUdoQztBQVlELE1BQU0sT0FBTyxlQUFlO0lBTXhCLFlBQVksTUFBNkIsRUFBRSxRQUFrQixFQUFFLE9BQW1CO1FBTGpFLG1CQUFjLEdBQUcsTUFBTSxDQUFDO1FBV2xDLGVBQVUsR0FBRyxDQUFDLEVBQUUsWUFBWSxFQUEwQyxFQUFRLEVBQUU7WUFDbkYsTUFBTSxLQUFLLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUM5QyxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLEtBQUssSUFBSSxHQUFHLENBQUM7WUFDeEMsS0FBSyxDQUFDLElBQUksR0FBRyxNQUFNLENBQUM7WUFDcEIsS0FBSyxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7WUFFckIsS0FBSyxDQUFDLFFBQVEsR0FBRyxHQUFTLEVBQUU7Z0JBQ3hCLE1BQU0sS0FBSyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUM7Z0JBRTFCLElBQUksQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLENBQUM7b0JBQ2pCLE9BQU87Z0JBQ1gsQ0FBQztnQkFFRCxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxZQUFZLENBQUMsQ0FBQztZQUN0QyxDQUFDLENBQUM7WUFFRixLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDbEIsQ0FBQyxDQUFDO1FBdEJFLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO0lBQzNCLENBQUM7SUFxQk0sT0FBTyxDQUFDLEtBQWUsRUFBRSxZQUFrQztRQUM5RCxNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRTNCLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNSLE9BQU87UUFDWCxDQUFDO1FBRUQsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3ZCLENBQUM7SUFFTSxVQUFVLENBQUMsSUFBVTtRQUN4QixNQUFNLFFBQVEsR0FBRyxJQUFJLFFBQVEsRUFBRSxDQUFDO1FBQ2hDLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxJQUFJLE1BQU0sQ0FBQztRQUM5QyxRQUFRLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUVqQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUN4QixPQUFPO1FBQ1gsQ0FBQztRQUVELElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRWhELE1BQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRTtZQUN2QyxPQUFPLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyx3QkFBd0I7WUFDN0MsTUFBTSxFQUFFLElBQUksQ0FBQyxjQUFjO1lBQzNCLElBQUksRUFBRSxRQUFRO1NBQ2pCLENBQUMsQ0FBQztRQUVILE1BQU07YUFDRCxJQUFJLENBQUMsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQzthQUNuQyxJQUFJLENBQUMsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxDQUFDO2FBQ2pELEtBQUssQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7YUFDM0IsT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFDMUUsQ0FBQztJQUVNLFdBQVcsQ0FBQyxHQUFXO1FBQzFCLElBQUksQ0FBQyxRQUFRLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNqRCxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEN1aUZpbGVSZXNwb25zZURhdGEgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcclxuXHJcbmV4cG9ydCBlbnVtIEN1aUZpbGVVcGxvYWRlclN0YXR1cyB7XHJcbiAgICBMb2FkaW5nID0gJ2xvYWRpbmcnLFxyXG4gICAgQ29tcGxldGVkID0gJ2NvbXBsZXRlZCdcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBDdWlGaWxlVXBsb2FkZXJDb25maWcge1xyXG4gICAgcmVhZG9ubHkgZW5kcG9pbnQ6IHN0cmluZztcclxuICAgIHJlYWRvbmx5IHR5cGVzOiBzdHJpbmc7XHJcbiAgICByZWFkb25seSBmaWVsZDogc3RyaW5nO1xyXG4gICAgcmVhZG9ubHkgYWRkaXRpb25hbFJlcXVlc3RIZWFkZXJzOiBIZWFkZXJzSW5pdDtcclxuICAgIHJlYWRvbmx5IGxvYWQ6IChzdGF0dXM6IEN1aUZpbGVVcGxvYWRlclN0YXR1cykgPT4gdm9pZDtcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgT25VcGxvYWQgPSAocmVzcG9uc2U6IEN1aUZpbGVSZXNwb25zZURhdGEsIGZpbGU/OiBGaWxlKSA9PiB2b2lkO1xyXG5cclxuZXhwb3J0IGNsYXNzIEN1aUZpbGVVcGxvYWRlciB7XHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IFJFUVVFU1RfTUVUSE9EID0gJ1BPU1QnO1xyXG4gICAgcHJpdmF0ZSByZWFkb25seSBjb25maWc6IEN1aUZpbGVVcGxvYWRlckNvbmZpZztcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgb25VcGxvYWQ6IE9uVXBsb2FkO1xyXG4gICAgcHJpdmF0ZSByZWFkb25seSBvbkVycm9yOiAoKSA9PiB2b2lkO1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKGNvbmZpZzogQ3VpRmlsZVVwbG9hZGVyQ29uZmlnLCBvblVwbG9hZDogT25VcGxvYWQsIG9uRXJyb3I6ICgpID0+IHZvaWQpIHtcclxuICAgICAgICB0aGlzLmNvbmZpZyA9IGNvbmZpZztcclxuICAgICAgICB0aGlzLm9uVXBsb2FkID0gb25VcGxvYWQ7XHJcbiAgICAgICAgdGhpcy5vbkVycm9yID0gb25FcnJvcjtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgc2VsZWN0RmlsZSA9ICh7IGZpbGVTZWxlY3RlZCB9OiB7IGZpbGVTZWxlY3RlZDogKGZpbGU6IEZpbGUpID0+IHZvaWQgfSk6IHZvaWQgPT4ge1xyXG4gICAgICAgIGNvbnN0IGlucHV0ID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnaW5wdXQnKTtcclxuICAgICAgICBjb25zdCB0eXBlcyA9IHRoaXMuY29uZmlnPy50eXBlcyB8fCAnKic7XHJcbiAgICAgICAgaW5wdXQudHlwZSA9ICdmaWxlJztcclxuICAgICAgICBpbnB1dC5hY2NlcHQgPSB0eXBlcztcclxuXHJcbiAgICAgICAgaW5wdXQub25jaGFuZ2UgPSAoKTogdm9pZCA9PiB7XHJcbiAgICAgICAgICAgIGNvbnN0IGZpbGVzID0gaW5wdXQuZmlsZXM7XHJcblxyXG4gICAgICAgICAgICBpZiAoIWZpbGVzPy5sZW5ndGgpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICAgICAgfVxyXG5cclxuICAgICAgICAgICAgdGhpcy5nZXRGaWxlKGZpbGVzLCBmaWxlU2VsZWN0ZWQpO1xyXG4gICAgICAgIH07XHJcblxyXG4gICAgICAgIGlucHV0LmNsaWNrKCk7XHJcbiAgICB9O1xyXG5cclxuICAgIHB1YmxpYyBnZXRGaWxlKGZpbGVzOiBGaWxlTGlzdCwgZmlsZVNlbGVjdGVkOiAoZmlsZTogRmlsZSkgPT4gdm9pZCk6IHZvaWQge1xyXG4gICAgICAgIGNvbnN0IGZpbGUgPSBmaWxlcy5pdGVtKDApO1xyXG5cclxuICAgICAgICBpZiAoIWZpbGUpIHtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgZmlsZVNlbGVjdGVkKGZpbGUpO1xyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyB1cGxvYWRGaWxlKGZpbGU6IEZpbGUpOiB2b2lkIHtcclxuICAgICAgICBjb25zdCBmb3JtRGF0YSA9IG5ldyBGb3JtRGF0YSgpO1xyXG4gICAgICAgIGNvbnN0IGZvcm1GaWVsZCA9IHRoaXMuY29uZmlnLmZpZWxkIHx8ICdmaWxlJztcclxuICAgICAgICBmb3JtRGF0YS5hcHBlbmQoZm9ybUZpZWxkLCBmaWxlKTtcclxuXHJcbiAgICAgICAgaWYgKCF0aGlzLmNvbmZpZy5lbmRwb2ludCkge1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICB0aGlzLmNvbmZpZy5sb2FkKEN1aUZpbGVVcGxvYWRlclN0YXR1cy5Mb2FkaW5nKTtcclxuXHJcbiAgICAgICAgY29uc3QgdXBsb2FkID0gZmV0Y2godGhpcy5jb25maWcuZW5kcG9pbnQsIHtcclxuICAgICAgICAgICAgaGVhZGVyczogdGhpcy5jb25maWcuYWRkaXRpb25hbFJlcXVlc3RIZWFkZXJzLFxyXG4gICAgICAgICAgICBtZXRob2Q6IHRoaXMuUkVRVUVTVF9NRVRIT0QsXHJcbiAgICAgICAgICAgIGJvZHk6IGZvcm1EYXRhXHJcbiAgICAgICAgfSk7XHJcblxyXG4gICAgICAgIHVwbG9hZFxyXG4gICAgICAgICAgICAudGhlbigocmVzcG9uc2UpID0+IHJlc3BvbnNlLmpzb24oKSlcclxuICAgICAgICAgICAgLnRoZW4oKHJlc3BvbnNlKSA9PiB0aGlzLm9uVXBsb2FkKHJlc3BvbnNlLCBmaWxlKSlcclxuICAgICAgICAgICAgLmNhdGNoKCgpID0+IHRoaXMub25FcnJvcigpKVxyXG4gICAgICAgICAgICAuZmluYWxseSgoKSA9PiB0aGlzLmNvbmZpZy5sb2FkKEN1aUZpbGVVcGxvYWRlclN0YXR1cy5Db21wbGV0ZWQpKTtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgdXBsb2FkQnlVcmwodXJsOiBzdHJpbmcpOiB2b2lkIHtcclxuICAgICAgICB0aGlzLm9uVXBsb2FkKHsgc3VjY2VzczogMSwgZmlsZTogeyB1cmwgfSB9KTtcclxuICAgIH1cclxufVxyXG4iXX0=
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvZWRpdG9yL3V0aWxzL2ZpbGUtdXBsb2FkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFOLElBQVkscUJBR1g7QUFIRCxXQUFZLHFCQUFxQjtJQUM3Qiw0Q0FBbUIsQ0FBQTtJQUNuQixnREFBdUIsQ0FBQTtBQUMzQixDQUFDLEVBSFcscUJBQXFCLEtBQXJCLHFCQUFxQixRQUdoQztBQVlELE1BQU0sT0FBTyxlQUFlO0lBTXhCLFlBQVksTUFBNkIsRUFBRSxRQUFrQixFQUFFLE9BQW1CO1FBTGpFLG1CQUFjLEdBQUcsTUFBTSxDQUFDO1FBV2xDLGVBQVUsR0FBRyxDQUFDLEVBQUUsWUFBWSxFQUEwQyxFQUFRLEVBQUU7WUFDbkYsTUFBTSxLQUFLLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUM5QyxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLEtBQUssSUFBSSxHQUFHLENBQUM7WUFDeEMsS0FBSyxDQUFDLElBQUksR0FBRyxNQUFNLENBQUM7WUFDcEIsS0FBSyxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7WUFFckIsS0FBSyxDQUFDLFFBQVEsR0FBRyxHQUFTLEVBQUU7Z0JBQ3hCLE1BQU0sS0FBSyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUM7Z0JBRTFCLElBQUksQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLENBQUM7b0JBQ2pCLE9BQU87Z0JBQ1gsQ0FBQztnQkFFRCxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxZQUFZLENBQUMsQ0FBQztZQUN0QyxDQUFDLENBQUM7WUFFRixLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDbEIsQ0FBQyxDQUFDO1FBdEJFLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO0lBQzNCLENBQUM7SUFxQk0sT0FBTyxDQUFDLEtBQWUsRUFBRSxZQUFrQztRQUM5RCxNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRTNCLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNSLE9BQU87UUFDWCxDQUFDO1FBRUQsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3ZCLENBQUM7SUFFTSxVQUFVLENBQUMsSUFBVTtRQUN4QixNQUFNLFFBQVEsR0FBRyxJQUFJLFFBQVEsRUFBRSxDQUFDO1FBQ2hDLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxJQUFJLE1BQU0sQ0FBQztRQUM5QyxRQUFRLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUVqQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUN4QixPQUFPO1FBQ1gsQ0FBQztRQUVELElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRWhELE1BQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRTtZQUN2QyxPQUFPLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyx3QkFBd0I7WUFDN0MsTUFBTSxFQUFFLElBQUksQ0FBQyxjQUFjO1lBQzNCLElBQUksRUFBRSxRQUFRO1NBQ2pCLENBQUMsQ0FBQztRQUVILE1BQU07YUFDRCxJQUFJLENBQUMsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQWtDLENBQUM7YUFDbkUsSUFBSSxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyw0QkFBNEIsQ0FBQyxRQUFRLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQzthQUNwRixLQUFLLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO2FBQzNCLE9BQU8sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDO0lBQzFFLENBQUM7SUFFTSxXQUFXLENBQUMsR0FBVztRQUMxQixJQUFJLENBQUMsUUFBUSxDQUFDLEVBQUUsRUFBRSxFQUFFLE1BQU0sQ0FBQyxVQUFVLEVBQUUsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUMxRSxDQUFDO0lBRU8sNEJBQTRCLENBQUMsUUFBNkI7UUFDOUQsT0FBTyxFQUFFLEVBQUUsRUFBRSxRQUFRLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsR0FBRyxFQUFFLFFBQVEsQ0FBQyxXQUFXLEVBQUUsRUFBRSxDQUFDO0lBQ2hGLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQ3VpRmlsZVJlc3BvbnNlRGF0YSwgQ3VpUmVzb3VyY2VGaWxlIH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XHJcblxyXG5leHBvcnQgZW51bSBDdWlGaWxlVXBsb2FkZXJTdGF0dXMge1xyXG4gICAgTG9hZGluZyA9ICdsb2FkaW5nJyxcclxuICAgIENvbXBsZXRlZCA9ICdjb21wbGV0ZWQnXHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ3VpRmlsZVVwbG9hZGVyQ29uZmlnIHtcclxuICAgIHJlYWRvbmx5IGVuZHBvaW50OiBzdHJpbmc7XHJcbiAgICByZWFkb25seSB0eXBlczogc3RyaW5nO1xyXG4gICAgcmVhZG9ubHkgZmllbGQ6IHN0cmluZztcclxuICAgIHJlYWRvbmx5IGFkZGl0aW9uYWxSZXF1ZXN0SGVhZGVyczogSGVhZGVyc0luaXQ7XHJcbiAgICByZWFkb25seSBsb2FkOiAoc3RhdHVzOiBDdWlGaWxlVXBsb2FkZXJTdGF0dXMpID0+IHZvaWQ7XHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIE9uVXBsb2FkID0gKHJlc3BvbnNlOiBDdWlSZXNvdXJjZUZpbGUsIGZpbGU/OiBGaWxlKSA9PiB2b2lkO1xyXG5cclxuZXhwb3J0IGNsYXNzIEN1aUZpbGVVcGxvYWRlciB7XHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IFJFUVVFU1RfTUVUSE9EID0gJ1BPU1QnO1xyXG4gICAgcHJpdmF0ZSByZWFkb25seSBjb25maWc6IEN1aUZpbGVVcGxvYWRlckNvbmZpZztcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgb25VcGxvYWQ6IE9uVXBsb2FkO1xyXG4gICAgcHJpdmF0ZSByZWFkb25seSBvbkVycm9yOiAoKSA9PiB2b2lkO1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKGNvbmZpZzogQ3VpRmlsZVVwbG9hZGVyQ29uZmlnLCBvblVwbG9hZDogT25VcGxvYWQsIG9uRXJyb3I6ICgpID0+IHZvaWQpIHtcclxuICAgICAgICB0aGlzLmNvbmZpZyA9IGNvbmZpZztcclxuICAgICAgICB0aGlzLm9uVXBsb2FkID0gb25VcGxvYWQ7XHJcbiAgICAgICAgdGhpcy5vbkVycm9yID0gb25FcnJvcjtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgc2VsZWN0RmlsZSA9ICh7IGZpbGVTZWxlY3RlZCB9OiB7IGZpbGVTZWxlY3RlZDogKGZpbGU6IEZpbGUpID0+IHZvaWQgfSk6IHZvaWQgPT4ge1xyXG4gICAgICAgIGNvbnN0IGlucHV0ID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnaW5wdXQnKTtcclxuICAgICAgICBjb25zdCB0eXBlcyA9IHRoaXMuY29uZmlnPy50eXBlcyB8fCAnKic7XHJcbiAgICAgICAgaW5wdXQudHlwZSA9ICdmaWxlJztcclxuICAgICAgICBpbnB1dC5hY2NlcHQgPSB0eXBlcztcclxuXHJcbiAgICAgICAgaW5wdXQub25jaGFuZ2UgPSAoKTogdm9pZCA9PiB7XHJcbiAgICAgICAgICAgIGNvbnN0IGZpbGVzID0gaW5wdXQuZmlsZXM7XHJcblxyXG4gICAgICAgICAgICBpZiAoIWZpbGVzPy5sZW5ndGgpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICAgICAgfVxyXG5cclxuICAgICAgICAgICAgdGhpcy5nZXRGaWxlKGZpbGVzLCBmaWxlU2VsZWN0ZWQpO1xyXG4gICAgICAgIH07XHJcblxyXG4gICAgICAgIGlucHV0LmNsaWNrKCk7XHJcbiAgICB9O1xyXG5cclxuICAgIHB1YmxpYyBnZXRGaWxlKGZpbGVzOiBGaWxlTGlzdCwgZmlsZVNlbGVjdGVkOiAoZmlsZTogRmlsZSkgPT4gdm9pZCk6IHZvaWQge1xyXG4gICAgICAgIGNvbnN0IGZpbGUgPSBmaWxlcy5pdGVtKDApO1xyXG5cclxuICAgICAgICBpZiAoIWZpbGUpIHtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgZmlsZVNlbGVjdGVkKGZpbGUpO1xyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyB1cGxvYWRGaWxlKGZpbGU6IEZpbGUpOiB2b2lkIHtcclxuICAgICAgICBjb25zdCBmb3JtRGF0YSA9IG5ldyBGb3JtRGF0YSgpO1xyXG4gICAgICAgIGNvbnN0IGZvcm1GaWVsZCA9IHRoaXMuY29uZmlnLmZpZWxkIHx8ICdmaWxlJztcclxuICAgICAgICBmb3JtRGF0YS5hcHBlbmQoZm9ybUZpZWxkLCBmaWxlKTtcclxuXHJcbiAgICAgICAgaWYgKCF0aGlzLmNvbmZpZy5lbmRwb2ludCkge1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICB0aGlzLmNvbmZpZy5sb2FkKEN1aUZpbGVVcGxvYWRlclN0YXR1cy5Mb2FkaW5nKTtcclxuXHJcbiAgICAgICAgY29uc3QgdXBsb2FkID0gZmV0Y2godGhpcy5jb25maWcuZW5kcG9pbnQsIHtcclxuICAgICAgICAgICAgaGVhZGVyczogdGhpcy5jb25maWcuYWRkaXRpb25hbFJlcXVlc3RIZWFkZXJzLFxyXG4gICAgICAgICAgICBtZXRob2Q6IHRoaXMuUkVRVUVTVF9NRVRIT0QsXHJcbiAgICAgICAgICAgIGJvZHk6IGZvcm1EYXRhXHJcbiAgICAgICAgfSk7XHJcblxyXG4gICAgICAgIHVwbG9hZFxyXG4gICAgICAgICAgICAudGhlbigocmVzcG9uc2UpID0+IHJlc3BvbnNlLmpzb24oKSBhcyBQcm9taXNlPEN1aUZpbGVSZXNwb25zZURhdGE+KVxyXG4gICAgICAgICAgICAudGhlbigocmVzcG9uc2UpID0+IHRoaXMub25VcGxvYWQodGhpcy5jb252ZXJ0VG9GaWxlU3VjY2Vzc1Jlc3BvbnNlKHJlc3BvbnNlKSwgZmlsZSkpXHJcbiAgICAgICAgICAgIC5jYXRjaCgoKSA9PiB0aGlzLm9uRXJyb3IoKSlcclxuICAgICAgICAgICAgLmZpbmFsbHkoKCkgPT4gdGhpcy5jb25maWcubG9hZChDdWlGaWxlVXBsb2FkZXJTdGF0dXMuQ29tcGxldGVkKSk7XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIHVwbG9hZEJ5VXJsKHVybDogc3RyaW5nKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5vblVwbG9hZCh7IGlkOiBjcnlwdG8ucmFuZG9tVVVJRCgpLCBzdWNjZXNzOiAxLCBmaWxlOiB7IHVybCB9IH0pO1xyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgY29udmVydFRvRmlsZVN1Y2Nlc3NSZXNwb25zZShyZXNwb25zZTogQ3VpRmlsZVJlc3BvbnNlRGF0YSk6IEN1aVJlc291cmNlRmlsZSB7XHJcbiAgICAgICAgcmV0dXJuIHsgaWQ6IHJlc3BvbnNlLmlkLCBzdWNjZXNzOiAxLCBmaWxlOiB7IHVybDogcmVzcG9uc2UuZG93bmxvYWRVcmwgfSB9O1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
@@ -6,13 +6,11 @@ import { CuiAuthService } from '../../../../providers';
6
6
  import { CUI_ACTIVITY_SERVICE_TOKEN } from '../user-action-context.option';
7
7
  import { TranslocoService } from '@jsverse/transloco';
8
8
  import { CuiTooltipDirective } from '../../../../directives';
9
- import { Router } from '@angular/router';
10
9
  import * as i0 from "@angular/core";
11
10
  import * as i1 from "../../../../components/svg/svg.component";
12
11
  export class CuiActivityItemComponent {
13
12
  constructor() {
14
13
  this.transloco = inject(TranslocoService);
15
- this.router = inject(Router);
16
14
  this.destroy = inject(DestroyRef);
17
15
  this.cuiAuthService = inject(CuiAuthService);
18
16
  this.cuiActivityService = inject(CUI_ACTIVITY_SERVICE_TOKEN);
@@ -46,7 +44,7 @@ export class CuiActivityItemComponent {
46
44
  ["DEVELOPER" /* CuiUserCompanyActivityType.Developer */]: "cuby-project" /* CuiApiUrl.Project */,
47
45
  ["MANUFACTURE" /* CuiUserCompanyActivityType.Manufacture */]: "cuby-manufacturing" /* CuiApiUrl.Manufacturing */
48
46
  };
49
- this.router.navigate([activityMap[type]]);
47
+ window.location.href = `${window.location.origin}/${activityMap[type]}`;
50
48
  });
51
49
  }
52
50
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiActivityItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
@@ -58,4 +56,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
58
56
  '[class.selected]': 'isSelected()'
59
57
  }, template: "<div\n class=\"wrapper\"\n (click)=\"onGoToActivity()\"\n [cuiTooltip]=\"activity().description\"\n>\n <button\n type=\"button\"\n class=\"activity-button\"\n >\n <cui-letter-box\n [letter]=\"activity().description[0]\"\n [shape]=\"'rounded'\"\n [backgroundColor]=\"letterBackgroundColor()\"\n size=\"md\"\n />\n <div class=\"text\">\n <span class=\"title\">{{ activity().description }}</span>\n <span class=\"sub-title\">{{ typeCompany() }}</span>\n </div>\n </button>\n\n @if (isSelected()) {\n <div class=\"icon-wrapper\">\n <cui-svg\n [icon]=\"'cuiIconCheck'\"\n color=\"var(--cui-info)\"\n />\n </div>\n }\n</div>\n", styles: [":host(.selected){background:var(--cui-badge-blue-bg);border-radius:8px}.wrapper{display:flex;justify-content:space-between}.activity-button{display:flex;gap:8px;align-items:center;padding-left:4px;height:36px;color:var(--cui-base-900)}.icon-wrapper{display:flex;align-items:center;justify-content:center;padding:8px}.text,.title{display:flex;flex-direction:column;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;align-items:flex-start}.sub-title{font-weight:400;font-size:12px;line-height:14px;color:var(--cui-base-400)}\n"] }]
60
58
  }] });
61
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity-item.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/widgets/ui/user-action-context-menu/activity-item/activity-item.component.ts","../../../../../../../projects/core/widgets/ui/user-action-context-menu/activity-item/activity-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAExG,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAEhE,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,0BAA0B,EAAE,MAAM,+BAA+B,CAAC;AAC3E,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;;;AAazC,MAAM,OAAO,wBAAwB;IAXrC;QAYqB,cAAS,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;QACrC,WAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QACxB,YAAO,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAC7B,mBAAc,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QACxC,uBAAkB,GAAG,MAAM,CAAC,0BAA0B,CAAC,CAAC;QAEtD,eAAU,GAAG,QAAQ,CAAC,GAAG,EAAE,CAC1C,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,UAAU,CAAC,CAC7E,CAAC;QACiB,0BAAqB,GAAG,QAAQ,CAAC,GAAG,EAAE;YACrD,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC;YAEzC,OAAO,WAAW,+DAA2C;gBACzD,CAAC,CAAC,uBAAuB;gBACzB,CAAC,CAAC,2BAA2B,CAAC;QACtC,CAAC,CAAC,CAAC;QAEa,aAAQ,GAAG,KAAK,CAAC,QAAQ,EAA0B,CAAC;QACpD,cAAS,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC;QAElC,gBAAW,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC3C,OAAO,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;KAwBN;IAtBa,cAAc;QACpB,IAAI,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC;YACpB,OAAO;QACX,CAAC;QAED,IAAI,CAAC,cAAc;aACd,aAAa,CAAC;YACX,IAAI,iEAA+B;YACnC,UAAU,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,UAAU;YACtC,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE;SAC9B,CAAC;aACD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;aACtC,SAAS,CAAC,GAAG,EAAE;YACZ,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC;YAClC,MAAM,WAAW,GAAG;gBAChB,wDAAsC,wCAAmB;gBACzD,4DAAwC,oDAAyB;aACpE,CAAC;YAEF,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAC;IACX,CAAC;+GA9CQ,wBAAwB;mGAAxB,wBAAwB,wZCvBrC,ozBA8BA,8kBDfc,qBAAqB,kHAAE,YAAY,wKAAE,mBAAmB;;4FAQzD,wBAAwB;kBAXpC,SAAS;+BACI,mBAAmB,cACjB,IAAI,WACP,CAAC,qBAAqB,EAAE,YAAY,EAAE,mBAAmB,CAAC,mBAGlD,uBAAuB,CAAC,MAAM,QACzC;wBACF,kBAAkB,EAAE,cAAc;qBACrC","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, DestroyRef, inject, input } from '@angular/core';\nimport { CuiApiUrl, CuiTokenExchangeType, CuiUserCompanyActivity, CuiUserCompanyActivityType } from '@cuby-ui/api';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\nimport { CuiLetterBoxComponent } from '../../../../components';\nimport { CuiSvgModule } from '../../../../components';\nimport { CuiAuthService } from '../../../../providers';\nimport { CUI_ACTIVITY_SERVICE_TOKEN } from '../user-action-context.option';\nimport { TranslocoService } from '@jsverse/transloco';\nimport { CuiTooltipDirective } from '../../../../directives';\nimport { Router } from '@angular/router';\n\n@Component({\n    selector: 'cui-activity-item',\n    standalone: true,\n    imports: [CuiLetterBoxComponent, CuiSvgModule, CuiTooltipDirective],\n    templateUrl: './activity-item.component.html',\n    styleUrl: './activity-item.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        '[class.selected]': 'isSelected()'\n    }\n})\nexport class CuiActivityItemComponent {\n    private readonly transloco = inject(TranslocoService);\n    private readonly router = inject(Router);\n    private readonly destroy = inject(DestroyRef);\n    private readonly cuiAuthService = inject(CuiAuthService);\n    private readonly cuiActivityService = inject(CUI_ACTIVITY_SERVICE_TOKEN);\n\n    protected readonly isSelected = computed(() =>\n        this.cuiActivityService.checkIsCurrentActivity(this.activity().activityId)\n    );\n    protected readonly letterBackgroundColor = computed(() => {\n        const licenseType = this.activity().type;\n\n        return licenseType === CuiUserCompanyActivityType.Manufacture\n            ? 'var(--cui-orange-500)'\n            : 'var(--cui-light-blue-500)';\n    });\n\n    public readonly activity = input.required<CuiUserCompanyActivity>();\n    public readonly companyId = input.required<string>();\n\n    protected readonly typeCompany = computed(() => {\n        return this.transloco.translate(this.activity().type);\n    });\n\n    protected onGoToActivity(): void {\n        if (this.isSelected()) {\n            return;\n        }\n\n        this.cuiAuthService\n            .exchangeToken({\n                type: CuiTokenExchangeType.Activity,\n                activityId: this.activity().activityId,\n                companyId: this.companyId()\n            })\n            .pipe(takeUntilDestroyed(this.destroy))\n            .subscribe(() => {\n                const type = this.activity().type;\n                const activityMap = {\n                    [CuiUserCompanyActivityType.Developer]: CuiApiUrl.Project,\n                    [CuiUserCompanyActivityType.Manufacture]: CuiApiUrl.Manufacturing\n                };\n\n                this.router.navigate([activityMap[type]]);\n            });\n    }\n}\n","<div\n    class=\"wrapper\"\n    (click)=\"onGoToActivity()\"\n    [cuiTooltip]=\"activity().description\"\n>\n    <button\n        type=\"button\"\n        class=\"activity-button\"\n    >\n        <cui-letter-box\n            [letter]=\"activity().description[0]\"\n            [shape]=\"'rounded'\"\n            [backgroundColor]=\"letterBackgroundColor()\"\n            size=\"md\"\n        />\n        <div class=\"text\">\n            <span class=\"title\">{{ activity().description }}</span>\n            <span class=\"sub-title\">{{ typeCompany() }}</span>\n        </div>\n    </button>\n\n    @if (isSelected()) {\n        <div class=\"icon-wrapper\">\n            <cui-svg\n                [icon]=\"'cuiIconCheck'\"\n                color=\"var(--cui-info)\"\n            />\n        </div>\n    }\n</div>\n"]}
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aXZpdHktaXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvdWkvdXNlci1hY3Rpb24tY29udGV4dC1tZW51L2FjdGl2aXR5LWl0ZW0vYWN0aXZpdHktaXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvdWkvdXNlci1hY3Rpb24tY29udGV4dC1tZW51L2FjdGl2aXR5LWl0ZW0vYWN0aXZpdHktaXRlbS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV4RyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUVoRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQzNFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7QUFhN0QsTUFBTSxPQUFPLHdCQUF3QjtJQVhyQztRQVlxQixjQUFTLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDckMsWUFBTyxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUM3QixtQkFBYyxHQUFHLE1BQU0sQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUN4Qyx1QkFBa0IsR0FBRyxNQUFNLENBQUMsMEJBQTBCLENBQUMsQ0FBQztRQUV0RCxlQUFVLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUMxQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsc0JBQXNCLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDLFVBQVUsQ0FBQyxDQUM3RSxDQUFDO1FBQ2lCLDBCQUFxQixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDckQsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDLElBQUksQ0FBQztZQUV6QyxPQUFPLFdBQVcsK0RBQTJDO2dCQUN6RCxDQUFDLENBQUMsdUJBQXVCO2dCQUN6QixDQUFDLENBQUMsMkJBQTJCLENBQUM7UUFDdEMsQ0FBQyxDQUFDLENBQUM7UUFFYSxhQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBMEIsQ0FBQztRQUNwRCxjQUFTLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBRWxDLGdCQUFXLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUMzQyxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMxRCxDQUFDLENBQUMsQ0FBQztLQXdCTjtJQXRCYSxjQUFjO1FBQ3BCLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRSxFQUFFLENBQUM7WUFDcEIsT0FBTztRQUNYLENBQUM7UUFFRCxJQUFJLENBQUMsY0FBYzthQUNkLGFBQWEsQ0FBQztZQUNYLElBQUksaUVBQStCO1lBQ25DLFVBQVUsRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsVUFBVTtZQUN0QyxTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRTtTQUM5QixDQUFDO2FBQ0QsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQzthQUN0QyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ1osTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDLElBQUksQ0FBQztZQUNsQyxNQUFNLFdBQVcsR0FBRztnQkFDaEIsd0RBQXNDLHdDQUFtQjtnQkFDekQsNERBQXdDLG9EQUF5QjthQUNwRSxDQUFDO1lBRUYsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEdBQUcsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLE1BQU0sSUFBSSxXQUFXLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztRQUM1RSxDQUFDLENBQUMsQ0FBQztJQUNYLENBQUM7K0dBN0NRLHdCQUF3QjttR0FBeEIsd0JBQXdCLHdaQ3RCckMsb3pCQThCQSw4a0JEaEJjLHFCQUFxQixrSEFBRSxZQUFZLHdLQUFFLG1CQUFtQjs7NEZBUXpELHdCQUF3QjtrQkFYcEMsU0FBUzsrQkFDSSxtQkFBbUIsY0FDakIsSUFBSSxXQUNQLENBQUMscUJBQXFCLEVBQUUsWUFBWSxFQUFFLG1CQUFtQixDQUFDLG1CQUdsRCx1QkFBdUIsQ0FBQyxNQUFNLFFBQ3pDO3dCQUNGLGtCQUFrQixFQUFFLGNBQWM7cUJBQ3JDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgY29tcHV0ZWQsIERlc3Ryb3lSZWYsIGluamVjdCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEN1aUFwaVVybCwgQ3VpVG9rZW5FeGNoYW5nZVR5cGUsIEN1aVVzZXJDb21wYW55QWN0aXZpdHksIEN1aVVzZXJDb21wYW55QWN0aXZpdHlUeXBlIH0gZnJvbSAnQGN1YnktdWkvYXBpJztcbmltcG9ydCB7IHRha2VVbnRpbERlc3Ryb3llZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvcnhqcy1pbnRlcm9wJztcblxuaW1wb3J0IHsgQ3VpTGV0dGVyQm94Q29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vLi4vY29tcG9uZW50cyc7XG5pbXBvcnQgeyBDdWlTdmdNb2R1bGUgfSBmcm9tICcuLi8uLi8uLi8uLi9jb21wb25lbnRzJztcbmltcG9ydCB7IEN1aUF1dGhTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vLi4vcHJvdmlkZXJzJztcbmltcG9ydCB7IENVSV9BQ1RJVklUWV9TRVJWSUNFX1RPS0VOIH0gZnJvbSAnLi4vdXNlci1hY3Rpb24tY29udGV4dC5vcHRpb24nO1xuaW1wb3J0IHsgVHJhbnNsb2NvU2VydmljZSB9IGZyb20gJ0Bqc3ZlcnNlL3RyYW5zbG9jbyc7XG5pbXBvcnQgeyBDdWlUb29sdGlwRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vLi4vLi4vZGlyZWN0aXZlcyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnY3VpLWFjdGl2aXR5LWl0ZW0nLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0N1aUxldHRlckJveENvbXBvbmVudCwgQ3VpU3ZnTW9kdWxlLCBDdWlUb29sdGlwRGlyZWN0aXZlXSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vYWN0aXZpdHktaXRlbS5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmw6ICcuL2FjdGl2aXR5LWl0ZW0uY29tcG9uZW50LnNjc3MnLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgJ1tjbGFzcy5zZWxlY3RlZF0nOiAnaXNTZWxlY3RlZCgpJ1xuICAgIH1cbn0pXG5leHBvcnQgY2xhc3MgQ3VpQWN0aXZpdHlJdGVtQ29tcG9uZW50IHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IHRyYW5zbG9jbyA9IGluamVjdChUcmFuc2xvY29TZXJ2aWNlKTtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGRlc3Ryb3kgPSBpbmplY3QoRGVzdHJveVJlZik7XG4gICAgcHJpdmF0ZSByZWFkb25seSBjdWlBdXRoU2VydmljZSA9IGluamVjdChDdWlBdXRoU2VydmljZSk7XG4gICAgcHJpdmF0ZSByZWFkb25seSBjdWlBY3Rpdml0eVNlcnZpY2UgPSBpbmplY3QoQ1VJX0FDVElWSVRZX1NFUlZJQ0VfVE9LRU4pO1xuXG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IGlzU2VsZWN0ZWQgPSBjb21wdXRlZCgoKSA9PlxuICAgICAgICB0aGlzLmN1aUFjdGl2aXR5U2VydmljZS5jaGVja0lzQ3VycmVudEFjdGl2aXR5KHRoaXMuYWN0aXZpdHkoKS5hY3Rpdml0eUlkKVxuICAgICk7XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IGxldHRlckJhY2tncm91bmRDb2xvciA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICAgICAgY29uc3QgbGljZW5zZVR5cGUgPSB0aGlzLmFjdGl2aXR5KCkudHlwZTtcblxuICAgICAgICByZXR1cm4gbGljZW5zZVR5cGUgPT09IEN1aVVzZXJDb21wYW55QWN0aXZpdHlUeXBlLk1hbnVmYWN0dXJlXG4gICAgICAgICAgICA/ICd2YXIoLS1jdWktb3JhbmdlLTUwMCknXG4gICAgICAgICAgICA6ICd2YXIoLS1jdWktbGlnaHQtYmx1ZS01MDApJztcbiAgICB9KTtcblxuICAgIHB1YmxpYyByZWFkb25seSBhY3Rpdml0eSA9IGlucHV0LnJlcXVpcmVkPEN1aVVzZXJDb21wYW55QWN0aXZpdHk+KCk7XG4gICAgcHVibGljIHJlYWRvbmx5IGNvbXBhbnlJZCA9IGlucHV0LnJlcXVpcmVkPHN0cmluZz4oKTtcblxuICAgIHByb3RlY3RlZCByZWFkb25seSB0eXBlQ29tcGFueSA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMudHJhbnNsb2NvLnRyYW5zbGF0ZSh0aGlzLmFjdGl2aXR5KCkudHlwZSk7XG4gICAgfSk7XG5cbiAgICBwcm90ZWN0ZWQgb25Hb1RvQWN0aXZpdHkoKTogdm9pZCB7XG4gICAgICAgIGlmICh0aGlzLmlzU2VsZWN0ZWQoKSkge1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy5jdWlBdXRoU2VydmljZVxuICAgICAgICAgICAgLmV4Y2hhbmdlVG9rZW4oe1xuICAgICAgICAgICAgICAgIHR5cGU6IEN1aVRva2VuRXhjaGFuZ2VUeXBlLkFjdGl2aXR5LFxuICAgICAgICAgICAgICAgIGFjdGl2aXR5SWQ6IHRoaXMuYWN0aXZpdHkoKS5hY3Rpdml0eUlkLFxuICAgICAgICAgICAgICAgIGNvbXBhbnlJZDogdGhpcy5jb21wYW55SWQoKVxuICAgICAgICAgICAgfSlcbiAgICAgICAgICAgIC5waXBlKHRha2VVbnRpbERlc3Ryb3llZCh0aGlzLmRlc3Ryb3kpKVxuICAgICAgICAgICAgLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICAgICAgICAgICAgY29uc3QgdHlwZSA9IHRoaXMuYWN0aXZpdHkoKS50eXBlO1xuICAgICAgICAgICAgICAgIGNvbnN0IGFjdGl2aXR5TWFwID0ge1xuICAgICAgICAgICAgICAgICAgICBbQ3VpVXNlckNvbXBhbnlBY3Rpdml0eVR5cGUuRGV2ZWxvcGVyXTogQ3VpQXBpVXJsLlByb2plY3QsXG4gICAgICAgICAgICAgICAgICAgIFtDdWlVc2VyQ29tcGFueUFjdGl2aXR5VHlwZS5NYW51ZmFjdHVyZV06IEN1aUFwaVVybC5NYW51ZmFjdHVyaW5nXG4gICAgICAgICAgICAgICAgfTtcblxuICAgICAgICAgICAgICAgIHdpbmRvdy5sb2NhdGlvbi5ocmVmID0gYCR7d2luZG93LmxvY2F0aW9uLm9yaWdpbn0vJHthY3Rpdml0eU1hcFt0eXBlXX1gO1xuICAgICAgICAgICAgfSk7XG4gICAgfVxufVxuIiwiPGRpdlxuICAgIGNsYXNzPVwid3JhcHBlclwiXG4gICAgKGNsaWNrKT1cIm9uR29Ub0FjdGl2aXR5KClcIlxuICAgIFtjdWlUb29sdGlwXT1cImFjdGl2aXR5KCkuZGVzY3JpcHRpb25cIlxuPlxuICAgIDxidXR0b25cbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIGNsYXNzPVwiYWN0aXZpdHktYnV0dG9uXCJcbiAgICA+XG4gICAgICAgIDxjdWktbGV0dGVyLWJveFxuICAgICAgICAgICAgW2xldHRlcl09XCJhY3Rpdml0eSgpLmRlc2NyaXB0aW9uWzBdXCJcbiAgICAgICAgICAgIFtzaGFwZV09XCIncm91bmRlZCdcIlxuICAgICAgICAgICAgW2JhY2tncm91bmRDb2xvcl09XCJsZXR0ZXJCYWNrZ3JvdW5kQ29sb3IoKVwiXG4gICAgICAgICAgICBzaXplPVwibWRcIlxuICAgICAgICAvPlxuICAgICAgICA8ZGl2IGNsYXNzPVwidGV4dFwiPlxuICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJ0aXRsZVwiPnt7IGFjdGl2aXR5KCkuZGVzY3JpcHRpb24gfX08L3NwYW4+XG4gICAgICAgICAgICA8c3BhbiBjbGFzcz1cInN1Yi10aXRsZVwiPnt7IHR5cGVDb21wYW55KCkgfX08L3NwYW4+XG4gICAgICAgIDwvZGl2PlxuICAgIDwvYnV0dG9uPlxuXG4gICAgQGlmIChpc1NlbGVjdGVkKCkpIHtcbiAgICAgICAgPGRpdiBjbGFzcz1cImljb24td3JhcHBlclwiPlxuICAgICAgICAgICAgPGN1aS1zdmdcbiAgICAgICAgICAgICAgICBbaWNvbl09XCInY3VpSWNvbkNoZWNrJ1wiXG4gICAgICAgICAgICAgICAgY29sb3I9XCJ2YXIoLS1jdWktaW5mbylcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgPC9kaXY+XG4gICAgfVxuPC9kaXY+XG4iXX0=
@@ -5,13 +5,11 @@ import { CuiAuthService } from '../../../../providers';
5
5
  import { TranslocoPipe } from '@jsverse/transloco';
6
6
  import { CuiTooltip } from '../../../../directives';
7
7
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
8
- import { Router } from '@angular/router';
9
8
  import * as i0 from "@angular/core";
10
9
  import * as i1 from "../../../../components/svg/svg.component";
11
10
  import * as i2 from "../../../../directives/tooltip/tooltip.directive";
12
11
  export class CompanyItemComponent {
13
12
  constructor() {
14
- this.router = inject(Router);
15
13
  this.cuiAuthService = inject(CuiAuthService);
16
14
  this.cuiActivityCompanyService = inject(CUI_ACTIVITY_SERVICE_TOKEN);
17
15
  this.COMPANY = 'company';
@@ -41,20 +39,21 @@ export class CompanyItemComponent {
41
39
  if (this.isSelected()) {
42
40
  return;
43
41
  }
44
- const { adminLink, userLink } = this.urlCompanyTemplate();
45
- const linkTemplate = this.checkIsAdmin() ? adminLink : userLink;
46
- const url = linkTemplate.replace('{id}', this.company().companyId);
47
- this.wentWorkspace("EXCHANGE_CONTEXT_COMPANY" /* CuiTokenExchangeType.Company */, this.company().companyId).subscribe(() => {
48
- this.router.navigateByUrl(url);
49
- });
50
- }
51
- wentWorkspace(type, companyId) {
52
- return this.cuiAuthService
42
+ this.cuiAuthService
53
43
  .exchangeToken({
54
- type,
55
- companyId
44
+ type: "EXCHANGE_CONTEXT_COMPANY" /* CuiTokenExchangeType.Company */,
45
+ companyId: this.company().companyId
56
46
  })
57
- .pipe(takeUntilDestroyed(this.destroy));
47
+ .pipe(takeUntilDestroyed(this.destroy))
48
+ .subscribe(() => {
49
+ const userBasePath = '/cuby-platform/user/works';
50
+ const adminBasePath = '/cuby-platform/admin/companies/edit';
51
+ const basePath = this.checkIsAdmin() ? adminBasePath : userBasePath;
52
+ const companyPath = this.checkIsAdmin()
53
+ ? `/${this.company().companyId}`
54
+ : `/${this.COMPANY}/${this.company().companyId}/company-structure`;
55
+ window.location.href = `${window.location.origin}${basePath}${companyPath}`;
56
+ });
58
57
  }
59
58
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CompanyItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
60
59
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CompanyItemComponent, isStandalone: true, selector: "cui-company-item", inputs: { company: { classPropertyName: "company", publicName: "company", isSignal: true, isRequired: true, transformFunction: null }, selected: { classPropertyName: "selected", publicName: "selected", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.selected": "isSelected()" } }, ngImport: i0, template: "<div\n class=\"title-company\"\n (click)=\"onGoToCompany()\"\n [cuiTooltip]=\"company().name\"\n>\n <button\n type=\"button\"\n class=\"company-button\"\n >\n <cui-letter-box\n [letter]=\"company().name[0]\"\n [backgroundColor]=\"'var(--cui-orange-500)'\"\n size=\"md\"\n />\n <div class=\"text\">\n <span class=\"title\">{{ company().name }}</span>\n <span class=\"sub-title\">{{ 'COMPANY' | transloco }}</span>\n </div>\n </button>\n\n @if (isSelected()) {\n <div class=\"icon-wrapper\">\n <cui-svg\n [icon]=\"'cuiIconCheck'\"\n color=\"var(--cui-info)\"\n />\n </div>\n }\n</div>\n", styles: [":host(.selected){background:var(--cui-badge-blue-bg);border-radius:8px}.title-company{display:flex;justify-content:space-between}.title-company:hover{width:100%;border-radius:8px;background-color:var(--cui-badge-light-blue-bg)}.company-button{display:flex;gap:8px;align-items:center;padding-left:4px;height:36px;color:var(--cui-base-900)}.icon-wrapper{display:flex;align-items:center;justify-content:center;padding:8px}.title{display:flex;flex-direction:column;font-weight:500;font-size:14px;line-height:20px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--cui-base-900);align-items:flex-start}.sub-title{font-weight:400;font-size:12px;line-height:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--cui-base-400)}.text{display:flex;flex-direction:column;align-items:flex-start}\n"], dependencies: [{ kind: "component", type: CuiLetterBoxComponent, selector: "cui-letter-box", inputs: ["letter", "backgroundColor", "size", "shape"] }, { kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i1.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "pipe", type: TranslocoPipe, name: "transloco" }, { kind: "directive", type: i2.CuiTooltipDirective, selector: "[cuiTooltip]:not(ng-container):not(ng-template)", inputs: ["cuiTooltipContext", "cuiTooltipAppearance", "cuiTooltip"] }] }); }
@@ -65,4 +64,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
65
64
  '[class.selected]': 'isSelected()'
66
65
  }, template: "<div\n class=\"title-company\"\n (click)=\"onGoToCompany()\"\n [cuiTooltip]=\"company().name\"\n>\n <button\n type=\"button\"\n class=\"company-button\"\n >\n <cui-letter-box\n [letter]=\"company().name[0]\"\n [backgroundColor]=\"'var(--cui-orange-500)'\"\n size=\"md\"\n />\n <div class=\"text\">\n <span class=\"title\">{{ company().name }}</span>\n <span class=\"sub-title\">{{ 'COMPANY' | transloco }}</span>\n </div>\n </button>\n\n @if (isSelected()) {\n <div class=\"icon-wrapper\">\n <cui-svg\n [icon]=\"'cuiIconCheck'\"\n color=\"var(--cui-info)\"\n />\n </div>\n }\n</div>\n", styles: [":host(.selected){background:var(--cui-badge-blue-bg);border-radius:8px}.title-company{display:flex;justify-content:space-between}.title-company:hover{width:100%;border-radius:8px;background-color:var(--cui-badge-light-blue-bg)}.company-button{display:flex;gap:8px;align-items:center;padding-left:4px;height:36px;color:var(--cui-base-900)}.icon-wrapper{display:flex;align-items:center;justify-content:center;padding:8px}.title{display:flex;flex-direction:column;font-weight:500;font-size:14px;line-height:20px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--cui-base-900);align-items:flex-start}.sub-title{font-weight:400;font-size:12px;line-height:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--cui-base-400)}.text{display:flex;flex-direction:column;align-items:flex-start}\n"] }]
67
66
  }] });
68
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"company-item.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/widgets/ui/user-action-context-menu/company-item/company-item.component.ts","../../../../../../../projects/core/widgets/ui/user-action-context-menu/company-item/company-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, DestroyRef, inject, input } from '@angular/core';\nimport { CuiTokenExchangeType, CuiTokenResponse, CuiUserCompany } from '@cuby-ui/api';\nimport { CuiLetterBoxComponent, CuiSvgModule } from '../../../../components';\nimport { CUI_ACTIVITY_SERVICE_TOKEN } from '../user-action-context.option';\n\nimport { CuiAuthService } from '../../../../providers';\nimport { CuiTokenData, CuiTokenRole } from '../../../../services';\nimport { TranslocoPipe } from '@jsverse/transloco';\nimport { CuiTooltip } from '../../../../directives';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { Observable } from 'rxjs';\nimport { Router } from '@angular/router';\n\n@Component({\n    selector: 'cui-company-item',\n    standalone: true,\n    imports: [CuiLetterBoxComponent, CuiSvgModule, TranslocoPipe, CuiTooltip],\n    templateUrl: './company-item.component.html',\n    styleUrl: './company-item.component.scss',\n    host: {\n        '[class.selected]': 'isSelected()'\n    }\n})\nexport class CompanyItemComponent {\n    private readonly router = inject(Router);\n    private readonly cuiAuthService = inject(CuiAuthService);\n    private readonly cuiActivityCompanyService = inject(CUI_ACTIVITY_SERVICE_TOKEN);\n\n    private readonly COMPANY: string = 'company';\n    private readonly destroy = inject(DestroyRef);\n\n    protected readonly isSelected = computed(() =>\n        this.cuiActivityCompanyService.checkIsCurrentCompany(this.company().companyId)\n    );\n\n    protected readonly urlCompanyTemplate = computed(() => {\n        const origin = window.location.origin;\n        const userBasePath = '/cuby-platform/user/works';\n        const adminBasePath = '/cuby-platform/admin/companies/edit';\n\n        return {\n            userLink: `${origin}${userBasePath}/${this.COMPANY}/{id}/company-structure`,\n            adminLink: `${origin}${adminBasePath}/{id}`\n        };\n    });\n\n    public readonly company = input.required<CuiUserCompany>();\n    public readonly selected = input(false);\n\n    public getRoles(): string[] {\n        const token = this.cuiAuthService.getAccessTokenData<CuiTokenData>();\n\n        return token.realm_access.roles;\n    }\n\n    public checkIsAdmin(): boolean {\n        const roles = this.getRoles();\n\n        return roles.includes(CuiTokenRole.Admin);\n    }\n\n    protected onGoToCompany(): void {\n        if (this.isSelected()) {\n            return;\n        }\n\n        const { adminLink, userLink } = this.urlCompanyTemplate();\n        const linkTemplate = this.checkIsAdmin() ? adminLink : userLink;\n        const url = linkTemplate.replace('{id}', this.company().companyId);\n\n        this.wentWorkspace(CuiTokenExchangeType.Company, this.company().companyId).subscribe(() => {\n            this.router.navigateByUrl(url);\n        });\n    }\n\n    private wentWorkspace(type: CuiTokenExchangeType, companyId: string): Observable<CuiTokenResponse> {\n        return this.cuiAuthService\n            .exchangeToken({\n                type,\n                companyId\n            })\n            .pipe(takeUntilDestroyed(this.destroy));\n    }\n}\n","<div\n    class=\"title-company\"\n    (click)=\"onGoToCompany()\"\n    [cuiTooltip]=\"company().name\"\n>\n    <button\n        type=\"button\"\n        class=\"company-button\"\n    >\n        <cui-letter-box\n            [letter]=\"company().name[0]\"\n            [backgroundColor]=\"'var(--cui-orange-500)'\"\n            size=\"md\"\n        />\n        <div class=\"text\">\n            <span class=\"title\">{{ company().name }}</span>\n            <span class=\"sub-title\">{{ 'COMPANY' | transloco }}</span>\n        </div>\n    </button>\n\n    @if (isSelected()) {\n        <div class=\"icon-wrapper\">\n            <cui-svg\n                [icon]=\"'cuiIconCheck'\"\n                color=\"var(--cui-info)\"\n            />\n        </div>\n    }\n</div>\n"]}
67
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"company-item.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/widgets/ui/user-action-context-menu/company-item/company-item.component.ts","../../../../../../../projects/core/widgets/ui/user-action-context-menu/company-item/company-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, DestroyRef, inject, input } from '@angular/core';\nimport { CuiTokenExchangeType, CuiUserCompany } from '@cuby-ui/api';\nimport { CuiLetterBoxComponent, CuiSvgModule } from '../../../../components';\nimport { CUI_ACTIVITY_SERVICE_TOKEN } from '../user-action-context.option';\n\nimport { CuiAuthService } from '../../../../providers';\nimport { CuiTokenData, CuiTokenRole } from '../../../../services';\nimport { TranslocoPipe } from '@jsverse/transloco';\nimport { CuiTooltip } from '../../../../directives';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\n@Component({\n    selector: 'cui-company-item',\n    standalone: true,\n    imports: [CuiLetterBoxComponent, CuiSvgModule, TranslocoPipe, CuiTooltip],\n    templateUrl: './company-item.component.html',\n    styleUrl: './company-item.component.scss',\n    host: {\n        '[class.selected]': 'isSelected()'\n    }\n})\nexport class CompanyItemComponent {\n    private readonly cuiAuthService = inject(CuiAuthService);\n    private readonly cuiActivityCompanyService = inject(CUI_ACTIVITY_SERVICE_TOKEN);\n\n    private readonly COMPANY: string = 'company';\n    private readonly destroy = inject(DestroyRef);\n\n    protected readonly isSelected = computed(() =>\n        this.cuiActivityCompanyService.checkIsCurrentCompany(this.company().companyId)\n    );\n\n    protected readonly urlCompanyTemplate = computed(() => {\n        const origin = window.location.origin;\n        const userBasePath = '/cuby-platform/user/works';\n        const adminBasePath = '/cuby-platform/admin/companies/edit';\n\n        return {\n            userLink: `${origin}${userBasePath}/${this.COMPANY}/{id}/company-structure`,\n            adminLink: `${origin}${adminBasePath}/{id}`\n        };\n    });\n\n    public readonly company = input.required<CuiUserCompany>();\n    public readonly selected = input(false);\n\n    public getRoles(): string[] {\n        const token = this.cuiAuthService.getAccessTokenData<CuiTokenData>();\n\n        return token.realm_access.roles;\n    }\n\n    public checkIsAdmin(): boolean {\n        const roles = this.getRoles();\n\n        return roles.includes(CuiTokenRole.Admin);\n    }\n\n    protected onGoToCompany(): void {\n        if (this.isSelected()) {\n            return;\n        }\n\n        this.cuiAuthService\n            .exchangeToken({\n                type: CuiTokenExchangeType.Company,\n                companyId: this.company().companyId\n            })\n            .pipe(takeUntilDestroyed(this.destroy))\n            .subscribe(() => {\n                const userBasePath = '/cuby-platform/user/works';\n                const adminBasePath = '/cuby-platform/admin/companies/edit';\n\n                const basePath = this.checkIsAdmin() ? adminBasePath : userBasePath;\n                const companyPath = this.checkIsAdmin()\n                    ? `/${this.company().companyId}`\n                    : `/${this.COMPANY}/${this.company().companyId}/company-structure`;\n\n                window.location.href = `${window.location.origin}${basePath}${companyPath}`;\n            });\n    }\n}\n","<div\n    class=\"title-company\"\n    (click)=\"onGoToCompany()\"\n    [cuiTooltip]=\"company().name\"\n>\n    <button\n        type=\"button\"\n        class=\"company-button\"\n    >\n        <cui-letter-box\n            [letter]=\"company().name[0]\"\n            [backgroundColor]=\"'var(--cui-orange-500)'\"\n            size=\"md\"\n        />\n        <div class=\"text\">\n            <span class=\"title\">{{ company().name }}</span>\n            <span class=\"sub-title\">{{ 'COMPANY' | transloco }}</span>\n        </div>\n    </button>\n\n    @if (isSelected()) {\n        <div class=\"icon-wrapper\">\n            <cui-svg\n                [icon]=\"'cuiIconCheck'\"\n                color=\"var(--cui-info)\"\n            />\n        </div>\n    }\n</div>\n"]}
@@ -5480,12 +5480,15 @@ class CuiFileUploader {
5480
5480
  });
5481
5481
  upload
5482
5482
  .then((response) => response.json())
5483
- .then((response) => this.onUpload(response, file))
5483
+ .then((response) => this.onUpload(this.convertToFileSuccessResponse(response), file))
5484
5484
  .catch(() => this.onError())
5485
5485
  .finally(() => this.config.load(CuiFileUploaderStatus.Completed));
5486
5486
  }
5487
5487
  uploadByUrl(url) {
5488
- this.onUpload({ success: 1, file: { url } });
5488
+ this.onUpload({ id: crypto.randomUUID(), success: 1, file: { url } });
5489
+ }
5490
+ convertToFileSuccessResponse(response) {
5491
+ return { id: response.id, success: 1, file: { url: response.downloadUrl } };
5489
5492
  }
5490
5493
  }
5491
5494
 
@@ -10359,7 +10362,6 @@ const CUI_ACTIVITY_SERVICE_TOKEN = new InjectionToken('ACTIVITY_SERVICE_TOKEN');
10359
10362
  class CuiActivityItemComponent {
10360
10363
  constructor() {
10361
10364
  this.transloco = inject(TranslocoService);
10362
- this.router = inject(Router);
10363
10365
  this.destroy = inject(DestroyRef);
10364
10366
  this.cuiAuthService = inject(CuiAuthService);
10365
10367
  this.cuiActivityService = inject(CUI_ACTIVITY_SERVICE_TOKEN);
@@ -10393,7 +10395,7 @@ class CuiActivityItemComponent {
10393
10395
  ["DEVELOPER" /* CuiUserCompanyActivityType.Developer */]: "cuby-project" /* CuiApiUrl.Project */,
10394
10396
  ["MANUFACTURE" /* CuiUserCompanyActivityType.Manufacture */]: "cuby-manufacturing" /* CuiApiUrl.Manufacturing */
10395
10397
  };
10396
- this.router.navigate([activityMap[type]]);
10398
+ window.location.href = `${window.location.origin}/${activityMap[type]}`;
10397
10399
  });
10398
10400
  }
10399
10401
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiActivityItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
@@ -10408,7 +10410,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
10408
10410
 
10409
10411
  class CompanyItemComponent {
10410
10412
  constructor() {
10411
- this.router = inject(Router);
10412
10413
  this.cuiAuthService = inject(CuiAuthService);
10413
10414
  this.cuiActivityCompanyService = inject(CUI_ACTIVITY_SERVICE_TOKEN);
10414
10415
  this.COMPANY = 'company';
@@ -10438,20 +10439,21 @@ class CompanyItemComponent {
10438
10439
  if (this.isSelected()) {
10439
10440
  return;
10440
10441
  }
10441
- const { adminLink, userLink } = this.urlCompanyTemplate();
10442
- const linkTemplate = this.checkIsAdmin() ? adminLink : userLink;
10443
- const url = linkTemplate.replace('{id}', this.company().companyId);
10444
- this.wentWorkspace("EXCHANGE_CONTEXT_COMPANY" /* CuiTokenExchangeType.Company */, this.company().companyId).subscribe(() => {
10445
- this.router.navigateByUrl(url);
10446
- });
10447
- }
10448
- wentWorkspace(type, companyId) {
10449
- return this.cuiAuthService
10442
+ this.cuiAuthService
10450
10443
  .exchangeToken({
10451
- type,
10452
- companyId
10444
+ type: "EXCHANGE_CONTEXT_COMPANY" /* CuiTokenExchangeType.Company */,
10445
+ companyId: this.company().companyId
10453
10446
  })
10454
- .pipe(takeUntilDestroyed(this.destroy));
10447
+ .pipe(takeUntilDestroyed(this.destroy))
10448
+ .subscribe(() => {
10449
+ const userBasePath = '/cuby-platform/user/works';
10450
+ const adminBasePath = '/cuby-platform/admin/companies/edit';
10451
+ const basePath = this.checkIsAdmin() ? adminBasePath : userBasePath;
10452
+ const companyPath = this.checkIsAdmin()
10453
+ ? `/${this.company().companyId}`
10454
+ : `/${this.COMPANY}/${this.company().companyId}/company-structure`;
10455
+ window.location.href = `${window.location.origin}${basePath}${companyPath}`;
10456
+ });
10455
10457
  }
10456
10458
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CompanyItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
10457
10459
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CompanyItemComponent, isStandalone: true, selector: "cui-company-item", inputs: { company: { classPropertyName: "company", publicName: "company", isSignal: true, isRequired: true, transformFunction: null }, selected: { classPropertyName: "selected", publicName: "selected", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.selected": "isSelected()" } }, ngImport: i0, template: "<div\n class=\"title-company\"\n (click)=\"onGoToCompany()\"\n [cuiTooltip]=\"company().name\"\n>\n <button\n type=\"button\"\n class=\"company-button\"\n >\n <cui-letter-box\n [letter]=\"company().name[0]\"\n [backgroundColor]=\"'var(--cui-orange-500)'\"\n size=\"md\"\n />\n <div class=\"text\">\n <span class=\"title\">{{ company().name }}</span>\n <span class=\"sub-title\">{{ 'COMPANY' | transloco }}</span>\n </div>\n </button>\n\n @if (isSelected()) {\n <div class=\"icon-wrapper\">\n <cui-svg\n [icon]=\"'cuiIconCheck'\"\n color=\"var(--cui-info)\"\n />\n </div>\n }\n</div>\n", styles: [":host(.selected){background:var(--cui-badge-blue-bg);border-radius:8px}.title-company{display:flex;justify-content:space-between}.title-company:hover{width:100%;border-radius:8px;background-color:var(--cui-badge-light-blue-bg)}.company-button{display:flex;gap:8px;align-items:center;padding-left:4px;height:36px;color:var(--cui-base-900)}.icon-wrapper{display:flex;align-items:center;justify-content:center;padding:8px}.title{display:flex;flex-direction:column;font-weight:500;font-size:14px;line-height:20px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--cui-base-900);align-items:flex-start}.sub-title{font-weight:400;font-size:12px;line-height:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--cui-base-400)}.text{display:flex;flex-direction:column;align-items:flex-start}\n"], dependencies: [{ kind: "component", type: CuiLetterBoxComponent, selector: "cui-letter-box", inputs: ["letter", "backgroundColor", "size", "shape"] }, { kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "pipe", type: TranslocoPipe, name: "transloco" }, { kind: "directive", type: CuiTooltipDirective, selector: "[cuiTooltip]:not(ng-container):not(ng-template)", inputs: ["cuiTooltipContext", "cuiTooltipAppearance", "cuiTooltip"] }] }); }