@libs-ui/components-inputs-emoji 0.2.10-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.
@@ -0,0 +1,96 @@
1
+ import { ChangeDetectionStrategy, Component, effect, input, output, signal, untracked, viewChild } from '@angular/core';
2
+ import { LibsUiComponentsInputsSearchComponent } from '@libs-ui/components-inputs-search';
3
+ import { LibsUiComponentsPopoverComponent } from '@libs-ui/components-popover';
4
+ import { LibsUiComponentsScrollOverlayDirective } from '@libs-ui/components-scroll-overlay';
5
+ import { deleteUnicode } from '@libs-ui/utils';
6
+ import { TranslateModule } from '@ngx-translate/core';
7
+ import { defaultConfigPopover, emojis } from './defines/emoji.define';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@ngx-translate/core";
10
+ export class LibsUiComponentsEmojiComponent {
11
+ /* PROPERTY */
12
+ emojisCategories = signal(new Array());
13
+ filter = signal({ page: 0, keySearch: '', groupSelected: 'Smileys & Emotion', perPage: 170 });
14
+ dataEmojiView = signal({ dataView: [], allData: [] });
15
+ /* INPUT */
16
+ configPopover = input(defaultConfigPopover, { transform: value => value ? value : defaultConfigPopover });
17
+ isNgContent = input();
18
+ zIndex = input(0, { transform: value => value ?? 0 });
19
+ modePopoverPosition = input();
20
+ classPopup = input('w-[290px] h-[245px]', { transform: val => val ?? 'w-[290px] h-[245px]' });
21
+ classInclude = input('', { transform: val => val ?? '' });
22
+ classIconInclude = input('', { transform: val => val ?? '' });
23
+ /* OUTPUT */
24
+ outEventEmoji = output();
25
+ moFunctionsControl = output();
26
+ /* VIEW CHILD */
27
+ emojiRef = viewChild('emojiRef');
28
+ elementViewEmoji = viewChild('elementViewEmoji');
29
+ constructor() {
30
+ this.emojisCategories.set(emojis.map(item => ({
31
+ ...item,
32
+ iconGroup: item.emojis[0].emoji,
33
+ emojis: new Array()
34
+ })));
35
+ effect(() => {
36
+ if (this.zIndex()) {
37
+ untracked(() => {
38
+ this.configPopover().zIndex = this.zIndex() + 5;
39
+ });
40
+ }
41
+ if (this.modePopoverPosition() && this.configPopover().position) {
42
+ untracked(() => {
43
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
44
+ this.configPopover().position.mode = this.modePopoverPosition();
45
+ });
46
+ }
47
+ if (this.configPopover()) {
48
+ this.configPopover().template = this.emojiRef();
49
+ }
50
+ });
51
+ }
52
+ ngAfterViewInit() {
53
+ this.getDataView();
54
+ }
55
+ /* FUNCTIONS */
56
+ async handlerAddEmoji(data) {
57
+ this.outEventEmoji.emit(data.emoji);
58
+ }
59
+ async handlerFunctionsControl(event) {
60
+ this.moFunctionsControl.emit(event);
61
+ }
62
+ async handlerChooseCategory(event, category) {
63
+ event.stopPropagation();
64
+ this.filter.update(data => ({ ...data, page: 0, groupSelected: category.group_name }));
65
+ this.getDataView();
66
+ this.elementViewEmoji()?.nativeElement.scroll({ top: 0 });
67
+ }
68
+ async handlerSearchEmoji(keySearch) {
69
+ this.filter.update(data => ({ ...data, page: 0, keySearch: keySearch.trim() }));
70
+ this.getDataView();
71
+ this.elementViewEmoji()?.nativeElement.scroll({ top: 0 });
72
+ }
73
+ handlerScrollBottom() {
74
+ this.filter.update(data => ({ ...data, page: data.page + 1, }));
75
+ this.getDataView();
76
+ }
77
+ getDataView() {
78
+ const emojiByGroup = emojis.find(item => item.group_name === this.filter().groupSelected);
79
+ const emojiMatch = emojiByGroup.emojis.filter(item => deleteUnicode(item.description).toLocaleLowerCase().includes(deleteUnicode(this.filter().keySearch.toLocaleLowerCase())));
80
+ const { page, perPage } = this.filter();
81
+ const dataInPage = emojiMatch.slice(page * perPage, page * perPage + perPage);
82
+ this.dataEmojiView.update(item => ({ ...item, allData: emojiMatch, dataView: page ? [...item.dataView, ...dataInPage] : dataInPage }));
83
+ }
84
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsEmojiComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
85
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsEmojiComponent, isStandalone: true, selector: "libs_ui-components-emoji", inputs: { configPopover: { classPropertyName: "configPopover", publicName: "configPopover", isSignal: true, isRequired: false, transformFunction: null }, isNgContent: { classPropertyName: "isNgContent", publicName: "isNgContent", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, modePopoverPosition: { classPropertyName: "modePopoverPosition", publicName: "modePopoverPosition", isSignal: true, isRequired: false, transformFunction: null }, classPopup: { classPropertyName: "classPopup", publicName: "classPopup", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, classIconInclude: { classPropertyName: "classIconInclude", publicName: "classIconInclude", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { outEventEmoji: "outEventEmoji", moFunctionsControl: "moFunctionsControl" }, viewQueries: [{ propertyName: "emojiRef", first: true, predicate: ["emojiRef"], descendants: true, isSignal: true }, { propertyName: "elementViewEmoji", first: true, predicate: ["elementViewEmoji"], descendants: true, isSignal: true }], ngImport: i0, template: "<libs_ui-components-popover [classInclude]=\"classInclude()\"\n [config]=\"{\n content: 'i18n_text_emoji',\n zIndex:(zIndex() || 1200) + 4\n }\"\n (outFunctionsControl)=\"handlerFunctionsControl($event)\">\n <libs_ui-components-popover type='other'\n mode='click-toggle'\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [config]=\"configPopover()\"\n [debugId]=\"'debug icon emoij'\"\n (outFunctionsControl)=\"handlerFunctionsControl($event)\">\n @if (!isNgContent()) {\n <i class='libs-ui-icon-add before:!text-[16px] {{ classIconInclude() }}'>\n </i>\n } @else {\n <ng-content></ng-content>\n }\n </libs_ui-components-popover>\n</libs_ui-components-popover>\n<ng-template #emojiRef>\n <div class=\"py-[10px] flex flex-col {{ classPopup() }}\">\n <div class=\"mx-[10px] mb-[12px]\">\n <div class=\"flex overflow-x-auto\">\n @for (category of emojisCategories(); track category;) {\n <div class=\"grow p-[4px] rounded-[4px] bg-[#ffffff] libs-ui-bg-list-hover\"\n (click)=\"handlerChooseCategory($event, category)\">\n <div class=\"mt-[1px] cursor-pointer text-[18px]\">\n {{ category.iconGroup }}\n </div>\n </div>\n }\n </div>\n </div>\n <div class=\"mx-[10px] mb-[12px]\">\n <libs_ui-components-inputs-search [searchConfig]=\"{\n placeholder: 'i18n_search',\n }\"\n [debounceTime]=\"0\"\n (outSearch)=\"handlerSearchEmoji($event)\" />\n </div>\n <div class=\"h-full w-full relative\">\n <div #elementViewEmoji\n class=\"w-full h-full px-[10px] absolute\"\n LibsUiComponentsScrollOverlayDirective\n (outScrollBottom)=\"handlerScrollBottom()\">\n @if (dataEmojiView().dataView.length) {\n @for (item of dataEmojiView().dataView; track $index) {\n <!-- n\u1EBFu sau c\u00F3 y\u00EAu c\u00E2u hover hi\u1EC3n th\u1ECB tooltio th\u00EC b\u1ECF [ignoreShowPopover]=\"true\" -->\n <span LibsUiComponentsPopoverDirective\n [ignoreShowPopover]=\"true\"\n [config]=\"{content:item.description,zIndex:(zIndex()|| 1200)+5}\"\n class=\"cursor-pointer flex shrink-0 h-fit m-[2px] float-left\"\n (click)=\"handlerAddEmoji(item)\">\n {{ item.emoji }}\n </span>\n }\n } @else {\n <div class=\"libs-ui-font-h5r text-[#9ca2ad] h-full w-full items-center justify-center\">\n {{ ( 'i18n_no_result') | translate }}\n </div>\n\n }\n </div>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "component", type: LibsUiComponentsInputsSearchComponent, selector: "libs_ui-components-inputs-search", inputs: ["disable", "readonly", "searchConfig", "ignoreAutoComplete", "debounceTime", "ignoreStopPropagationEvent", "focusTimeOut", "blurTimeOut"], outputs: ["outSearch", "outValueChange", "outIconLeft", "outIconRight", "outFocusAndBlur", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsPopoverComponent, selector: "libs_ui-components-popover,[LibsUiComponentsPopoverDirective]", inputs: ["debugId", "flagMouse", "type", "mode", "config", "ignoreShowPopover", "elementRefCustom", "classInclude", "ignoreHiddenPopoverContentWhenMouseLeave", "ignoreStopPropagationEvent", "ignoreCursorPointerModeLikeClick", "isAddContentToParentDocument", "ignoreClickOutside"], outputs: ["outEvent", "outChangStageFlagMouse", "outEventPopoverContent", "outFunctionsControl"] }, { kind: "directive", type: LibsUiComponentsScrollOverlayDirective, selector: "[LibsUiComponentsScrollOverlayDirective]", inputs: ["debugMode", "classContainer", "options", "elementCheckScrollX", "elementCheckScrollY"], outputs: ["outScroll", "outScrollX", "outScrollY", "outScrollTop", "outScrollBottom"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
86
+ }
87
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsEmojiComponent, decorators: [{
88
+ type: Component,
89
+ args: [{ selector: 'libs_ui-components-emoji', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
90
+ TranslateModule,
91
+ LibsUiComponentsInputsSearchComponent,
92
+ LibsUiComponentsPopoverComponent,
93
+ LibsUiComponentsScrollOverlayDirective
94
+ ], template: "<libs_ui-components-popover [classInclude]=\"classInclude()\"\n [config]=\"{\n content: 'i18n_text_emoji',\n zIndex:(zIndex() || 1200) + 4\n }\"\n (outFunctionsControl)=\"handlerFunctionsControl($event)\">\n <libs_ui-components-popover type='other'\n mode='click-toggle'\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [config]=\"configPopover()\"\n [debugId]=\"'debug icon emoij'\"\n (outFunctionsControl)=\"handlerFunctionsControl($event)\">\n @if (!isNgContent()) {\n <i class='libs-ui-icon-add before:!text-[16px] {{ classIconInclude() }}'>\n </i>\n } @else {\n <ng-content></ng-content>\n }\n </libs_ui-components-popover>\n</libs_ui-components-popover>\n<ng-template #emojiRef>\n <div class=\"py-[10px] flex flex-col {{ classPopup() }}\">\n <div class=\"mx-[10px] mb-[12px]\">\n <div class=\"flex overflow-x-auto\">\n @for (category of emojisCategories(); track category;) {\n <div class=\"grow p-[4px] rounded-[4px] bg-[#ffffff] libs-ui-bg-list-hover\"\n (click)=\"handlerChooseCategory($event, category)\">\n <div class=\"mt-[1px] cursor-pointer text-[18px]\">\n {{ category.iconGroup }}\n </div>\n </div>\n }\n </div>\n </div>\n <div class=\"mx-[10px] mb-[12px]\">\n <libs_ui-components-inputs-search [searchConfig]=\"{\n placeholder: 'i18n_search',\n }\"\n [debounceTime]=\"0\"\n (outSearch)=\"handlerSearchEmoji($event)\" />\n </div>\n <div class=\"h-full w-full relative\">\n <div #elementViewEmoji\n class=\"w-full h-full px-[10px] absolute\"\n LibsUiComponentsScrollOverlayDirective\n (outScrollBottom)=\"handlerScrollBottom()\">\n @if (dataEmojiView().dataView.length) {\n @for (item of dataEmojiView().dataView; track $index) {\n <!-- n\u1EBFu sau c\u00F3 y\u00EAu c\u00E2u hover hi\u1EC3n th\u1ECB tooltio th\u00EC b\u1ECF [ignoreShowPopover]=\"true\" -->\n <span LibsUiComponentsPopoverDirective\n [ignoreShowPopover]=\"true\"\n [config]=\"{content:item.description,zIndex:(zIndex()|| 1200)+5}\"\n class=\"cursor-pointer flex shrink-0 h-fit m-[2px] float-left\"\n (click)=\"handlerAddEmoji(item)\">\n {{ item.emoji }}\n </span>\n }\n } @else {\n <div class=\"libs-ui-font-h5r text-[#9ca2ad] h-full w-full items-center justify-center\">\n {{ ( 'i18n_no_result') | translate }}\n </div>\n\n }\n </div>\n </div>\n </div>\n</ng-template>\n" }]
95
+ }], ctorParameters: () => [] });
96
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"emoji.component.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/inputs/emoji/src/emoji.component.ts","../../../../../../libs-ui/components/inputs/emoji/src/emoji.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, Component, effect, ElementRef, input, output, signal, TemplateRef, untracked, viewChild } from '@angular/core';\nimport { LibsUiComponentsInputsSearchComponent } from '@libs-ui/components-inputs-search';\nimport { IPopoverFunctionControlEvent, IPopoverOverlay, LibsUiComponentsPopoverComponent } from '@libs-ui/components-popover';\nimport { LibsUiComponentsScrollOverlayDirective } from '@libs-ui/components-scroll-overlay';\nimport { TYPE_TEMPLATE_REF } from '@libs-ui/interfaces-types';\nimport { deleteUnicode } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { defaultConfigPopover, emojis } from './defines/emoji.define';\nimport { IEmoji, IGroupEmoji } from './interfaces/emoji.interface';\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-emoji',\n  templateUrl: './emoji.component.html',\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    TranslateModule,\n    LibsUiComponentsInputsSearchComponent,\n    LibsUiComponentsPopoverComponent,\n    LibsUiComponentsScrollOverlayDirective\n  ]\n})\nexport class LibsUiComponentsEmojiComponent implements AfterViewInit {\n  /* PROPERTY */\n  protected emojisCategories = signal<Array<IGroupEmoji>>(new Array<IGroupEmoji>());\n  protected filter = signal({ page: 0, keySearch: '', groupSelected: 'Smileys & Emotion', perPage: 170 });\n  protected dataEmojiView = signal<{ dataView: Array<IEmoji>, allData: Array<IEmoji> }>({ dataView: [], allData: [] });\n\n  /* INPUT */\n  readonly configPopover = input<IPopoverOverlay, IPopoverOverlay | undefined>(defaultConfigPopover, { transform: value => value ? value : defaultConfigPopover });\n  readonly isNgContent = input<boolean>();\n  zIndex = input<number, number | undefined>(0, { transform: value => value ?? 0 });\n  readonly modePopoverPosition = input<'start' | 'center' | 'end' | undefined>();\n  readonly classPopup = input<string, string | undefined>('w-[290px] h-[245px]', { transform: val => val ?? 'w-[290px] h-[245px]' });\n  readonly classInclude = input<string, string | undefined>('', { transform: val => val ?? '' });\n  readonly classIconInclude = input<string, string | undefined>('', { transform: val => val ?? '' });\n\n  /* OUTPUT */\n  readonly outEventEmoji = output<string>();\n  readonly moFunctionsControl = output<IPopoverFunctionControlEvent>();\n\n  /* VIEW CHILD */\n  private readonly emojiRef = viewChild<TemplateRef<TYPE_TEMPLATE_REF>>('emojiRef');\n  private readonly elementViewEmoji = viewChild<ElementRef<TYPE_TEMPLATE_REF>>('elementViewEmoji');\n\n  constructor(\n  ) {\n    this.emojisCategories.set(emojis.map(item => ({\n      ...item,\n      iconGroup: item.emojis[0].emoji,\n      emojis: new Array<IEmoji>()\n    })));\n\n    effect(() => {\n      if (this.zIndex()) {\n        untracked(() => {\n          this.configPopover().zIndex = this.zIndex() + 5;\n        });\n      }\n\n      if (this.modePopoverPosition() && this.configPopover().position) {\n        untracked(() => {\n          // eslint-disable-next-line @typescript-eslint/no-explicit-any\n          (this.configPopover() as any).position.mode = this.modePopoverPosition();\n        });\n      }\n\n      if (this.configPopover()) {\n        this.configPopover().template = this.emojiRef();\n      }\n    });\n  }\n\n  ngAfterViewInit(): void {\n    this.getDataView();\n  }\n\n  /* FUNCTIONS */\n  protected async handlerAddEmoji(data: IEmoji) {\n    this.outEventEmoji.emit(data.emoji);\n  }\n\n  protected async handlerFunctionsControl(event: IPopoverFunctionControlEvent) {\n    this.moFunctionsControl.emit(event);\n  }\n\n  protected async handlerChooseCategory(event: Event, category: IGroupEmoji) {\n    event.stopPropagation();\n    this.filter.update(data => ({ ...data, page: 0, groupSelected: category.group_name }));\n    this.getDataView();\n    this.elementViewEmoji()?.nativeElement.scroll({ top: 0 });\n  }\n\n  protected async handlerSearchEmoji(keySearch: string) {\n    this.filter.update(data => ({ ...data, page: 0, keySearch: keySearch.trim() }));\n    this.getDataView();\n    this.elementViewEmoji()?.nativeElement.scroll({ top: 0 });\n  }\n\n  protected handlerScrollBottom() {\n    this.filter.update(data => ({ ...data, page: data.page + 1, }));\n    this.getDataView();\n  }\n\n  private getDataView() {\n    const emojiByGroup = emojis.find(item => item.group_name === this.filter().groupSelected) as IGroupEmoji;\n    const emojiMatch = emojiByGroup.emojis.filter(item => deleteUnicode(item.description).toLocaleLowerCase().includes(deleteUnicode(this.filter().keySearch.toLocaleLowerCase())));\n\n    const { page, perPage } = this.filter();\n    const dataInPage = emojiMatch.slice(page * perPage, page * perPage + perPage);\n\n    this.dataEmojiView.update(item => ({ ...item, allData: emojiMatch, dataView: page ? [...item.dataView, ...dataInPage] : dataInPage }));\n  }\n\n}\n","<libs_ui-components-popover [classInclude]=\"classInclude()\"\n  [config]=\"{\n    content: 'i18n_text_emoji',\n    zIndex:(zIndex() || 1200) + 4\n  }\"\n  (outFunctionsControl)=\"handlerFunctionsControl($event)\">\n  <libs_ui-components-popover type='other'\n    mode='click-toggle'\n    [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n    [config]=\"configPopover()\"\n    [debugId]=\"'debug icon emoij'\"\n    (outFunctionsControl)=\"handlerFunctionsControl($event)\">\n    @if (!isNgContent()) {\n      <i class='libs-ui-icon-add before:!text-[16px] {{ classIconInclude() }}'>\n      </i>\n    } @else {\n      <ng-content></ng-content>\n    }\n  </libs_ui-components-popover>\n</libs_ui-components-popover>\n<ng-template #emojiRef>\n  <div class=\"py-[10px] flex flex-col {{ classPopup() }}\">\n    <div class=\"mx-[10px] mb-[12px]\">\n      <div class=\"flex overflow-x-auto\">\n        @for (category of emojisCategories(); track category;) {\n          <div class=\"grow p-[4px] rounded-[4px] bg-[#ffffff] libs-ui-bg-list-hover\"\n            (click)=\"handlerChooseCategory($event, category)\">\n            <div class=\"mt-[1px] cursor-pointer text-[18px]\">\n              {{ category.iconGroup }}\n            </div>\n          </div>\n        }\n      </div>\n    </div>\n    <div class=\"mx-[10px] mb-[12px]\">\n      <libs_ui-components-inputs-search [searchConfig]=\"{\n          placeholder: 'i18n_search',\n        }\"\n        [debounceTime]=\"0\"\n        (outSearch)=\"handlerSearchEmoji($event)\" />\n    </div>\n    <div class=\"h-full w-full relative\">\n      <div #elementViewEmoji\n        class=\"w-full h-full  px-[10px] absolute\"\n        LibsUiComponentsScrollOverlayDirective\n        (outScrollBottom)=\"handlerScrollBottom()\">\n        @if (dataEmojiView().dataView.length) {\n          @for (item of dataEmojiView().dataView; track $index) {\n            <!-- nếu sau có yêu câu hover hiển thị tooltio thì bỏ [ignoreShowPopover]=\"true\" -->\n            <span LibsUiComponentsPopoverDirective\n              [ignoreShowPopover]=\"true\"\n              [config]=\"{content:item.description,zIndex:(zIndex()|| 1200)+5}\"\n              class=\"cursor-pointer flex shrink-0 h-fit m-[2px] float-left\"\n              (click)=\"handlerAddEmoji(item)\">\n              {{ item.emoji }}\n            </span>\n          }\n        } @else {\n          <div class=\"libs-ui-font-h5r text-[#9ca2ad] h-full w-full items-center justify-center\">\n            {{ ( 'i18n_no_result') | translate }}\n          </div>\n\n        }\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}
@@ -0,0 +1,2 @@
1
+ export * from './emoji.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvaW5wdXRzL2Vtb2ppL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9lbW9qaS5jb21wb25lbnQnO1xuIl19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1vamkuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2lucHV0cy9lbW9qaS9zcmMvaW50ZXJmYWNlcy9lbW9qaS5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSUdyb3VwRW1vamkge1xuICBncm91cF9uYW1lOiBzdHJpbmc7XG4gIGVtb2ppczogQXJyYXk8SUVtb2ppPjtcbiAgaWNvbkdyb3VwPzogc3RyaW5nO1xufVxuXG5cbmV4cG9ydCBpbnRlcmZhY2UgSUVtb2ppIHtcbiAgZW1vamk6IHN0cmluZztcbiAgZGVzY3JpcHRpb246IHN0cmluZztcbiAgY2F0ZWdvcnk6IHN0cmluZztcbiAgZGlzcGxheT86IGJvb2xlYW47XG59Il19
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlicy11aS1jb21wb25lbnRzLWlucHV0cy1lbW9qaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMtdWkvY29tcG9uZW50cy9pbnB1dHMvZW1vamkvc3JjL2xpYnMtdWktY29tcG9uZW50cy1pbnB1dHMtZW1vamkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=