@libs-ui/components-inputs-emoji 0.2.221 → 0.2.223

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.
@@ -82,7 +82,7 @@ export class LibsUiComponentsEmojiComponent {
82
82
  this.dataEmojiView.update(item => ({ ...item, allData: emojiMatch, dataView: page ? [...item.dataView, ...dataInPage] : dataInPage }));
83
83
  }
84
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", "ignoreInit", "classContainer", "options", "elementCheckScrollX", "elementCheckScrollY", "elementScroll"], outputs: ["outScroll", "outScrollX", "outScrollY", "outScrollTop", "outScrollBottom"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
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", "initEventInElementRefCustom", "classInclude", "ignoreHiddenPopoverContentWhenMouseLeave", "ignoreStopPropagationEvent", "ignoreCursorPointerModeLikeClick", "isAddContentToParentDocument", "ignoreClickOutside"], outputs: ["outEvent", "outChangStageFlagMouse", "outEventPopoverContent", "outFunctionsControl"] }, { kind: "directive", type: LibsUiComponentsScrollOverlayDirective, selector: "[LibsUiComponentsScrollOverlayDirective]", inputs: ["debugMode", "ignoreInit", "classContainer", "options", "elementCheckScrollX", "elementCheckScrollY", "elementScroll"], outputs: ["outScroll", "outScrollX", "outScrollY", "outScrollTop", "outScrollBottom"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
86
86
  }
