coer-elements 0.0.19 → 0.0.20

Sign up to get free protection for your applications and to get access to all the features.
Files changed (62) hide show
  1. package/components/lib/coer-button/coer-button.component.d.ts +2 -2
  2. package/components/lib/coer-filebox/coer-filebox.component.d.ts +1 -1
  3. package/components/lib/coer-grid/coer-grid.component.d.ts +1 -1
  4. package/components/lib/coer-grid/coer-grid.extension.d.ts +1 -1
  5. package/components/lib/coer-grid/coer-grid.templates.d.ts +1 -1
  6. package/components/lib/coer-numberbox/coer-numberbox.component.d.ts +1 -1
  7. package/components/lib/coer-page-title/coer-page-title.component.d.ts +1 -1
  8. package/components/lib/coer-switch/coer-switch.component.d.ts +1 -1
  9. package/components/lib/coer-textarea/coer-textarea.component.d.ts +1 -1
  10. package/components/lib/coer-textbox/coer-textbox.component.d.ts +1 -1
  11. package/directives/lib/life-cycle.directive.d.ts +5 -3
  12. package/esm2022/components/lib/coer-filebox/coer-filebox.component.mjs +1 -1
  13. package/esm2022/components/lib/coer-grid/coer-grid.component.mjs +1 -1
  14. package/esm2022/components/lib/coer-grid/coer-grid.extension.mjs +1 -1
  15. package/esm2022/components/lib/coer-grid/coer-grid.templates.mjs +1 -1
  16. package/esm2022/components/lib/coer-page-title/coer-page-title.component.mjs +1 -1
  17. package/esm2022/components/lib/coer-tab/coer-tab.component.mjs +1 -1
  18. package/esm2022/directives/lib/life-cycle.directive.mjs +6 -2
  19. package/esm2022/interfaces/index.mjs +36 -2
  20. package/esm2022/interfaces/lib/coer-menu/menu-selected.interface.mjs +2 -0
  21. package/esm2022/interfaces/lib/service/http-request.interface.mjs +2 -0
  22. package/esm2022/interfaces/lib/service/http-response.interface.mjs +2 -0
  23. package/esm2022/interfaces/lib/service/patch.interface.mjs +2 -0
  24. package/esm2022/signals/index.mjs +3 -1
  25. package/esm2022/signals/lib/is-menu-open.signal.mjs +3 -0
  26. package/esm2022/signals/lib/menu.signal.mjs +3 -0
  27. package/esm2022/tools/lib/breadcrumbs.class.mjs +1 -1
  28. package/esm2022/tools/lib/menu.class.mjs +1 -1
  29. package/esm2022/tools/lib/page.class.mjs +1 -1
  30. package/esm2022/tools/lib/screen.class.mjs +1 -1
  31. package/esm2022/tools/lib/source.class.mjs +1 -1
  32. package/fesm2022/coer-elements.mjs +11 -3
  33. package/fesm2022/coer-elements.mjs.map +1 -1
  34. package/interfaces/index.d.ts +30 -1
  35. package/interfaces/lib/coer-menu/menu-selected.interface.d.ts +10 -0
  36. package/interfaces/lib/service/http-request.interface.d.ts +10 -0
  37. package/interfaces/lib/service/http-response.interface.d.ts +6 -0
  38. package/package.json +1 -1
  39. package/signals/index.d.ts +2 -0
  40. package/signals/lib/is-menu-open.signal.d.ts +1 -0
  41. package/signals/lib/menu.signal.d.ts +2 -0
  42. package/src/interfaces/index.ts +48 -3
  43. package/src/interfaces/lib/service/http-request.interface.ts +11 -0
  44. package/src/interfaces/lib/service/http-response.interface.ts +6 -0
  45. package/tools/lib/breadcrumbs.class.d.ts +1 -1
  46. package/tools/lib/menu.class.d.ts +1 -1
  47. package/tools/lib/page.class.d.ts +1 -2
  48. package/tools/lib/screen.class.d.ts +1 -1
  49. package/tools/lib/source.class.d.ts +1 -1
  50. package/esm2022/interfaces/coer-filebox/index.mjs +0 -3
  51. package/esm2022/interfaces/coer-grid/index.mjs +0 -21
  52. package/esm2022/interfaces/lib/patch.interface.mjs +0 -2
  53. package/esm2022/interfaces/page-title/index.mjs +0 -3
  54. package/interfaces/coer-filebox/index.d.ts +0 -2
  55. package/interfaces/coer-grid/index.d.ts +0 -20
  56. package/interfaces/page-title/index.d.ts +0 -2
  57. package/src/interfaces/coer-filebox/index.ts +0 -2
  58. package/src/interfaces/coer-grid/index.ts +0 -20
  59. package/src/interfaces/coer-menu/index.ts +0 -3
  60. package/src/interfaces/page-title/index.ts +0 -2
  61. /package/interfaces/lib/{patch.interface.d.ts → service/patch.interface.d.ts} +0 -0
  62. /package/src/interfaces/lib/{patch.interface.ts → service/patch.interface.ts} +0 -0
