@libs-ui/components-gallery 0.2.29 → 0.2.30-6.2
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/esm2022/gallery.component.mjs +38 -29
- package/esm2022/index.mjs +2 -1
- package/esm2022/viewer/viewer.component.mjs +42 -33
- package/fesm2022/libs-ui-components-gallery.mjs +360 -30
- package/fesm2022/libs-ui-components-gallery.mjs.map +1 -1
- package/gallery.component.d.ts +2 -1
- package/index.d.ts +1 -0
- package/package.json +11 -3
- package/viewer/viewer.component.d.ts +5 -3
- package/fesm2022/libs-ui-components-gallery-viewer.component-Dpt0hJu8.mjs +0 -313
- package/fesm2022/libs-ui-components-gallery-viewer.component-Dpt0hJu8.mjs.map +0 -1
|
@@ -1,20 +1,19 @@
|
|
|
1
1
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
2
2
|
import { AsyncPipe, NgComponentOutlet } from '@angular/common';
|
|
3
|
-
import { ChangeDetectionStrategy, Component, computed, effect, inject, input, model, output, signal } from '@angular/core';
|
|
3
|
+
import { ChangeDetectionStrategy, Component, computed, effect, inject, input, model, output, signal, untracked } from '@angular/core';
|
|
4
4
|
import { LibsUiIconsGetIconComponentPipe } from '@libs-ui/icons';
|
|
5
5
|
import { LibsUiDynamicComponentService } from '@libs-ui/services-dynamic-component';
|
|
6
|
-
import { isEmbedFrame, UtilsCommunicateMicro, uuid } from '@libs-ui/utils';
|
|
7
|
-
import dayjs from 'dayjs';
|
|
6
|
+
import { getDayjs, isEmbedFrame, UtilsCommunicateMicro, UtilsCommunicateMicroKeyGlobal, uuid } from '@libs-ui/utils';
|
|
8
7
|
import * as i0 from "@angular/core";
|
|
9
8
|
export class LibsUiComponentsGalleryComponent {
|
|
10
|
-
|
|
9
|
+
// #region PROPERTY
|
|
11
10
|
imagesDisplay = computed(() => {
|
|
12
11
|
return this.images().slice(this.start(), this.end());
|
|
13
12
|
});
|
|
14
13
|
idOverlay = signal(uuid());
|
|
15
14
|
idInterval = signal(undefined);
|
|
16
15
|
viewerRef;
|
|
17
|
-
|
|
16
|
+
// #region INPUT
|
|
18
17
|
images = model.required();
|
|
19
18
|
start = input(0);
|
|
20
19
|
end = input(3);
|
|
@@ -22,21 +21,27 @@ export class LibsUiComponentsGalleryComponent {
|
|
|
22
21
|
fieldDisplaySrcImage = input('url');
|
|
23
22
|
ignoreOverlayCountImage = input();
|
|
24
23
|
imageArrayStringConvert = input(); // sử dụng trong 1 số trường hợp images là Array<string>
|
|
25
|
-
|
|
24
|
+
// #region OUTPUT
|
|
26
25
|
outFunctionsControl = output();
|
|
27
|
-
|
|
26
|
+
outViewerEvent = output();
|
|
27
|
+
// #region INJECT
|
|
28
28
|
dynamicComponent = inject(LibsUiDynamicComponentService);
|
|
29
29
|
constructor() {
|
|
30
30
|
effect(() => {
|
|
31
|
-
|
|
32
|
-
|
|
31
|
+
const imgConvert = this.imageArrayStringConvert();
|
|
32
|
+
const fieldGetSrc = this.fieldDisplaySrcImage();
|
|
33
|
+
if (!imgConvert?.length || !fieldGetSrc) {
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
untracked(() => {
|
|
37
|
+
const convertedImages = imgConvert?.map(item => {
|
|
33
38
|
return {
|
|
34
|
-
[
|
|
39
|
+
[fieldGetSrc]: item
|
|
35
40
|
};
|
|
36
41
|
}) || [];
|
|
37
42
|
this.images.set(convertedImages);
|
|
38
|
-
}
|
|
39
|
-
}
|
|
43
|
+
});
|
|
44
|
+
});
|
|
40
45
|
}
|
|
41
46
|
ngOnInit() {
|
|
42
47
|
this.outFunctionsControl.emit({
|
|
@@ -63,19 +68,20 @@ export class LibsUiComponentsGalleryComponent {
|
|
|
63
68
|
this.closePopup();
|
|
64
69
|
});
|
|
65
70
|
this.dynamicComponent.addToBody(this.viewerRef);
|
|
71
|
+
this.outViewerEvent.emit('show');
|
|
66
72
|
if (isEmbedFrame()) {
|
|
67
73
|
const data = {
|
|
68
|
-
type:
|
|
74
|
+
type: UtilsCommunicateMicroKeyGlobal.KEY_MESSAGE_MODAL,
|
|
69
75
|
response: {
|
|
70
76
|
message: 'open',
|
|
71
77
|
state: true,
|
|
72
78
|
idOverlay: this.idOverlay,
|
|
73
|
-
timeLiveUpdate:
|
|
79
|
+
timeLiveUpdate: getDayjs().unix()
|
|
74
80
|
}
|
|
75
81
|
};
|
|
76
82
|
UtilsCommunicateMicro.PostMessageToParent(data);
|
|
77
83
|
this.idInterval.set(setInterval(() => {
|
|
78
|
-
data.response.timeLiveUpdate =
|
|
84
|
+
data.response.timeLiveUpdate = getDayjs().unix();
|
|
79
85
|
UtilsCommunicateMicro.PostMessageToParent(data);
|
|
80
86
|
}, 2000));
|
|
81
87
|
}
|
|
@@ -87,20 +93,23 @@ export class LibsUiComponentsGalleryComponent {
|
|
|
87
93
|
}
|
|
88
94
|
closePopup() {
|
|
89
95
|
clearInterval(this.idInterval());
|
|
96
|
+
if (this.viewerRef) {
|
|
97
|
+
this.outViewerEvent.emit('remove');
|
|
98
|
+
if (isEmbedFrame()) {
|
|
99
|
+
const data = {
|
|
100
|
+
type: UtilsCommunicateMicroKeyGlobal.KEY_MESSAGE_MODAL,
|
|
101
|
+
response: {
|
|
102
|
+
message: 'close',
|
|
103
|
+
state: false,
|
|
104
|
+
idOverlay: this.idOverlay
|
|
105
|
+
}
|
|
106
|
+
};
|
|
107
|
+
UtilsCommunicateMicro.PostMessageToParent(data);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
90
110
|
this.dynamicComponent.remove(this.viewerRef);
|
|
91
111
|
this.viewerRef = undefined;
|
|
92
112
|
this.outFunctionsControl.emit({ viewerRef: this.ViewerRef, open: (imageSelected) => this.handlerSelectImage(undefined, imageSelected) });
|
|
93
|
-
if (isEmbedFrame()) {
|
|
94
|
-
const data = {
|
|
95
|
-
type: "MICRO_SITE_MODAL_EVENT",
|
|
96
|
-
response: {
|
|
97
|
-
message: 'close',
|
|
98
|
-
state: false,
|
|
99
|
-
idOverlay: this.idOverlay
|
|
100
|
-
}
|
|
101
|
-
};
|
|
102
|
-
UtilsCommunicateMicro.PostMessageToParent(data);
|
|
103
|
-
}
|
|
104
113
|
}
|
|
105
114
|
get ViewerRef() {
|
|
106
115
|
return this.viewerRef;
|
|
@@ -110,13 +119,13 @@ export class LibsUiComponentsGalleryComponent {
|
|
|
110
119
|
this.closePopup();
|
|
111
120
|
}
|
|
112
121
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsGalleryComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
113
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsGalleryComponent, isStandalone: true, selector: "libs_ui-components-gallery", inputs: { images: { classPropertyName: "images", publicName: "images", isSignal: true, isRequired: true, transformFunction: null }, start: { classPropertyName: "start", publicName: "start", isSignal: true, isRequired: false, transformFunction: null }, end: { classPropertyName: "end", publicName: "end", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, fieldDisplaySrcImage: { classPropertyName: "fieldDisplaySrcImage", publicName: "fieldDisplaySrcImage", isSignal: true, isRequired: false, transformFunction: null }, ignoreOverlayCountImage: { classPropertyName: "ignoreOverlayCountImage", publicName: "ignoreOverlayCountImage", isSignal: true, isRequired: false, transformFunction: null }, imageArrayStringConvert: { classPropertyName: "imageArrayStringConvert", publicName: "imageArrayStringConvert", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { images: "imagesChange", outFunctionsControl: "outFunctionsControl" }, ngImport: i0, template: "@if(images()) {\n<div class=\"flex nowrap w-100 h-100\">\n
|
|
122
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsGalleryComponent, isStandalone: true, selector: "libs_ui-components-gallery", inputs: { images: { classPropertyName: "images", publicName: "images", isSignal: true, isRequired: true, transformFunction: null }, start: { classPropertyName: "start", publicName: "start", isSignal: true, isRequired: false, transformFunction: null }, end: { classPropertyName: "end", publicName: "end", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, fieldDisplaySrcImage: { classPropertyName: "fieldDisplaySrcImage", publicName: "fieldDisplaySrcImage", isSignal: true, isRequired: false, transformFunction: null }, ignoreOverlayCountImage: { classPropertyName: "ignoreOverlayCountImage", publicName: "ignoreOverlayCountImage", isSignal: true, isRequired: false, transformFunction: null }, imageArrayStringConvert: { classPropertyName: "imageArrayStringConvert", publicName: "imageArrayStringConvert", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { images: "imagesChange", outFunctionsControl: "outFunctionsControl", outViewerEvent: "outViewerEvent" }, ngImport: i0, template: "@if (images()) {\n <div class=\"flex nowrap w-100 h-100\">\n @for (image of imagesDisplay(); track $index; let last = $last) {\n <div class=\"w-full h-full libs-ui-border-general relative cursor-pointer\"\n [class.mr-[12px]]=\"!last\"\n (click)=\"handlerSelectImage($event, image)\">\n <div class=\"flex items-center justify-center w-full h-full\">\n @if (!image['isError']) {\n <img [src]=\"image[fieldDisplaySrcImage()]\"\n class=\"flex max-w-full max-h-full m-auto\"\n (error)='handlerImageError($event, image)' />\n }\n @if (image['isError']) {\n <div *ngComponentOutlet=\"'image-default' | LibsUiIconsGetIconComponentPipe | async\"></div>\n }\n </div>\n @if (last && images().length > end() && !ignoreOverlayCountImage()) {\n <div class=\"flex w-full h-full absolute top-0 left-0 items-center justify-center bg-[#000] opacity-5\">\n </div>\n <div class=\"flex w-full h-full absolute top-0 left-0 items-center justify-center\">\n <span class=\"libs-ui-font-h3s libs-ui-font-size-20px text-[#ffffff]\">+ {{ images().length - end() }}</span>\n </div>\n }\n </div>\n }\n </div>\n}\n", styles: [""], dependencies: [{ kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: LibsUiIconsGetIconComponentPipe, name: "LibsUiIconsGetIconComponentPipe" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
114
123
|
}
|
|
115
124
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsGalleryComponent, decorators: [{
|
|
116
125
|
type: Component,
|
|
117
126
|
args: [{ selector: 'libs_ui-components-gallery', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
|
|
118
127
|
NgComponentOutlet, AsyncPipe,
|
|
119
128
|
LibsUiIconsGetIconComponentPipe
|
|
120
|
-
], template: "@if(images()) {\n<div class=\"flex nowrap w-100 h-100\">\n
|
|
129
|
+
], template: "@if (images()) {\n <div class=\"flex nowrap w-100 h-100\">\n @for (image of imagesDisplay(); track $index; let last = $last) {\n <div class=\"w-full h-full libs-ui-border-general relative cursor-pointer\"\n [class.mr-[12px]]=\"!last\"\n (click)=\"handlerSelectImage($event, image)\">\n <div class=\"flex items-center justify-center w-full h-full\">\n @if (!image['isError']) {\n <img [src]=\"image[fieldDisplaySrcImage()]\"\n class=\"flex max-w-full max-h-full m-auto\"\n (error)='handlerImageError($event, image)' />\n }\n @if (image['isError']) {\n <div *ngComponentOutlet=\"'image-default' | LibsUiIconsGetIconComponentPipe | async\"></div>\n }\n </div>\n @if (last && images().length > end() && !ignoreOverlayCountImage()) {\n <div class=\"flex w-full h-full absolute top-0 left-0 items-center justify-center bg-[#000] opacity-5\">\n </div>\n <div class=\"flex w-full h-full absolute top-0 left-0 items-center justify-center\">\n <span class=\"libs-ui-font-h3s libs-ui-font-size-20px text-[#ffffff]\">+ {{ images().length - end() }}</span>\n </div>\n }\n </div>\n }\n </div>\n}\n" }]
|
|
121
130
|
}], ctorParameters: () => [] });
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gallery.component.js","sourceRoot":"","sources":["../../../../../libs-ui/components/gallery/src/gallery.component.ts","../../../../../libs-ui/components/gallery/src/gallery.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { AsyncPipe, NgComponentOutlet } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, ComponentRef, computed, effect, inject, input, model, OnDestroy, OnInit, output, signal } from '@angular/core';\nimport { LibsUiIconsGetIconComponentPipe } from '@libs-ui/icons';\nimport { IEvent } from '@libs-ui/interfaces-types';\nimport { LibsUiDynamicComponentService } from '@libs-ui/services-dynamic-component';\nimport { isEmbedFrame, UtilsCommunicateMicro, uuid } from '@libs-ui/utils';\nimport dayjs from 'dayjs';\nimport { IGalleryFunctionsControlEvent } from './interfaces/functions-control-event.interface';\nimport { LibsUiComponentsGalleryViewerComponent } from './viewer/viewer.component';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-gallery',\n  templateUrl: './gallery.component.html',\n  styleUrls: ['./gallery.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    NgComponentOutlet, AsyncPipe,\n    LibsUiIconsGetIconComponentPipe\n  ]\n})\nexport class LibsUiComponentsGalleryComponent implements OnInit, OnDestroy {\n  /* PROPERTY */\n  protected imagesDisplay = computed(() => {\n    return this.images().slice(this.start(), this.end());\n  });\n\n  private idOverlay = signal<string>(uuid());\n  private idInterval = signal<number | undefined>(undefined);\n  private viewerRef: ComponentRef<LibsUiComponentsGalleryViewerComponent> | undefined;\n\n  /* INPUT */\n  readonly images = model.required<Array<Record<string, any>>>();\n  readonly start = input<number>(0);\n  readonly end = input<number>(3);\n  readonly zIndex = input<number>(1200);\n  readonly fieldDisplaySrcImage = input<string>('url');\n  readonly ignoreOverlayCountImage = input<boolean>();\n  readonly imageArrayStringConvert = input<Array<string>>(); // sử dụng trong 1 số trường hợp images là Array<string>\n\n  /* OUTPUT */\n  readonly outFunctionsControl = output<IGalleryFunctionsControlEvent>();\n\n  /* INJECT */\n  private dynamicComponent = inject(LibsUiDynamicComponentService);\n\n  constructor() {\n    effect(() => {\n      if (this.imageArrayStringConvert()?.length && this.fieldDisplaySrcImage()) {\n        const convertedImages = this.imageArrayStringConvert()?.map(item => {\n          return {\n            [this.fieldDisplaySrcImage()]: item\n          } as Record<string, any>;\n        }) || [];\n\n        this.images.set(convertedImages);\n      }\n    }, { allowSignalWrites: true });\n  }\n\n  ngOnInit() {\n    this.outFunctionsControl.emit({\n      open: (imageSelected: Record<string, any>) => this.handlerSelectImage(undefined, imageSelected),\n      viewerRef: this.ViewerRef\n    })\n  }\n\n  /* FUNCTIONS */\n  protected async handlerSelectImage(event: MouseEvent | undefined, imageSelected: Record<string, any>) {\n    event?.stopPropagation();\n\n    if (this.viewerRef) {\n      return;\n    }\n\n    const viewerComponent = await import('./viewer/viewer.component').then(c => c.LibsUiComponentsGalleryViewerComponent);\n\n    this.viewerRef = this.dynamicComponent.resolveComponentFactory(viewerComponent);\n\n    this.outFunctionsControl.emit({ viewerRef: this.ViewerRef, open: (imageSelected: Record<string, any>) => this.handlerSelectImage(undefined, imageSelected) });\n\n    this.viewerRef.setInput('fieldDisplaySrcImage', this.fieldDisplaySrcImage());\n    this.viewerRef.setInput('images', this.images());\n    this.viewerRef.setInput('imageSelected', imageSelected);\n    this.viewerRef.setInput('zIndex', this.zIndex());\n    this.viewerRef.setInput('singleImage', this.images().length <= 1);\n\n    const sub = this.viewerRef.instance.outClose.subscribe(() => {\n      sub.unsubscribe();\n      this.closePopup();\n    });\n\n    this.dynamicComponent.addToBody(this.viewerRef);\n\n    if (isEmbedFrame()) {\n      const data = {\n        type: \"MICRO_SITE_MODAL_EVENT\",\n        response: {\n          message: 'open',\n          state: true,\n          idOverlay: this.idOverlay,\n          timeLiveUpdate: dayjs().unix()\n        }\n      };\n\n      UtilsCommunicateMicro.PostMessageToParent(data);\n\n      this.idInterval.set((setInterval(() => {\n        data.response.timeLiveUpdate = dayjs().unix();\n\n        UtilsCommunicateMicro.PostMessageToParent(data);\n      }, 2000) as unknown) as number);\n    }\n  }\n\n  protected handlerImageError(e: ErrorEvent, image: Record<string, any>) {\n    const event = e as IEvent;\n\n    event.stopPropagation();\n\n    image['isError'] = true;\n  }\n\n  private closePopup() {\n    clearInterval(this.idInterval());\n    this.dynamicComponent.remove(this.viewerRef);\n    this.viewerRef = undefined;\n    this.outFunctionsControl.emit({ viewerRef: this.ViewerRef, open: (imageSelected: Record<string, any>) => this.handlerSelectImage(undefined, imageSelected) });\n    if (isEmbedFrame()) {\n      const data = {\n        type: \"MICRO_SITE_MODAL_EVENT\",\n        response: {\n          message: 'close',\n          state: false,\n          idOverlay: this.idOverlay\n        }\n      };\n\n      UtilsCommunicateMicro.PostMessageToParent(data);\n    }\n  }\n\n  private get ViewerRef() {\n    return this.viewerRef;\n  }\n\n  ngOnDestroy() {\n    this.viewerRef?.destroy();\n    this.closePopup();\n  }\n}\n","@if(images()) {\n<div class=\"flex nowrap w-100 h-100\">\n  @for (image of imagesDisplay(); track $index; let last = $last) {\n  <div class=\"w-full h-full libs-ui-border-general relative cursor-pointer\"\n    [class.mr-[12px]]=\"!last\"\n    (click)=\"handlerSelectImage($event, image)\">\n    <div class=\"flex items-center justify-center w-full h-full\">\n      @if(!image['isError']) {\n      <img [src]=\"image[fieldDisplaySrcImage()]\"\n        class=\"flex mo-lib-percent-max-height-100 mo-lib-percent-max-width-100 m-auto\"\n        (error)='handlerImageError($event, image)' />\n      }\n      @if(image['isError']) {\n      <div *ngComponentOutlet=\"'image-default' | LibsUiIconsGetIconComponentPipe | async\"></div>\n      }\n    </div>\n    @if(last && images().length > end() && !ignoreOverlayCountImage()) {\n    <div class=\"flex w-full h-full absolute top-0 left-0 items-center justify-center bg-[#000] opacity-5\">\n    </div>\n    <div class=\"flex w-full h-full absolute top-0 left-0 items-center justify-center\">\n      <span class=\"libs-ui-font-h3s libs-ui-font-size-20px text-[#ffffff]\">+ {{images().length - end()}}</span>\n    </div>\n    }\n  </div>\n  }\n</div>\n}"]}
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gallery.component.js","sourceRoot":"","sources":["../../../../../libs-ui/components/gallery/src/gallery.component.ts","../../../../../libs-ui/components/gallery/src/gallery.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { AsyncPipe, NgComponentOutlet } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, ComponentRef, computed, effect, inject, input, model, OnDestroy, OnInit, output, signal, untracked } from '@angular/core';\nimport { LibsUiIconsGetIconComponentPipe } from '@libs-ui/icons';\nimport { IEvent } from '@libs-ui/interfaces-types';\nimport { LibsUiDynamicComponentService } from '@libs-ui/services-dynamic-component';\nimport { getDayjs, isEmbedFrame, UtilsCommunicateMicro, UtilsCommunicateMicroKeyGlobal, uuid } from '@libs-ui/utils';\nimport { Dayjs } from 'dayjs';\nimport { IGalleryFunctionsControlEvent } from './interfaces/functions-control-event.interface';\nimport { LibsUiComponentsGalleryViewerComponent } from './viewer/viewer.component';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-gallery',\n  templateUrl: './gallery.component.html',\n  styleUrls: ['./gallery.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    NgComponentOutlet, AsyncPipe,\n    LibsUiIconsGetIconComponentPipe\n  ]\n})\nexport class LibsUiComponentsGalleryComponent implements OnInit, OnDestroy {\n  // #region PROPERTY\n  protected imagesDisplay = computed(() => {\n    return this.images().slice(this.start(), this.end());\n  });\n\n  private idOverlay = signal<string>(uuid());\n  private idInterval = signal<number | undefined>(undefined);\n  private viewerRef: ComponentRef<LibsUiComponentsGalleryViewerComponent> | undefined;\n\n  // #region INPUT\n  readonly images = model.required<Array<Record<string, any>>>();\n  readonly start = input<number>(0);\n  readonly end = input<number>(3);\n  readonly zIndex = input<number>(1200);\n  readonly fieldDisplaySrcImage = input<string>('url');\n  readonly ignoreOverlayCountImage = input<boolean>();\n  readonly imageArrayStringConvert = input<Array<string>>(); // sử dụng trong 1 số trường hợp images là Array<string>\n\n  // #region OUTPUT\n  readonly outFunctionsControl = output<IGalleryFunctionsControlEvent>();\n  readonly outViewerEvent = output<'show' | 'remove'>();\n\n  // #region INJECT\n  private dynamicComponent = inject(LibsUiDynamicComponentService);\n\n  constructor() {\n    effect(() => {\n      const imgConvert = this.imageArrayStringConvert();\n      const fieldGetSrc = this.fieldDisplaySrcImage();\n\n      if (!imgConvert?.length || !fieldGetSrc) {\n        return;\n      }\n      untracked(() => {\n        const convertedImages = imgConvert?.map(item => {\n          return {\n            [fieldGetSrc]: item\n          } as Record<string, any>;\n        }) || [];\n\n        this.images.set(convertedImages);\n      });\n    });\n  }\n\n  ngOnInit() {\n    this.outFunctionsControl.emit({\n      open: (imageSelected: Record<string, any>) => this.handlerSelectImage(undefined, imageSelected),\n      viewerRef: this.ViewerRef\n    })\n  }\n\n  /* FUNCTIONS */\n  protected async handlerSelectImage(event: MouseEvent | undefined, imageSelected: Record<string, any>) {\n    event?.stopPropagation();\n\n    if (this.viewerRef) {\n      return;\n    }\n\n    const viewerComponent = await import('./viewer/viewer.component').then(c => c.LibsUiComponentsGalleryViewerComponent);\n\n    this.viewerRef = this.dynamicComponent.resolveComponentFactory(viewerComponent);\n    this.outFunctionsControl.emit({ viewerRef: this.ViewerRef, open: (imageSelected: Record<string, any>) => this.handlerSelectImage(undefined, imageSelected) });\n\n    this.viewerRef.setInput('fieldDisplaySrcImage', this.fieldDisplaySrcImage());\n    this.viewerRef.setInput('images', this.images());\n    this.viewerRef.setInput('imageSelected', imageSelected);\n    this.viewerRef.setInput('zIndex', this.zIndex());\n    this.viewerRef.setInput('singleImage', this.images().length <= 1);\n\n    const sub = this.viewerRef.instance.outClose.subscribe(() => {\n      sub.unsubscribe();\n      this.closePopup();\n    });\n\n    this.dynamicComponent.addToBody(this.viewerRef);\n    this.outViewerEvent.emit('show');\n\n    if (isEmbedFrame()) {\n      const data = {\n        type: UtilsCommunicateMicroKeyGlobal.KEY_MESSAGE_MODAL,\n        response: {\n          message: 'open',\n          state: true,\n          idOverlay: this.idOverlay,\n          timeLiveUpdate: getDayjs<Dayjs>().unix()\n        }\n      };\n\n      UtilsCommunicateMicro.PostMessageToParent(data);\n\n      this.idInterval.set((setInterval(() => {\n        data.response.timeLiveUpdate = getDayjs<Dayjs>().unix();\n\n        UtilsCommunicateMicro.PostMessageToParent(data);\n      }, 2000) as unknown) as number);\n    }\n  }\n\n  protected handlerImageError(e: ErrorEvent, image: Record<string, any>) {\n    const event = e as IEvent;\n\n    event.stopPropagation();\n\n    image['isError'] = true;\n  }\n\n  private closePopup() {\n    clearInterval(this.idInterval());\n    if (this.viewerRef) {\n      this.outViewerEvent.emit('remove');\n      if (isEmbedFrame()) {\n        const data = {\n          type: UtilsCommunicateMicroKeyGlobal.KEY_MESSAGE_MODAL,\n          response: {\n            message: 'close',\n            state: false,\n            idOverlay: this.idOverlay\n          }\n        };\n\n        UtilsCommunicateMicro.PostMessageToParent(data);\n      }\n    }\n    this.dynamicComponent.remove(this.viewerRef);\n    this.viewerRef = undefined;\n    this.outFunctionsControl.emit({ viewerRef: this.ViewerRef, open: (imageSelected: Record<string, any>) => this.handlerSelectImage(undefined, imageSelected) });\n  }\n\n  private get ViewerRef() {\n    return this.viewerRef;\n  }\n\n  ngOnDestroy() {\n    this.viewerRef?.destroy();\n    this.closePopup();\n  }\n}\n","@if (images()) {\n  <div class=\"flex nowrap w-100 h-100\">\n    @for (image of imagesDisplay(); track $index; let last = $last) {\n      <div class=\"w-full h-full libs-ui-border-general relative cursor-pointer\"\n        [class.mr-[12px]]=\"!last\"\n        (click)=\"handlerSelectImage($event, image)\">\n        <div class=\"flex items-center justify-center w-full h-full\">\n          @if (!image['isError']) {\n            <img [src]=\"image[fieldDisplaySrcImage()]\"\n              class=\"flex max-w-full max-h-full m-auto\"\n              (error)='handlerImageError($event, image)' />\n          }\n          @if (image['isError']) {\n            <div *ngComponentOutlet=\"'image-default' | LibsUiIconsGetIconComponentPipe | async\"></div>\n          }\n        </div>\n        @if (last && images().length > end() && !ignoreOverlayCountImage()) {\n          <div class=\"flex w-full h-full absolute top-0 left-0 items-center justify-center bg-[#000] opacity-5\">\n          </div>\n          <div class=\"flex w-full h-full absolute top-0 left-0 items-center justify-center\">\n            <span class=\"libs-ui-font-h3s libs-ui-font-size-20px text-[#ffffff]\">+ {{ images().length - end() }}</span>\n          </div>\n        }\n      </div>\n    }\n  </div>\n}\n"]}
|
package/esm2022/index.mjs
CHANGED
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
export * from './gallery.component';
|
|
2
|
-
|
|
2
|
+
export * from './viewer/viewer.component';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZ2FsbGVyeS9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9nYWxsZXJ5LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3ZpZXdlci92aWV3ZXIuY29tcG9uZW50JzsiXX0=
|