87
87
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsEmojiComponent, decorators: [{
88
88
  type: Component,
@@ -93,4 +93,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
93
93
  LibsUiComponentsScrollOverlayDirective
94
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
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":"AAAA,OAAO,EAAiB,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAc,KAAK,EAAE,MAAM,EAAE,MAAM,EAAe,SAAS,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAChK,OAAO,EAAE,qCAAqC,EAAE,MAAM,mCAAmC,CAAC;AAC1F,OAAO,EAAiD,gCAAgC,EAAE,MAAM,6BAA6B,CAAC;AAC9H,OAAO,EAAE,sCAAsC,EAAE,MAAM,oCAAoC,CAAC;AAE5F,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;;;AAetE,MAAM,OAAO,8BAA8B;IACzC,mBAAmB;IACT,gBAAgB,GAAG,MAAM,CAAqB,IAAI,KAAK,EAAe,CAAC,CAAC;IACxE,MAAM,GAAG,MAAM,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,aAAa,EAAE,mBAAmB,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC;IAC9F,aAAa,GAAG,MAAM,CAAsD,EAAE,QAAQ,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC;IAErH,gBAAgB;IACP,aAAa,GAAG,KAAK,CAA+C,oBAAoB,EAAE,EAAE,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,oBAAoB,EAAE,CAAC,CAAC;IACxJ,WAAW,GAAG,KAAK,EAAW,CAAC;IACxC,MAAM,GAAG,KAAK,CAA6B,CAAC,EAAE,EAAE,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC;IACzE,mBAAmB,GAAG,KAAK,EAA0C,CAAC;IACtE,UAAU,GAAG,KAAK,CAA6B,qBAAqB,EAAE,EAAE,SAAS,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,qBAAqB,EAAE,CAAC,CAAC;IAC1H,YAAY,GAAG,KAAK,CAA6B,EAAE,EAAE,EAAE,SAAS,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,CAAC;IACtF,gBAAgB,GAAG,KAAK,CAA6B,EAAE,EAAE,EAAE,SAAS,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,CAAC;IAEnG,iBAAiB;IACR,aAAa,GAAG,MAAM,EAAU,CAAC;IACjC,kBAAkB,GAAG,MAAM,EAAgC,CAAC;IAErE,gBAAgB;IACC,QAAQ,GAAG,SAAS,CAAiC,UAAU,CAAC,CAAC;IACjE,gBAAgB,GAAG,SAAS,CAAgC,kBAAkB,CAAC,CAAC;IAEjG;QAEE,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAC5C,GAAG,IAAI;YACP,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK;YAC/B,MAAM,EAAE,IAAI,KAAK,EAAU;SAC5B,CAAC,CAAC,CAAC,CAAC;QAEL,MAAM,CAAC,GAAG,EAAE;YACV,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC;gBAClB,SAAS,CAAC,GAAG,EAAE;oBACb,IAAI,CAAC,aAAa,EAAE,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;gBAClD,CAAC,CAAC,CAAC;YACL,CAAC;YAED,IAAI,IAAI,CAAC,mBAAmB,EAAE,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC,QAAQ,EAAE,CAAC;gBAChE,SAAS,CAAC,GAAG,EAAE;oBACb,8DAA8D;oBAC7D,IAAI,CAAC,aAAa,EAAU,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBAC3E,CAAC,CAAC,CAAC;YACL,CAAC;YAED,IAAI,IAAI,CAAC,aAAa,EAAE,EAAE,CAAC;gBACzB,IAAI,CAAC,aAAa,EAAE,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClD,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,eAAe;QACb,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,eAAe;IACL,KAAK,CAAC,eAAe,CAAC,IAAY;QAC1C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAES,KAAK,CAAC,uBAAuB,CAAC,KAAmC;QACzE,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAES,KAAK,CAAC,qBAAqB,CAAC,KAAY,EAAE,QAAqB;QACvE,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,IAAI,EAAE,CAAC,EAAE,aAAa,EAAE,QAAQ,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;QACvF,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,gBAAgB,EAAE,EAAE,aAAa,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;IAC5D,CAAC;IAES,KAAK,CAAC,kBAAkB,CAAC,SAAiB;QAClD,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,IAAI,EAAE,CAAC,EAAE,SAAS,EAAE,SAAS,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;QAChF,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,gBAAgB,EAAE,EAAE,aAAa,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;IAC5D,CAAC;IAES,mBAAmB;QAC3B,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;QAChE,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAEO,WAAW;QACjB,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,KAAK,IAAI,CAAC,MAAM,EAAE,CAAC,aAAa,CAAgB,CAAC;QACzG,MAAM,UAAU,GAAG,YAAY,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,iBAAiB,EAAE,CAAC,CAAC,CAAC,CAAC;QAEhL,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QACxC,MAAM,UAAU,GAAG,UAAU,CAAC,KAAK,CAAC,IAAI,GAAG,OAAO,EAAE,IAAI,GAAG,OAAO,GAAG,OAAO,CAAC,CAAC;QAE9E,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;IACzI,CAAC;wGA1FU,8BAA8B;4FAA9B,8BAA8B,w4CCtB3C,8lFAmEA,2CDnDI,eAAe,4FACf,qCAAqC,oVACrC,gCAAgC,qeAChC,sCAAsC;;4FAG7B,8BAA8B;kBAb1C,SAAS;+BAEE,0BAA0B,cAExB,IAAI,mBACC,uBAAuB,CAAC,MAAM,WACtC;wBACP,eAAe;wBACf,qCAAqC;wBACrC,gCAAgC;wBAChC,sCAAsC;qBACvC","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  // #region 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  // #region 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  // #region 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"]}
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  // #region 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  // #region 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  // #region 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"]}
@@ -1872,7 +1872,7 @@ class LibsUiComponentsEmojiComponent {
1872
1872
  this.dataEmojiView.update(item => ({ ...item, allData: emojiMatch, dataView: page ? [...item.dataView, ...dataInPage] : dataInPage }));
1873
1873
  }
1874
1874
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsEmojiComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1875
- 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", "ignoreInit", "classContainer", "options", "elementCheckScrollX", "elementCheckScrollY", "elementScroll"], outputs: ["outScroll", "outScrollX", "outScrollY", "outScrollTop", "outScrollBottom"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
1875
+ 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", "initEventInElementRefCustom", "classInclude", "ignoreHiddenPopoverContentWhenMouseLeave", "ignoreStopPropagationEvent", "ignoreCursorPointerModeLikeClick", "isAddContentToParentDocument", "ignoreClickOutside"], outputs: ["outEvent", "outChangStageFlagMouse", "outEventPopoverContent", "outFunctionsControl"] }, { kind: "directive", type: LibsUiComponentsScrollOverlayDirective, selector: "[LibsUiComponentsScrollOverlayDirective]", inputs: ["debugMode", "ignoreInit", "classContainer", "options", "elementCheckScrollX", "elementCheckScrollY", "elementScroll"], outputs: ["outScroll", "outScrollX", "outScrollY", "outScrollTop", "outScrollBottom"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
1876
1876
  }
1877
1877
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsEmojiComponent, decorators: [{
1878
1878
  type: Component,