@libs-ui/components-gallery 0.2.26

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/README.md ADDED
@@ -0,0 +1,3 @@
1
+ # gallery
2
+
3
+ This library was generated with [Nx](https://nx.dev).
@@ -0,0 +1,122 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ import { AsyncPipe, NgComponentOutlet } from '@angular/common';
3
+ import { ChangeDetectionStrategy, Component, computed, effect, inject, input, model, output, signal } from '@angular/core';
4
+ import { LibsUiIconsGetIconComponentPipe } from '@libs-ui/icons';
5
+ import { LibsUiDynamicComponentService } from '@libs-ui/services-dynamic-component';
6
+ import { isEmbedFrame, UtilsCommunicateMicro, uuid } from '@libs-ui/utils';
7
+ import dayjs from 'dayjs';
8
+ import * as i0 from "@angular/core";
9
+ export class LibsUiComponentsGalleryComponent {
10
+ /* PROPERTY */
11
+ imagesDisplay = computed(() => {
12
+ return this.images().slice(this.start(), this.end());
13
+ });
14
+ idOverlay = signal(uuid());
15
+ idInterval = signal(undefined);
16
+ viewerRef;
17
+ /* INPUT */
18
+ images = model.required();
19
+ start = input(0);
20
+ end = input(3);
21
+ zIndex = input(1200);
22
+ fieldDisplaySrcImage = input('url');
23
+ ignoreOverlayCountImage = input();
24
+ imageArrayStringConvert = input(); // sử dụng trong 1 số trường hợp images là Array<string>
25
+ /* OUTPUT */
26
+ outFunctionsControl = output();
27
+ /* INJECT */
28
+ dynamicComponent = inject(LibsUiDynamicComponentService);
29
+ constructor() {
30
+ effect(() => {
31
+ if (this.imageArrayStringConvert()?.length && this.fieldDisplaySrcImage()) {
32
+ const convertedImages = this.imageArrayStringConvert()?.map(item => {
33
+ return {
34
+ [this.fieldDisplaySrcImage()]: item
35
+ };
36
+ }) || [];
37
+ this.images.set(convertedImages);
38
+ }
39
+ }, { allowSignalWrites: true });
40
+ }
41
+ ngOnInit() {
42
+ this.outFunctionsControl.emit({
43
+ open: (imageSelected) => this.handlerSelectImage(undefined, imageSelected),
44
+ viewerRef: this.ViewerRef
45
+ });
46
+ }
47
+ /* FUNCTIONS */
48
+ async handlerSelectImage(event, imageSelected) {
49
+ event?.stopPropagation();
50
+ if (this.viewerRef) {
51
+ return;
52
+ }
53
+ const viewerComponent = await import('./viewer/viewer.component').then(c => c.LibsUiComponentsGalleryViewerComponent);
54
+ this.viewerRef = this.dynamicComponent.resolveComponentFactory(viewerComponent);
55
+ this.outFunctionsControl.emit({ viewerRef: this.ViewerRef, open: (imageSelected) => this.handlerSelectImage(undefined, imageSelected) });
56
+ this.viewerRef.setInput('fieldDisplaySrcImage', this.fieldDisplaySrcImage());
57
+ this.viewerRef.setInput('images', this.images());
58
+ this.viewerRef.setInput('imageSelected', imageSelected);
59
+ this.viewerRef.setInput('zIndex', this.zIndex());
60
+ this.viewerRef.setInput('singleImage', this.images().length <= 1);
61
+ const sub = this.viewerRef.instance.outClose.subscribe(() => {
62
+ sub.unsubscribe();
63
+ this.closePopup();
64
+ });
65
+ this.dynamicComponent.addToBody(this.viewerRef);
66
+ if (isEmbedFrame()) {
67
+ const data = {
68
+ type: "MICRO_SITE_MODAL_EVENT",
69
+ response: {
70
+ message: 'open',
71
+ state: true,
72
+ idOverlay: this.idOverlay,
73
+ timeLiveUpdate: dayjs().unix()
74
+ }
75
+ };
76
+ UtilsCommunicateMicro.PostMessageToParent(data);
77
+ this.idInterval.set(setInterval(() => {
78
+ data.response.timeLiveUpdate = dayjs().unix();
79
+ UtilsCommunicateMicro.PostMessageToParent(data);
80
+ }, 2000));
81
+ }
82
+ }
83
+ handlerImageError(e, image) {
84
+ const event = e;
85
+ event.stopPropagation();
86
+ image['isError'] = true;
87
+ }
88
+ closePopup() {
89
+ clearInterval(this.idInterval());
90
+ this.dynamicComponent.remove(this.viewerRef);
91
+ this.viewerRef = undefined;
92
+ 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
+ }
105
+ get ViewerRef() {
106
+ return this.viewerRef;
107
+ }
108
+ ngOnDestroy() {
109
+ this.viewerRef?.destroy();
110
+ this.closePopup();
111
+ }
112
+ 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 @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}", 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
+ }
115
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsGalleryComponent, decorators: [{
116
+ type: Component,
117
+ args: [{ selector: 'libs_ui-components-gallery', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
118
+ NgComponentOutlet, AsyncPipe,
119
+ LibsUiIconsGetIconComponentPipe
120
+ ], 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 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}" }]
121
+ }], 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}"]}
@@ -0,0 +1,2 @@
1
+ export * from './gallery.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZ2FsbGVyeS9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZ2FsbGVyeS5jb21wb25lbnQnO1xuIl19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuY3Rpb25zLWNvbnRyb2wtZXZlbnQuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2dhbGxlcnkvc3JjL2ludGVyZmFjZXMvZnVuY3Rpb25zLWNvbnRyb2wtZXZlbnQuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55ICovXG5pbXBvcnQgeyBDb21wb25lbnRSZWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIElHYWxsZXJ5RnVuY3Rpb25zQ29udHJvbEV2ZW50IHtcbiAgb3BlbjogKGltYWdlU2VsZWN0ZWQ6IFJlY29yZDxzdHJpbmcsIGFueT4pID0+IFByb21pc2U8dm9pZD47XG4gIHZpZXdlclJlZjogQ29tcG9uZW50UmVmPGFueT4gfCB1bmRlZmluZWQ7XG59Il19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiem9vbS5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZ2FsbGVyeS9zcmMvaW50ZXJmYWNlcy96b29tLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJWm9vbURyYWdIVE1MRWxlbWVudCBleHRlbmRzIEhUTUxFbGVtZW50IHtcbiAgc3RvcERyYWdnYWJsZUJlaGF2aW9yPygpOiBJWm9vbURyYWdIVE1MRWxlbWVudCB8IG51bGw7XG59Il19
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlicy11aS1jb21wb25lbnRzLWdhbGxlcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZ2FsbGVyeS9zcmMvbGlicy11aS1jb21wb25lbnRzLWdhbGxlcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=