@@ -8,7 +8,7 @@ export declare class CoerButton implements OnInit, OnDestroy {
8
8
  id: string;
9
9
  color: import("@angular/core").InputSignal<"warning" | "danger" | "success" | "default" | "primary" | "secondary" | "navigation">;
10
10
  type: import("@angular/core").InputSignal<"icon" | "filled" | "outline" | "icon-outline" | "icon-no-border">;
11
- icon: import("@angular/core").InputSignal<"" | "delete" | "new" | "save" | "cancel" | "import" | "excel" | "menu" | "edit" | "go" | "back">;
11
+ icon: import("@angular/core").InputSignal<"" | "cancel" | "menu" | "delete" | "new" | "save" | "import" | "excel" | "edit" | "go" | "back">;
12
12
  iconPosition: import("@angular/core").InputSignal<"left" | "right">;
13
13
  animation: import("@angular/core").InputSignal<boolean>;
14
14
  isLoading: import("@angular/core").InputSignal<boolean>;
@@ -23,7 +23,7 @@ export declare class CoerButton implements OnInit, OnDestroy {
23
23
  marginBottom: import("@angular/core").InputSignal<string>;
24
24
  marginLeft: import("@angular/core").InputSignal<string>;
25
25
  path: import("@angular/core").InputSignal<string | (string | number)[]>;
26
- tooltipPosition: import("@angular/core").InputSignal<"left" | "right" | "top" | "bottom">;
26
+ tooltipPosition: import("@angular/core").InputSignal<"top" | "bottom" | "left" | "right">;
27
27
  set tooltip(value: string);
28
28
  onClick: EventEmitter<MouseEvent>;
29
29
  protected _isEnable: import("@angular/core").Signal<boolean>;
@@ -1,5 +1,5 @@
1
1
  import { ElementRef } from '@angular/core';
2
- import { IFile, IFileImage } from '../../../interfaces/coer-filebox';
2
+ import { IFile, IFileImage } from '../../../interfaces';
3
3
  import { CoerAlert } from '../../lib/coer-alert/coer-alert.component';
4
4
  import { CoerModal } from '../../lib/coer-modal/coer-modal.component';
5
5
  import * as i0 from "@angular/core";
@@ -1,5 +1,5 @@
1
1
  import { CoerGridExtension } from './coer-grid.extension';
2
- import { IGridLength } from '../../../interfaces/coer-grid';
2
+ import { IGridLength } from '../../../interfaces';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class CoerGrid<T> extends CoerGridExtension<T> {
5
5
  dataSource: import("@angular/core").Signal<T[]>;
@@ -1,4 +1,4 @@
1
- import { IGridButtonByRow, IGridColumn, IGridDataSource, IGridImport, IGridHeaderButton, IGridHeaderExportButton, IGridKeyupEnter, IGridSearch, IGridInputSwitchChange, IGridInputTextbox, IGridSort, IGridCheckbox, IGridInputCheckbox, IGridHeader } from "../../../interfaces/coer-grid";
1
+ import { IGridButtonByRow, IGridColumn, IGridDataSource, IGridImport, IGridHeaderButton, IGridHeaderExportButton, IGridKeyupEnter, IGridSearch, IGridInputSwitchChange, IGridInputTextbox, IGridSort, IGridCheckbox, IGridInputCheckbox, IGridHeader } from "../../../interfaces";
2
2
  import { AfterViewInit, ElementRef } from "@angular/core";
3
3
  import { CoerAlert } from "../../lib/coer-alert/coer-alert.component";
4
4
  import { CoerCheckbox } from "../../lib/coer-checkbox/coer-checkbox.component";
@@ -1,4 +1,4 @@
1
- import { IGridCoerSwitch, IGridCoerTextBox, IGridItem } from "../../../interfaces/coer-grid";
1
+ import { IGridCoerSwitch, IGridCoerTextBox, IGridItem } from "../../../interfaces";
2
2
  export declare const GridTemplates: {
3
3
  /** Template for boolean property */
4
4
  isActiveTemplate: (item: IGridItem<any>) => string;
@@ -31,7 +31,7 @@ export declare class CoerNumberBox extends ControlValue implements OnInit {
31
31
  isReadonly: import("@angular/core").InputSignal<boolean>;
32
32
  isLoading: import("@angular/core").InputSignal<boolean>;
33
33
  selectOnFocus: import("@angular/core").InputSignal<boolean>;
34
- textPosition: import("@angular/core").InputSignal<"left" | "right" | "center">;
34
+ textPosition: import("@angular/core").InputSignal<"center" | "left" | "right">;
35
35
  onKeyupEnter: import("@angular/core").OutputEmitterRef<string | number>;
36
36
  onInput: import("@angular/core").OutputEmitterRef<string | number>;
37
37
  ngOnInit(): void;
@@ -1,4 +1,4 @@
1
- import { IBreadcrumb, IGoBack } from '../../../interfaces/page-title';
1
+ import { IBreadcrumb, IGoBack } from '../../../interfaces';
2
2
  import * as i0 from "@angular/core";
3
3
  export declare class CoerPageTitle {
4
4
  title: string | null;
@@ -15,7 +15,7 @@ export declare class CoerSwitch extends ControlValue implements OnInit, OnDestro
15
15
  isDisabled: import("@angular/core").InputSignal<boolean>;
16
16
  isLoading: import("@angular/core").InputSignal<boolean>;
17
17
  isInvisible: import("@angular/core").InputSignal<boolean>;
18
- tooltipPosition: import("@angular/core").InputSignal<"left" | "right" | "top" | "bottom">;
18
+ tooltipPosition: import("@angular/core").InputSignal<"top" | "bottom" | "left" | "right">;
19
19
  set tooltip(value: string);
20
20
  onChange: import("@angular/core").OutputEmitterRef<boolean>;
21
21
  ngOnInit(): void;
@@ -28,7 +28,7 @@ export declare class CoerTextarea extends ControlValue implements OnInit {
28
28
  isLoading: import("@angular/core").InputSignal<boolean>;
29
29
  showFooter: import("@angular/core").InputSignal<boolean>;
30
30
  resize: import("@angular/core").InputSignal<boolean>;
31
- textPosition: import("@angular/core").InputSignal<"left" | "right" | "center">;
31
+ textPosition: import("@angular/core").InputSignal<"center" | "left" | "right">;
32
32
  onInput: import("@angular/core").OutputEmitterRef<string | number>;
33
33
  ngOnInit(): void;
34
34
  get value(): string | number | null | undefined;
@@ -29,7 +29,7 @@ export declare class CoerTextBox extends ControlValue implements OnInit {
29
29
  isReadonly: import("@angular/core").InputSignal<boolean>;
30
30
  isLoading: import("@angular/core").InputSignal<boolean>;
31
31
  selectOnFocus: import("@angular/core").InputSignal<boolean>;
32
- textPosition: import("@angular/core").InputSignal<"left" | "right" | "center">;
32
+ textPosition: import("@angular/core").InputSignal<"center" | "left" | "right">;
33
33
  onKeyupEnter: import("@angular/core").OutputEmitterRef<string | number>;
34
34
  onInput: import("@angular/core").OutputEmitterRef<string | number>;
35
35
  onClickClear: import("@angular/core").OutputEmitterRef<void>;
@@ -1,14 +1,16 @@
1
- import { OnDestroy, OnInit, ElementRef, AfterViewInit } from '@angular/core';
1
+ import { OnDestroy, OnInit, ElementRef, AfterViewInit, OnChanges, SimpleChanges } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
- export declare class LifeCycleDirective implements OnInit, AfterViewInit, OnDestroy {
3
+ export declare class LifeCycleDirective implements OnChanges, OnInit, AfterViewInit, OnDestroy {
4
4
  private element;
5
+ OnChanges: import("@angular/core").OutputEmitterRef<SimpleChanges>;
5
6
  onInit: import("@angular/core").OutputEmitterRef<HTMLElement>;
6
7
  afterViewInit: import("@angular/core").OutputEmitterRef<HTMLElement>;
7
8
  onDestroy: import("@angular/core").OutputEmitterRef<HTMLElement>;
8
9
  constructor(element: ElementRef);
10
+ ngOnChanges(changes: SimpleChanges): void;
9
11
  ngOnInit(): void;
10
12
  ngAfterViewInit(): void;
11
13
  ngOnDestroy(): void;
12
14
  static ɵfac: i0.ɵɵFactoryDeclaration<LifeCycleDirective, never>;
13
- static ɵdir: i0.ɵɵDirectiveDeclaration<LifeCycleDirective, "[lifecycle]", never, {}, { "onInit": "onInit"; "afterViewInit": "afterViewInit"; "onDestroy": "onDestroy"; }, never, never, false, never>;
15
+ static ɵdir: i0.ɵɵDirectiveDeclaration<LifeCycleDirective, "[lifecycle]", never, {}, { "OnChanges": "OnChanges"; "onInit": "onInit"; "afterViewInit": "afterViewInit"; "onDestroy": "onDestroy"; }, never, never, false, never>;
14
16
  }
@@ -101,4 +101,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
101
101
  }], propDecorators: { image: [{
102
102
  type: Input
103
103
  }] } });
104
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"coer-filebox.component.js","sourceRoot":"","sources":["../../../../../../projects/coer-elements/src/components/lib/coer-filebox/coer-filebox.component.ts","../../../../../../projects/coer-elements/src/components/lib/coer-filebox/coer-filebox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, ElementRef, inject, Input, input, output, viewChild } from '@angular/core';\r\nimport { IFile, IFileImage } from '../../../interfaces/coer-filebox';\r\nimport { CoerAlert } from '../../lib/coer-alert/coer-alert.component';\r\nimport { CoerModal } from '../../lib/coer-modal/coer-modal.component';\r\nimport { Files } from '../../../tools/lib/files.class';\r\nimport { Tools } from '../../../tools/lib/tools';\r\n\r\n@Component({\r\n    selector: 'coer-filebox',\r\n    templateUrl: './coer-filebox.component.html',\r\n    styleUrl: './coer-filebox.component.scss'\r\n})\r\nexport class CoerFilebox {\r\n\r\n    //Injections\r\n    protected readonly alert = inject(CoerAlert);\r\n    protected IsNull = Tools.IsNull;\r\n    protected IsNotNull = Tools.IsNotNull;\r\n\r\n    //Elements\r\n    protected inputFileImage = viewChild.required<ElementRef>('inputFileImage');\r\n    protected modal = viewChild.required<CoerModal>('modal');\r\n\r\n    //Variables\r\n    protected base64: string = '';\r\n    protected _image: IFileImage | null = null;\r\n    private readonly imageExtensions = ['png', 'jpeg', 'jpg', 'gif', 'svg'];\r\n\r\n    //Inputs\r\n    public type = input<'image'>('image');\r\n    public multiple = input<boolean>(false);\r\n    public isLoading = input<boolean>(false);\r\n    public isDisabled = input<boolean>(false);\r\n\r\n    @Input() set image(value: IFileImage | null | undefined) {\r\n        this._image = Tools.IsNotNull(value) ? value as IFileImage : null;\r\n\r\n        if(Tools.IsNotNull(value)) {\r\n            if((value?.value as File)?.name) {\r\n                Files.ConvertToBase64(value?.value as File).then(base64 => {\r\n                    return this.base64 = base64;\r\n                });\r\n            }\r\n\r\n            else this.base64 = (value?.value as string);\r\n        }\r\n    }\r\n\r\n    //Outputs\r\n    public onSelected = output<IFile[]>();\r\n    public onDeleteImage = output<void>();\r\n\r\n    //computed\r\n    protected _isEnable = computed<boolean>(() => {\r\n        return !this.isLoading() && !this.isDisabled();\r\n    });\r\n\r\n\r\n    /** */\r\n    protected async UploadImages(event: any): Promise<void> {\r\n        const selectedFiles: File[] = Array.from(event.target.files);\r\n\r\n        const files: IFile[] = [];\r\n        let extension: string | null = null;\r\n        for (const file of selectedFiles) {\r\n\r\n            extension = this.GetExtensionFile(file.name) || '';\r\n\r\n            if (this.imageExtensions.includes(extension)) {\r\n                files.push({\r\n                    file: file,\r\n                    extension: extension,\r\n                    base64: await Files.ConvertToBase64(file) as string\r\n                });\r\n            }\r\n\r\n            else this.alert.Warning(`<b>.${extension}</b> extension not allowed`, 'Files');\r\n        }\r\n\r\n        //Response\r\n        this.inputFileImage().nativeElement.value = null;\r\n        this.onSelected.emit([...files]);\r\n    }\r\n\r\n\r\n    /** */\r\n    private GetExtensionFile = (fileName: string): string | null => {\r\n        if (fileName.includes('.')) {\r\n            let worlds = fileName.split('.') as string[];\r\n            if (worlds.length > 0) {\r\n                let extension = worlds.pop()!;\r\n                extension = extension.trim();\r\n                extension = extension.toLowerCase();\r\n                if (extension.length > 0) return extension;\r\n            }\r\n        }\r\n\r\n        this.alert.Warning('The file extension could not be recognized', 'Files');\r\n        return null;\r\n    }\r\n\r\n\r\n    /** */\r\n    protected DeleteImage(event: any): void {\r\n        event.stopPropagation();\r\n\r\n        if(this._isEnable()) {\r\n            this.onDeleteImage.emit();\r\n        }\r\n    }\r\n\r\n\r\n    /** */\r\n    protected ExpandImage(event: any): void {\r\n        event.stopPropagation();\r\n        this.modal().Open();\r\n    }\r\n}","<div class=\"coer-filebox\">\r\n    @if(type() == 'image') {\r\n        <figure (click)=\"_isEnable() ? inputFileImage.click() : null\"\r\n            [ngClass]=\"{ 'dashed': IsNull(_image?.value) }\"\r\n            [ngStyle]=\"{\r\n                'margin-top': _image?.marginTop || '',\r\n                'margin-right': _image?.marginRight || '',\r\n                'margin-bottom': _image?.marginBottom || '',\r\n                'margin-left': _image?.marginLeft || ''\r\n            }\">\r\n\r\n            @if(isLoading()) {\r\n                <div class=\"loading\">\r\n                    <i class=\"spinner-border\"></i>\r\n                </div>\r\n\r\n                <div class=\"placeholder-glow\">\r\n                    <span class=\"placeholder\"></span>\r\n                </div>\r\n            }\r\n\r\n            <img [src]=\"base64 | noImage\"\r\n                [ngStyle]=\"{\r\n                    'width': _image?.width || '',\r\n                    'max-width': _image?.maxWidth || '',\r\n                    'height': _image?.height || '',\r\n                    'max-height': _image?.maxHeight || '210px'\r\n                }\">\r\n\r\n            <input #inputFileImage\r\n                type=\"file\"\r\n                accept=\"image/png, image/jpeg, image/gif, image/svg+xml\"\r\n                (change)=\"UploadImages($event)\"\r\n                [multiple]=\"multiple()\">\r\n\r\n            @if(_isEnable() && IsNotNull(_image) && IsNotNull(_image!.value)) {\r\n                <div class=\"icon-container\">\r\n                    @if(IsNull(_image?.allowDelete) || _image!.allowDelete) {\r\n                        <i class=\"fa-solid fa-trash-can\" (click)=\"DeleteImage($event)\"></i>\r\n                    }\r\n\r\n                    @if(IsNull(_image?.allowExpand) || _image!.allowExpand) {\r\n                        <i class=\"fa-solid fa-expand\" (click)=\"ExpandImage($event)\"></i>\r\n                    }\r\n                </div>\r\n            }\r\n        </figure>\r\n    }\r\n\r\n    <!-- Modal -->\r\n    <coer-modal #modal [title]=\"_image?.name || ''\" height=\"90vh\" width=\"full\">\r\n        <div class=\"modal-image\" [ngStyle]=\"{ 'background-image': 'url(' + base64 + ')' }\"></div>\r\n    </coer-modal>\r\n</div>"]}
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"coer-filebox.component.js","sourceRoot":"","sources":["../../../../../../projects/coer-elements/src/components/lib/coer-filebox/coer-filebox.component.ts","../../../../../../projects/coer-elements/src/components/lib/coer-filebox/coer-filebox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, ElementRef, inject, Input, input, output, viewChild } from '@angular/core';\r\nimport { IFile, IFileImage } from '../../../interfaces';\r\nimport { CoerAlert } from '../../lib/coer-alert/coer-alert.component';\r\nimport { CoerModal } from '../../lib/coer-modal/coer-modal.component';\r\nimport { Files } from '../../../tools/lib/files.class';\r\nimport { Tools } from '../../../tools/lib/tools';\r\n\r\n@Component({\r\n    selector: 'coer-filebox',\r\n    templateUrl: './coer-filebox.component.html',\r\n    styleUrl: './coer-filebox.component.scss'\r\n})\r\nexport class CoerFilebox {\r\n\r\n    //Injections\r\n    protected readonly alert = inject(CoerAlert);\r\n    protected IsNull = Tools.IsNull;\r\n    protected IsNotNull = Tools.IsNotNull;\r\n\r\n    //Elements\r\n    protected inputFileImage = viewChild.required<ElementRef>('inputFileImage');\r\n    protected modal = viewChild.required<CoerModal>('modal');\r\n\r\n    //Variables\r\n    protected base64: string = '';\r\n    protected _image: IFileImage | null = null;\r\n    private readonly imageExtensions = ['png', 'jpeg', 'jpg', 'gif', 'svg'];\r\n\r\n    //Inputs\r\n    public type = input<'image'>('image');\r\n    public multiple = input<boolean>(false);\r\n    public isLoading = input<boolean>(false);\r\n    public isDisabled = input<boolean>(false);\r\n\r\n    @Input() set image(value: IFileImage | null | undefined) {\r\n        this._image = Tools.IsNotNull(value) ? value as IFileImage : null;\r\n\r\n        if(Tools.IsNotNull(value)) {\r\n            if((value?.value as File)?.name) {\r\n                Files.ConvertToBase64(value?.value as File).then(base64 => {\r\n                    return this.base64 = base64;\r\n                });\r\n            }\r\n\r\n            else this.base64 = (value?.value as string);\r\n        }\r\n    }\r\n\r\n    //Outputs\r\n    public onSelected = output<IFile[]>();\r\n    public onDeleteImage = output<void>();\r\n\r\n    //computed\r\n    protected _isEnable = computed<boolean>(() => {\r\n        return !this.isLoading() && !this.isDisabled();\r\n    });\r\n\r\n\r\n    /** */\r\n    protected async UploadImages(event: any): Promise<void> {\r\n        const selectedFiles: File[] = Array.from(event.target.files);\r\n\r\n        const files: IFile[] = [];\r\n        let extension: string | null = null;\r\n        for (const file of selectedFiles) {\r\n\r\n            extension = this.GetExtensionFile(file.name) || '';\r\n\r\n            if (this.imageExtensions.includes(extension)) {\r\n                files.push({\r\n                    file: file,\r\n                    extension: extension,\r\n                    base64: await Files.ConvertToBase64(file) as string\r\n                });\r\n            }\r\n\r\n            else this.alert.Warning(`<b>.${extension}</b> extension not allowed`, 'Files');\r\n        }\r\n\r\n        //Response\r\n        this.inputFileImage().nativeElement.value = null;\r\n        this.onSelected.emit([...files]);\r\n    }\r\n\r\n\r\n    /** */\r\n    private GetExtensionFile = (fileName: string): string | null => {\r\n        if (fileName.includes('.')) {\r\n            let worlds = fileName.split('.') as string[];\r\n            if (worlds.length > 0) {\r\n                let extension = worlds.pop()!;\r\n                extension = extension.trim();\r\n                extension = extension.toLowerCase();\r\n                if (extension.length > 0) return extension;\r\n            }\r\n        }\r\n\r\n        this.alert.Warning('The file extension could not be recognized', 'Files');\r\n        return null;\r\n    }\r\n\r\n\r\n    /** */\r\n    protected DeleteImage(event: any): void {\r\n        event.stopPropagation();\r\n\r\n        if(this._isEnable()) {\r\n            this.onDeleteImage.emit();\r\n        }\r\n    }\r\n\r\n\r\n    /** */\r\n    protected ExpandImage(event: any): void {\r\n        event.stopPropagation();\r\n        this.modal().Open();\r\n    }\r\n}","<div class=\"coer-filebox\">\r\n    @if(type() == 'image') {\r\n        <figure (click)=\"_isEnable() ? inputFileImage.click() : null\"\r\n            [ngClass]=\"{ 'dashed': IsNull(_image?.value) }\"\r\n            [ngStyle]=\"{\r\n                'margin-top': _image?.marginTop || '',\r\n                'margin-right': _image?.marginRight || '',\r\n                'margin-bottom': _image?.marginBottom || '',\r\n                'margin-left': _image?.marginLeft || ''\r\n            }\">\r\n\r\n            @if(isLoading()) {\r\n                <div class=\"loading\">\r\n                    <i class=\"spinner-border\"></i>\r\n                </div>\r\n\r\n                <div class=\"placeholder-glow\">\r\n                    <span class=\"placeholder\"></span>\r\n                </div>\r\n            }\r\n\r\n            <img [src]=\"base64 | noImage\"\r\n                [ngStyle]=\"{\r\n                    'width': _image?.width || '',\r\n                    'max-width': _image?.maxWidth || '',\r\n                    'height': _image?.height || '',\r\n                    'max-height': _image?.maxHeight || '210px'\r\n                }\">\r\n\r\n            <input #inputFileImage\r\n                type=\"file\"\r\n                accept=\"image/png, image/jpeg, image/gif, image/svg+xml\"\r\n                (change)=\"UploadImages($event)\"\r\n                [multiple]=\"multiple()\">\r\n\r\n            @if(_isEnable() && IsNotNull(_image) && IsNotNull(_image!.value)) {\r\n                <div class=\"icon-container\">\r\n                    @if(IsNull(_image?.allowDelete) || _image!.allowDelete) {\r\n                        <i class=\"fa-solid fa-trash-can\" (click)=\"DeleteImage($event)\"></i>\r\n                    }\r\n\r\n                    @if(IsNull(_image?.allowExpand) || _image!.allowExpand) {\r\n                        <i class=\"fa-solid fa-expand\" (click)=\"ExpandImage($event)\"></i>\r\n                    }\r\n                </div>\r\n            }\r\n        </figure>\r\n    }\r\n\r\n    <!-- Modal -->\r\n    <coer-modal #modal [title]=\"_image?.name || ''\" height=\"90vh\" width=\"full\">\r\n        <div class=\"modal-image\" [ngStyle]=\"{ 'background-image': 'url(' + base64 + ')' }\"></div>\r\n    </coer-modal>\r\n</div>"]}