@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.
- package/editor/interfaces/file-response-data.d.ts +5 -0
- package/editor/tools/video.tool.d.ts +1 -1
- package/editor/utils/file-uploader.d.ts +3 -2
- package/esm2022/editor/interfaces/file-response-data.mjs +1 -1
- package/esm2022/editor/tools/attaches.tool.mjs +1 -1
- package/esm2022/editor/tools/image.tool.mjs +1 -1
- package/esm2022/editor/tools/video.tool.mjs +1 -1
- package/esm2022/editor/utils/file-uploader.mjs +6 -3
- package/esm2022/widgets/ui/user-action-context-menu/activity-item/activity-item.component.mjs +2 -4
- package/esm2022/widgets/ui/user-action-context-menu/company-item/company-item.component.mjs +14 -15
- package/fesm2022/cuby-ui-core.mjs +19 -17
- package/fesm2022/cuby-ui-core.mjs.map +1 -1
- package/package.json +4 -4
- package/widgets/ui/user-action-context-menu/activity-item/activity-item.component.d.ts +0 -1
- package/widgets/ui/user-action-context-menu/company-item/company-item.component.d.ts +0 -2
|
@@ -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,
|
|
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 {
|
|
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:
|
|
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,
|
|
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,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvZWRpdG9yL3V0aWxzL2ZpbGUtdXBsb2FkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFOLElBQVkscUJBR1g7QUFIRCxXQUFZLHFCQUFxQjtJQUM3Qiw0Q0FBbUIsQ0FBQTtJQUNuQixnREFBdUIsQ0FBQTtBQUMzQixDQUFDLEVBSFcscUJBQXFCLEtBQXJCLHFCQUFxQixRQUdoQztBQVlELE1BQU0sT0FBTyxlQUFlO0lBTXhCLFlBQVksTUFBNkIsRUFBRSxRQUFrQixFQUFFLE9BQW1CO1FBTGpFLG1CQUFjLEdBQUcsTUFBTSxDQUFDO1FBV2xDLGVBQVUsR0FBRyxDQUFDLEVBQUUsWUFBWSxFQUEwQyxFQUFRLEVBQUU7WUFDbkYsTUFBTSxLQUFLLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUM5QyxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLEtBQUssSUFBSSxHQUFHLENBQUM7WUFDeEMsS0FBSyxDQUFDLElBQUksR0FBRyxNQUFNLENBQUM7WUFDcEIsS0FBSyxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7WUFFckIsS0FBSyxDQUFDLFFBQVEsR0FBRyxHQUFTLEVBQUU7Z0JBQ3hCLE1BQU0sS0FBSyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUM7Z0JBRTFCLElBQUksQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLENBQUM7b0JBQ2pCLE9BQU87Z0JBQ1gsQ0FBQztnQkFFRCxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxZQUFZLENBQUMsQ0FBQztZQUN0QyxDQUFDLENBQUM7WUFFRixLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDbEIsQ0FBQyxDQUFDO1FBdEJFLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO0lBQzNCLENBQUM7SUFxQk0sT0FBTyxDQUFDLEtBQWUsRUFBRSxZQUFrQztRQUM5RCxNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRTNCLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNSLE9BQU87UUFDWCxDQUFDO1FBRUQsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3ZCLENBQUM7SUFFTSxVQUFVLENBQUMsSUFBVTtRQUN4QixNQUFNLFFBQVEsR0FBRyxJQUFJLFFBQVEsRUFBRSxDQUFDO1FBQ2hDLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxJQUFJLE1BQU0sQ0FBQztRQUM5QyxRQUFRLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUVqQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUN4QixPQUFPO1FBQ1gsQ0FBQztRQUVELElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRWhELE1BQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRTtZQUN2QyxPQUFPLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyx3QkFBd0I7WUFDN0MsTUFBTSxFQUFFLElBQUksQ0FBQyxjQUFjO1lBQzNCLElBQUksRUFBRSxRQUFRO1NBQ2pCLENBQUMsQ0FBQztRQUVILE1BQU07YUFDRCxJQUFJLENBQUMsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQWtDLENBQUM7YUFDbkUsSUFBSSxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyw0QkFBNEIsQ0FBQyxRQUFRLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQzthQUNwRixLQUFLLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO2FBQzNCLE9BQU8sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDO0lBQzFFLENBQUM7SUFFTSxXQUFXLENBQUMsR0FBVztRQUMxQixJQUFJLENBQUMsUUFBUSxDQUFDLEVBQUUsRUFBRSxFQUFFLE1BQU0sQ0FBQyxVQUFVLEVBQUUsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUMxRSxDQUFDO0lBRU8sNEJBQTRCLENBQUMsUUFBNkI7UUFDOUQsT0FBTyxFQUFFLEVBQUUsRUFBRSxRQUFRLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsR0FBRyxFQUFFLFFBQVEsQ0FBQyxXQUFXLEVBQUUsRUFBRSxDQUFDO0lBQ2hGLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQ3VpRmlsZVJlc3BvbnNlRGF0YSwgQ3VpUmVzb3VyY2VGaWxlIH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XHJcblxyXG5leHBvcnQgZW51bSBDdWlGaWxlVXBsb2FkZXJTdGF0dXMge1xyXG4gICAgTG9hZGluZyA9ICdsb2FkaW5nJyxcclxuICAgIENvbXBsZXRlZCA9ICdjb21wbGV0ZWQnXHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ3VpRmlsZVVwbG9hZGVyQ29uZmlnIHtcclxuICAgIHJlYWRvbmx5IGVuZHBvaW50OiBzdHJpbmc7XHJcbiAgICByZWFkb25seSB0eXBlczogc3RyaW5nO1xyXG4gICAgcmVhZG9ubHkgZmllbGQ6IHN0cmluZztcclxuICAgIHJlYWRvbmx5IGFkZGl0aW9uYWxSZXF1ZXN0SGVhZGVyczogSGVhZGVyc0luaXQ7XHJcbiAgICByZWFkb25seSBsb2FkOiAoc3RhdHVzOiBDdWlGaWxlVXBsb2FkZXJTdGF0dXMpID0+IHZvaWQ7XHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIE9uVXBsb2FkID0gKHJlc3BvbnNlOiBDdWlSZXNvdXJjZUZpbGUsIGZpbGU/OiBGaWxlKSA9PiB2b2lkO1xyXG5cclxuZXhwb3J0IGNsYXNzIEN1aUZpbGVVcGxvYWRlciB7XHJcbiAgICBwcml2YXRlIHJlYWRvbmx5IFJFUVVFU1RfTUVUSE9EID0gJ1BPU1QnO1xyXG4gICAgcHJpdmF0ZSByZWFkb25seSBjb25maWc6IEN1aUZpbGVVcGxvYWRlckNvbmZpZztcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgb25VcGxvYWQ6IE9uVXBsb2FkO1xyXG4gICAgcHJpdmF0ZSByZWFkb25seSBvbkVycm9yOiAoKSA9PiB2b2lkO1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKGNvbmZpZzogQ3VpRmlsZVVwbG9hZGVyQ29uZmlnLCBvblVwbG9hZDogT25VcGxvYWQsIG9uRXJyb3I6ICgpID0+IHZvaWQpIHtcclxuICAgICAgICB0aGlzLmNvbmZpZyA9IGNvbmZpZztcclxuICAgICAgICB0aGlzLm9uVXBsb2FkID0gb25VcGxvYWQ7XHJcbiAgICAgICAgdGhpcy5vbkVycm9yID0gb25FcnJvcjtcclxuICAgIH1cclxuXHJcbiAgICBwdWJsaWMgc2VsZWN0RmlsZSA9ICh7IGZpbGVTZWxlY3RlZCB9OiB7IGZpbGVTZWxlY3RlZDogKGZpbGU6IEZpbGUpID0+IHZvaWQgfSk6IHZvaWQgPT4ge1xyXG4gICAgICAgIGNvbnN0IGlucHV0ID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnaW5wdXQnKTtcclxuICAgICAgICBjb25zdCB0eXBlcyA9IHRoaXMuY29uZmlnPy50eXBlcyB8fCAnKic7XHJcbiAgICAgICAgaW5wdXQudHlwZSA9ICdmaWxlJztcclxuICAgICAgICBpbnB1dC5hY2NlcHQgPSB0eXBlcztcclxuXHJcbiAgICAgICAgaW5wdXQub25jaGFuZ2UgPSAoKTogdm9pZCA9PiB7XHJcbiAgICAgICAgICAgIGNvbnN0IGZpbGVzID0gaW5wdXQuZmlsZXM7XHJcblxyXG4gICAgICAgICAgICBpZiAoIWZpbGVzPy5sZW5ndGgpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICAgICAgfVxyXG5cclxuICAgICAgICAgICAgdGhpcy5nZXRGaWxlKGZpbGVzLCBmaWxlU2VsZWN0ZWQpO1xyXG4gICAgICAgIH07XHJcblxyXG4gICAgICAgIGlucHV0LmNsaWNrKCk7XHJcbiAgICB9O1xyXG5cclxuICAgIHB1YmxpYyBnZXRGaWxlKGZpbGVzOiBGaWxlTGlzdCwgZmlsZVNlbGVjdGVkOiAoZmlsZTogRmlsZSkgPT4gdm9pZCk6IHZvaWQge1xyXG4gICAgICAgIGNvbnN0IGZpbGUgPSBmaWxlcy5pdGVtKDApO1xyXG5cclxuICAgICAgICBpZiAoIWZpbGUpIHtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgZmlsZVNlbGVjdGVkKGZpbGUpO1xyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyB1cGxvYWRGaWxlKGZpbGU6IEZpbGUpOiB2b2lkIHtcclxuICAgICAgICBjb25zdCBmb3JtRGF0YSA9IG5ldyBGb3JtRGF0YSgpO1xyXG4gICAgICAgIGNvbnN0IGZvcm1GaWVsZCA9IHRoaXMuY29uZmlnLmZpZWxkIHx8ICdmaWxlJztcclxuICAgICAgICBmb3JtRGF0YS5hcHBlbmQoZm9ybUZpZWxkLCBmaWxlKTtcclxuXHJcbiAgICAgICAgaWYgKCF0aGlzLmNvbmZpZy5lbmRwb2ludCkge1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICB0aGlzLmNvbmZpZy5sb2FkKEN1aUZpbGVVcGxvYWRlclN0YXR1cy5Mb2FkaW5nKTtcclxuXHJcbiAgICAgICAgY29uc3QgdXBsb2FkID0gZmV0Y2godGhpcy5jb25maWcuZW5kcG9pbnQsIHtcclxuICAgICAgICAgICAgaGVhZGVyczogdGhpcy5jb25maWcuYWRkaXRpb25hbFJlcXVlc3RIZWFkZXJzLFxyXG4gICAgICAgICAgICBtZXRob2Q6IHRoaXMuUkVRVUVTVF9NRVRIT0QsXHJcbiAgICAgICAgICAgIGJvZHk6IGZvcm1EYXRhXHJcbiAgICAgICAgfSk7XHJcblxyXG4gICAgICAgIHVwbG9hZFxyXG4gICAgICAgICAgICAudGhlbigocmVzcG9uc2UpID0+IHJlc3BvbnNlLmpzb24oKSBhcyBQcm9taXNlPEN1aUZpbGVSZXNwb25zZURhdGE+KVxyXG4gICAgICAgICAgICAudGhlbigocmVzcG9uc2UpID0+IHRoaXMub25VcGxvYWQodGhpcy5jb252ZXJ0VG9GaWxlU3VjY2Vzc1Jlc3BvbnNlKHJlc3BvbnNlKSwgZmlsZSkpXHJcbiAgICAgICAgICAgIC5jYXRjaCgoKSA9PiB0aGlzLm9uRXJyb3IoKSlcclxuICAgICAgICAgICAgLmZpbmFsbHkoKCkgPT4gdGhpcy5jb25maWcubG9hZChDdWlGaWxlVXBsb2FkZXJTdGF0dXMuQ29tcGxldGVkKSk7XHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIHVwbG9hZEJ5VXJsKHVybDogc3RyaW5nKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5vblVwbG9hZCh7IGlkOiBjcnlwdG8ucmFuZG9tVVVJRCgpLCBzdWNjZXNzOiAxLCBmaWxlOiB7IHVybCB9IH0pO1xyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgY29udmVydFRvRmlsZVN1Y2Nlc3NSZXNwb25zZShyZXNwb25zZTogQ3VpRmlsZVJlc3BvbnNlRGF0YSk6IEN1aVJlc291cmNlRmlsZSB7XHJcbiAgICAgICAgcmV0dXJuIHsgaWQ6IHJlc3BvbnNlLmlkLCBzdWNjZXNzOiAxLCBmaWxlOiB7IHVybDogcmVzcG9uc2UuZG93bmxvYWRVcmwgfSB9O1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
|
package/esm2022/widgets/ui/user-action-context-menu/activity-item/activity-item.component.mjs
CHANGED
|
@@ -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
|
-
|
|
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,
|
|
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
|
-
|
|
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,
|
|
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
|
-
|
|
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
|
-
|
|
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"] }] }); }
|