@libs-ui/components-inputs-calculator 0.2.175 → 0.2.177
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.
|
@@ -161,7 +161,7 @@ export class LibsUiComponentsInputsCalculatorComponent {
|
|
|
161
161
|
});
|
|
162
162
|
}
|
|
163
163
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsInputsCalculatorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
164
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsInputsCalculatorComponent, isStandalone: true, selector: "libs_ui-components-inputs-calculator", inputs: { expressions: { classPropertyName: "expressions", publicName: "expressions", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, labelButtonSave: { classPropertyName: "labelButtonSave", publicName: "labelButtonSave", isSignal: true, isRequired: false, transformFunction: null }, configField: { classPropertyName: "configField", publicName: "configField", isSignal: true, isRequired: false, transformFunction: null }, ignoreButtonSave: { classPropertyName: "ignoreButtonSave", publicName: "ignoreButtonSave", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, classContainerInput: { classPropertyName: "classContainerInput", publicName: "classContainerInput", isSignal: true, isRequired: false, transformFunction: null }, classContainerButton: { classPropertyName: "classContainerButton", publicName: "classContainerButton", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { outChangeExpressions: "outChangeExpressions" }, viewQueries: [{ propertyName: "inputRef", predicate: ["inputRef"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"w-full\">\n <div class=\"p-[8px] rounded-[12px] bg-[#f8f9fa] {{ classInclude() }}\">\n <div #calculatorInput\n class=\"py-[10px] px-[12px] libs-ui-font-h5r rounded-[8px] bg-[#ffffff] min-h-[160px] mb-[8px] border-[1px] {{ isFocus() ? 'border-[var(--libs-ui-color-light-1)]' : 'border-[#ffffff]' }} {{ classContainerInput() }}\"\n (mouseup)=\"handlerClickInput($event)\">\n <ul class=\"before:content-[''] before:table after:content-[''] after:table after:clear-both\">\n @for (item of listExpressions(); track $index; let i = $index) {\n <li class=\"float-left mb-[8px]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none text-center\"\n [class.ml-[-8px]]=\"i === 0\"\n [style.width.px]=\"inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(i)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n @switch (item.type) {\n @case ('operation') {\n <li class=\"float-left mb-[8px] text-center w-[24px] rounded-[4px] p-[4px] bg-[var(--libs-ui-color-light-2)]\">{{ item.data }}</li>\n }\n @case ('value') {\n <li class=\"float-left mb-[8px] text-center rounded-[4px] py-[4px] px-[8px] bg-[#E6E7EA] flex max-w-[calc(100%-8px)]\">\n <libs_ui-components-popover [type]=\"'text'\">{{ item.data }}</libs_ui-components-popover>\n </li>\n }\n @case ('field') {\n @if (item.data | LibsUiComponentsInputsCalculatorGetFieldSelectedPipe:configField()?.getFieldSelected; as fieldSelected) {\n <li class=\"float-left mb-[8px]\">\n <libs_ui-components-buttons-button class=\"max-w-[150px] block\"\n [label]=\"fieldSelected.name || ''\"\n [classInclude]=\"'!justify-center !py-[3px] !px-[7px] !w-full'\"\n [classIconLeft]=\"fieldSelected.icon || ''\"\n [classIconRight]=\"'libs-ui-icon-move-right rotate-90'\"\n [classLabel]=\"'libs-ui-font-h5r'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:false,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: i, key: item.data},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, i)\" />\n </li>\n }\n }\n }\n }\n <li class=\"float-left mb-[8px] max-w-[100%]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none max-w-[100%] {{ listExpressions().length ? 'text-center' : '' }}\"\n [style.width.px]=\"listExpressions().length ? (inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput) : 150\"\n [placeholder]=\"!listExpressions().length ? (placeholder() | translate) : ''\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(listExpressions().length)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n </ul>\n </div>\n <div class=\"grid grid-cols-4 gap-[8px] {{ classContainerButton() }}\">\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"configField()?.label || 'i18n_select_field'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:true,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: -1},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, -1)\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-violet'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'Fx'\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-danger-high'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'C'\"\n (outClick)=\"handlerClick($event, 'c')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'('\"\n (outClick)=\"handlerClick($event, '(')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"')'\"\n (outClick)=\"handlerClick($event, ')')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'/'\"\n (outClick)=\"handlerClick($event, '/')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'1'\"\n (outClick)=\"handlerClick($event, '1')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'2'\"\n (outClick)=\"handlerClick($event, '2')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'3'\"\n (outClick)=\"handlerClick($event, '3')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-close'\"\n (outClick)=\"handlerClick($event, '*')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'4'\"\n (outClick)=\"handlerClick($event, '4')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'5'\"\n (outClick)=\"handlerClick($event, '5')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'6'\"\n (outClick)=\"handlerClick($event, '6')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'-'\"\n (outClick)=\"handlerClick($event, '-')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'7'\"\n (outClick)=\"handlerClick($event, '7')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'8'\"\n (outClick)=\"handlerClick($event, '8')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'9'\"\n (outClick)=\"handlerClick($event, '9')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-add'\"\n (outClick)=\"handlerClick($event, '+')\" />\n </div>\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"'0'\"\n [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n (outClick)=\"handlerClick($event, '0')\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'.'\"\n (outClick)=\"handlerClick($event, '.')\" />\n </div>\n </div>\n </div>\n @if (!ignoreButtonSave()) {\n <div class=\"mt-[16px]\">\n <libs_ui-components-buttons-button [label]=\"labelButtonSave()\"\n [disable]=\"!isChangeExpression()\"\n [classInclude]=\"'justify-center w-full'\"\n (outClick)=\"handlerSave($event)\" />\n </div>\n }\n</div>\n\n<ng-template #listViewRef\n let-data='itemContext'>\n <libs_ui-components-list [zIndex]=\"zIndex()\"\n [config]=\"configField()?.listConfig\"\n [maxItemShow]=\"6\"\n [clickExactly]=\"false\"\n [searchConfig]=\"{noBorder: true, placeholder: configField()?.placeholderInputList || 'i18n_search'}\"\n [multiKeySelected]=\"data.key ? [data.key] : []\"\n (outSelectMultiKey)=\"handlerSelectedField($event, data.index)\">\n </libs_ui-components-list>\n</ng-template>\n", dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "component", type: LibsUiComponentsButtonsButtonComponent, selector: "libs_ui-components-buttons-button", inputs: ["flagMouse", "type", "buttonCustom", "sizeButton", "label", "disable", "isPending", "imageLeft", "classInclude", "classIconLeft", "classIconRight", "classLabel", "iconOnlyType", "popover", "ignoreStopPropagationEvent", "zIndex", "widthLabelPopover", "styleIconLeft", "styleButton", "ignoreFocusWhenInputTab", "ignoreSetClickWhenShowPopover", "ignorePointerEvent", "isActive"], outputs: ["outClick", "outPopoverEvent", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsListComponent, selector: "libs_ui-components-list", inputs: ["hiddenInputSearch", "dropdownTabKeyActive", "keySearch", "paddingLeftItem", "config", "autoSelectedFirstItemCallOutsideBefore", "isSearchOnline", "disable", "disableLabel", "labelConfig", "searchConfig", "searchPadding", "dividerClassInclude", "hasDivider", "buttonsOther", "hasButtonUnSelectOption", "clickExactly", "backgroundListCustom", "maxItemShow", "keySelected", "multiKeySelected", "keysDisableItem", "keysHiddenItem", "focusInputSearch", "skipFocusInputWhenKeySearchStoreUndefined", "functionGetItemsAutoAddList", "validRequired", "showValidateBottom", "zIndex", "loadingIconSize", "templateRefSearchNoData", "resetKeyWhenSelectAllKeyDropdown", "ignoreClassDisableDefaultWhenUseKeysDisableItem"], outputs: ["outSelectKey", "outSelectMultiKey", "outUnSelectMultiKey", "outClickButtonOther", "outFieldKey", "outChangeView", "outKeySearch", "outLoading", "outFunctionsControl", "outChangStageFlagMousePopover", "outLoadItemsComplete"] }, { kind: "pipe", type: LibsUiComponentsInputsCalculatorGetFieldSelectedPipe, name: "LibsUiComponentsInputsCalculatorGetFieldSelectedPipe" }, { 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: "pipe", type: LibsUiComponentsInputsCalculatorGetWidthInputPipe, name: "LibsUiComponentsInputsCalculatorGetWidthInputPipe" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
164
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsInputsCalculatorComponent, isStandalone: true, selector: "libs_ui-components-inputs-calculator", inputs: { expressions: { classPropertyName: "expressions", publicName: "expressions", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, labelButtonSave: { classPropertyName: "labelButtonSave", publicName: "labelButtonSave", isSignal: true, isRequired: false, transformFunction: null }, configField: { classPropertyName: "configField", publicName: "configField", isSignal: true, isRequired: false, transformFunction: null }, ignoreButtonSave: { classPropertyName: "ignoreButtonSave", publicName: "ignoreButtonSave", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, classContainerInput: { classPropertyName: "classContainerInput", publicName: "classContainerInput", isSignal: true, isRequired: false, transformFunction: null }, classContainerButton: { classPropertyName: "classContainerButton", publicName: "classContainerButton", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { outChangeExpressions: "outChangeExpressions" }, viewQueries: [{ propertyName: "inputRef", predicate: ["inputRef"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"w-full\">\n <div class=\"p-[8px] rounded-[12px] bg-[#f8f9fa] {{ classInclude() }}\">\n <div #calculatorInput\n class=\"py-[10px] px-[12px] libs-ui-font-h5r rounded-[8px] bg-[#ffffff] min-h-[160px] mb-[8px] border-[1px] {{ isFocus() ? 'border-[var(--libs-ui-color-light-1)]' : 'border-[#ffffff]' }} {{ classContainerInput() }}\"\n (mouseup)=\"handlerClickInput($event)\">\n <ul class=\"before:content-[''] before:table after:content-[''] after:table after:clear-both\">\n @for (item of listExpressions(); track $index; let i = $index) {\n <li class=\"float-left mb-[8px]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none text-center\"\n [class.ml-[-8px]]=\"i === 0\"\n [style.width.px]=\"inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(i)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n @switch (item.type) {\n @case ('operation') {\n <li class=\"float-left mb-[8px] text-center w-[24px] rounded-[4px] p-[4px] bg-[var(--libs-ui-color-light-2)]\">{{ item.data }}</li>\n }\n @case ('value') {\n <li class=\"float-left mb-[8px] text-center rounded-[4px] py-[4px] px-[8px] bg-[#E6E7EA] flex max-w-[calc(100%-8px)]\">\n <libs_ui-components-popover [type]=\"'text'\">{{ item.data }}</libs_ui-components-popover>\n </li>\n }\n @case ('field') {\n @if (item.data | LibsUiComponentsInputsCalculatorGetFieldSelectedPipe:configField()?.getFieldSelected; as fieldSelected) {\n <li class=\"float-left mb-[8px]\">\n <libs_ui-components-buttons-button class=\"max-w-[150px] block\"\n [label]=\"fieldSelected.name || ''\"\n [classInclude]=\"'!justify-center !py-[3px] !px-[7px] !w-full'\"\n [classIconLeft]=\"fieldSelected.icon || ''\"\n [classIconRight]=\"'libs-ui-icon-move-right rotate-90'\"\n [classLabel]=\"'libs-ui-font-h5r'\"\n [zIndex]=\" zIndex()\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:false,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: i, key: item.data},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, i)\" />\n </li>\n }\n }\n }\n }\n <li class=\"float-left mb-[8px] max-w-[100%]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none max-w-[100%] {{ listExpressions().length ? 'text-center' : '' }}\"\n [style.width.px]=\"listExpressions().length ? (inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput) : 150\"\n [placeholder]=\"!listExpressions().length ? (placeholder() | translate) : ''\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(listExpressions().length)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n </ul>\n </div>\n <div class=\"grid grid-cols-4 gap-[8px] {{ classContainerButton() }}\">\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"configField()?.label || 'i18n_select_field'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:true,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: -1},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, -1)\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-violet'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'Fx'\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-danger-high'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'C'\"\n (outClick)=\"handlerClick($event, 'c')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'('\"\n (outClick)=\"handlerClick($event, '(')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"')'\"\n (outClick)=\"handlerClick($event, ')')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'/'\"\n (outClick)=\"handlerClick($event, '/')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'1'\"\n (outClick)=\"handlerClick($event, '1')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'2'\"\n (outClick)=\"handlerClick($event, '2')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'3'\"\n (outClick)=\"handlerClick($event, '3')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-close'\"\n (outClick)=\"handlerClick($event, '*')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'4'\"\n (outClick)=\"handlerClick($event, '4')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'5'\"\n (outClick)=\"handlerClick($event, '5')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'6'\"\n (outClick)=\"handlerClick($event, '6')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'-'\"\n (outClick)=\"handlerClick($event, '-')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'7'\"\n (outClick)=\"handlerClick($event, '7')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'8'\"\n (outClick)=\"handlerClick($event, '8')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'9'\"\n (outClick)=\"handlerClick($event, '9')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-add'\"\n (outClick)=\"handlerClick($event, '+')\" />\n </div>\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"'0'\"\n [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n (outClick)=\"handlerClick($event, '0')\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'.'\"\n (outClick)=\"handlerClick($event, '.')\" />\n </div>\n </div>\n </div>\n @if (!ignoreButtonSave()) {\n <div class=\"mt-[16px]\">\n <libs_ui-components-buttons-button [label]=\"labelButtonSave()\"\n [disable]=\"!isChangeExpression()\"\n [classInclude]=\"'justify-center w-full'\"\n (outClick)=\"handlerSave($event)\" />\n </div>\n }\n</div>\n\n<ng-template #listViewRef\n let-data='itemContext'>\n <libs_ui-components-list [zIndex]=\"zIndex()\"\n [config]=\"configField()?.listConfig\"\n [maxItemShow]=\"6\"\n [clickExactly]=\"false\"\n [searchConfig]=\"{noBorder: true, placeholder: configField()?.placeholderInputList || 'i18n_search'}\"\n [multiKeySelected]=\"data.key ? [data.key] : []\"\n (outSelectMultiKey)=\"handlerSelectedField($event, data.index)\">\n </libs_ui-components-list>\n</ng-template>\n", dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "component", type: LibsUiComponentsButtonsButtonComponent, selector: "libs_ui-components-buttons-button", inputs: ["flagMouse", "type", "buttonCustom", "sizeButton", "label", "disable", "isPending", "imageLeft", "classInclude", "classIconLeft", "classIconRight", "classLabel", "iconOnlyType", "popover", "ignoreStopPropagationEvent", "zIndex", "widthLabelPopover", "styleIconLeft", "styleButton", "ignoreFocusWhenInputTab", "ignoreSetClickWhenShowPopover", "ignorePointerEvent", "isActive"], outputs: ["outClick", "outPopoverEvent", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsListComponent, selector: "libs_ui-components-list", inputs: ["hiddenInputSearch", "dropdownTabKeyActive", "keySearch", "paddingLeftItem", "config", "autoSelectedFirstItemCallOutsideBefore", "isSearchOnline", "disable", "disableLabel", "labelConfig", "searchConfig", "searchPadding", "dividerClassInclude", "hasDivider", "buttonsOther", "hasButtonUnSelectOption", "clickExactly", "backgroundListCustom", "maxItemShow", "keySelected", "multiKeySelected", "keysDisableItem", "keysHiddenItem", "focusInputSearch", "skipFocusInputWhenKeySearchStoreUndefined", "functionGetItemsAutoAddList", "validRequired", "showValidateBottom", "zIndex", "loadingIconSize", "templateRefSearchNoData", "resetKeyWhenSelectAllKeyDropdown", "ignoreClassDisableDefaultWhenUseKeysDisableItem"], outputs: ["outSelectKey", "outSelectMultiKey", "outUnSelectMultiKey", "outClickButtonOther", "outFieldKey", "outChangeView", "outKeySearch", "outLoading", "outFunctionsControl", "outChangStageFlagMousePopover", "outLoadItemsComplete"] }, { kind: "pipe", type: LibsUiComponentsInputsCalculatorGetFieldSelectedPipe, name: "LibsUiComponentsInputsCalculatorGetFieldSelectedPipe" }, { 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: "pipe", type: LibsUiComponentsInputsCalculatorGetWidthInputPipe, name: "LibsUiComponentsInputsCalculatorGetWidthInputPipe" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
165
165
|
}
|
|
166
166
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsInputsCalculatorComponent, decorators: [{
|
|
167
167
|
type: Component,
|
|
@@ -172,6 +172,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
172
172
|
LibsUiComponentsInputsCalculatorGetFieldSelectedPipe,
|
|
173
173
|
LibsUiComponentsPopoverComponent,
|
|
174
174
|
LibsUiComponentsInputsCalculatorGetWidthInputPipe
|
|
175
|
-
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"w-full\">\n <div class=\"p-[8px] rounded-[12px] bg-[#f8f9fa] {{ classInclude() }}\">\n <div #calculatorInput\n class=\"py-[10px] px-[12px] libs-ui-font-h5r rounded-[8px] bg-[#ffffff] min-h-[160px] mb-[8px] border-[1px] {{ isFocus() ? 'border-[var(--libs-ui-color-light-1)]' : 'border-[#ffffff]' }} {{ classContainerInput() }}\"\n (mouseup)=\"handlerClickInput($event)\">\n <ul class=\"before:content-[''] before:table after:content-[''] after:table after:clear-both\">\n @for (item of listExpressions(); track $index; let i = $index) {\n <li class=\"float-left mb-[8px]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none text-center\"\n [class.ml-[-8px]]=\"i === 0\"\n [style.width.px]=\"inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(i)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n @switch (item.type) {\n @case ('operation') {\n <li class=\"float-left mb-[8px] text-center w-[24px] rounded-[4px] p-[4px] bg-[var(--libs-ui-color-light-2)]\">{{ item.data }}</li>\n }\n @case ('value') {\n <li class=\"float-left mb-[8px] text-center rounded-[4px] py-[4px] px-[8px] bg-[#E6E7EA] flex max-w-[calc(100%-8px)]\">\n <libs_ui-components-popover [type]=\"'text'\">{{ item.data }}</libs_ui-components-popover>\n </li>\n }\n @case ('field') {\n @if (item.data | LibsUiComponentsInputsCalculatorGetFieldSelectedPipe:configField()?.getFieldSelected; as fieldSelected) {\n <li class=\"float-left mb-[8px]\">\n <libs_ui-components-buttons-button class=\"max-w-[150px] block\"\n [label]=\"fieldSelected.name || ''\"\n [classInclude]=\"'!justify-center !py-[3px] !px-[7px] !w-full'\"\n [classIconLeft]=\"fieldSelected.icon || ''\"\n [classIconRight]=\"'libs-ui-icon-move-right rotate-90'\"\n [classLabel]=\"'libs-ui-font-h5r'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:false,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: i, key: item.data},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, i)\" />\n </li>\n }\n }\n }\n }\n <li class=\"float-left mb-[8px] max-w-[100%]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none max-w-[100%] {{ listExpressions().length ? 'text-center' : '' }}\"\n [style.width.px]=\"listExpressions().length ? (inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput) : 150\"\n [placeholder]=\"!listExpressions().length ? (placeholder() | translate) : ''\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(listExpressions().length)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n </ul>\n </div>\n <div class=\"grid grid-cols-4 gap-[8px] {{ classContainerButton() }}\">\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"configField()?.label || 'i18n_select_field'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:true,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: -1},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, -1)\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-violet'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'Fx'\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-danger-high'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'C'\"\n (outClick)=\"handlerClick($event, 'c')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'('\"\n (outClick)=\"handlerClick($event, '(')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"')'\"\n (outClick)=\"handlerClick($event, ')')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'/'\"\n (outClick)=\"handlerClick($event, '/')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'1'\"\n (outClick)=\"handlerClick($event, '1')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'2'\"\n (outClick)=\"handlerClick($event, '2')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'3'\"\n (outClick)=\"handlerClick($event, '3')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-close'\"\n (outClick)=\"handlerClick($event, '*')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'4'\"\n (outClick)=\"handlerClick($event, '4')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'5'\"\n (outClick)=\"handlerClick($event, '5')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'6'\"\n (outClick)=\"handlerClick($event, '6')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'-'\"\n (outClick)=\"handlerClick($event, '-')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'7'\"\n (outClick)=\"handlerClick($event, '7')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'8'\"\n (outClick)=\"handlerClick($event, '8')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'9'\"\n (outClick)=\"handlerClick($event, '9')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-add'\"\n (outClick)=\"handlerClick($event, '+')\" />\n </div>\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"'0'\"\n [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n (outClick)=\"handlerClick($event, '0')\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'.'\"\n (outClick)=\"handlerClick($event, '.')\" />\n </div>\n </div>\n </div>\n @if (!ignoreButtonSave()) {\n <div class=\"mt-[16px]\">\n <libs_ui-components-buttons-button [label]=\"labelButtonSave()\"\n [disable]=\"!isChangeExpression()\"\n [classInclude]=\"'justify-center w-full'\"\n (outClick)=\"handlerSave($event)\" />\n </div>\n }\n</div>\n\n<ng-template #listViewRef\n let-data='itemContext'>\n <libs_ui-components-list [zIndex]=\"zIndex()\"\n [config]=\"configField()?.listConfig\"\n [maxItemShow]=\"6\"\n [clickExactly]=\"false\"\n [searchConfig]=\"{noBorder: true, placeholder: configField()?.placeholderInputList || 'i18n_search'}\"\n [multiKeySelected]=\"data.key ? [data.key] : []\"\n (outSelectMultiKey)=\"handlerSelectedField($event, data.index)\">\n </libs_ui-components-list>\n</ng-template>\n" }]
|
|
175
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"w-full\">\n <div class=\"p-[8px] rounded-[12px] bg-[#f8f9fa] {{ classInclude() }}\">\n <div #calculatorInput\n class=\"py-[10px] px-[12px] libs-ui-font-h5r rounded-[8px] bg-[#ffffff] min-h-[160px] mb-[8px] border-[1px] {{ isFocus() ? 'border-[var(--libs-ui-color-light-1)]' : 'border-[#ffffff]' }} {{ classContainerInput() }}\"\n (mouseup)=\"handlerClickInput($event)\">\n <ul class=\"before:content-[''] before:table after:content-[''] after:table after:clear-both\">\n @for (item of listExpressions(); track $index; let i = $index) {\n <li class=\"float-left mb-[8px]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none text-center\"\n [class.ml-[-8px]]=\"i === 0\"\n [style.width.px]=\"inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(i)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n @switch (item.type) {\n @case ('operation') {\n <li class=\"float-left mb-[8px] text-center w-[24px] rounded-[4px] p-[4px] bg-[var(--libs-ui-color-light-2)]\">{{ item.data }}</li>\n }\n @case ('value') {\n <li class=\"float-left mb-[8px] text-center rounded-[4px] py-[4px] px-[8px] bg-[#E6E7EA] flex max-w-[calc(100%-8px)]\">\n <libs_ui-components-popover [type]=\"'text'\">{{ item.data }}</libs_ui-components-popover>\n </li>\n }\n @case ('field') {\n @if (item.data | LibsUiComponentsInputsCalculatorGetFieldSelectedPipe:configField()?.getFieldSelected; as fieldSelected) {\n <li class=\"float-left mb-[8px]\">\n <libs_ui-components-buttons-button class=\"max-w-[150px] block\"\n [label]=\"fieldSelected.name || ''\"\n [classInclude]=\"'!justify-center !py-[3px] !px-[7px] !w-full'\"\n [classIconLeft]=\"fieldSelected.icon || ''\"\n [classIconRight]=\"'libs-ui-icon-move-right rotate-90'\"\n [classLabel]=\"'libs-ui-font-h5r'\"\n [zIndex]=\" zIndex()\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:false,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: i, key: item.data},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, i)\" />\n </li>\n }\n }\n }\n }\n <li class=\"float-left mb-[8px] max-w-[100%]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none max-w-[100%] {{ listExpressions().length ? 'text-center' : '' }}\"\n [style.width.px]=\"listExpressions().length ? (inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput) : 150\"\n [placeholder]=\"!listExpressions().length ? (placeholder() | translate) : ''\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(listExpressions().length)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n </ul>\n </div>\n <div class=\"grid grid-cols-4 gap-[8px] {{ classContainerButton() }}\">\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"configField()?.label || 'i18n_select_field'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:true,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: -1},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, -1)\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-violet'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'Fx'\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-danger-high'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'C'\"\n (outClick)=\"handlerClick($event, 'c')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'('\"\n (outClick)=\"handlerClick($event, '(')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"')'\"\n (outClick)=\"handlerClick($event, ')')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'/'\"\n (outClick)=\"handlerClick($event, '/')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'1'\"\n (outClick)=\"handlerClick($event, '1')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'2'\"\n (outClick)=\"handlerClick($event, '2')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'3'\"\n (outClick)=\"handlerClick($event, '3')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-close'\"\n (outClick)=\"handlerClick($event, '*')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'4'\"\n (outClick)=\"handlerClick($event, '4')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'5'\"\n (outClick)=\"handlerClick($event, '5')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'6'\"\n (outClick)=\"handlerClick($event, '6')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'-'\"\n (outClick)=\"handlerClick($event, '-')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'7'\"\n (outClick)=\"handlerClick($event, '7')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'8'\"\n (outClick)=\"handlerClick($event, '8')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'9'\"\n (outClick)=\"handlerClick($event, '9')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-add'\"\n (outClick)=\"handlerClick($event, '+')\" />\n </div>\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"'0'\"\n [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n (outClick)=\"handlerClick($event, '0')\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'.'\"\n (outClick)=\"handlerClick($event, '.')\" />\n </div>\n </div>\n </div>\n @if (!ignoreButtonSave()) {\n <div class=\"mt-[16px]\">\n <libs_ui-components-buttons-button [label]=\"labelButtonSave()\"\n [disable]=\"!isChangeExpression()\"\n [classInclude]=\"'justify-center w-full'\"\n (outClick)=\"handlerSave($event)\" />\n </div>\n }\n</div>\n\n<ng-template #listViewRef\n let-data='itemContext'>\n <libs_ui-components-list [zIndex]=\"zIndex()\"\n [config]=\"configField()?.listConfig\"\n [maxItemShow]=\"6\"\n [clickExactly]=\"false\"\n [searchConfig]=\"{noBorder: true, placeholder: configField()?.placeholderInputList || 'i18n_search'}\"\n [multiKeySelected]=\"data.key ? [data.key] : []\"\n (outSelectMultiKey)=\"handlerSelectedField($event, data.index)\">\n </libs_ui-components-list>\n</ng-template>\n" }]
|
|
176
176
|
}] });
|
|
177
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsY3VsYXRvci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvaW5wdXRzL2NhbGN1bGF0b3Ivc3JjL2NhbGN1bGF0b3IuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2lucHV0cy9jYWxjdWxhdG9yL3NyYy9jYWxjdWxhdG9yLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzVILE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsc0NBQXNDLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RixPQUFPLEVBQXlCLDZCQUE2QixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFHaEcsT0FBTyxFQUFFLFNBQVMsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2pFLE9BQU8sRUFBZ0MsZ0NBQWdDLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUM3RyxPQUFPLEVBQUUsb0RBQW9ELEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUN2RyxPQUFPLEVBQUUsaURBQWlELEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7O0FBaUJqRyxNQUFNLE9BQU8seUNBQXlDO0lBQzFDLFVBQVUsR0FBRyxNQUFNLENBQXFCLFNBQVMsQ0FBQyxDQUFDO0lBQ25ELE9BQU8sR0FBRyxNQUFNLENBQVUsS0FBSyxDQUFDLENBQUM7SUFDakMsZUFBZSxHQUFHLE1BQU0sQ0FBb0MsRUFBRSxDQUFDLENBQUM7SUFDaEUsa0JBQWtCLEdBQUcsTUFBTSxDQUFVLEtBQUssQ0FBQyxDQUFDO0lBRTlDLFFBQVEsR0FBRyxZQUFZ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QUksQ0FBQyxzQkFBc0IsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDekMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7WUFFeEIsT0FBTyxLQUFLLENBQUM7UUFDZixDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7d0dBbkxVLHlDQUF5Qzs0RkFBekMseUNBQXlDLDRpREMxQnRELHF2VkErT0EsMkNEOU5JLGVBQWUsNEZBQ2Ysc0NBQXNDLGloQkFDdEMsNkJBQTZCLHcvQkFDN0Isb0RBQW9ELDZGQUNwRCxnQ0FBZ0MsZ2VBQ2hDLGlEQUFpRDs7NEZBSXhDLHlDQUF5QztrQkFmckQsU0FBUzsrQkFFRSxzQ0FBc0MsY0FFcEMsSUFBSSxXQUNQO3dCQUNQLGVBQWU7d0JBQ2Ysc0NBQXNDO3dCQUN0Qyw2QkFBNkI7d0JBQzdCLG9EQUFvRDt3QkFDcEQsZ0NBQWdDO3dCQUNoQyxpREFBaUQ7cUJBQ2xELG1CQUNnQix1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRWxlbWVudFJlZiwgaW5wdXQsIE9uSW5pdCwgb3V0cHV0LCBzaWduYWwsIHZpZXdDaGlsZHJlbiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tIFwiQG5neC10cmFuc2xhdGUvY29yZVwiO1xuaW1wb3J0IHsgTGlic1VpQ29tcG9uZW50c0J1dHRvbnNCdXR0b25Db21wb25lbnQgfSBmcm9tICdAbGlicy11aS9jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uJztcbmltcG9ydCB7IElMaXN0RGF0YUVtaXRNdWx0aUtleSwgTGlic1VpQ29tcG9uZW50c0xpc3RDb21wb25lbnQgfSBmcm9tICdAbGlicy11aS9jb21wb25lbnRzLWxpc3QnO1xuaW1wb3J0IHsgSUlucHV0Q2FsY3VsYXRvckNvbmZpZ0ZpZWxkLCBJSW5wdXRDYWxjdWxhdG9yRXhwcmVzc2lvbiB9IGZyb20gXCIuL2ludGVyZmFjZXNcIjtcbmltcG9ydCB7IElFdmVudCB9IGZyb20gXCJAbGlicy11aS9pbnRlcmZhY2VzLXR5cGVzXCI7XG5pbXBvcnQgeyBjbG9uZURlZXAsIFV0aWxzS2V5Q29kZUNvbnN0YW50IH0gZnJvbSBcIkBsaWJzLXVpL3V0aWxzXCI7XG5pbXBvcnQgeyBJUG9wb3ZlckZ1bmN0aW9uQ29udHJvbEV2ZW50LCBMaWJzVWlDb21wb25lbnRzUG9wb3ZlckNvbXBvbmVudCB9IGZyb20gXCJAbGlicy11aS9jb21wb25lbnRzLXBvcG92ZXJcIjtcbmltcG9ydCB7IExpYnNVaUNvbXBvbmVudHNJbnB1dHNDYWxjdWxhdG9yR2V0RmllbGRTZWxlY3RlZFBpcGUgfSBmcm9tIFwiLi9waXBlcy9nZXQtZmllbGQtc2VsZWN0ZWQucGlwZVwiO1xuaW1wb3J0IHsgTGlic1VpQ29tcG9uZW50c0lucHV0c0NhbGN1bGF0b3JHZXRXaWR0aElucHV0UGlwZSB9IGZyb20gXCIuL3BpcGVzL2dldC13aWR0aC1pbnB1dC5waXBlXCI7XG5cbkBDb21wb25lbnQoe1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L2NvbXBvbmVudC1zZWxlY3RvclxuICBzZWxlY3RvcjogJ2xpYnNfdWktY29tcG9uZW50cy1pbnB1dHMtY2FsY3VsYXRvcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9jYWxjdWxhdG9yLmNvbXBvbmVudC5odG1sJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIFRyYW5zbGF0ZU1vZHVsZSxcbiAgICBMaWJzVWlDb21wb25lbnRzQnV0dG9uc0J1dHRvbkNvbXBvbmVudCxcbiAgICBMaWJzVWlDb21wb25lbnRzTGlzdENvbXBvbmVudCxcbiAgICBMaWJzVWlDb21wb25lbnRzSW5wdXRzQ2FsY3VsYXRvckdldEZpZWxkU2VsZWN0ZWRQaXBlLFxuICAgIExpYnNVaUNvbXBvbmVudHNQb3BvdmVyQ29tcG9uZW50LFxuICAgIExpYnNVaUNvbXBvbmVudHNJbnB1dHNDYWxjdWxhdG9yR2V0V2lkdGhJbnB1dFBpcGVcbiAgXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgTGlic1VpQ29tcG9uZW50c0lucHV0c0NhbGN1bGF0b3JDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBwcm90ZWN0ZWQgaW5kZXhGb2N1cyA9IHNpZ25hbDxudW1iZXIgfCB1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XG4gIHByb3RlY3RlZCBpc0ZvY3VzID0gc2lnbmFsPGJvb2xlYW4+KGZhbHNlKTtcbiAgcHJvdGVjdGVkIGxpc3RFeHByZXNzaW9ucyA9IHNpZ25hbDxBcnJheTxJSW5wdXRDYWxjdWxhdG9yRXhwcmVzc2lvbj4+KFtdKTtcbiAgcHJvdGVjdGVkIGlzQ2hhbmdlRXhwcmVzc2lvbiA9IHNpZ25hbDxib29sZWFuPihmYWxzZSk7XG5cbiAgcHJpdmF0ZSBpbnB1dFJlZiA9IHZpZXdDaGlsZHJlbjxFbGVtZW50UmVmPignaW5wdXRSZWYnKTtcbiAgcHJpdmF0ZSB0aW1lT3V0ID0gc2lnbmFsPG51bWJlciB8IHVuZGVmaW5lZD4odW5kZWZpbmVkKTtcbiAgcHJpdmF0ZSB0b29sdGlwRnVuY3Rpb25Db250cm9sID0gc2lnbmFsPE1hcDxudW1iZXIsIElQb3BvdmVyRnVuY3Rpb25Db250cm9sRXZlbnQ+PihuZXcgTWFwKCkpO1xuXG4gIHJlYWRvbmx5IGV4cHJlc3Npb25zID0gaW5wdXQ8QXJyYXk8SUlucHV0Q2FsY3VsYXRvckV4cHJlc3Npb24+PihbXSk7XG4gIHJlYWRvbmx5IHpJbmRleCA9IGlucHV0PG51bWJlcj4oMTApO1xuICByZWFkb25seSBwbGFjZWhvbGRlciA9IGlucHV0PHN0cmluZz4oJ2kxOG5fZW50ZXJfcGFyYW1zJyk7XG4gIHJlYWRvbmx5IGxhYmVsQnV0dG9uU2F2ZSA9IGlucHV0PHN0cmluZz4oJ2kxOG5fc2F2ZV9jYWxjdWxhdGlvbicpO1xuICByZWFkb25seSBjb25maWdGaWVsZCA9IGlucHV0PElJbnB1dENhbGN1bGF0b3JDb25maWdGaWVsZD4oKTtcbiAgcmVhZG9ubHkgaWdub3JlQnV0dG9uU2F2ZSA9IGlucHV0PGJvb2xlYW4+KGZhbHNlKTtcbiAgcmVhZG9ubHkgY2xhc3NJbmNsdWRlID0gaW5wdXQ8c3RyaW5nLCBzdHJpbmcgfCB1bmRlZmluZWQ+KCcnLCB7IHRyYW5zZm9ybTogKHZhbHVlKSA9PiB2YWx1ZSB8fCAnJyB9KTtcbiAgcmVhZG9ubHkgY2xhc3NDb250YWluZXJJbnB1dCA9IGlucHV0PHN0cmluZywgc3RyaW5nIHwgdW5kZWZpbmVkPignJywgeyB0cmFuc2Zvcm06ICh2YWx1ZSkgPT4gdmFsdWUgfHwgJycgfSk7XG4gIHJlYWRvbmx5IGNsYXNzQ29udGFpbmVyQnV0dG9uID0gaW5wdXQ8c3RyaW5nLCBzdHJpbmcgfCB1bmRlZmluZWQ+KCcnLCB7IHRyYW5zZm9ybTogKHZhbHVlKSA9PiB2YWx1ZSB8fCAnJyB9KTtcblxuICByZWFkb25seSBvdXRDaGFuZ2VFeHByZXNzaW9ucyA9IG91dHB1dDxBcnJheTxJSW5wdXRDYWxjdWxhdG9yRXhwcmVzc2lvbj4+KCk7XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5saXN0RXhwcmVzc2lvbnMuc2V0KGNsb25lRGVlcCh0aGlzLmV4cHJlc3Npb25zKCkpKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBoYW5kbGVyQ2xpY2soZXZlbnQ6IEV2ZW50LCBidXR0b246ICcrJyB8ICctJyB8ICcqJyB8ICcvJyB8ICdjJyB8ICcuJyB8ICcoJyB8ICcpJyB8ICcwJyB8ICcxJyB8ICcyJyB8ICczJyB8ICc0JyB8ICc1JyB8ICc2JyB8ICc3JyB8ICc4JyB8ICc5Jykge1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgIGNvbnN0IGV4cHJlc3Npb246IElJbnB1dENhbGN1bGF0b3JFeHByZXNzaW9uID0geyB0eXBlOiAnZmllbGQnLCBkYXRhOiBidXR0b24gfTtcblxuICAgIGlmIChidXR0b24gPT09ICdjJykge1xuICAgICAgaWYgKCF0aGlzLmxpc3RFeHByZXNzaW9ucygpLmxlbmd0aCB8fCB0aGlzLmluZGV4Rm9jdXMoKSA9PT0gMCkge1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG4gICAgICByZXR1cm4gdGhpcy51cGRhdGVFeHByZXNzaW9ucyh1bmRlZmluZWQsIHR5cGVvZiB0aGlzLmluZGV4Rm9jdXMoKSAhPT0gJ3VuZGVmaW5lZCcgPyAoKHRoaXMuaW5kZXhGb2N1cygpIHx8IDEpIC0gMSkgOiAodGhpcy5saXN0RXhwcmVzc2lvbnMoKS5sZW5ndGggLSAxKSk7XG4gICAgfVxuICAgIHN3aXRjaCAoYnV0dG9uKSB7XG4gICAgICBjYXNlICcrJzpcbiAgICAgIGNhc2UgJy0nOlxuICAgICAgY2FzZSAnKic6XG4gICAgICBjYXNlICcvJzpcbiAgICAgICAgZXhwcmVzc2lvbi50eXBlID0gJ29wZXJhdGlvbic7XG4gICAgICAgIGJyZWFrO1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgZXhwcmVzc2lvbi50eXBlID0gJ3ZhbHVlJztcbiAgICB9XG4gICAgdGhpcy51cGRhdGVFeHByZXNzaW9ucyhleHByZXNzaW9uLCB0eXBlb2YgdGhpcy5pbmRleEZvY3VzKCkgIT09ICd1bmRlZmluZWQnID8gKHRoaXMuaW5kZXhGb2N1cygpIHx8IDApIDogdGhpcy5saXN0RXhwcmVzc2lvbnMoKS5sZW5ndGgpO1xuICB9XG5cbiAgcHJpdmF0ZSB1cGRhdGVFeHByZXNzaW9ucyhpdGVtOiBJSW5wdXRDYWxjdWxhdG9yRXhwcmVzc2lvbiB8IHVuZGVmaW5lZCwgcG9zaXRpb246IG51bWJlciwgaXNEZWxldGU/OiBib29sZWFuKSB7XG4gICAgdGhpcy5pc0NoYW5nZUV4cHJlc3Npb24uc2V0KHRydWUpO1xuICAgIHRoaXMubGlzdEV4cHJlc3Npb25zLnVwZGF0ZSgodmFsdWUpID0+IHtcbiAgICAgIGlmIChpdGVtKSB7XG4gICAgICAgIHZhbHVlLnNwbGljZShwb3NpdGlvbiB8fCAwLCAwLCBpdGVtKTtcbiAgICAgIH1cbiAgICAgIGlmICghaXRlbSkge1xuICAgICAgICB2YWx1ZS5zcGxpY2UocG9zaXRpb24gfHwgMCwgMSk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBbLi4udmFsdWVdO1xuICAgIH0pXG5cbiAgICB0aGlzLmluZGV4Rm9jdXMudXBkYXRlKHZhbHVlID0+IHtcbiAgICAgIGlmICghaXRlbSkge1xuICAgICAgICBpZiAodmFsdWUpIHtcbiAgICAgICAgICB2YWx1ZSA9IGlzRGVsZXRlID8gdmFsdWUgOiB2YWx1ZSAtIDE7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gdmFsdWUgPyB2YWx1ZSA6IHBvc2l0aW9uO1xuICAgICAgfVxuICAgICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgICAgdmFsdWUgPSB0aGlzLmxpc3RFeHByZXNzaW9ucygpLmxlbmd0aDtcblxuICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICB9XG4gICAgICB2YWx1ZSsrO1xuXG4gICAgICByZXR1cm4gdmFsdWU7XG4gICAgfSlcbiAgICBjb25zdCBpbmRleEZvY3VzID0gdGhpcy5pbmRleEZvY3VzKCk7XG5cbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIGlmICh0eXBlb2YgaW5kZXhGb2N1cyAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgICAgdGhpcy5pbnB1dFJlZigpW2luZGV4Rm9jdXNdPy5uYXRpdmVFbGVtZW50LmZvY3VzKCk7XG4gICAgICB9XG4gICAgfSwgMTAwKVxuICB9XG5cbiAgcHJvdGVjdGVkIGhhbmRsZXJFdmVudEtleVVwSW5wdXQoZXZlbnQ6IEV2ZW50KSB7XG4gICAgY29uc3Qga2V5Q29kZSA9IChldmVudCBhcyBJRXZlbnQpLmtleUNvZGU7XG4gICAgY29uc3QgdmFsdWUgPSAoZXZlbnQgYXMgSUV2ZW50KS50YXJnZXQudmFsdWU7XG4gICAgY29uc3Qgc2hpZnRLZXkgPSAoZXZlbnQgYXMgSUV2ZW50KS5zaGlmdEtleTtcblxuICAgIGlmICgoKFtVdGlsc0tleUNvZGVDb25zdGFudC5FUVVBTFMsIFV0aWxzS2V5Q29kZUNvbnN0YW50LkVJR0hUXS5pbmNsdWRlcyhrZXlDb2RlKSAmJiBzaGlmdEtleSkgfHwgKFtVdGlsc0tleUNvZGVDb25zdGFudC5EQVNILCBVdGlsc0tleUNvZGVDb25zdGFudC5TTEFTSF0uaW5jbHVkZXMoa2V5Q29kZSkgJiYgIXNoaWZ0S2V5KSkgJiYgdmFsdWUubGVuZ3RoID09PSAxKSB7XG4gICAgICAoZXZlbnQgYXMgSUV2ZW50KS50YXJnZXQudmFsdWUgPSAnJztcblxuICAgICAgcmV0dXJuIHRoaXMudXBkYXRlRXhwcmVzc2lvbnMoeyB0eXBlOiAnb3BlcmF0aW9uJywgZGF0YTogdmFsdWUgfSwgdGhpcy5pbmRleEZvY3VzKCkgfHwgdGhpcy5saXN0RXhwcmVzc2lvbnMoKS5sZW5ndGgpO1xuICAgIH1cbiAgfVxuXG4gIHByb3RlY3RlZCBoYW5kbGVyRXZlbnRLZXlJbnB1dChldmVudDogRXZlbnQpIHtcbiAgICBjb25zdCBrZXlDb2RlID0gKGV2ZW50IGFzIElFdmVudCkua2V5Q29kZTtcbiAgICBjb25zdCB2YWx1ZSA9IChldmVudCBhcyBJRXZlbnQpLnRhcmdldC52YWx1ZTtcblxuICAgIGlmIChrZXlDb2RlID09PSBVdGlsc0tleUNvZGVDb25zdGFudC5CQUNLU1BBQ0UpIHtcbiAgICAgIGlmICghdmFsdWUgJiYgdGhpcy5saXN0RXhwcmVzc2lvbnMoKS5sZW5ndGggJiYgKHRoaXMuaW5kZXhGb2N1cygpIHx8IDApID4gMCkge1xuICAgICAgICByZXR1cm4gdGhpcy51cGRhdGVFeHByZXNzaW9ucyh1bmRlZmluZWQsICh0aGlzLmluZGV4Rm9jdXMoKSB8fCAwKSAtIDEpO1xuICAgICAgfVxuICAgIH1cbiAgICBpZiAoa2V5Q29kZSA9PT0gVXRpbHNLZXlDb2RlQ29uc3RhbnQuREVMRVRFKSB7XG4gICAgICBpZiAoIXZhbHVlICYmIHRoaXMubGlzdEV4cHJlc3Npb25zKCkubGVuZ3RoICYmICh0aGlzLmluZGV4Rm9jdXMoKSB8fCAwKSA8IHRoaXMubGlzdEV4cHJlc3Npb25zKCkubGVuZ3RoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLnVwZGF0ZUV4cHJlc3Npb25zKHVuZGVmaW5lZCwgKHRoaXMuaW5kZXhGb2N1cygpIHx8IDApLCB0cnVlKTtcbiAgICAgIH1cbiAgICB9XG4gICAgaWYgKGtleUNvZGUgPT09IFV0aWxzS2V5Q29kZUNvbnN0YW50LkVOVEVSKSB7XG4gICAgICBpZiAodmFsdWUpIHtcbiAgICAgICAgKGV2ZW50IGFzIElFdmVudCkudGFyZ2V0LnZhbHVlID0gJyc7XG5cbiAgICAgICAgcmV0dXJuIHRoaXMudXBkYXRlRXhwcmVzc2lvbnMoeyB0eXBlOiAndmFsdWUnLCBkYXRhOiB2YWx1ZSB9LCB0aGlzLmluZGV4Rm9jdXMoKSB8fCB0aGlzLmxpc3RFeHByZXNzaW9ucygpLmxlbmd0aCk7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcHJvdGVjdGVkIGhhbmRsZXJGb2N1c0FuZEJsdXJJbnB1dChpbmRleDogbnVtYmVyIHwgdW5kZWZpbmVkKSB7XG4gICAgaWYgKHR5cGVvZiBpbmRleCAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgIHRoaXMuaW5kZXhGb2N1cy5zZXQoaW5kZXgpO1xuICAgICAgdGhpcy5pc0ZvY3VzLnNldCh0cnVlKTtcbiAgICAgIGNsZWFyVGltZW91dCh0aGlzLnRpbWVPdXQoKSk7XG5cbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgdGhpcy50aW1lT3V0LnNldChzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHRoaXMuaXNGb2N1cy5zZXQoZmFsc2UpO1xuICAgIH0sIDI1MCkpXG4gIH1cblxuICBwcm90ZWN0ZWQgaGFuZGxlckNsaWNrSW5wdXQoZXZlbnQ6IEV2ZW50KSB7XG4gICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgaWYgKCF0aGlzLmlzRm9jdXMoKSkge1xuICAgICAgdGhpcy5pbnB1dFJlZigpW3RoaXMuaW5wdXRSZWYoKS5sZW5ndGggLSAxXS5uYXRpdmVFbGVtZW50LmZvY3VzKCk7XG4gICAgfVxuICB9XG5cbiAgcHJvdGVjdGVkIGhhbmRsZXJTYXZlKGV2ZW50OiBFdmVudCkge1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgIHRoaXMuaXNDaGFuZ2VFeHByZXNzaW9uLnNldChmYWxzZSk7XG4gICAgdGhpcy5vdXRDaGFuZ2VFeHByZXNzaW9ucy5lbWl0KGNsb25lRGVlcCh0aGlzLmxpc3RFeHByZXNzaW9ucygpKSk7XG4gIH1cblxuICBwcm90ZWN0ZWQgaGFuZGxlclNlbGVjdGVkRmllbGQoZXZlbnQ6IElMaXN0RGF0YUVtaXRNdWx0aUtleSB8IHVuZGVmaW5lZCwgaW5kZXg6IG51bWJlcikge1xuICAgIGlmICghZXZlbnQ/LmtleXMubGVuZ3RoKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIGlmIChpbmRleCA+PSAwKSB7XG4gICAgICB0aGlzLmxpc3RFeHByZXNzaW9ucy51cGRhdGUodmFsdWUgPT4ge1xuICAgICAgICB2YWx1ZS5mb3JFYWNoKChpdGVtLCBpKSA9PiB7XG4gICAgICAgICAgaWYgKGkgPT09IGluZGV4KSB7XG4gICAgICAgICAgICBpZiAoaXRlbS5kYXRhICE9PSBldmVudC5rZXlzWzBdKSB7XG4gICAgICAgICAgICAgIHRoaXMudG9vbHRpcEZ1bmN0aW9uQ29udHJvbCgpLmdldChpbmRleCk/LnJlbW92ZVBvcG92ZXJPdmVybGF5KCk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpdGVtLmRhdGEgPSBldmVudC5rZXlzWzBdIGFzIHN0cmluZ1xuICAgICAgICAgIH1cbiAgICAgICAgfSlcblxuICAgICAgICByZXR1cm4gWy4uLnZhbHVlXTtcbiAgICAgIH0pXG5cbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgdGhpcy51cGRhdGVFeHByZXNzaW9ucyh7IHR5cGU6ICdmaWVsZCcsIGRhdGE6IGV2ZW50LmtleXNbMF0gYXMgc3RyaW5nIH0sIHR5cGVvZiB0aGlzLmluZGV4Rm9jdXMoKSAhPT0gJ3VuZGVmaW5lZCcgPyAodGhpcy5pbmRleEZvY3VzKCkgfHwgMCkgOiB0aGlzLmxpc3RFeHByZXNzaW9ucygpLmxlbmd0aCk7XG4gICAgdGhpcy50b29sdGlwRnVuY3Rpb25Db250cm9sKCkuZ2V0KGluZGV4KT8ucmVtb3ZlUG9wb3Zlck92ZXJsYXkoKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBoYW5kbGVyRnVuY3Rpb25Db250cm9sQnV0dG9uKGV2ZW50OiBJUG9wb3ZlckZ1bmN0aW9uQ29udHJvbEV2ZW50LCBpbmRleDogbnVtYmVyKSB7XG4gICAgdGhpcy50b29sdGlwRnVuY3Rpb25Db250cm9sLnVwZGF0ZSh2YWx1ZSA9PiB7XG4gICAgICB2YWx1ZS5zZXQoaW5kZXgsIGV2ZW50KTtcblxuICAgICAgcmV0dXJuIHZhbHVlO1xuICAgIH0pXG4gIH1cbn0iLCI8ZGl2IGNsYXNzPVwidy1mdWxsXCI+XG4gIDxkaXYgY2xhc3M9XCJwLVs4cHhdIHJvdW5kZWQtWzEycHhdIGJnLVsjZjhmOWZhXSB7eyBjbGFzc0luY2x1ZGUoKSB9fVwiPlxuICAgIDxkaXYgI2NhbGN1bGF0b3JJbnB1dFxuICAgICAgY2xhc3M9XCJweS1bMTBweF0gcHgtWzEycHhdIGxpYnMtdWktZm9udC1oNXIgcm91bmRlZC1bOHB4XSBiZy1bI2ZmZmZmZl0gbWluLWgtWzE2MHB4XSBtYi1bOHB4XSBib3JkZXItWzFweF0ge3sgaXNGb2N1cygpID8gJ2JvcmRlci1bdmFyKC0tbGlicy11aS1jb2xvci1saWdodC0xKV0nIDogJ2JvcmRlci1bI2ZmZmZmZl0nIH19IHt7IGNsYXNzQ29udGFpbmVySW5wdXQoKSB9fVwiXG4gICAgICAobW91c2V1cCk9XCJoYW5kbGVyQ2xpY2tJbnB1dCgkZXZlbnQpXCI+XG4gICAgICA8dWwgY2xhc3M9XCJiZWZvcmU6Y29udGVudC1bJyddIGJlZm9yZTp0YWJsZSBhZnRlcjpjb250ZW50LVsnJ10gYWZ0ZXI6dGFibGUgYWZ0ZXI6Y2xlYXItYm90aFwiPlxuICAgICAgICBAZm9yIChpdGVtIG9mIGxpc3RFeHByZXNzaW9ucygpOyB0cmFjayAkaW5kZXg7IGxldCBpID0gJGluZGV4KSB7XG4gICAgICAgICAgPGxpIGNsYXNzPVwiZmxvYXQtbGVmdCBtYi1bOHB4XVwiPlxuICAgICAgICAgICAgPGlucHV0ICNpbnB1dFJlZlxuICAgICAgICAgICAgICB0eXBlPVwidGV4dFwiXG4gICAgICAgICAgICAgIGNsYXNzPVwiaW5saW5lLWJsb2NrIGgtWzI0cHhdIG91dGxpbmUtbm9uZSB0ZXh0LWNlbnRlclwiXG4gICAgICAgICAgICAgIFtjbGFzcy5tbC1bLThweF1dPVwiaSA9PT0gMFwiXG4gICAgICAgICAgICAgIFtzdHlsZS53aWR0aC5weF09XCJpbnB1dFJlZi52YWx1ZSB8IExpYnNVaUNvbXBvbmVudHNJbnB1dHNDYWxjdWxhdG9yR2V0V2lkdGhJbnB1dFBpcGU6Y2FsY3VsYXRvcklucHV0XCJcbiAgICAgICAgICAgICAgKGtleWRvd24pPVwiaGFuZGxlckV2ZW50S2V5SW5wdXQoJGV2ZW50KVwiXG4gICAgICAgICAgICAgIChrZXl1cCk9XCJoYW5kbGVyRXZlbnRLZXlVcElucHV0KCRldmVudClcIlxuICAgICAgICAgICAgICAoZm9jdXMpPVwiaGFuZGxlckZvY3VzQW5kQmx1cklucHV0KGkpXCJcbiAgICAgICAgICAgICAgKGJsdXIpPVwiaGFuZGxlckZvY3VzQW5kQmx1cklucHV0KHVuZGVmaW5lZClcIiAvPlxuICAgICAgICAgIDwvbGk+XG4gICAgICAgICAgQHN3aXRjaCAoaXRlbS50eXBlKSB7XG4gICAgICAgICAgICBAY2FzZSAoJ29wZXJhdGlvbicpIHtcbiAgICAgICAgICAgICAgPGxpIGNsYXNzPVwiZmxvYXQtbGVmdCBtYi1bOHB4XSB0ZXh0LWNlbnRlciB3LVsyNHB4XSByb3VuZGVkLVs0cHhdIHAtWzRweF0gYmctW3ZhcigtLWxpYnMtdWktY29sb3ItbGlnaHQtMildXCI+e3sgaXRlbS5kYXRhIH19PC9saT5cbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIEBjYXNlICgndmFsdWUnKSB7XG4gICAgICAgICAgICAgIDxsaSBjbGFzcz1cImZsb2F0LWxlZnQgbWItWzhweF0gdGV4dC1jZW50ZXIgcm91bmRlZC1bNHB4XSBweS1bNHB4XSBweC1bOHB4XSBiZy1bI0U2RTdFQV0gZmxleCBtYXgtdy1bY2FsYygxMDAlLThweCldXCI+XG4gICAgICAgICAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1wb3BvdmVyIFt0eXBlXT1cIid0ZXh0J1wiPnt7IGl0ZW0uZGF0YSB9fTwvbGlic191aS1jb21wb25lbnRzLXBvcG92ZXI+XG4gICAgICAgICAgICAgIDwvbGk+XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBAY2FzZSAoJ2ZpZWxkJykge1xuICAgICAgICAgICAgICBAaWYgKGl0ZW0uZGF0YSB8IExpYnNVaUNvbXBvbmVudHNJbnB1dHNDYWxjdWxhdG9yR2V0RmllbGRTZWxlY3RlZFBpcGU6Y29uZmlnRmllbGQoKT8uZ2V0RmllbGRTZWxlY3RlZDsgYXMgZmllbGRTZWxlY3RlZCkge1xuICAgICAgICAgICAgICAgIDxsaSBjbGFzcz1cImZsb2F0LWxlZnQgbWItWzhweF1cIj5cbiAgICAgICAgICAgICAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gY2xhc3M9XCJtYXgtdy1bMTUwcHhdIGJsb2NrXCJcbiAgICAgICAgICAgICAgICAgICAgW2xhYmVsXT1cImZpZWxkU2VsZWN0ZWQubmFtZSB8fCAnJ1wiXG4gICAgICAgICAgICAgICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJyFqdXN0aWZ5LWNlbnRlciAhcHktWzNweF0gIXB4LVs3cHhdICF3LWZ1bGwnXCJcbiAgICAgICAgICAgICAgICAgICAgW2NsYXNzSWNvbkxlZnRdPVwiZmllbGRTZWxlY3RlZC5pY29uIHx8ICcnXCJcbiAgICAgICAgICAgICAgICAgICAgW2NsYXNzSWNvblJpZ2h0XT1cIidsaWJzLXVpLWljb24tbW92ZS1yaWdodCByb3RhdGUtOTAnXCJcbiAgICAgICAgICAgICAgICAgICAgW2NsYXNzTGFiZWxdPVwiJ2xpYnMtdWktZm9udC1oNXInXCJcbiAgICAgICAgICAgICAgICAgICAgW3BvcG92ZXJdPVwie1xuICAgICAgICAgICAgICAgICAgICAgIG1vZGU6ICdjbGljay10b2dnbGUnLFxuICAgICAgICAgICAgICAgICAgICAgIGlnbm9yZUhpZGRlblBvcG92ZXJDb250ZW50V2hlbk1vdXNlTGVhdmU6IHRydWUsXG4gICAgICAgICAgICAgICAgICAgICAgY29uZmlnOiB7XG4gICAgICAgICAgICAgICAgICAgICAgICB6SW5kZXg6IHpJbmRleCgpLFxuICAgICAgICAgICAgICAgICAgICAgICAgYW5pbWF0aW9uQ29uZmlnOiB7fSxcbiAgICAgICAgICAgICAgICAgICAgICAgIHdpZHRoQnlQYXJlbnQ6ZmFsc2UsXG4gICAgICAgICAgICAgICAgICAgICAgICBwYXJlbnRCb3JkZXJXaWR0aDogMCxcbiAgICAgICAgICAgICAgICAgICAgICAgIG1heEhlaWdodDoyMDQ4LFxuICAgICAgICAgICAgICAgICAgICAgICAgbWF4V2lkdGg6IDIwNDgsXG4gICAgICAgICAgICAgICAgICAgICAgICBkaXJlY3Rpb246ICdib3R0b20nLFxuICAgICAgICAgICAgICAgICAgICAgICAgZGlyZWN0aW9uRGlzdGFuY2U6MixcbiAgICAgICAgICAgICAgICAgICAgICAgIHRlbXBsYXRlOiBsaXN0Vmlld1JlZixcbiAgICAgICAgICAgICAgICAgICAgICAgIGl0ZW1Db250ZXh0OiB7aW5kZXg6IGksIGtleTogaXRlbS5kYXRhfSxcbiAgICAgICAgICAgICAgICAgICAgICAgIHdoaXRlVGhlbWU6dHJ1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgIGlnbm9yZUFycm93OnRydWUsXG4gICAgICAgICAgICAgICAgICAgICAgICBjbGFzc0luY2x1ZGU6JyFyb3VuZGVkLVs0cHhdICF3LVsyNzJweF0nLFxuICAgICAgICAgICAgICAgICAgICAgICAgcG9zaXRpb246eyBtb2RlOidzdGFydCcsZGlzdGFuY2U6MCB9LFxuICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgfVwiXG4gICAgICAgICAgICAgICAgICAgIChvdXRGdW5jdGlvbnNDb250cm9sKT1cImhhbmRsZXJGdW5jdGlvbkNvbnRyb2xCdXR0b24oJGV2ZW50LCBpKVwiIC8+XG4gICAgICAgICAgICAgICAgPC9saT5cbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICA8bGkgY2xhc3M9XCJmbG9hdC1sZWZ0IG1iLVs4cHhdIG1heC13LVsxMDAlXVwiPlxuICAgICAgICAgIDxpbnB1dCAjaW5wdXRSZWZcbiAgICAgICAgICAgIHR5cGU9XCJ0ZXh0XCJcbiAgICAgICAgICAgIGNsYXNzPVwiaW5saW5lLWJsb2NrIGgtWzI0cHhdIG91dGxpbmUtbm9uZSBtYXgtdy1bMTAwJV0ge3sgbGlzdEV4cHJlc3Npb25zKCkubGVuZ3RoID8gJ3RleHQtY2VudGVyJyA6ICcnIH19XCJcbiAgICAgICAgICAgIFtzdHlsZS53aWR0aC5weF09XCJsaXN0RXhwcmVzc2lvbnMoKS5sZW5ndGggPyAoaW5wdXRSZWYudmFsdWUgfCBMaWJzVWlDb21wb25lbnRzSW5wdXRzQ2FsY3VsYXRvckdldFdpZHRoSW5wdXRQaXBlOmNhbGN1bGF0b3JJbnB1dCkgOiAxNTBcIlxuICAgICAgICAgICAgW3BsYWNlaG9sZGVyXT1cIiFsaXN0RXhwcmVzc2lvbnMoKS5sZW5ndGggPyAocGxhY2Vob2xkZXIoKSB8IHRyYW5zbGF0ZSkgOiAnJ1wiXG4gICAgICAgICAgICAoa2V5ZG93bik9XCJoYW5kbGVyRXZlbnRLZXlJbnB1dCgkZXZlbnQpXCJcbiAgICAgICAgICAgIChrZXl1cCk9XCJoYW5kbGVyRXZlbnRLZXlVcElucHV0KCRldmVudClcIlxuICAgICAgICAgICAgKGZvY3VzKT1cImhhbmRsZXJGb2N1c0FuZEJsdXJJbnB1dChsaXN0RXhwcmVzc2lvbnMoKS5sZW5ndGgpXCJcbiAgICAgICAgICAgIChibHVyKT1cImhhbmRsZXJGb2N1c0FuZEJsdXJJbnB1dCh1bmRlZmluZWQpXCIgLz5cbiAgICAgICAgPC9saT5cbiAgICAgIDwvdWw+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBjbGFzcz1cImdyaWQgZ3JpZC1jb2xzLTQgZ2FwLVs4cHhdIHt7IGNsYXNzQ29udGFpbmVyQnV0dG9uKCkgfX1cIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtWzEvNF1cIj5cbiAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1idXR0b25zLWJ1dHRvbiBbbGFiZWxdPVwiY29uZmlnRmllbGQoKT8ubGFiZWwgfHwgJ2kxOG5fc2VsZWN0X2ZpZWxkJ1wiXG4gICAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInIXctZnVsbCAhanVzdGlmeS1jZW50ZXInXCJcbiAgICAgICAgICBbcG9wb3Zlcl09XCJ7XG4gICAgICAgICAgICBtb2RlOiAnY2xpY2stdG9nZ2xlJyxcbiAgICAgICAgICAgIGlnbm9yZUhpZGRlblBvcG92ZXJDb250ZW50V2hlbk1vdXNlTGVhdmU6IHRydWUsXG4gICAgICAgICAgICBjb25maWc6IHtcbiAgICAgICAgICAgICAgekluZGV4OiB6SW5kZXgoKSxcbiAgICAgICAgICAgICAgYW5pbWF0aW9uQ29uZmlnOiB7fSxcbiAgICAgICAgICAgICAgd2lkdGhCeVBhcmVudDp0cnVlLFxuICAgICAgICAgICAgICBwYXJlbnRCb3JkZXJXaWR0aDogMCxcbiAgICAgICAgICAgICAgbWF4SGVpZ2h0OjIwNDgsXG4gICAgICAgICAgICAgIG1heFdpZHRoOiAyMDQ4LFxuICAgICAgICAgICAgICBkaXJlY3Rpb246ICdib3R0b20nLFxuICAgICAgICAgICAgICBkaXJlY3Rpb25EaXN0YW5jZToyLFxuICAgICAgICAgICAgICB0ZW1wbGF0ZTogbGlzdFZpZXdSZWYsXG4gICAgICAgICAgICAgIGl0ZW1Db250ZXh0OiB7aW5kZXg6IC0xfSxcbiAgICAgICAgICAgICAgd2hpdGVUaGVtZTp0cnVlLFxuICAgICAgICAgICAgICBpZ25vcmVBcnJvdzp0cnVlLFxuICAgICAgICAgICAgICBjbGFzc0luY2x1ZGU6JyFyb3VuZGVkLVs0cHhdICF3LVsyNzJweF0nLFxuICAgICAgICAgICAgICBwb3NpdGlvbjp7IG1vZGU6J3N0YXJ0JyxkaXN0YW5jZTowIH0sXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVwiXG4gICAgICAgICAgKG91dEZ1bmN0aW9uc0NvbnRyb2wpPVwiaGFuZGxlckZ1bmN0aW9uQ29udHJvbEJ1dHRvbigkZXZlbnQsIC0xKVwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtWzQvNF1cIj5cbiAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1idXR0b25zLWJ1dHRvbiBbdHlwZV09XCInYnV0dG9uLXZpb2xldCdcIlxuICAgICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJyF3LWZ1bGwgIWp1c3RpZnktY2VudGVyJ1wiXG4gICAgICAgICAgW2xhYmVsXT1cIidGeCdcIiAvPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLVsxXVwiPlxuICAgICAgICA8bGlic191aS1jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uIFt0eXBlXT1cIididXR0b24tZGFuZ2VyLWhpZ2gnXCJcbiAgICAgICAgICBbY2xhc3NJbmNsdWRlXT1cIichdy1mdWxsICFqdXN0aWZ5LWNlbnRlcidcIlxuICAgICAgICAgIFtsYWJlbF09XCInQydcIlxuICAgICAgICAgIChvdXRDbGljayk9XCJoYW5kbGVyQ2xpY2soJGV2ZW50LCAnYycpXCIgLz5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC1bMl1cIj5cbiAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1idXR0b25zLWJ1dHRvbiBbdHlwZV09XCInYnV0dG9uLXRoaXJkJ1wiXG4gICAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInIXctZnVsbCAhanVzdGlmeS1jZW50ZXInXCJcbiAgICAgICAgICBbbGFiZWxdPVwiJygnXCJcbiAgICAgICAgICAob3V0Q2xpY2spPVwiaGFuZGxlckNsaWNrKCRldmVudCwgJygnKVwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtWzNdXCI+XG4gICAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gW3R5cGVdPVwiJ2J1dHRvbi10aGlyZCdcIlxuICAgICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJyF3LWZ1bGwgIWp1c3RpZnktY2VudGVyJ1wiXG4gICAgICAgICAgW2xhYmVsXT1cIicpJ1wiXG4gICAgICAgICAgKG91dENsaWNrKT1cImhhbmRsZXJDbGljaygkZXZlbnQsICcpJylcIiAvPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLVs0XVwiPlxuICAgICAgICA8bGlic191aS1jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uIFt0eXBlXT1cIididXR0b24tc2Vjb25kYXJ5J1wiXG4gICAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInIXctZnVsbCAhanVzdGlmeS1jZW50ZXInXCJcbiAgICAgICAgICBbbGFiZWxdPVwiJy8nXCJcbiAgICAgICAgICAob3V0Q2xpY2spPVwiaGFuZGxlckNsaWNrKCRldmVudCwgJy8nKVwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtWzFdXCI+XG4gICAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gW3R5cGVdPVwiJ2J1dHRvbi10aGlyZCdcIlxuICAgICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJyF3LWZ1bGwgIWp1c3RpZnktY2VudGVyJ1wiXG4gICAgICAgICAgW2xhYmVsXT1cIicxJ1wiXG4gICAgICAgICAgKG91dENsaWNrKT1cImhhbmRsZXJDbGljaygkZXZlbnQsICcxJylcIiAvPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLVsyXVwiPlxuICAgICAgICA8bGlic191aS1jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uIFt0eXBlXT1cIididXR0b24tdGhpcmQnXCJcbiAgICAgICAgICBbY2xhc3NJbmNsdWRlXT1cIichdy1mdWxsICFqdXN0aWZ5LWNlbnRlcidcIlxuICAgICAgICAgIFtsYWJlbF09XCInMidcIlxuICAgICAgICAgIChvdXRDbGljayk9XCJoYW5kbGVyQ2xpY2soJGV2ZW50LCAnMicpXCIgLz5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC1bM11cIj5cbiAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1idXR0b25zLWJ1dHRvbiBbdHlwZV09XCInYnV0dG9uLXRoaXJkJ1wiXG4gICAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInIXctZnVsbCAhanVzdGlmeS1jZW50ZXInXCJcbiAgICAgICAgICBbbGFiZWxdPVwiJzMnXCJcbiAgICAgICAgICAob3V0Q2xpY2spPVwiaGFuZGxlckNsaWNrKCRldmVudCwgJzMnKVwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtWzRdXCI+XG4gICAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gW3R5cGVdPVwiJ2J1dHRvbi1zZWNvbmRhcnknXCJcbiAgICAgICAgICBbY2xhc3NJbmNsdWRlXT1cIichdy1mdWxsICFqdXN0aWZ5LWNlbnRlcidcIlxuICAgICAgICAgIFtpY29uT25seVR5cGVdPVwidHJ1ZVwiXG4gICAgICAgICAgW2NsYXNzSWNvbkxlZnRdPVwiJ2xpYnMtdWktaWNvbi1jbG9zZSdcIlxuICAgICAgICAgIChvdXRDbGljayk9XCJoYW5kbGVyQ2xpY2soJGV2ZW50LCAnKicpXCIgLz5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC1bMV1cIj5cbiAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1idXR0b25zLWJ1dHRvbiBbdHlwZV09XCInYnV0dG9uLXRoaXJkJ1wiXG4gICAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInIXctZnVsbCAhanVzdGlmeS1jZW50ZXInXCJcbiAgICAgICAgICBbbGFiZWxdPVwiJzQnXCJcbiAgICAgICAgICAob3V0Q2xpY2spPVwiaGFuZGxlckNsaWNrKCRldmVudCwgJzQnKVwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtWzJdXCI+XG4gICAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gW3R5cGVdPVwiJ2J1dHRvbi10aGlyZCdcIlxuICAgICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJyF3LWZ1bGwgIWp1c3RpZnktY2VudGVyJ1wiXG4gICAgICAgICAgW2xhYmVsXT1cIic1J1wiXG4gICAgICAgICAgKG91dENsaWNrKT1cImhhbmRsZXJDbGljaygkZXZlbnQsICc1JylcIiAvPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLVszXVwiPlxuICAgICAgICA8bGlic191aS1jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uIFt0eXBlXT1cIididXR0b24tdGhpcmQnXCJcbiAgICAgICAgICBbY2xhc3NJbmNsdWRlXT1cIichdy1mdWxsICFqdXN0aWZ5LWNlbnRlcidcIlxuICAgICAgICAgIFtsYWJlbF09XCInNidcIlxuICAgICAgICAgIChvdXRDbGljayk9XCJoYW5kbGVyQ2xpY2soJGV2ZW50LCAnNicpXCIgLz5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC1bNF1cIj5cbiAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1idXR0b25zLWJ1dHRvbiBbdHlwZV09XCInYnV0dG9uLXNlY29uZGFyeSdcIlxuICAgICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJyF3LWZ1bGwgIWp1c3RpZnktY2VudGVyJ1wiXG4gICAgICAgICAgW2xhYmVsXT1cIictJ1wiXG4gICAgICAgICAgKG91dENsaWNrKT1cImhhbmRsZXJDbGljaygkZXZlbnQsICctJylcIiAvPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLVsxXVwiPlxuICAgICAgICA8bGlic191aS1jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uIFt0eXBlXT1cIididXR0b24tdGhpcmQnXCJcbiAgICAgICAgICBbY2xhc3NJbmNsdWRlXT1cIichdy1mdWxsICFqdXN0aWZ5LWNlbnRlcidcIlxuICAgICAgICAgIFtsYWJlbF09XCInNydcIlxuICAgICAgICAgIChvdXRDbGljayk9XCJoYW5kbGVyQ2xpY2soJGV2ZW50LCAnNycpXCIgLz5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC1bMl1cIj5cbiAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1idXR0b25zLWJ1dHRvbiBbdHlwZV09XCInYnV0dG9uLXRoaXJkJ1wiXG4gICAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInIXctZnVsbCAhanVzdGlmeS1jZW50ZXInXCJcbiAgICAgICAgICBbbGFiZWxdPVwiJzgnXCJcbiAgICAgICAgICAob3V0Q2xpY2spPVwiaGFuZGxlckNsaWNrKCRldmVudCwgJzgnKVwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtWzNdXCI+XG4gICAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gW3R5cGVdPVwiJ2J1dHRvbi10aGlyZCdcIlxuICAgICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJyF3LWZ1bGwgIWp1c3RpZnktY2VudGVyJ1wiXG4gICAgICAgICAgW2xhYmVsXT1cIic5J1wiXG4gICAgICAgICAgKG91dENsaWNrKT1cImhhbmRsZXJDbGljaygkZXZlbnQsICc5JylcIiAvPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLVs0XVwiPlxuICAgICAgICA8bGlic191aS1jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uIFt0eXBlXT1cIididXR0b24tc2Vjb25kYXJ5J1wiXG4gICAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInIXctZnVsbCAhanVzdGlmeS1jZW50ZXInXCJcbiAgICAgICAgICBbaWNvbk9ubHlUeXBlXT1cInRydWVcIlxuICAgICAgICAgIFtjbGFzc0ljb25MZWZ0XT1cIidsaWJzLXVpLWljb24tYWRkJ1wiXG4gICAgICAgICAgKG91dENsaWNrKT1cImhhbmRsZXJDbGljaygkZXZlbnQsICcrJylcIiAvPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLVsxLzRdXCI+XG4gICAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gW2xhYmVsXT1cIicwJ1wiXG4gICAgICAgICAgW3R5cGVdPVwiJ2J1dHRvbi10aGlyZCdcIlxuICAgICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJyF3LWZ1bGwgIWp1c3RpZnktY2VudGVyJ1wiXG4gICAgICAgICAgKG91dENsaWNrKT1cImhhbmRsZXJDbGljaygkZXZlbnQsICcwJylcIiAvPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLVs0LzRdXCI+XG4gICAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gW3R5cGVdPVwiJ2J1dHRvbi10aGlyZCdcIlxuICAgICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJyF3LWZ1bGwgIWp1c3RpZnktY2VudGVyJ1wiXG4gICAgICAgICAgW2xhYmVsXT1cIicuJ1wiXG4gICAgICAgICAgKG91dENsaWNrKT1cImhhbmRsZXJDbGljaygkZXZlbnQsICcuJylcIiAvPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuICBAaWYgKCFpZ25vcmVCdXR0b25TYXZlKCkpIHtcbiAgICA8ZGl2IGNsYXNzPVwibXQtWzE2cHhdXCI+XG4gICAgICA8bGlic191aS1jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uIFtsYWJlbF09XCJsYWJlbEJ1dHRvblNhdmUoKVwiXG4gICAgICAgIFtkaXNhYmxlXT1cIiFpc0NoYW5nZUV4cHJlc3Npb24oKVwiXG4gICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJ2p1c3RpZnktY2VudGVyIHctZnVsbCdcIlxuICAgICAgICAob3V0Q2xpY2spPVwiaGFuZGxlclNhdmUoJGV2ZW50KVwiIC8+XG4gICAgPC9kaXY+XG4gIH1cbjwvZGl2PlxuXG48bmctdGVtcGxhdGUgI2xpc3RWaWV3UmVmXG4gIGxldC1kYXRhPSdpdGVtQ29udGV4dCc+XG4gIDxsaWJzX3VpLWNvbXBvbmVudHMtbGlzdCBbekluZGV4XT1cInpJbmRleCgpXCJcbiAgICBbY29uZmlnXT1cImNvbmZpZ0ZpZWxkKCk/Lmxpc3RDb25maWdcIlxuICAgIFttYXhJdGVtU2hvd109XCI2XCJcbiAgICBbY2xpY2tFeGFjdGx5XT1cImZhbHNlXCJcbiAgICBbc2VhcmNoQ29uZmlnXT1cIntub0JvcmRlcjogdHJ1ZSwgcGxhY2Vob2xkZXI6IGNvbmZpZ0ZpZWxkKCk/LnBsYWNlaG9sZGVySW5wdXRMaXN0IHx8ICdpMThuX3NlYXJjaCd9XCJcbiAgICBbbXVsdGlLZXlTZWxlY3RlZF09XCJkYXRhLmtleSA/IFtkYXRhLmtleV0gOiBbXVwiXG4gICAgKG91dFNlbGVjdE11bHRpS2V5KT1cImhhbmRsZXJTZWxlY3RlZEZpZWxkKCRldmVudCwgZGF0YS5pbmRleClcIj5cbiAgPC9saWJzX3VpLWNvbXBvbmVudHMtbGlzdD5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsY3VsYXRvci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvaW5wdXRzL2NhbGN1bGF0b3Ivc3JjL2NhbGN1bGF0b3IuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2lucHV0cy9jYWxjdWxhdG9yL3NyYy9jYWxjdWxhdG9yLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzVILE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsc0NBQXNDLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RixPQUFPLEVBQXlCLDZCQUE2QixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFHaEcsT0FBTyxFQUFFLFNBQVMsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2pFLE9BQU8sRUFBZ0MsZ0NBQWdDLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUM3RyxPQUFPLEVBQUUsb0RBQW9ELEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUN2RyxPQUFPLEVBQUUsaURBQWlELEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7O0FBaUJqRyxNQUFNLE9BQU8seUNBQXlDO0lBQzFDLFVBQVUsR0FBRyxNQUFNLENBQXFCLFNBQVMsQ0FBQyxDQUFDO0lBQ25ELE9BQU8sR0FBRyxNQUFNLENBQVUsS0FBSyxDQUFDLENBQUM7SUFDakMsZUFBZSxHQUFHLE1BQU0sQ0FBb0MsRUFBRSxDQUFDLENBQUM7SUFDaEUsa0JBQWtCLEdBQUcsTUFBTSxDQUFVLEtBQUssQ0FBQyxDQUFDO0lBRTlDLFFBQVEsR0FBRyxZQUFZ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QUksQ0FBQyxzQkFBc0IsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDekMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7WUFFeEIsT0FBTyxLQUFLLENBQUM7UUFDZixDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7d0dBbkxVLHlDQUF5Qzs0RkFBekMseUNBQXlDLDRpREMxQnRELGl5VkFnUEEsMkNEL05JLGVBQWUsNEZBQ2Ysc0NBQXNDLGloQkFDdEMsNkJBQTZCLHcvQkFDN0Isb0RBQW9ELDZGQUNwRCxnQ0FBZ0MsZ2VBQ2hDLGlEQUFpRDs7NEZBSXhDLHlDQUF5QztrQkFmckQsU0FBUzsrQkFFRSxzQ0FBc0MsY0FFcEMsSUFBSSxXQUNQO3dCQUNQLGVBQWU7d0JBQ2Ysc0NBQXNDO3dCQUN0Qyw2QkFBNkI7d0JBQzdCLG9EQUFvRDt3QkFDcEQsZ0NBQWdDO3dCQUNoQyxpREFBaUQ7cUJBQ2xELG1CQUNnQix1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRWxlbWVudFJlZiwgaW5wdXQsIE9uSW5pdCwgb3V0cHV0LCBzaWduYWwsIHZpZXdDaGlsZHJlbiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tIFwiQG5neC10cmFuc2xhdGUvY29yZVwiO1xuaW1wb3J0IHsgTGlic1VpQ29tcG9uZW50c0J1dHRvbnNCdXR0b25Db21wb25lbnQgfSBmcm9tICdAbGlicy11aS9jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uJztcbmltcG9ydCB7IElMaXN0RGF0YUVtaXRNdWx0aUtleSwgTGlic1VpQ29tcG9uZW50c0xpc3RDb21wb25lbnQgfSBmcm9tICdAbGlicy11aS9jb21wb25lbnRzLWxpc3QnO1xuaW1wb3J0IHsgSUlucHV0Q2FsY3VsYXRvckNvbmZpZ0ZpZWxkLCBJSW5wdXRDYWxjdWxhdG9yRXhwcmVzc2lvbiB9IGZyb20gXCIuL2ludGVyZmFjZXNcIjtcbmltcG9ydCB7IElFdmVudCB9IGZyb20gXCJAbGlicy11aS9pbnRlcmZhY2VzLXR5cGVzXCI7XG5pbXBvcnQgeyBjbG9uZURlZXAsIFV0aWxzS2V5Q29kZUNvbnN0YW50IH0gZnJvbSBcIkBsaWJzLXVpL3V0aWxzXCI7XG5pbXBvcnQgeyBJUG9wb3ZlckZ1bmN0aW9uQ29udHJvbEV2ZW50LCBMaWJzVWlDb21wb25lbnRzUG9wb3ZlckNvbXBvbmVudCB9IGZyb20gXCJAbGlicy11aS9jb21wb25lbnRzLXBvcG92ZXJcIjtcbmltcG9ydCB7IExpYnNVaUNvbXBvbmVudHNJbnB1dHNDYWxjdWxhdG9yR2V0RmllbGRTZWxlY3RlZFBpcGUgfSBmcm9tIFwiLi9waXBlcy9nZXQtZmllbGQtc2VsZWN0ZWQucGlwZVwiO1xuaW1wb3J0IHsgTGlic1VpQ29tcG9uZW50c0lucHV0c0NhbGN1bGF0b3JHZXRXaWR0aElucHV0UGlwZSB9IGZyb20gXCIuL3BpcGVzL2dldC13aWR0aC1pbnB1dC5waXBlXCI7XG5cbkBDb21wb25lbnQoe1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L2NvbXBvbmVudC1zZWxlY3RvclxuICBzZWxlY3RvcjogJ2xpYnNfdWktY29tcG9uZW50cy1pbnB1dHMtY2FsY3VsYXRvcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9jYWxjdWxhdG9yLmNvbXBvbmVudC5odG1sJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIFRyYW5zbGF0ZU1vZHVsZSxcbiAgICBMaWJzVWlDb21wb25lbnRzQnV0dG9uc0J1dHRvbkNvbXBvbmVudCxcbiAgICBMaWJzVWlDb21wb25lbnRzTGlzdENvbXBvbmVudCxcbiAgICBMaWJzVWlDb21wb25lbnRzSW5wdXRzQ2FsY3VsYXRvckdldEZpZWxkU2VsZWN0ZWRQaXBlLFxuICAgIExpYnNVaUNvbXBvbmVudHNQb3BvdmVyQ29tcG9uZW50LFxuICAgIExpYnNVaUNvbXBvbmVudHNJbnB1dHNDYWxjdWxhdG9yR2V0V2lkdGhJbnB1dFBpcGVcbiAgXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgTGlic1VpQ29tcG9uZW50c0lucHV0c0NhbGN1bGF0b3JDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBwcm90ZWN0ZWQgaW5kZXhGb2N1cyA9IHNpZ25hbDxudW1iZXIgfCB1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XG4gIHByb3RlY3RlZCBpc0ZvY3VzID0gc2lnbmFsPGJvb2xlYW4+KGZhbHNlKTtcbiAgcHJvdGVjdGVkIGxpc3RFeHByZXNzaW9ucyA9IHNpZ25hbDxBcnJheTxJSW5wdXRDYWxjdWxhdG9yRXhwcmVzc2lvbj4+KFtdKTtcbiAgcHJvdGVjdGVkIGlzQ2hhbmdlRXhwcmVzc2lvbiA9IHNpZ25hbDxib29sZWFuPihmYWxzZSk7XG5cbiAgcHJpdmF0ZSBpbnB1dFJlZiA9IHZpZXdDaGlsZHJlbjxFbGVtZW50UmVmPignaW5wdXRSZWYnKTtcbiAgcHJpdmF0ZSB0aW1lT3V0ID0gc2lnbmFsPG51bWJlciB8IHVuZGVmaW5lZD4odW5kZWZpbmVkKTtcbiAgcHJpdmF0ZSB0b29sdGlwRnVuY3Rpb25Db250cm9sID0gc2lnbmFsPE1hcDxudW1iZXIsIElQb3BvdmVyRnVuY3Rpb25Db250cm9sRXZlbnQ+PihuZXcgTWFwKCkpO1xuXG4gIHJlYWRvbmx5IGV4cHJlc3Npb25zID0gaW5wdXQ8QXJyYXk8SUlucHV0Q2FsY3VsYXRvckV4cHJlc3Npb24+PihbXSk7XG4gIHJlYWRvbmx5IHpJbmRleCA9IGlucHV0PG51bWJlcj4oMTApO1xuICByZWFkb25seSBwbGFjZWhvbGRlciA9IGlucHV0PHN0cmluZz4oJ2kxOG5fZW50ZXJfcGFyYW1zJyk7XG4gIHJlYWRvbmx5IGxhYmVsQnV0dG9uU2F2ZSA9IGlucHV0PHN0cmluZz4oJ2kxOG5fc2F2ZV9jYWxjdWxhdGlvbicpO1xuICByZWFkb25seSBjb25maWdGaWVsZCA9IGlucHV0PElJbnB1dENhbGN1bGF0b3JDb25maWdGaWVsZD4oKTtcbiAgcmVhZG9ubHkgaWdub3JlQnV0dG9uU2F2ZSA9IGlucHV0PGJvb2xlYW4+KGZhbHNlKTtcbiAgcmVhZG9ubHkgY2xhc3NJbmNsdWRlID0gaW5wdXQ8c3RyaW5nLCBzdHJpbmcgfCB1bmRlZmluZWQ+KCcnLCB7IHRyYW5zZm9ybTogKHZhbHVlKSA9PiB2YWx1ZSB8fCAnJyB9KTtcbiAgcmVhZG9ubHkgY2xhc3NDb250YWluZXJJbnB1dCA9IGlucHV0PHN0cmluZywgc3RyaW5nIHwgdW5kZWZpbmVkPignJywgeyB0cmFuc2Zvcm06ICh2YWx1ZSkgPT4gdmFsdWUgfHwgJycgfSk7XG4gIHJlYWRvbmx5IGNsYXNzQ29udGFpbmVyQnV0dG9uID0gaW5wdXQ8c3RyaW5nLCBzdHJpbmcgfCB1bmRlZmluZWQ+KCcnLCB7IHRyYW5zZm9ybTogKHZhbHVlKSA9PiB2YWx1ZSB8fCAnJyB9KTtcblxuICByZWFkb25seSBvdXRDaGFuZ2VFeHByZXNzaW9ucyA9IG91dHB1dDxBcnJheTxJSW5wdXRDYWxjdWxhdG9yRXhwcmVzc2lvbj4+KCk7XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5saXN0RXhwcmVzc2lvbnMuc2V0KGNsb25lRGVlcCh0aGlzLmV4cHJlc3Npb25zKCkpKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBoYW5kbGVyQ2xpY2soZXZlbnQ6IEV2ZW50LCBidXR0b246ICcrJyB8ICctJyB8ICcqJyB8ICcvJyB8ICdjJyB8ICcuJyB8ICcoJyB8ICcpJyB8ICcwJyB8ICcxJyB8ICcyJyB8ICczJyB8ICc0JyB8ICc1JyB8ICc2JyB8ICc3JyB8ICc4JyB8ICc5Jykge1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgIGNvbnN0IGV4cHJlc3Npb246IElJbnB1dENhbGN1bGF0b3JFeHByZXNzaW9uID0geyB0eXBlOiAnZmllbGQnLCBkYXRhOiBidXR0b24gfTtcblxuICAgIGlmIChidXR0b24gPT09ICdjJykge1xuICAgICAgaWYgKCF0aGlzLmxpc3RFeHByZXNzaW9ucygpLmxlbmd0aCB8fCB0aGlzLmluZGV4Rm9jdXMoKSA9PT0gMCkge1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG4gICAgICByZXR1cm4gdGhpcy51cGRhdGVFeHByZXNzaW9ucyh1bmRlZmluZWQsIHR5cGVvZiB0aGlzLmluZGV4Rm9jdXMoKSAhPT0gJ3VuZGVmaW5lZCcgPyAoKHRoaXMuaW5kZXhGb2N1cygpIHx8IDEpIC0gMSkgOiAodGhpcy5saXN0RXhwcmVzc2lvbnMoKS5sZW5ndGggLSAxKSk7XG4gICAgfVxuICAgIHN3aXRjaCAoYnV0dG9uKSB7XG4gICAgICBjYXNlICcrJzpcbiAgICAgIGNhc2UgJy0nOlxuICAgICAgY2FzZSAnKic6XG4gICAgICBjYXNlICcvJzpcbiAgICAgICAgZXhwcmVzc2lvbi50eXBlID0gJ29wZXJhdGlvbic7XG4gICAgICAgIGJyZWFrO1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgZXhwcmVzc2lvbi50eXBlID0gJ3ZhbHVlJztcbiAgICB9XG4gICAgdGhpcy51cGRhdGVFeHByZXNzaW9ucyhleHByZXNzaW9uLCB0eXBlb2YgdGhpcy5pbmRleEZvY3VzKCkgIT09ICd1bmRlZmluZWQnID8gKHRoaXMuaW5kZXhGb2N1cygpIHx8IDApIDogdGhpcy5saXN0RXhwcmVzc2lvbnMoKS5sZW5ndGgpO1xuICB9XG5cbiAgcHJpdmF0ZSB1cGRhdGVFeHByZXNzaW9ucyhpdGVtOiBJSW5wdXRDYWxjdWxhdG9yRXhwcmVzc2lvbiB8IHVuZGVmaW5lZCwgcG9zaXRpb246IG51bWJlciwgaXNEZWxldGU/OiBib29sZWFuKSB7XG4gICAgdGhpcy5pc0NoYW5nZUV4cHJlc3Npb24uc2V0KHRydWUpO1xuICAgIHRoaXMubGlzdEV4cHJlc3Npb25zLnVwZGF0ZSgodmFsdWUpID0+IHtcbiAgICAgIGlmIChpdGVtKSB7XG4gICAgICAgIHZhbHVlLnNwbGljZShwb3NpdGlvbiB8fCAwLCAwLCBpdGVtKTtcbiAgICAgIH1cbiAgICAgIGlmICghaXRlbSkge1xuICAgICAgICB2YWx1ZS5zcGxpY2UocG9zaXRpb24gfHwgMCwgMSk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBbLi4udmFsdWVdO1xuICAgIH0pXG5cbiAgICB0aGlzLmluZGV4Rm9jdXMudXBkYXRlKHZhbHVlID0+IHtcbiAgICAgIGlmICghaXRlbSkge1xuICAgICAgICBpZiAodmFsdWUpIHtcbiAgICAgICAgICB2YWx1ZSA9IGlzRGVsZXRlID8gdmFsdWUgOiB2YWx1ZSAtIDE7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gdmFsdWUgPyB2YWx1ZSA6IHBvc2l0aW9uO1xuICAgICAgfVxuICAgICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgICAgdmFsdWUgPSB0aGlzLmxpc3RFeHByZXNzaW9ucygpLmxlbmd0aDtcblxuICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICB9XG4gICAgICB2YWx1ZSsrO1xuXG4gICAgICByZXR1cm4gdmFsdWU7XG4gICAgfSlcbiAgICBjb25zdCBpbmRleEZvY3VzID0gdGhpcy5pbmRleEZvY3VzKCk7XG5cbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIGlmICh0eXBlb2YgaW5kZXhGb2N1cyAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgICAgdGhpcy5pbnB1dFJlZigpW2luZGV4Rm9jdXNdPy5uYXRpdmVFbGVtZW50LmZvY3VzKCk7XG4gICAgICB9XG4gICAgfSwgMTAwKVxuICB9XG5cbiAgcHJvdGVjdGVkIGhhbmRsZXJFdmVudEtleVVwSW5wdXQoZXZlbnQ6IEV2ZW50KSB7XG4gICAgY29uc3Qga2V5Q29kZSA9IChldmVudCBhcyBJRXZlbnQpLmtleUNvZGU7XG4gICAgY29uc3QgdmFsdWUgPSAoZXZlbnQgYXMgSUV2ZW50KS50YXJnZXQudmFsdWU7XG4gICAgY29uc3Qgc2hpZnRLZXkgPSAoZXZlbnQgYXMgSUV2ZW50KS5zaGlmdEtleTtcblxuICAgIGlmICgoKFtVdGlsc0tleUNvZGVDb25zdGFudC5FUVVBTFMsIFV0aWxzS2V5Q29kZUNvbnN0YW50LkVJR0hUXS5pbmNsdWRlcyhrZXlDb2RlKSAmJiBzaGlmdEtleSkgfHwgKFtVdGlsc0tleUNvZGVDb25zdGFudC5EQVNILCBVdGlsc0tleUNvZGVDb25zdGFudC5TTEFTSF0uaW5jbHVkZXMoa2V5Q29kZSkgJiYgIXNoaWZ0S2V5KSkgJiYgdmFsdWUubGVuZ3RoID09PSAxKSB7XG4gICAgICAoZXZlbnQgYXMgSUV2ZW50KS50YXJnZXQudmFsdWUgPSAnJztcblxuICAgICAgcmV0dXJuIHRoaXMudXBkYXRlRXhwcmVzc2lvbnMoeyB0eXBlOiAnb3BlcmF0aW9uJywgZGF0YTogdmFsdWUgfSwgdGhpcy5pbmRleEZvY3VzKCkgfHwgdGhpcy5saXN0RXhwcmVzc2lvbnMoKS5sZW5ndGgpO1xuICAgIH1cbiAgfVxuXG4gIHByb3RlY3RlZCBoYW5kbGVyRXZlbnRLZXlJbnB1dChldmVudDogRXZlbnQpIHtcbiAgICBjb25zdCBrZXlDb2RlID0gKGV2ZW50IGFzIElFdmVudCkua2V5Q29kZTtcbiAgICBjb25zdCB2YWx1ZSA9IChldmVudCBhcyBJRXZlbnQpLnRhcmdldC52YWx1ZTtcblxuICAgIGlmIChrZXlDb2RlID09PSBVdGlsc0tleUNvZGVDb25zdGFudC5CQUNLU1BBQ0UpIHtcbiAgICAgIGlmICghdmFsdWUgJiYgdGhpcy5saXN0RXhwcmVzc2lvbnMoKS5sZW5ndGggJiYgKHRoaXMuaW5kZXhGb2N1cygpIHx8IDApID4gMCkge1xuICAgICAgICByZXR1cm4gdGhpcy51cGRhdGVFeHByZXNzaW9ucyh1bmRlZmluZWQsICh0aGlzLmluZGV4Rm9jdXMoKSB8fCAwKSAtIDEpO1xuICAgICAgfVxuICAgIH1cbiAgICBpZiAoa2V5Q29kZSA9PT0gVXRpbHNLZXlDb2RlQ29uc3RhbnQuREVMRVRFKSB7XG4gICAgICBpZiAoIXZhbHVlICYmIHRoaXMubGlzdEV4cHJlc3Npb25zKCkubGVuZ3RoICYmICh0aGlzLmluZGV4Rm9jdXMoKSB8fCAwKSA8IHRoaXMubGlzdEV4cHJlc3Npb25zKCkubGVuZ3RoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLnVwZGF0ZUV4cHJlc3Npb25zKHVuZGVmaW5lZCwgKHRoaXMuaW5kZXhGb2N1cygpIHx8IDApLCB0cnVlKTtcbiAgICAgIH1cbiAgICB9XG4gICAgaWYgKGtleUNvZGUgPT09IFV0aWxzS2V5Q29kZUNvbnN0YW50LkVOVEVSKSB7XG4gICAgICBpZiAodmFsdWUpIHtcbiAgICAgICAgKGV2ZW50IGFzIElFdmVudCkudGFyZ2V0LnZhbHVlID0gJyc7XG5cbiAgICAgICAgcmV0dXJuIHRoaXMudXBkYXRlRXhwcmVzc2lvbnMoeyB0eXBlOiAndmFsdWUnLCBkYXRhOiB2YWx1ZSB9LCB0aGlzLmluZGV4Rm9jdXMoKSB8fCB0aGlzLmxpc3RFeHByZXNzaW9ucygpLmxlbmd0aCk7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcHJvdGVjdGVkIGhhbmRsZXJGb2N1c0FuZEJsdXJJbnB1dChpbmRleDogbnVtYmVyIHwgdW5kZWZpbmVkKSB7XG4gICAgaWYgKHR5cGVvZiBpbmRleCAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICAgIHRoaXMuaW5kZXhGb2N1cy5zZXQoaW5kZXgpO1xuICAgICAgdGhpcy5pc0ZvY3VzLnNldCh0cnVlKTtcbiAgICAgIGNsZWFyVGltZW91dCh0aGlzLnRpbWVPdXQoKSk7XG5cbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgdGhpcy50aW1lT3V0LnNldChzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHRoaXMuaXNGb2N1cy5zZXQoZmFsc2UpO1xuICAgIH0sIDI1MCkpXG4gIH1cblxuICBwcm90ZWN0ZWQgaGFuZGxlckNsaWNrSW5wdXQoZXZlbnQ6IEV2ZW50KSB7XG4gICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgaWYgKCF0aGlzLmlzRm9jdXMoKSkge1xuICAgICAgdGhpcy5pbnB1dFJlZigpW3RoaXMuaW5wdXRSZWYoKS5sZW5ndGggLSAxXS5uYXRpdmVFbGVtZW50LmZvY3VzKCk7XG4gICAgfVxuICB9XG5cbiAgcHJvdGVjdGVkIGhhbmRsZXJTYXZlKGV2ZW50OiBFdmVudCkge1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgIHRoaXMuaXNDaGFuZ2VFeHByZXNzaW9uLnNldChmYWxzZSk7XG4gICAgdGhpcy5vdXRDaGFuZ2VFeHByZXNzaW9ucy5lbWl0KGNsb25lRGVlcCh0aGlzLmxpc3RFeHByZXNzaW9ucygpKSk7XG4gIH1cblxuICBwcm90ZWN0ZWQgaGFuZGxlclNlbGVjdGVkRmllbGQoZXZlbnQ6IElMaXN0RGF0YUVtaXRNdWx0aUtleSB8IHVuZGVmaW5lZCwgaW5kZXg6IG51bWJlcikge1xuICAgIGlmICghZXZlbnQ/LmtleXMubGVuZ3RoKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIGlmIChpbmRleCA+PSAwKSB7XG4gICAgICB0aGlzLmxpc3RFeHByZXNzaW9ucy51cGRhdGUodmFsdWUgPT4ge1xuICAgICAgICB2YWx1ZS5mb3JFYWNoKChpdGVtLCBpKSA9PiB7XG4gICAgICAgICAgaWYgKGkgPT09IGluZGV4KSB7XG4gICAgICAgICAgICBpZiAoaXRlbS5kYXRhICE9PSBldmVudC5rZXlzWzBdKSB7XG4gICAgICAgICAgICAgIHRoaXMudG9vbHRpcEZ1bmN0aW9uQ29udHJvbCgpLmdldChpbmRleCk/LnJlbW92ZVBvcG92ZXJPdmVybGF5KCk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpdGVtLmRhdGEgPSBldmVudC5rZXlzWzBdIGFzIHN0cmluZ1xuICAgICAgICAgIH1cbiAgICAgICAgfSlcblxuICAgICAgICByZXR1cm4gWy4uLnZhbHVlXTtcbiAgICAgIH0pXG5cbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgdGhpcy51cGRhdGVFeHByZXNzaW9ucyh7IHR5cGU6ICdmaWVsZCcsIGRhdGE6IGV2ZW50LmtleXNbMF0gYXMgc3RyaW5nIH0sIHR5cGVvZiB0aGlzLmluZGV4Rm9jdXMoKSAhPT0gJ3VuZGVmaW5lZCcgPyAodGhpcy5pbmRleEZvY3VzKCkgfHwgMCkgOiB0aGlzLmxpc3RFeHByZXNzaW9ucygpLmxlbmd0aCk7XG4gICAgdGhpcy50b29sdGlwRnVuY3Rpb25Db250cm9sKCkuZ2V0KGluZGV4KT8ucmVtb3ZlUG9wb3Zlck92ZXJsYXkoKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBoYW5kbGVyRnVuY3Rpb25Db250cm9sQnV0dG9uKGV2ZW50OiBJUG9wb3ZlckZ1bmN0aW9uQ29udHJvbEV2ZW50LCBpbmRleDogbnVtYmVyKSB7XG4gICAgdGhpcy50b29sdGlwRnVuY3Rpb25Db250cm9sLnVwZGF0ZSh2YWx1ZSA9PiB7XG4gICAgICB2YWx1ZS5zZXQoaW5kZXgsIGV2ZW50KTtcblxuICAgICAgcmV0dXJuIHZhbHVlO1xuICAgIH0pXG4gIH1cbn0iLCI8ZGl2IGNsYXNzPVwidy1mdWxsXCI+XG4gIDxkaXYgY2xhc3M9XCJwLVs4cHhdIHJvdW5kZWQtWzEycHhdIGJnLVsjZjhmOWZhXSB7eyBjbGFzc0luY2x1ZGUoKSB9fVwiPlxuICAgIDxkaXYgI2NhbGN1bGF0b3JJbnB1dFxuICAgICAgY2xhc3M9XCJweS1bMTBweF0gcHgtWzEycHhdIGxpYnMtdWktZm9udC1oNXIgcm91bmRlZC1bOHB4XSBiZy1bI2ZmZmZmZl0gbWluLWgtWzE2MHB4XSBtYi1bOHB4XSBib3JkZXItWzFweF0ge3sgaXNGb2N1cygpID8gJ2JvcmRlci1bdmFyKC0tbGlicy11aS1jb2xvci1saWdodC0xKV0nIDogJ2JvcmRlci1bI2ZmZmZmZl0nIH19IHt7IGNsYXNzQ29udGFpbmVySW5wdXQoKSB9fVwiXG4gICAgICAobW91c2V1cCk9XCJoYW5kbGVyQ2xpY2tJbnB1dCgkZXZlbnQpXCI+XG4gICAgICA8dWwgY2xhc3M9XCJiZWZvcmU6Y29udGVudC1bJyddIGJlZm9yZTp0YWJsZSBhZnRlcjpjb250ZW50LVsnJ10gYWZ0ZXI6dGFibGUgYWZ0ZXI6Y2xlYXItYm90aFwiPlxuICAgICAgICBAZm9yIChpdGVtIG9mIGxpc3RFeHByZXNzaW9ucygpOyB0cmFjayAkaW5kZXg7IGxldCBpID0gJGluZGV4KSB7XG4gICAgICAgICAgPGxpIGNsYXNzPVwiZmxvYXQtbGVmdCBtYi1bOHB4XVwiPlxuICAgICAgICAgICAgPGlucHV0ICNpbnB1dFJlZlxuICAgICAgICAgICAgICB0eXBlPVwidGV4dFwiXG4gICAgICAgICAgICAgIGNsYXNzPVwiaW5saW5lLWJsb2NrIGgtWzI0cHhdIG91dGxpbmUtbm9uZSB0ZXh0LWNlbnRlclwiXG4gICAgICAgICAgICAgIFtjbGFzcy5tbC1bLThweF1dPVwiaSA9PT0gMFwiXG4gICAgICAgICAgICAgIFtzdHlsZS53aWR0aC5weF09XCJpbnB1dFJlZi52YWx1ZSB8IExpYnNVaUNvbXBvbmVudHNJbnB1dHNDYWxjdWxhdG9yR2V0V2lkdGhJbnB1dFBpcGU6Y2FsY3VsYXRvcklucHV0XCJcbiAgICAgICAgICAgICAgKGtleWRvd24pPVwiaGFuZGxlckV2ZW50S2V5SW5wdXQoJGV2ZW50KVwiXG4gICAgICAgICAgICAgIChrZXl1cCk9XCJoYW5kbGVyRXZlbnRLZXlVcElucHV0KCRldmVudClcIlxuICAgICAgICAgICAgICAoZm9jdXMpPVwiaGFuZGxlckZvY3VzQW5kQmx1cklucHV0KGkpXCJcbiAgICAgICAgICAgICAgKGJsdXIpPVwiaGFuZGxlckZvY3VzQW5kQmx1cklucHV0KHVuZGVmaW5lZClcIiAvPlxuICAgICAgICAgIDwvbGk+XG4gICAgICAgICAgQHN3aXRjaCAoaXRlbS50eXBlKSB7XG4gICAgICAgICAgICBAY2FzZSAoJ29wZXJhdGlvbicpIHtcbiAgICAgICAgICAgICAgPGxpIGNsYXNzPVwiZmxvYXQtbGVmdCBtYi1bOHB4XSB0ZXh0LWNlbnRlciB3LVsyNHB4XSByb3VuZGVkLVs0cHhdIHAtWzRweF0gYmctW3ZhcigtLWxpYnMtdWktY29sb3ItbGlnaHQtMildXCI+e3sgaXRlbS5kYXRhIH19PC9saT5cbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIEBjYXNlICgndmFsdWUnKSB7XG4gICAgICAgICAgICAgIDxsaSBjbGFzcz1cImZsb2F0LWxlZnQgbWItWzhweF0gdGV4dC1jZW50ZXIgcm91bmRlZC1bNHB4XSBweS1bNHB4XSBweC1bOHB4XSBiZy1bI0U2RTdFQV0gZmxleCBtYXgtdy1bY2FsYygxMDAlLThweCldXCI+XG4gICAgICAgICAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1wb3BvdmVyIFt0eXBlXT1cIid0ZXh0J1wiPnt7IGl0ZW0uZGF0YSB9fTwvbGlic191aS1jb21wb25lbnRzLXBvcG92ZXI+XG4gICAgICAgICAgICAgIDwvbGk+XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBAY2FzZSAoJ2ZpZWxkJykge1xuICAgICAgICAgICAgICBAaWYgKGl0ZW0uZGF0YSB8IExpYnNVaUNvbXBvbmVudHNJbnB1dHNDYWxjdWxhdG9yR2V0RmllbGRTZWxlY3RlZFBpcGU6Y29uZmlnRmllbGQoKT8uZ2V0RmllbGRTZWxlY3RlZDsgYXMgZmllbGRTZWxlY3RlZCkge1xuICAgICAgICAgICAgICAgIDxsaSBjbGFzcz1cImZsb2F0LWxlZnQgbWItWzhweF1cIj5cbiAgICAgICAgICAgICAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gY2xhc3M9XCJtYXgtdy1bMTUwcHhdIGJsb2NrXCJcbiAgICAgICAgICAgICAgICAgICAgW2xhYmVsXT1cImZpZWxkU2VsZWN0ZWQubmFtZSB8fCAnJ1wiXG4gICAgICAgICAgICAgICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJyFqdXN0aWZ5LWNlbnRlciAhcHktWzNweF0gIXB4LVs3cHhdICF3LWZ1bGwnXCJcbiAgICAgICAgICAgICAgICAgICAgW2NsYXNzSWNvbkxlZnRdPVwiZmllbGRTZWxlY3RlZC5pY29uIHx8ICcnXCJcbiAgICAgICAgICAgICAgICAgICAgW2NsYXNzSWNvblJpZ2h0XT1cIidsaWJzLXVpLWljb24tbW92ZS1yaWdodCByb3RhdGUtOTAnXCJcbiAgICAgICAgICAgICAgICAgICAgW2NsYXNzTGFiZWxdPVwiJ2xpYnMtdWktZm9udC1oNXInXCJcbiAgICAgICAgICAgICAgICAgICAgW3pJbmRleF09XCIgekluZGV4KClcIlxuICAgICAgICAgICAgICAgICAgICBbcG9wb3Zlcl09XCJ7XG4gICAgICAgICAgICAgICAgICAgICAgbW9kZTogJ2NsaWNrLXRvZ2dsZScsXG4gICAgICAgICAgICAgICAgICAgICAgaWdub3JlSGlkZGVuUG9wb3ZlckNvbnRlbnRXaGVuTW91c2VMZWF2ZTogdHJ1ZSxcbiAgICAgICAgICAgICAgICAgICAgICBjb25maWc6IHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHpJbmRleDogekluZGV4KCksXG4gICAgICAgICAgICAgICAgICAgICAgICBhbmltYXRpb25Db25maWc6IHt9LFxuICAgICAgICAgICAgICAgICAgICAgICAgd2lkdGhCeVBhcmVudDpmYWxzZSxcbiAgICAgICAgICAgICAgICAgICAgICAgIHBhcmVudEJvcmRlcldpZHRoOiAwLFxuICAgICAgICAgICAgICAgICAgICAgICAgbWF4SGVpZ2h0OjIwNDgsXG4gICAgICAgICAgICAgICAgICAgICAgICBtYXhXaWR0aDogMjA0OCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGRpcmVjdGlvbjogJ2JvdHRvbScsXG4gICAgICAgICAgICAgICAgICAgICAgICBkaXJlY3Rpb25EaXN0YW5jZToyLFxuICAgICAgICAgICAgICAgICAgICAgICAgdGVtcGxhdGU6IGxpc3RWaWV3UmVmLFxuICAgICAgICAgICAgICAgICAgICAgICAgaXRlbUNvbnRleHQ6IHtpbmRleDogaSwga2V5OiBpdGVtLmRhdGF9LFxuICAgICAgICAgICAgICAgICAgICAgICAgd2hpdGVUaGVtZTp0cnVlLFxuICAgICAgICAgICAgICAgICAgICAgICAgaWdub3JlQXJyb3c6dHJ1ZSxcbiAgICAgICAgICAgICAgICAgICAgICAgIGNsYXNzSW5jbHVkZTonIXJvdW5kZWQtWzRweF0gIXctWzI3MnB4XScsXG4gICAgICAgICAgICAgICAgICAgICAgICBwb3NpdGlvbjp7IG1vZGU6J3N0YXJ0JyxkaXN0YW5jZTowIH0sXG4gICAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICB9XCJcbiAgICAgICAgICAgICAgICAgICAgKG91dEZ1bmN0aW9uc0NvbnRyb2wpPVwiaGFuZGxlckZ1bmN0aW9uQ29udHJvbEJ1dHRvbigkZXZlbnQsIGkpXCIgLz5cbiAgICAgICAgICAgICAgICA8L2xpPlxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIDxsaSBjbGFzcz1cImZsb2F0LWxlZnQgbWItWzhweF0gbWF4LXctWzEwMCVdXCI+XG4gICAgICAgICAgPGlucHV0ICNpbnB1dFJlZlxuICAgICAgICAgICAgdHlwZT1cInRleHRcIlxuICAgICAgICAgICAgY2xhc3M9XCJpbmxpbmUtYmxvY2sgaC1bMjRweF0gb3V0bGluZS1ub25lIG1heC13LVsxMDAlXSB7eyBsaXN0RXhwcmVzc2lvbnMoKS5sZW5ndGggPyAndGV4dC1jZW50ZXInIDogJycgfX1cIlxuICAgICAgICAgICAgW3N0eWxlLndpZHRoLnB4XT1cImxpc3RFeHByZXNzaW9ucygpLmxlbmd0aCA/IChpbnB1dFJlZi52YWx1ZSB8IExpYnNVaUNvbXBvbmVudHNJbnB1dHNDYWxjdWxhdG9yR2V0V2lkdGhJbnB1dFBpcGU6Y2FsY3VsYXRvcklucHV0KSA6IDE1MFwiXG4gICAgICAgICAgICBbcGxhY2Vob2xkZXJdPVwiIWxpc3RFeHByZXNzaW9ucygpLmxlbmd0aCA/IChwbGFjZWhvbGRlcigpIHwgdHJhbnNsYXRlKSA6ICcnXCJcbiAgICAgICAgICAgIChrZXlkb3duKT1cImhhbmRsZXJFdmVudEtleUlucHV0KCRldmVudClcIlxuICAgICAgICAgICAgKGtleXVwKT1cImhhbmRsZXJFdmVudEtleVVwSW5wdXQoJGV2ZW50KVwiXG4gICAgICAgICAgICAoZm9jdXMpPVwiaGFuZGxlckZvY3VzQW5kQmx1cklucHV0KGxpc3RFeHByZXNzaW9ucygpLmxlbmd0aClcIlxuICAgICAgICAgICAgKGJsdXIpPVwiaGFuZGxlckZvY3VzQW5kQmx1cklucHV0KHVuZGVmaW5lZClcIiAvPlxuICAgICAgICA8L2xpPlxuICAgICAgPC91bD5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2IGNsYXNzPVwiZ3JpZCBncmlkLWNvbHMtNCBnYXAtWzhweF0ge3sgY2xhc3NDb250YWluZXJCdXR0b24oKSB9fVwiPlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC1bMS80XVwiPlxuICAgICAgICA8bGlic191aS1jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uIFtsYWJlbF09XCJjb25maWdGaWVsZCgpPy5sYWJlbCB8fCAnaTE4bl9zZWxlY3RfZmllbGQnXCJcbiAgICAgICAgICBbY2xhc3NJbmNsdWRlXT1cIichdy1mdWxsICFqdXN0aWZ5LWNlbnRlcidcIlxuICAgICAgICAgIFtwb3BvdmVyXT1cIntcbiAgICAgICAgICAgIG1vZGU6ICdjbGljay10b2dnbGUnLFxuICAgICAgICAgICAgaWdub3JlSGlkZGVuUG9wb3ZlckNvbnRlbnRXaGVuTW91c2VMZWF2ZTogdHJ1ZSxcbiAgICAgICAgICAgIGNvbmZpZzoge1xuICAgICAgICAgICAgICB6SW5kZXg6IHpJbmRleCgpLFxuICAgICAgICAgICAgICBhbmltYXRpb25Db25maWc6IHt9LFxuICAgICAgICAgICAgICB3aWR0aEJ5UGFyZW50OnRydWUsXG4gICAgICAgICAgICAgIHBhcmVudEJvcmRlcldpZHRoOiAwLFxuICAgICAgICAgICAgICBtYXhIZWlnaHQ6MjA0OCxcbiAgICAgICAgICAgICAgbWF4V2lkdGg6IDIwNDgsXG4gICAgICAgICAgICAgIGRpcmVjdGlvbjogJ2JvdHRvbScsXG4gICAgICAgICAgICAgIGRpcmVjdGlvbkRpc3RhbmNlOjIsXG4gICAgICAgICAgICAgIHRlbXBsYXRlOiBsaXN0Vmlld1JlZixcbiAgICAgICAgICAgICAgaXRlbUNvbnRleHQ6IHtpbmRleDogLTF9LFxuICAgICAgICAgICAgICB3aGl0ZVRoZW1lOnRydWUsXG4gICAgICAgICAgICAgIGlnbm9yZUFycm93OnRydWUsXG4gICAgICAgICAgICAgIGNsYXNzSW5jbHVkZTonIXJvdW5kZWQtWzRweF0gIXctWzI3MnB4XScsXG4gICAgICAgICAgICAgIHBvc2l0aW9uOnsgbW9kZTonc3RhcnQnLGRpc3RhbmNlOjAgfSxcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XCJcbiAgICAgICAgICAob3V0RnVuY3Rpb25zQ29udHJvbCk9XCJoYW5kbGVyRnVuY3Rpb25Db250cm9sQnV0dG9uKCRldmVudCwgLTEpXCIgLz5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC1bNC80XVwiPlxuICAgICAgICA8bGlic191aS1jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uIFt0eXBlXT1cIididXR0b24tdmlvbGV0J1wiXG4gICAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInIXctZnVsbCAhanVzdGlmeS1jZW50ZXInXCJcbiAgICAgICAgICBbbGFiZWxdPVwiJ0Z4J1wiIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtWzFdXCI+XG4gICAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gW3R5cGVdPVwiJ2J1dHRvbi1kYW5nZXItaGlnaCdcIlxuICAgICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJyF3LWZ1bGwgIWp1c3RpZnktY2VudGVyJ1wiXG4gICAgICAgICAgW2xhYmVsXT1cIidDJ1wiXG4gICAgICAgICAgKG91dENsaWNrKT1cImhhbmRsZXJDbGljaygkZXZlbnQsICdjJylcIiAvPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLVsyXVwiPlxuICAgICAgICA8bGlic191aS1jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uIFt0eXBlXT1cIididXR0b24tdGhpcmQnXCJcbiAgICAgICAgICBbY2xhc3NJbmNsdWRlXT1cIichdy1mdWxsICFqdXN0aWZ5LWNlbnRlcidcIlxuICAgICAgICAgIFtsYWJlbF09XCInKCdcIlxuICAgICAgICAgIChvdXRDbGljayk9XCJoYW5kbGVyQ2xpY2soJGV2ZW50LCAnKCcpXCIgLz5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC1bM11cIj5cbiAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1idXR0b25zLWJ1dHRvbiBbdHlwZV09XCInYnV0dG9uLXRoaXJkJ1wiXG4gICAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInIXctZnVsbCAhanVzdGlmeS1jZW50ZXInXCJcbiAgICAgICAgICBbbGFiZWxdPVwiJyknXCJcbiAgICAgICAgICAob3V0Q2xpY2spPVwiaGFuZGxlckNsaWNrKCRldmVudCwgJyknKVwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtWzRdXCI+XG4gICAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gW3R5cGVdPVwiJ2J1dHRvbi1zZWNvbmRhcnknXCJcbiAgICAgICAgICBbY2xhc3NJbmNsdWRlXT1cIichdy1mdWxsICFqdXN0aWZ5LWNlbnRlcidcIlxuICAgICAgICAgIFtsYWJlbF09XCInLydcIlxuICAgICAgICAgIChvdXRDbGljayk9XCJoYW5kbGVyQ2xpY2soJGV2ZW50LCAnLycpXCIgLz5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC1bMV1cIj5cbiAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1idXR0b25zLWJ1dHRvbiBbdHlwZV09XCInYnV0dG9uLXRoaXJkJ1wiXG4gICAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInIXctZnVsbCAhanVzdGlmeS1jZW50ZXInXCJcbiAgICAgICAgICBbbGFiZWxdPVwiJzEnXCJcbiAgICAgICAgICAob3V0Q2xpY2spPVwiaGFuZGxlckNsaWNrKCRldmVudCwgJzEnKVwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtWzJdXCI+XG4gICAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gW3R5cGVdPVwiJ2J1dHRvbi10aGlyZCdcIlxuICAgICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJyF3LWZ1bGwgIWp1c3RpZnktY2VudGVyJ1wiXG4gICAgICAgICAgW2xhYmVsXT1cIicyJ1wiXG4gICAgICAgICAgKG91dENsaWNrKT1cImhhbmRsZXJDbGljaygkZXZlbnQsICcyJylcIiAvPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLVszXVwiPlxuICAgICAgICA8bGlic191aS1jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uIFt0eXBlXT1cIididXR0b24tdGhpcmQnXCJcbiAgICAgICAgICBbY2xhc3NJbmNsdWRlXT1cIichdy1mdWxsICFqdXN0aWZ5LWNlbnRlcidcIlxuICAgICAgICAgIFtsYWJlbF09XCInMydcIlxuICAgICAgICAgIChvdXRDbGljayk9XCJoYW5kbGVyQ2xpY2soJGV2ZW50LCAnMycpXCIgLz5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC1bNF1cIj5cbiAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1idXR0b25zLWJ1dHRvbiBbdHlwZV09XCInYnV0dG9uLXNlY29uZGFyeSdcIlxuICAgICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJyF3LWZ1bGwgIWp1c3RpZnktY2VudGVyJ1wiXG4gICAgICAgICAgW2ljb25Pbmx5VHlwZV09XCJ0cnVlXCJcbiAgICAgICAgICBbY2xhc3NJY29uTGVmdF09XCInbGlicy11aS1pY29uLWNsb3NlJ1wiXG4gICAgICAgICAgKG91dENsaWNrKT1cImhhbmRsZXJDbGljaygkZXZlbnQsICcqJylcIiAvPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLVsxXVwiPlxuICAgICAgICA8bGlic191aS1jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uIFt0eXBlXT1cIididXR0b24tdGhpcmQnXCJcbiAgICAgICAgICBbY2xhc3NJbmNsdWRlXT1cIichdy1mdWxsICFqdXN0aWZ5LWNlbnRlcidcIlxuICAgICAgICAgIFtsYWJlbF09XCInNCdcIlxuICAgICAgICAgIChvdXRDbGljayk9XCJoYW5kbGVyQ2xpY2soJGV2ZW50LCAnNCcpXCIgLz5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC1bMl1cIj5cbiAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1idXR0b25zLWJ1dHRvbiBbdHlwZV09XCInYnV0dG9uLXRoaXJkJ1wiXG4gICAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInIXctZnVsbCAhanVzdGlmeS1jZW50ZXInXCJcbiAgICAgICAgICBbbGFiZWxdPVwiJzUnXCJcbiAgICAgICAgICAob3V0Q2xpY2spPVwiaGFuZGxlckNsaWNrKCRldmVudCwgJzUnKVwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtWzNdXCI+XG4gICAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gW3R5cGVdPVwiJ2J1dHRvbi10aGlyZCdcIlxuICAgICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJyF3LWZ1bGwgIWp1c3RpZnktY2VudGVyJ1wiXG4gICAgICAgICAgW2xhYmVsXT1cIic2J1wiXG4gICAgICAgICAgKG91dENsaWNrKT1cImhhbmRsZXJDbGljaygkZXZlbnQsICc2JylcIiAvPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLVs0XVwiPlxuICAgICAgICA8bGlic191aS1jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uIFt0eXBlXT1cIididXR0b24tc2Vjb25kYXJ5J1wiXG4gICAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInIXctZnVsbCAhanVzdGlmeS1jZW50ZXInXCJcbiAgICAgICAgICBbbGFiZWxdPVwiJy0nXCJcbiAgICAgICAgICAob3V0Q2xpY2spPVwiaGFuZGxlckNsaWNrKCRldmVudCwgJy0nKVwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtWzFdXCI+XG4gICAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gW3R5cGVdPVwiJ2J1dHRvbi10aGlyZCdcIlxuICAgICAgICAgIFtjbGFzc0luY2x1ZGVdPVwiJyF3LWZ1bGwgIWp1c3RpZnktY2VudGVyJ1wiXG4gICAgICAgICAgW2xhYmVsXT1cIic3J1wiXG4gICAgICAgICAgKG91dENsaWNrKT1cImhhbmRsZXJDbGljaygkZXZlbnQsICc3JylcIiAvPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwiY29sLVsyXVwiPlxuICAgICAgICA8bGlic191aS1jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uIFt0eXBlXT1cIididXR0b24tdGhpcmQnXCJcbiAgICAgICAgICBbY2xhc3NJbmNsdWRlXT1cIichdy1mdWxsICFqdXN0aWZ5LWNlbnRlcidcIlxuICAgICAgICAgIFtsYWJlbF09XCInOCdcIlxuICAgICAgICAgIChvdXRDbGljayk9XCJoYW5kbGVyQ2xpY2soJGV2ZW50LCAnOCcpXCIgLz5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImNvbC1bM11cIj5cbiAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1idXR0b25zLWJ1dHRvbiBbdHlwZV09XCInYnV0dG9uLXRoaXJkJ1wiXG4gICAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInIXctZnVsbCAhanVzdGlmeS1jZW50ZXInXCJcbiAgICAgICAgICBbbGFiZWxdPVwiJzknXCJcbiAgICAgICAgICAob3V0Q2xpY2spPVwiaGFuZGxlckNsaWNrKCRldmVudCwgJzknKVwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtWzRdXCI+XG4gICAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gW3R5cGVdPVwiJ2J1dHRvbi1zZWNvbmRhcnknXCJcbiAgICAgICAgICBbY2xhc3NJbmNsdWRlXT1cIichdy1mdWxsICFqdXN0aWZ5LWNlbnRlcidcIlxuICAgICAgICAgIFtpY29uT25seVR5cGVdPVwidHJ1ZVwiXG4gICAgICAgICAgW2NsYXNzSWNvbkxlZnRdPVwiJ2xpYnMtdWktaWNvbi1hZGQnXCJcbiAgICAgICAgICAob3V0Q2xpY2spPVwiaGFuZGxlckNsaWNrKCRldmVudCwgJysnKVwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtWzEvNF1cIj5cbiAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1idXR0b25zLWJ1dHRvbiBbbGFiZWxdPVwiJzAnXCJcbiAgICAgICAgICBbdHlwZV09XCInYnV0dG9uLXRoaXJkJ1wiXG4gICAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInIXctZnVsbCAhanVzdGlmeS1jZW50ZXInXCJcbiAgICAgICAgICAob3V0Q2xpY2spPVwiaGFuZGxlckNsaWNrKCRldmVudCwgJzAnKVwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjb2wtWzQvNF1cIj5cbiAgICAgICAgPGxpYnNfdWktY29tcG9uZW50cy1idXR0b25zLWJ1dHRvbiBbdHlwZV09XCInYnV0dG9uLXRoaXJkJ1wiXG4gICAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInIXctZnVsbCAhanVzdGlmeS1jZW50ZXInXCJcbiAgICAgICAgICBbbGFiZWxdPVwiJy4nXCJcbiAgICAgICAgICAob3V0Q2xpY2spPVwiaGFuZGxlckNsaWNrKCRldmVudCwgJy4nKVwiIC8+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG4gIEBpZiAoIWlnbm9yZUJ1dHRvblNhdmUoKSkge1xuICAgIDxkaXYgY2xhc3M9XCJtdC1bMTZweF1cIj5cbiAgICAgIDxsaWJzX3VpLWNvbXBvbmVudHMtYnV0dG9ucy1idXR0b24gW2xhYmVsXT1cImxhYmVsQnV0dG9uU2F2ZSgpXCJcbiAgICAgICAgW2Rpc2FibGVdPVwiIWlzQ2hhbmdlRXhwcmVzc2lvbigpXCJcbiAgICAgICAgW2NsYXNzSW5jbHVkZV09XCInanVzdGlmeS1jZW50ZXIgdy1mdWxsJ1wiXG4gICAgICAgIChvdXRDbGljayk9XCJoYW5kbGVyU2F2ZSgkZXZlbnQpXCIgLz5cbiAgICA8L2Rpdj5cbiAgfVxuPC9kaXY+XG5cbjxuZy10ZW1wbGF0ZSAjbGlzdFZpZXdSZWZcbiAgbGV0LWRhdGE9J2l0ZW1Db250ZXh0Jz5cbiAgPGxpYnNfdWktY29tcG9uZW50cy1saXN0IFt6SW5kZXhdPVwiekluZGV4KClcIlxuICAgIFtjb25maWddPVwiY29uZmlnRmllbGQoKT8ubGlzdENvbmZpZ1wiXG4gICAgW21heEl0ZW1TaG93XT1cIjZcIlxuICAgIFtjbGlja0V4YWN0bHldPVwiZmFsc2VcIlxuICAgIFtzZWFyY2hDb25maWddPVwie25vQm9yZGVyOiB0cnVlLCBwbGFjZWhvbGRlcjogY29uZmlnRmllbGQoKT8ucGxhY2Vob2xkZXJJbnB1dExpc3QgfHwgJ2kxOG5fc2VhcmNoJ31cIlxuICAgIFttdWx0aUtleVNlbGVjdGVkXT1cImRhdGEua2V5ID8gW2RhdGEua2V5XSA6IFtdXCJcbiAgICAob3V0U2VsZWN0TXVsdGlLZXkpPVwiaGFuZGxlclNlbGVjdGVkRmllbGQoJGV2ZW50LCBkYXRhLmluZGV4KVwiPlxuICA8L2xpYnNfdWktY29tcG9uZW50cy1saXN0PlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
|
|
@@ -198,7 +198,7 @@ class LibsUiComponentsInputsCalculatorComponent {
|
|
|
198
198
|
});
|
|
199
199
|
}
|
|
200
200
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsInputsCalculatorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
201
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsInputsCalculatorComponent, isStandalone: true, selector: "libs_ui-components-inputs-calculator", inputs: { expressions: { classPropertyName: "expressions", publicName: "expressions", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, labelButtonSave: { classPropertyName: "labelButtonSave", publicName: "labelButtonSave", isSignal: true, isRequired: false, transformFunction: null }, configField: { classPropertyName: "configField", publicName: "configField", isSignal: true, isRequired: false, transformFunction: null }, ignoreButtonSave: { classPropertyName: "ignoreButtonSave", publicName: "ignoreButtonSave", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, classContainerInput: { classPropertyName: "classContainerInput", publicName: "classContainerInput", isSignal: true, isRequired: false, transformFunction: null }, classContainerButton: { classPropertyName: "classContainerButton", publicName: "classContainerButton", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { outChangeExpressions: "outChangeExpressions" }, viewQueries: [{ propertyName: "inputRef", predicate: ["inputRef"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"w-full\">\n <div class=\"p-[8px] rounded-[12px] bg-[#f8f9fa] {{ classInclude() }}\">\n <div #calculatorInput\n class=\"py-[10px] px-[12px] libs-ui-font-h5r rounded-[8px] bg-[#ffffff] min-h-[160px] mb-[8px] border-[1px] {{ isFocus() ? 'border-[var(--libs-ui-color-light-1)]' : 'border-[#ffffff]' }} {{ classContainerInput() }}\"\n (mouseup)=\"handlerClickInput($event)\">\n <ul class=\"before:content-[''] before:table after:content-[''] after:table after:clear-both\">\n @for (item of listExpressions(); track $index; let i = $index) {\n <li class=\"float-left mb-[8px]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none text-center\"\n [class.ml-[-8px]]=\"i === 0\"\n [style.width.px]=\"inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(i)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n @switch (item.type) {\n @case ('operation') {\n <li class=\"float-left mb-[8px] text-center w-[24px] rounded-[4px] p-[4px] bg-[var(--libs-ui-color-light-2)]\">{{ item.data }}</li>\n }\n @case ('value') {\n <li class=\"float-left mb-[8px] text-center rounded-[4px] py-[4px] px-[8px] bg-[#E6E7EA] flex max-w-[calc(100%-8px)]\">\n <libs_ui-components-popover [type]=\"'text'\">{{ item.data }}</libs_ui-components-popover>\n </li>\n }\n @case ('field') {\n @if (item.data | LibsUiComponentsInputsCalculatorGetFieldSelectedPipe:configField()?.getFieldSelected; as fieldSelected) {\n <li class=\"float-left mb-[8px]\">\n <libs_ui-components-buttons-button class=\"max-w-[150px] block\"\n [label]=\"fieldSelected.name || ''\"\n [classInclude]=\"'!justify-center !py-[3px] !px-[7px] !w-full'\"\n [classIconLeft]=\"fieldSelected.icon || ''\"\n [classIconRight]=\"'libs-ui-icon-move-right rotate-90'\"\n [classLabel]=\"'libs-ui-font-h5r'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:false,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: i, key: item.data},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, i)\" />\n </li>\n }\n }\n }\n }\n <li class=\"float-left mb-[8px] max-w-[100%]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none max-w-[100%] {{ listExpressions().length ? 'text-center' : '' }}\"\n [style.width.px]=\"listExpressions().length ? (inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput) : 150\"\n [placeholder]=\"!listExpressions().length ? (placeholder() | translate) : ''\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(listExpressions().length)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n </ul>\n </div>\n <div class=\"grid grid-cols-4 gap-[8px] {{ classContainerButton() }}\">\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"configField()?.label || 'i18n_select_field'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:true,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: -1},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, -1)\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-violet'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'Fx'\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-danger-high'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'C'\"\n (outClick)=\"handlerClick($event, 'c')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'('\"\n (outClick)=\"handlerClick($event, '(')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"')'\"\n (outClick)=\"handlerClick($event, ')')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'/'\"\n (outClick)=\"handlerClick($event, '/')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'1'\"\n (outClick)=\"handlerClick($event, '1')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'2'\"\n (outClick)=\"handlerClick($event, '2')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'3'\"\n (outClick)=\"handlerClick($event, '3')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-close'\"\n (outClick)=\"handlerClick($event, '*')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'4'\"\n (outClick)=\"handlerClick($event, '4')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'5'\"\n (outClick)=\"handlerClick($event, '5')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'6'\"\n (outClick)=\"handlerClick($event, '6')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'-'\"\n (outClick)=\"handlerClick($event, '-')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'7'\"\n (outClick)=\"handlerClick($event, '7')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'8'\"\n (outClick)=\"handlerClick($event, '8')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'9'\"\n (outClick)=\"handlerClick($event, '9')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-add'\"\n (outClick)=\"handlerClick($event, '+')\" />\n </div>\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"'0'\"\n [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n (outClick)=\"handlerClick($event, '0')\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'.'\"\n (outClick)=\"handlerClick($event, '.')\" />\n </div>\n </div>\n </div>\n @if (!ignoreButtonSave()) {\n <div class=\"mt-[16px]\">\n <libs_ui-components-buttons-button [label]=\"labelButtonSave()\"\n [disable]=\"!isChangeExpression()\"\n [classInclude]=\"'justify-center w-full'\"\n (outClick)=\"handlerSave($event)\" />\n </div>\n }\n</div>\n\n<ng-template #listViewRef\n let-data='itemContext'>\n <libs_ui-components-list [zIndex]=\"zIndex()\"\n [config]=\"configField()?.listConfig\"\n [maxItemShow]=\"6\"\n [clickExactly]=\"false\"\n [searchConfig]=\"{noBorder: true, placeholder: configField()?.placeholderInputList || 'i18n_search'}\"\n [multiKeySelected]=\"data.key ? [data.key] : []\"\n (outSelectMultiKey)=\"handlerSelectedField($event, data.index)\">\n </libs_ui-components-list>\n</ng-template>\n", dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "component", type: LibsUiComponentsButtonsButtonComponent, selector: "libs_ui-components-buttons-button", inputs: ["flagMouse", "type", "buttonCustom", "sizeButton", "label", "disable", "isPending", "imageLeft", "classInclude", "classIconLeft", "classIconRight", "classLabel", "iconOnlyType", "popover", "ignoreStopPropagationEvent", "zIndex", "widthLabelPopover", "styleIconLeft", "styleButton", "ignoreFocusWhenInputTab", "ignoreSetClickWhenShowPopover", "ignorePointerEvent", "isActive"], outputs: ["outClick", "outPopoverEvent", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsListComponent, selector: "libs_ui-components-list", inputs: ["hiddenInputSearch", "dropdownTabKeyActive", "keySearch", "paddingLeftItem", "config", "autoSelectedFirstItemCallOutsideBefore", "isSearchOnline", "disable", "disableLabel", "labelConfig", "searchConfig", "searchPadding", "dividerClassInclude", "hasDivider", "buttonsOther", "hasButtonUnSelectOption", "clickExactly", "backgroundListCustom", "maxItemShow", "keySelected", "multiKeySelected", "keysDisableItem", "keysHiddenItem", "focusInputSearch", "skipFocusInputWhenKeySearchStoreUndefined", "functionGetItemsAutoAddList", "validRequired", "showValidateBottom", "zIndex", "loadingIconSize", "templateRefSearchNoData", "resetKeyWhenSelectAllKeyDropdown", "ignoreClassDisableDefaultWhenUseKeysDisableItem"], outputs: ["outSelectKey", "outSelectMultiKey", "outUnSelectMultiKey", "outClickButtonOther", "outFieldKey", "outChangeView", "outKeySearch", "outLoading", "outFunctionsControl", "outChangStageFlagMousePopover", "outLoadItemsComplete"] }, { kind: "pipe", type: LibsUiComponentsInputsCalculatorGetFieldSelectedPipe, name: "LibsUiComponentsInputsCalculatorGetFieldSelectedPipe" }, { 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: "pipe", type: LibsUiComponentsInputsCalculatorGetWidthInputPipe, name: "LibsUiComponentsInputsCalculatorGetWidthInputPipe" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
201
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsInputsCalculatorComponent, isStandalone: true, selector: "libs_ui-components-inputs-calculator", inputs: { expressions: { classPropertyName: "expressions", publicName: "expressions", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, labelButtonSave: { classPropertyName: "labelButtonSave", publicName: "labelButtonSave", isSignal: true, isRequired: false, transformFunction: null }, configField: { classPropertyName: "configField", publicName: "configField", isSignal: true, isRequired: false, transformFunction: null }, ignoreButtonSave: { classPropertyName: "ignoreButtonSave", publicName: "ignoreButtonSave", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, classContainerInput: { classPropertyName: "classContainerInput", publicName: "classContainerInput", isSignal: true, isRequired: false, transformFunction: null }, classContainerButton: { classPropertyName: "classContainerButton", publicName: "classContainerButton", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { outChangeExpressions: "outChangeExpressions" }, viewQueries: [{ propertyName: "inputRef", predicate: ["inputRef"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"w-full\">\n <div class=\"p-[8px] rounded-[12px] bg-[#f8f9fa] {{ classInclude() }}\">\n <div #calculatorInput\n class=\"py-[10px] px-[12px] libs-ui-font-h5r rounded-[8px] bg-[#ffffff] min-h-[160px] mb-[8px] border-[1px] {{ isFocus() ? 'border-[var(--libs-ui-color-light-1)]' : 'border-[#ffffff]' }} {{ classContainerInput() }}\"\n (mouseup)=\"handlerClickInput($event)\">\n <ul class=\"before:content-[''] before:table after:content-[''] after:table after:clear-both\">\n @for (item of listExpressions(); track $index; let i = $index) {\n <li class=\"float-left mb-[8px]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none text-center\"\n [class.ml-[-8px]]=\"i === 0\"\n [style.width.px]=\"inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(i)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n @switch (item.type) {\n @case ('operation') {\n <li class=\"float-left mb-[8px] text-center w-[24px] rounded-[4px] p-[4px] bg-[var(--libs-ui-color-light-2)]\">{{ item.data }}</li>\n }\n @case ('value') {\n <li class=\"float-left mb-[8px] text-center rounded-[4px] py-[4px] px-[8px] bg-[#E6E7EA] flex max-w-[calc(100%-8px)]\">\n <libs_ui-components-popover [type]=\"'text'\">{{ item.data }}</libs_ui-components-popover>\n </li>\n }\n @case ('field') {\n @if (item.data | LibsUiComponentsInputsCalculatorGetFieldSelectedPipe:configField()?.getFieldSelected; as fieldSelected) {\n <li class=\"float-left mb-[8px]\">\n <libs_ui-components-buttons-button class=\"max-w-[150px] block\"\n [label]=\"fieldSelected.name || ''\"\n [classInclude]=\"'!justify-center !py-[3px] !px-[7px] !w-full'\"\n [classIconLeft]=\"fieldSelected.icon || ''\"\n [classIconRight]=\"'libs-ui-icon-move-right rotate-90'\"\n [classLabel]=\"'libs-ui-font-h5r'\"\n [zIndex]=\" zIndex()\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:false,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: i, key: item.data},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, i)\" />\n </li>\n }\n }\n }\n }\n <li class=\"float-left mb-[8px] max-w-[100%]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none max-w-[100%] {{ listExpressions().length ? 'text-center' : '' }}\"\n [style.width.px]=\"listExpressions().length ? (inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput) : 150\"\n [placeholder]=\"!listExpressions().length ? (placeholder() | translate) : ''\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(listExpressions().length)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n </ul>\n </div>\n <div class=\"grid grid-cols-4 gap-[8px] {{ classContainerButton() }}\">\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"configField()?.label || 'i18n_select_field'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:true,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: -1},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, -1)\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-violet'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'Fx'\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-danger-high'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'C'\"\n (outClick)=\"handlerClick($event, 'c')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'('\"\n (outClick)=\"handlerClick($event, '(')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"')'\"\n (outClick)=\"handlerClick($event, ')')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'/'\"\n (outClick)=\"handlerClick($event, '/')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'1'\"\n (outClick)=\"handlerClick($event, '1')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'2'\"\n (outClick)=\"handlerClick($event, '2')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'3'\"\n (outClick)=\"handlerClick($event, '3')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-close'\"\n (outClick)=\"handlerClick($event, '*')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'4'\"\n (outClick)=\"handlerClick($event, '4')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'5'\"\n (outClick)=\"handlerClick($event, '5')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'6'\"\n (outClick)=\"handlerClick($event, '6')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'-'\"\n (outClick)=\"handlerClick($event, '-')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'7'\"\n (outClick)=\"handlerClick($event, '7')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'8'\"\n (outClick)=\"handlerClick($event, '8')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'9'\"\n (outClick)=\"handlerClick($event, '9')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-add'\"\n (outClick)=\"handlerClick($event, '+')\" />\n </div>\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"'0'\"\n [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n (outClick)=\"handlerClick($event, '0')\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'.'\"\n (outClick)=\"handlerClick($event, '.')\" />\n </div>\n </div>\n </div>\n @if (!ignoreButtonSave()) {\n <div class=\"mt-[16px]\">\n <libs_ui-components-buttons-button [label]=\"labelButtonSave()\"\n [disable]=\"!isChangeExpression()\"\n [classInclude]=\"'justify-center w-full'\"\n (outClick)=\"handlerSave($event)\" />\n </div>\n }\n</div>\n\n<ng-template #listViewRef\n let-data='itemContext'>\n <libs_ui-components-list [zIndex]=\"zIndex()\"\n [config]=\"configField()?.listConfig\"\n [maxItemShow]=\"6\"\n [clickExactly]=\"false\"\n [searchConfig]=\"{noBorder: true, placeholder: configField()?.placeholderInputList || 'i18n_search'}\"\n [multiKeySelected]=\"data.key ? [data.key] : []\"\n (outSelectMultiKey)=\"handlerSelectedField($event, data.index)\">\n </libs_ui-components-list>\n</ng-template>\n", dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "component", type: LibsUiComponentsButtonsButtonComponent, selector: "libs_ui-components-buttons-button", inputs: ["flagMouse", "type", "buttonCustom", "sizeButton", "label", "disable", "isPending", "imageLeft", "classInclude", "classIconLeft", "classIconRight", "classLabel", "iconOnlyType", "popover", "ignoreStopPropagationEvent", "zIndex", "widthLabelPopover", "styleIconLeft", "styleButton", "ignoreFocusWhenInputTab", "ignoreSetClickWhenShowPopover", "ignorePointerEvent", "isActive"], outputs: ["outClick", "outPopoverEvent", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsListComponent, selector: "libs_ui-components-list", inputs: ["hiddenInputSearch", "dropdownTabKeyActive", "keySearch", "paddingLeftItem", "config", "autoSelectedFirstItemCallOutsideBefore", "isSearchOnline", "disable", "disableLabel", "labelConfig", "searchConfig", "searchPadding", "dividerClassInclude", "hasDivider", "buttonsOther", "hasButtonUnSelectOption", "clickExactly", "backgroundListCustom", "maxItemShow", "keySelected", "multiKeySelected", "keysDisableItem", "keysHiddenItem", "focusInputSearch", "skipFocusInputWhenKeySearchStoreUndefined", "functionGetItemsAutoAddList", "validRequired", "showValidateBottom", "zIndex", "loadingIconSize", "templateRefSearchNoData", "resetKeyWhenSelectAllKeyDropdown", "ignoreClassDisableDefaultWhenUseKeysDisableItem"], outputs: ["outSelectKey", "outSelectMultiKey", "outUnSelectMultiKey", "outClickButtonOther", "outFieldKey", "outChangeView", "outKeySearch", "outLoading", "outFunctionsControl", "outChangStageFlagMousePopover", "outLoadItemsComplete"] }, { kind: "pipe", type: LibsUiComponentsInputsCalculatorGetFieldSelectedPipe, name: "LibsUiComponentsInputsCalculatorGetFieldSelectedPipe" }, { 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: "pipe", type: LibsUiComponentsInputsCalculatorGetWidthInputPipe, name: "LibsUiComponentsInputsCalculatorGetWidthInputPipe" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
202
202
|
}
|
|
203
203
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsInputsCalculatorComponent, decorators: [{
|
|
204
204
|
type: Component,
|
|
@@ -209,7 +209,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
209
209
|
LibsUiComponentsInputsCalculatorGetFieldSelectedPipe,
|
|
210
210
|
LibsUiComponentsPopoverComponent,
|
|
211
211
|
LibsUiComponentsInputsCalculatorGetWidthInputPipe
|
|
212
|
-
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"w-full\">\n <div class=\"p-[8px] rounded-[12px] bg-[#f8f9fa] {{ classInclude() }}\">\n <div #calculatorInput\n class=\"py-[10px] px-[12px] libs-ui-font-h5r rounded-[8px] bg-[#ffffff] min-h-[160px] mb-[8px] border-[1px] {{ isFocus() ? 'border-[var(--libs-ui-color-light-1)]' : 'border-[#ffffff]' }} {{ classContainerInput() }}\"\n (mouseup)=\"handlerClickInput($event)\">\n <ul class=\"before:content-[''] before:table after:content-[''] after:table after:clear-both\">\n @for (item of listExpressions(); track $index; let i = $index) {\n <li class=\"float-left mb-[8px]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none text-center\"\n [class.ml-[-8px]]=\"i === 0\"\n [style.width.px]=\"inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(i)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n @switch (item.type) {\n @case ('operation') {\n <li class=\"float-left mb-[8px] text-center w-[24px] rounded-[4px] p-[4px] bg-[var(--libs-ui-color-light-2)]\">{{ item.data }}</li>\n }\n @case ('value') {\n <li class=\"float-left mb-[8px] text-center rounded-[4px] py-[4px] px-[8px] bg-[#E6E7EA] flex max-w-[calc(100%-8px)]\">\n <libs_ui-components-popover [type]=\"'text'\">{{ item.data }}</libs_ui-components-popover>\n </li>\n }\n @case ('field') {\n @if (item.data | LibsUiComponentsInputsCalculatorGetFieldSelectedPipe:configField()?.getFieldSelected; as fieldSelected) {\n <li class=\"float-left mb-[8px]\">\n <libs_ui-components-buttons-button class=\"max-w-[150px] block\"\n [label]=\"fieldSelected.name || ''\"\n [classInclude]=\"'!justify-center !py-[3px] !px-[7px] !w-full'\"\n [classIconLeft]=\"fieldSelected.icon || ''\"\n [classIconRight]=\"'libs-ui-icon-move-right rotate-90'\"\n [classLabel]=\"'libs-ui-font-h5r'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:false,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: i, key: item.data},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, i)\" />\n </li>\n }\n }\n }\n }\n <li class=\"float-left mb-[8px] max-w-[100%]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none max-w-[100%] {{ listExpressions().length ? 'text-center' : '' }}\"\n [style.width.px]=\"listExpressions().length ? (inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput) : 150\"\n [placeholder]=\"!listExpressions().length ? (placeholder() | translate) : ''\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(listExpressions().length)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n </ul>\n </div>\n <div class=\"grid grid-cols-4 gap-[8px] {{ classContainerButton() }}\">\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"configField()?.label || 'i18n_select_field'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:true,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: -1},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, -1)\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-violet'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'Fx'\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-danger-high'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'C'\"\n (outClick)=\"handlerClick($event, 'c')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'('\"\n (outClick)=\"handlerClick($event, '(')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"')'\"\n (outClick)=\"handlerClick($event, ')')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'/'\"\n (outClick)=\"handlerClick($event, '/')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'1'\"\n (outClick)=\"handlerClick($event, '1')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'2'\"\n (outClick)=\"handlerClick($event, '2')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'3'\"\n (outClick)=\"handlerClick($event, '3')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-close'\"\n (outClick)=\"handlerClick($event, '*')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'4'\"\n (outClick)=\"handlerClick($event, '4')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'5'\"\n (outClick)=\"handlerClick($event, '5')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'6'\"\n (outClick)=\"handlerClick($event, '6')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'-'\"\n (outClick)=\"handlerClick($event, '-')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'7'\"\n (outClick)=\"handlerClick($event, '7')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'8'\"\n (outClick)=\"handlerClick($event, '8')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'9'\"\n (outClick)=\"handlerClick($event, '9')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-add'\"\n (outClick)=\"handlerClick($event, '+')\" />\n </div>\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"'0'\"\n [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n (outClick)=\"handlerClick($event, '0')\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'.'\"\n (outClick)=\"handlerClick($event, '.')\" />\n </div>\n </div>\n </div>\n @if (!ignoreButtonSave()) {\n <div class=\"mt-[16px]\">\n <libs_ui-components-buttons-button [label]=\"labelButtonSave()\"\n [disable]=\"!isChangeExpression()\"\n [classInclude]=\"'justify-center w-full'\"\n (outClick)=\"handlerSave($event)\" />\n </div>\n }\n</div>\n\n<ng-template #listViewRef\n let-data='itemContext'>\n <libs_ui-components-list [zIndex]=\"zIndex()\"\n [config]=\"configField()?.listConfig\"\n [maxItemShow]=\"6\"\n [clickExactly]=\"false\"\n [searchConfig]=\"{noBorder: true, placeholder: configField()?.placeholderInputList || 'i18n_search'}\"\n [multiKeySelected]=\"data.key ? [data.key] : []\"\n (outSelectMultiKey)=\"handlerSelectedField($event, data.index)\">\n </libs_ui-components-list>\n</ng-template>\n" }]
|
|
212
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"w-full\">\n <div class=\"p-[8px] rounded-[12px] bg-[#f8f9fa] {{ classInclude() }}\">\n <div #calculatorInput\n class=\"py-[10px] px-[12px] libs-ui-font-h5r rounded-[8px] bg-[#ffffff] min-h-[160px] mb-[8px] border-[1px] {{ isFocus() ? 'border-[var(--libs-ui-color-light-1)]' : 'border-[#ffffff]' }} {{ classContainerInput() }}\"\n (mouseup)=\"handlerClickInput($event)\">\n <ul class=\"before:content-[''] before:table after:content-[''] after:table after:clear-both\">\n @for (item of listExpressions(); track $index; let i = $index) {\n <li class=\"float-left mb-[8px]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none text-center\"\n [class.ml-[-8px]]=\"i === 0\"\n [style.width.px]=\"inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(i)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n @switch (item.type) {\n @case ('operation') {\n <li class=\"float-left mb-[8px] text-center w-[24px] rounded-[4px] p-[4px] bg-[var(--libs-ui-color-light-2)]\">{{ item.data }}</li>\n }\n @case ('value') {\n <li class=\"float-left mb-[8px] text-center rounded-[4px] py-[4px] px-[8px] bg-[#E6E7EA] flex max-w-[calc(100%-8px)]\">\n <libs_ui-components-popover [type]=\"'text'\">{{ item.data }}</libs_ui-components-popover>\n </li>\n }\n @case ('field') {\n @if (item.data | LibsUiComponentsInputsCalculatorGetFieldSelectedPipe:configField()?.getFieldSelected; as fieldSelected) {\n <li class=\"float-left mb-[8px]\">\n <libs_ui-components-buttons-button class=\"max-w-[150px] block\"\n [label]=\"fieldSelected.name || ''\"\n [classInclude]=\"'!justify-center !py-[3px] !px-[7px] !w-full'\"\n [classIconLeft]=\"fieldSelected.icon || ''\"\n [classIconRight]=\"'libs-ui-icon-move-right rotate-90'\"\n [classLabel]=\"'libs-ui-font-h5r'\"\n [zIndex]=\" zIndex()\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:false,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: i, key: item.data},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, i)\" />\n </li>\n }\n }\n }\n }\n <li class=\"float-left mb-[8px] max-w-[100%]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none max-w-[100%] {{ listExpressions().length ? 'text-center' : '' }}\"\n [style.width.px]=\"listExpressions().length ? (inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput) : 150\"\n [placeholder]=\"!listExpressions().length ? (placeholder() | translate) : ''\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(listExpressions().length)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n </ul>\n </div>\n <div class=\"grid grid-cols-4 gap-[8px] {{ classContainerButton() }}\">\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"configField()?.label || 'i18n_select_field'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:true,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: -1},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, -1)\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-violet'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'Fx'\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-danger-high'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'C'\"\n (outClick)=\"handlerClick($event, 'c')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'('\"\n (outClick)=\"handlerClick($event, '(')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"')'\"\n (outClick)=\"handlerClick($event, ')')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'/'\"\n (outClick)=\"handlerClick($event, '/')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'1'\"\n (outClick)=\"handlerClick($event, '1')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'2'\"\n (outClick)=\"handlerClick($event, '2')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'3'\"\n (outClick)=\"handlerClick($event, '3')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-close'\"\n (outClick)=\"handlerClick($event, '*')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'4'\"\n (outClick)=\"handlerClick($event, '4')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'5'\"\n (outClick)=\"handlerClick($event, '5')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'6'\"\n (outClick)=\"handlerClick($event, '6')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'-'\"\n (outClick)=\"handlerClick($event, '-')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'7'\"\n (outClick)=\"handlerClick($event, '7')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'8'\"\n (outClick)=\"handlerClick($event, '8')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'9'\"\n (outClick)=\"handlerClick($event, '9')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-add'\"\n (outClick)=\"handlerClick($event, '+')\" />\n </div>\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"'0'\"\n [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n (outClick)=\"handlerClick($event, '0')\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'.'\"\n (outClick)=\"handlerClick($event, '.')\" />\n </div>\n </div>\n </div>\n @if (!ignoreButtonSave()) {\n <div class=\"mt-[16px]\">\n <libs_ui-components-buttons-button [label]=\"labelButtonSave()\"\n [disable]=\"!isChangeExpression()\"\n [classInclude]=\"'justify-center w-full'\"\n (outClick)=\"handlerSave($event)\" />\n </div>\n }\n</div>\n\n<ng-template #listViewRef\n let-data='itemContext'>\n <libs_ui-components-list [zIndex]=\"zIndex()\"\n [config]=\"configField()?.listConfig\"\n [maxItemShow]=\"6\"\n [clickExactly]=\"false\"\n [searchConfig]=\"{noBorder: true, placeholder: configField()?.placeholderInputList || 'i18n_search'}\"\n [multiKeySelected]=\"data.key ? [data.key] : []\"\n (outSelectMultiKey)=\"handlerSelectedField($event, data.index)\">\n </libs_ui-components-list>\n</ng-template>\n" }]
|
|
213
213
|
}] });
|
|
214
214
|
|
|
215
215
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"libs-ui-components-inputs-calculator.mjs","sources":["../../../../../../libs-ui/components/inputs/calculator/src/pipes/get-field-selected.pipe.ts","../../../../../../libs-ui/components/inputs/calculator/src/pipes/get-width-input.pipe.ts","../../../../../../libs-ui/components/inputs/calculator/src/calculator.component.ts","../../../../../../libs-ui/components/inputs/calculator/src/calculator.component.html","../../../../../../libs-ui/components/inputs/calculator/src/libs-ui-components-inputs-calculator.ts"],"sourcesContent":["import { Pipe, PipeTransform } from '@angular/core';\nimport { IInputCalculatorField } from '../interfaces';\n\n@Pipe({\n name: 'LibsUiComponentsInputsCalculatorGetFieldSelectedPipe',\n standalone: true\n})\n\nexport class LibsUiComponentsInputsCalculatorGetFieldSelectedPipe implements PipeTransform {\n\n transform(fieldId: string | number, getFieldSelected?: (key: string) => IInputCalculatorField | undefined): IInputCalculatorField | undefined {\n\n\n return getFieldSelected?.(typeof fieldId === 'number' ? fieldId.toString() : fieldId);\n }\n\n}\n","import { Pipe, PipeTransform } from '@angular/core';\n\n@Pipe({\n name: 'LibsUiComponentsInputsCalculatorGetWidthInputPipe',\n standalone: true\n})\n\nexport class LibsUiComponentsInputsCalculatorGetWidthInputPipe implements PipeTransform {\n\n transform(text: string, element: HTMLDivElement): number {\n if (!text) {\n return 8;\n }\n const div = document.createElement('span');\n\n div.textContent = text;\n element.appendChild(div);\n const width = div.offsetWidth + 8;\n\n div.remove();\n\n return width;\n }\n\n}\n","import { ChangeDetectionStrategy, Component, ElementRef, input, OnInit, output, signal, viewChildren } from \"@angular/core\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';\nimport { IListDataEmitMultiKey, LibsUiComponentsListComponent } from '@libs-ui/components-list';\nimport { IInputCalculatorConfigField, IInputCalculatorExpression } from \"./interfaces\";\nimport { IEvent } from \"@libs-ui/interfaces-types\";\nimport { cloneDeep, UtilsKeyCodeConstant } from \"@libs-ui/utils\";\nimport { IPopoverFunctionControlEvent, LibsUiComponentsPopoverComponent } from \"@libs-ui/components-popover\";\nimport { LibsUiComponentsInputsCalculatorGetFieldSelectedPipe } from \"./pipes/get-field-selected.pipe\";\nimport { LibsUiComponentsInputsCalculatorGetWidthInputPipe } from \"./pipes/get-width-input.pipe\";\n\n@Component({\n // eslint-disable-next-line @angular-eslint/component-selector\n selector: 'libs_ui-components-inputs-calculator',\n templateUrl: './calculator.component.html',\n standalone: true,\n imports: [\n TranslateModule,\n LibsUiComponentsButtonsButtonComponent,\n LibsUiComponentsListComponent,\n LibsUiComponentsInputsCalculatorGetFieldSelectedPipe,\n LibsUiComponentsPopoverComponent,\n LibsUiComponentsInputsCalculatorGetWidthInputPipe\n ],\n changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class LibsUiComponentsInputsCalculatorComponent implements OnInit {\n protected indexFocus = signal<number | undefined>(undefined);\n protected isFocus = signal<boolean>(false);\n protected listExpressions = signal<Array<IInputCalculatorExpression>>([]);\n protected isChangeExpression = signal<boolean>(false);\n\n private inputRef = viewChildren<ElementRef>('inputRef');\n private timeOut = signal<number | undefined>(undefined);\n private tooltipFunctionControl = signal<Map<number, IPopoverFunctionControlEvent>>(new Map());\n\n readonly expressions = input<Array<IInputCalculatorExpression>>([]);\n readonly zIndex = input<number>(10);\n readonly placeholder = input<string>('i18n_enter_params');\n readonly labelButtonSave = input<string>('i18n_save_calculation');\n readonly configField = input<IInputCalculatorConfigField>();\n readonly ignoreButtonSave = input<boolean>(false);\n readonly classInclude = input<string, string | undefined>('', { transform: (value) => value || '' });\n readonly classContainerInput = input<string, string | undefined>('', { transform: (value) => value || '' });\n readonly classContainerButton = input<string, string | undefined>('', { transform: (value) => value || '' });\n\n readonly outChangeExpressions = output<Array<IInputCalculatorExpression>>();\n\n ngOnInit() {\n this.listExpressions.set(cloneDeep(this.expressions()));\n }\n\n protected handlerClick(event: Event, button: '+' | '-' | '*' | '/' | 'c' | '.' | '(' | ')' | '0' | '1' | '2' | '3' | '4' | '5' | '6' | '7' | '8' | '9') {\n event.stopPropagation();\n const expression: IInputCalculatorExpression = { type: 'field', data: button };\n\n if (button === 'c') {\n if (!this.listExpressions().length || this.indexFocus() === 0) {\n return;\n }\n return this.updateExpressions(undefined, typeof this.indexFocus() !== 'undefined' ? ((this.indexFocus() || 1) - 1) : (this.listExpressions().length - 1));\n }\n switch (button) {\n case '+':\n case '-':\n case '*':\n case '/':\n expression.type = 'operation';\n break;\n default:\n expression.type = 'value';\n }\n this.updateExpressions(expression, typeof this.indexFocus() !== 'undefined' ? (this.indexFocus() || 0) : this.listExpressions().length);\n }\n\n private updateExpressions(item: IInputCalculatorExpression | undefined, position: number, isDelete?: boolean) {\n this.isChangeExpression.set(true);\n this.listExpressions.update((value) => {\n if (item) {\n value.splice(position || 0, 0, item);\n }\n if (!item) {\n value.splice(position || 0, 1);\n }\n\n return [...value];\n })\n\n this.indexFocus.update(value => {\n if (!item) {\n if (value) {\n value = isDelete ? value : value - 1;\n }\n\n return value ? value : position;\n }\n if (typeof value === 'undefined') {\n value = this.listExpressions().length;\n\n return value;\n }\n value++;\n\n return value;\n })\n const indexFocus = this.indexFocus();\n\n setTimeout(() => {\n if (typeof indexFocus !== 'undefined') {\n this.inputRef()[indexFocus]?.nativeElement.focus();\n }\n }, 100)\n }\n\n protected handlerEventKeyUpInput(event: Event) {\n const keyCode = (event as IEvent).keyCode;\n const value = (event as IEvent).target.value;\n const shiftKey = (event as IEvent).shiftKey;\n\n if ((([UtilsKeyCodeConstant.EQUALS, UtilsKeyCodeConstant.EIGHT].includes(keyCode) && shiftKey) || ([UtilsKeyCodeConstant.DASH, UtilsKeyCodeConstant.SLASH].includes(keyCode) && !shiftKey)) && value.length === 1) {\n (event as IEvent).target.value = '';\n\n return this.updateExpressions({ type: 'operation', data: value }, this.indexFocus() || this.listExpressions().length);\n }\n }\n\n protected handlerEventKeyInput(event: Event) {\n const keyCode = (event as IEvent).keyCode;\n const value = (event as IEvent).target.value;\n\n if (keyCode === UtilsKeyCodeConstant.BACKSPACE) {\n if (!value && this.listExpressions().length && (this.indexFocus() || 0) > 0) {\n return this.updateExpressions(undefined, (this.indexFocus() || 0) - 1);\n }\n }\n if (keyCode === UtilsKeyCodeConstant.DELETE) {\n if (!value && this.listExpressions().length && (this.indexFocus() || 0) < this.listExpressions().length) {\n return this.updateExpressions(undefined, (this.indexFocus() || 0), true);\n }\n }\n if (keyCode === UtilsKeyCodeConstant.ENTER) {\n if (value) {\n (event as IEvent).target.value = '';\n\n return this.updateExpressions({ type: 'value', data: value }, this.indexFocus() || this.listExpressions().length);\n }\n }\n }\n\n protected handlerFocusAndBlurInput(index: number | undefined) {\n if (typeof index !== 'undefined') {\n this.indexFocus.set(index);\n this.isFocus.set(true);\n clearTimeout(this.timeOut());\n\n return;\n }\n this.timeOut.set(setTimeout(() => {\n this.isFocus.set(false);\n }, 250))\n }\n\n protected handlerClickInput(event: Event) {\n event.stopPropagation();\n if (!this.isFocus()) {\n this.inputRef()[this.inputRef().length - 1].nativeElement.focus();\n }\n }\n\n protected handlerSave(event: Event) {\n event.stopPropagation();\n this.isChangeExpression.set(false);\n this.outChangeExpressions.emit(cloneDeep(this.listExpressions()));\n }\n\n protected handlerSelectedField(event: IListDataEmitMultiKey | undefined, index: number) {\n if (!event?.keys.length) {\n return;\n }\n if (index >= 0) {\n this.listExpressions.update(value => {\n value.forEach((item, i) => {\n if (i === index) {\n if (item.data !== event.keys[0]) {\n this.tooltipFunctionControl().get(index)?.removePopoverOverlay();\n }\n item.data = event.keys[0] as string\n }\n })\n\n return [...value];\n })\n\n return;\n }\n this.updateExpressions({ type: 'field', data: event.keys[0] as string }, typeof this.indexFocus() !== 'undefined' ? (this.indexFocus() || 0) : this.listExpressions().length);\n this.tooltipFunctionControl().get(index)?.removePopoverOverlay();\n }\n\n protected handlerFunctionControlButton(event: IPopoverFunctionControlEvent, index: number) {\n this.tooltipFunctionControl.update(value => {\n value.set(index, event);\n\n return value;\n })\n }\n}","<div class=\"w-full\">\n <div class=\"p-[8px] rounded-[12px] bg-[#f8f9fa] {{ classInclude() }}\">\n <div #calculatorInput\n class=\"py-[10px] px-[12px] libs-ui-font-h5r rounded-[8px] bg-[#ffffff] min-h-[160px] mb-[8px] border-[1px] {{ isFocus() ? 'border-[var(--libs-ui-color-light-1)]' : 'border-[#ffffff]' }} {{ classContainerInput() }}\"\n (mouseup)=\"handlerClickInput($event)\">\n <ul class=\"before:content-[''] before:table after:content-[''] after:table after:clear-both\">\n @for (item of listExpressions(); track $index; let i = $index) {\n <li class=\"float-left mb-[8px]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none text-center\"\n [class.ml-[-8px]]=\"i === 0\"\n [style.width.px]=\"inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(i)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n @switch (item.type) {\n @case ('operation') {\n <li class=\"float-left mb-[8px] text-center w-[24px] rounded-[4px] p-[4px] bg-[var(--libs-ui-color-light-2)]\">{{ item.data }}</li>\n }\n @case ('value') {\n <li class=\"float-left mb-[8px] text-center rounded-[4px] py-[4px] px-[8px] bg-[#E6E7EA] flex max-w-[calc(100%-8px)]\">\n <libs_ui-components-popover [type]=\"'text'\">{{ item.data }}</libs_ui-components-popover>\n </li>\n }\n @case ('field') {\n @if (item.data | LibsUiComponentsInputsCalculatorGetFieldSelectedPipe:configField()?.getFieldSelected; as fieldSelected) {\n <li class=\"float-left mb-[8px]\">\n <libs_ui-components-buttons-button class=\"max-w-[150px] block\"\n [label]=\"fieldSelected.name || ''\"\n [classInclude]=\"'!justify-center !py-[3px] !px-[7px] !w-full'\"\n [classIconLeft]=\"fieldSelected.icon || ''\"\n [classIconRight]=\"'libs-ui-icon-move-right rotate-90'\"\n [classLabel]=\"'libs-ui-font-h5r'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:false,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: i, key: item.data},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, i)\" />\n </li>\n }\n }\n }\n }\n <li class=\"float-left mb-[8px] max-w-[100%]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none max-w-[100%] {{ listExpressions().length ? 'text-center' : '' }}\"\n [style.width.px]=\"listExpressions().length ? (inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput) : 150\"\n [placeholder]=\"!listExpressions().length ? (placeholder() | translate) : ''\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(listExpressions().length)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n </ul>\n </div>\n <div class=\"grid grid-cols-4 gap-[8px] {{ classContainerButton() }}\">\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"configField()?.label || 'i18n_select_field'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:true,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: -1},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, -1)\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-violet'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'Fx'\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-danger-high'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'C'\"\n (outClick)=\"handlerClick($event, 'c')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'('\"\n (outClick)=\"handlerClick($event, '(')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"')'\"\n (outClick)=\"handlerClick($event, ')')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'/'\"\n (outClick)=\"handlerClick($event, '/')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'1'\"\n (outClick)=\"handlerClick($event, '1')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'2'\"\n (outClick)=\"handlerClick($event, '2')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'3'\"\n (outClick)=\"handlerClick($event, '3')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-close'\"\n (outClick)=\"handlerClick($event, '*')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'4'\"\n (outClick)=\"handlerClick($event, '4')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'5'\"\n (outClick)=\"handlerClick($event, '5')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'6'\"\n (outClick)=\"handlerClick($event, '6')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'-'\"\n (outClick)=\"handlerClick($event, '-')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'7'\"\n (outClick)=\"handlerClick($event, '7')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'8'\"\n (outClick)=\"handlerClick($event, '8')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'9'\"\n (outClick)=\"handlerClick($event, '9')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-add'\"\n (outClick)=\"handlerClick($event, '+')\" />\n </div>\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"'0'\"\n [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n (outClick)=\"handlerClick($event, '0')\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'.'\"\n (outClick)=\"handlerClick($event, '.')\" />\n </div>\n </div>\n </div>\n @if (!ignoreButtonSave()) {\n <div class=\"mt-[16px]\">\n <libs_ui-components-buttons-button [label]=\"labelButtonSave()\"\n [disable]=\"!isChangeExpression()\"\n [classInclude]=\"'justify-center w-full'\"\n (outClick)=\"handlerSave($event)\" />\n </div>\n }\n</div>\n\n<ng-template #listViewRef\n let-data='itemContext'>\n <libs_ui-components-list [zIndex]=\"zIndex()\"\n [config]=\"configField()?.listConfig\"\n [maxItemShow]=\"6\"\n [clickExactly]=\"false\"\n [searchConfig]=\"{noBorder: true, placeholder: configField()?.placeholderInputList || 'i18n_search'}\"\n [multiKeySelected]=\"data.key ? [data.key] : []\"\n (outSelectMultiKey)=\"handlerSelectedField($event, data.index)\">\n </libs_ui-components-list>\n</ng-template>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;;;;;MAQa,oDAAoD,CAAA;IAE/D,SAAS,CAAC,OAAwB,EAAE,gBAAqE,EAAA;AAGvG,QAAA,OAAO,gBAAgB,GAAG,OAAO,OAAO,KAAK,QAAQ,GAAG,OAAO,CAAC,QAAQ,EAAE,GAAG,OAAO,CAAC;;wGAL5E,oDAAoD,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,IAAA,EAAA,CAAA;sGAApD,oDAAoD,EAAA,YAAA,EAAA,IAAA,EAAA,IAAA,EAAA,sDAAA,EAAA,CAAA;;4FAApD,oDAAoD,EAAA,UAAA,EAAA,CAAA;kBALhE,IAAI;AAAC,YAAA,IAAA,EAAA,CAAA;AACJ,oBAAA,IAAI,EAAE,sDAAsD;AAC5D,oBAAA,UAAU,EAAE;AACb,iBAAA;;;MCCY,iDAAiD,CAAA;IAE5D,SAAS,CAAC,IAAY,EAAE,OAAuB,EAAA;QAC7C,IAAI,CAAC,IAAI,EAAE;AACT,YAAA,OAAO,CAAC;;QAEV,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC;AAE1C,QAAA,GAAG,CAAC,WAAW,GAAG,IAAI;AACtB,QAAA,OAAO,CAAC,WAAW,CAAC,GAAG,CAAC;AACxB,QAAA,MAAM,KAAK,GAAG,GAAG,CAAC,WAAW,GAAG,CAAC;QAEjC,GAAG,CAAC,MAAM,EAAE;AAEZ,QAAA,OAAO,KAAK;;wGAdH,iDAAiD,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,IAAA,EAAA,CAAA;sGAAjD,iDAAiD,EAAA,YAAA,EAAA,IAAA,EAAA,IAAA,EAAA,mDAAA,EAAA,CAAA;;4FAAjD,iDAAiD,EAAA,UAAA,EAAA,CAAA;kBAL7D,IAAI;AAAC,YAAA,IAAA,EAAA,CAAA;AACJ,oBAAA,IAAI,EAAE,mDAAmD;AACzD,oBAAA,UAAU,EAAE;AACb,iBAAA;;;MCqBY,yCAAyC,CAAA;AAC1C,IAAA,UAAU,GAAG,MAAM,CAAqB,SAAS,CAAC;AAClD,IAAA,OAAO,GAAG,MAAM,CAAU,KAAK,CAAC;AAChC,IAAA,eAAe,GAAG,MAAM,CAAoC,EAAE,CAAC;AAC/D,IAAA,kBAAkB,GAAG,MAAM,CAAU,KAAK,CAAC;AAE7C,IAAA,QAAQ,GAAG,YAAY,CAAa,UAAU,CAAC;AAC/C,IAAA,OAAO,GAAG,MAAM,CAAqB,SAAS,CAAC;AAC/C,IAAA,sBAAsB,GAAG,MAAM,CAA4C,IAAI,GAAG,EAAE,CAAC;AAEpF,IAAA,WAAW,GAAG,KAAK,CAAoC,EAAE,CAAC;AAC1D,IAAA,MAAM,GAAG,KAAK,CAAS,EAAE,CAAC;AAC1B,IAAA,WAAW,GAAG,KAAK,CAAS,mBAAmB,CAAC;AAChD,IAAA,eAAe,GAAG,KAAK,CAAS,uBAAuB,CAAC;IACxD,WAAW,GAAG,KAAK,EAA+B;AAClD,IAAA,gBAAgB,GAAG,KAAK,CAAU,KAAK,CAAC;AACxC,IAAA,YAAY,GAAG,KAAK,CAA6B,EAAE,EAAE,EAAE,SAAS,EAAE,CAAC,KAAK,KAAK,KAAK,IAAI,EAAE,EAAE,CAAC;AAC3F,IAAA,mBAAmB,GAAG,KAAK,CAA6B,EAAE,EAAE,EAAE,SAAS,EAAE,CAAC,KAAK,KAAK,KAAK,IAAI,EAAE,EAAE,CAAC;AAClG,IAAA,oBAAoB,GAAG,KAAK,CAA6B,EAAE,EAAE,EAAE,SAAS,EAAE,CAAC,KAAK,KAAK,KAAK,IAAI,EAAE,EAAE,CAAC;IAEnG,oBAAoB,GAAG,MAAM,EAAqC;IAE3E,QAAQ,GAAA;AACN,QAAA,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;;IAG/C,YAAY,CAAC,KAAY,EAAE,MAAiH,EAAA;QACpJ,KAAK,CAAC,eAAe,EAAE;QACvB,MAAM,UAAU,GAA+B,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE;AAE9E,QAAA,IAAI,MAAM,KAAK,GAAG,EAAE;AAClB,YAAA,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,MAAM,IAAI,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,EAAE;gBAC7D;;AAEF,YAAA,OAAO,IAAI,CAAC,iBAAiB,CAAC,SAAS,EAAE,OAAO,IAAI,CAAC,UAAU,EAAE,KAAK,WAAW,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,eAAe,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;;QAE3J,QAAQ,MAAM;AACZ,YAAA,KAAK,GAAG;AACR,YAAA,KAAK,GAAG;AACR,YAAA,KAAK,GAAG;AACR,YAAA,KAAK,GAAG;AACN,gBAAA,UAAU,CAAC,IAAI,GAAG,WAAW;gBAC7B;AACF,YAAA;AACE,gBAAA,UAAU,CAAC,IAAI,GAAG,OAAO;;AAE7B,QAAA,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE,OAAO,IAAI,CAAC,UAAU,EAAE,KAAK,WAAW,IAAI,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC,MAAM,CAAC;;AAGjI,IAAA,iBAAiB,CAAC,IAA4C,EAAE,QAAgB,EAAE,QAAkB,EAAA;AAC1G,QAAA,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC;QACjC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,KAAK,KAAI;YACpC,IAAI,IAAI,EAAE;gBACR,KAAK,CAAC,MAAM,CAAC,QAAQ,IAAI,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC;;YAEtC,IAAI,CAAC,IAAI,EAAE;gBACT,KAAK,CAAC,MAAM,CAAC,QAAQ,IAAI,CAAC,EAAE,CAAC,CAAC;;AAGhC,YAAA,OAAO,CAAC,GAAG,KAAK,CAAC;AACnB,SAAC,CAAC;AAEF,QAAA,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,IAAG;YAC7B,IAAI,CAAC,IAAI,EAAE;gBACT,IAAI,KAAK,EAAE;AACT,oBAAA,KAAK,GAAG,QAAQ,GAAG,KAAK,GAAG,KAAK,GAAG,CAAC;;gBAGtC,OAAO,KAAK,GAAG,KAAK,GAAG,QAAQ;;AAEjC,YAAA,IAAI,OAAO,KAAK,KAAK,WAAW,EAAE;AAChC,gBAAA,KAAK,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC,MAAM;AAErC,gBAAA,OAAO,KAAK;;AAEd,YAAA,KAAK,EAAE;AAEP,YAAA,OAAO,KAAK;AACd,SAAC,CAAC;AACF,QAAA,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE;QAEpC,UAAU,CAAC,MAAK;AACd,YAAA,IAAI,OAAO,UAAU,KAAK,WAAW,EAAE;gBACrC,IAAI,CAAC,QAAQ,EAAE,CAAC,UAAU,CAAC,EAAE,aAAa,CAAC,KAAK,EAAE;;SAErD,EAAE,GAAG,CAAC;;AAGC,IAAA,sBAAsB,CAAC,KAAY,EAAA;AAC3C,QAAA,MAAM,OAAO,GAAI,KAAgB,CAAC,OAAO;AACzC,QAAA,MAAM,KAAK,GAAI,KAAgB,CAAC,MAAM,CAAC,KAAK;AAC5C,QAAA,MAAM,QAAQ,GAAI,KAAgB,CAAC,QAAQ;QAE3C,IAAI,CAAC,CAAC,CAAC,oBAAoB,CAAC,MAAM,EAAE,oBAAoB,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,QAAQ,MAAM,CAAC,oBAAoB,CAAC,IAAI,EAAE,oBAAoB,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;AAChN,YAAA,KAAgB,CAAC,MAAM,CAAC,KAAK,GAAG,EAAE;YAEnC,OAAO,IAAI,CAAC,iBAAiB,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC,MAAM,CAAC;;;AAI/G,IAAA,oBAAoB,CAAC,KAAY,EAAA;AACzC,QAAA,MAAM,OAAO,GAAI,KAAgB,CAAC,OAAO;AACzC,QAAA,MAAM,KAAK,GAAI,KAAgB,CAAC,MAAM,CAAC,KAAK;AAE5C,QAAA,IAAI,OAAO,KAAK,oBAAoB,CAAC,SAAS,EAAE;YAC9C,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,EAAE;AAC3E,gBAAA,OAAO,IAAI,CAAC,iBAAiB,CAAC,SAAS,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;;;AAG1E,QAAA,IAAI,OAAO,KAAK,oBAAoB,CAAC,MAAM,EAAE;YAC3C,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC,MAAM,EAAE;AACvG,gBAAA,OAAO,IAAI,CAAC,iBAAiB,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,GAAG,IAAI,CAAC;;;AAG5E,QAAA,IAAI,OAAO,KAAK,oBAAoB,CAAC,KAAK,EAAE;YAC1C,IAAI,KAAK,EAAE;AACR,gBAAA,KAAgB,CAAC,MAAM,CAAC,KAAK,GAAG,EAAE;gBAEnC,OAAO,IAAI,CAAC,iBAAiB,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC,MAAM,CAAC;;;;AAK7G,IAAA,wBAAwB,CAAC,KAAyB,EAAA;AAC1D,QAAA,IAAI,OAAO,KAAK,KAAK,WAAW,EAAE;AAChC,YAAA,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC;AAC1B,YAAA,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC;AACtB,YAAA,YAAY,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAE5B;;QAEF,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,MAAK;AAC/B,YAAA,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC;AACzB,SAAC,EAAE,GAAG,CAAC,CAAC;;AAGA,IAAA,iBAAiB,CAAC,KAAY,EAAA;QACtC,KAAK,CAAC,eAAe,EAAE;AACvB,QAAA,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE;AACnB,YAAA,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK,EAAE;;;AAI3D,IAAA,WAAW,CAAC,KAAY,EAAA;QAChC,KAAK,CAAC,eAAe,EAAE;AACvB,QAAA,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAC;AAClC,QAAA,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;;IAGzD,oBAAoB,CAAC,KAAwC,EAAE,KAAa,EAAA;AACpF,QAAA,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE;YACvB;;AAEF,QAAA,IAAI,KAAK,IAAI,CAAC,EAAE;AACd,YAAA,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,KAAK,IAAG;gBAClC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,KAAI;AACxB,oBAAA,IAAI,CAAC,KAAK,KAAK,EAAE;wBACf,IAAI,IAAI,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;4BAC/B,IAAI,CAAC,sBAAsB,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,oBAAoB,EAAE;;wBAElE,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAW;;AAEvC,iBAAC,CAAC;AAEF,gBAAA,OAAO,CAAC,GAAG,KAAK,CAAC;AACnB,aAAC,CAAC;YAEF;;QAEF,IAAI,CAAC,iBAAiB,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC,CAAW,EAAE,EAAE,OAAO,IAAI,CAAC,UAAU,EAAE,KAAK,WAAW,IAAI,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC,MAAM,CAAC;QAC7K,IAAI,CAAC,sBAAsB,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,oBAAoB,EAAE;;IAGxD,4BAA4B,CAAC,KAAmC,EAAE,KAAa,EAAA;AACvF,QAAA,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,KAAK,IAAG;AACzC,YAAA,KAAK,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC;AAEvB,YAAA,OAAO,KAAK;AACd,SAAC,CAAC;;wGAlLO,yCAAyC,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA;AAAzC,IAAA,OAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,SAAA,EAAA,IAAA,EAAA,yCAAyC,EC1BtD,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,sCAAA,EAAA,MAAA,EAAA,EAAA,WAAA,EAAA,EAAA,iBAAA,EAAA,aAAA,EAAA,UAAA,EAAA,aAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,MAAA,EAAA,EAAA,iBAAA,EAAA,QAAA,EAAA,UAAA,EAAA,QAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,WAAA,EAAA,EAAA,iBAAA,EAAA,aAAA,EAAA,UAAA,EAAA,aAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,eAAA,EAAA,EAAA,iBAAA,EAAA,iBAAA,EAAA,UAAA,EAAA,iBAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,WAAA,EAAA,EAAA,iBAAA,EAAA,aAAA,EAAA,UAAA,EAAA,aAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,gBAAA,EAAA,EAAA,iBAAA,EAAA,kBAAA,EAAA,UAAA,EAAA,kBAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,YAAA,EAAA,EAAA,iBAAA,EAAA,cAAA,EAAA,UAAA,EAAA,cAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,mBAAA,EAAA,EAAA,iBAAA,EAAA,qBAAA,EAAA,UAAA,EAAA,qBAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,oBAAA,EAAA,EAAA,iBAAA,EAAA,sBAAA,EAAA,UAAA,EAAA,sBAAA,EAAA,QAAA,EAAA,IAAA,EAAA,UAAA,EAAA,KAAA,EAAA,iBAAA,EAAA,IAAA,EAAA,EAAA,EAAA,OAAA,EAAA,EAAA,oBAAA,EAAA,sBAAA,EAAA,EAAA,WAAA,EAAA,CAAA,EAAA,YAAA,EAAA,UAAA,EAAA,SAAA,EAAA,CAAA,UAAA,CAAA,EAAA,WAAA,EAAA,IAAA,EAAA,QAAA,EAAA,IAAA,EAAA,CAAA,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,EAAA,qvVA+OA,ED9NI,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,UAAA,EAAA,IAAA,EAAA,eAAe,EACf,EAAA,EAAA,IAAA,EAAA,MAAA,EAAA,IAAA,EAAA,EAAA,CAAA,aAAA,EAAA,IAAA,EAAA,WAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,sCAAsC,EACtC,QAAA,EAAA,mCAAA,EAAA,MAAA,EAAA,CAAA,WAAA,EAAA,MAAA,EAAA,cAAA,EAAA,YAAA,EAAA,OAAA,EAAA,SAAA,EAAA,WAAA,EAAA,WAAA,EAAA,cAAA,EAAA,eAAA,EAAA,gBAAA,EAAA,YAAA,EAAA,cAAA,EAAA,SAAA,EAAA,4BAAA,EAAA,QAAA,EAAA,mBAAA,EAAA,eAAA,EAAA,aAAA,EAAA,yBAAA,EAAA,+BAAA,EAAA,oBAAA,EAAA,UAAA,CAAA,EAAA,OAAA,EAAA,CAAA,UAAA,EAAA,iBAAA,EAAA,qBAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,6BAA6B,EAC7B,QAAA,EAAA,yBAAA,EAAA,MAAA,EAAA,CAAA,mBAAA,EAAA,sBAAA,EAAA,WAAA,EAAA,iBAAA,EAAA,QAAA,EAAA,wCAAA,EAAA,gBAAA,EAAA,SAAA,EAAA,cAAA,EAAA,aAAA,EAAA,cAAA,EAAA,eAAA,EAAA,qBAAA,EAAA,YAAA,EAAA,cAAA,EAAA,yBAAA,EAAA,cAAA,EAAA,sBAAA,EAAA,aAAA,EAAA,aAAA,EAAA,kBAAA,EAAA,iBAAA,EAAA,gBAAA,EAAA,kBAAA,EAAA,2CAAA,EAAA,6BAAA,EAAA,eAAA,EAAA,oBAAA,EAAA,QAAA,EAAA,iBAAA,EAAA,yBAAA,EAAA,kCAAA,EAAA,iDAAA,CAAA,EAAA,OAAA,EAAA,CAAA,cAAA,EAAA,mBAAA,EAAA,qBAAA,EAAA,qBAAA,EAAA,aAAA,EAAA,eAAA,EAAA,cAAA,EAAA,YAAA,EAAA,qBAAA,EAAA,+BAAA,EAAA,sBAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,MAAA,EAAA,IAAA,EAAA,oDAAoD,EACpD,IAAA,EAAA,sDAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,gCAAgC,geAChC,iDAAiD,EAAA,IAAA,EAAA,mDAAA,EAAA,CAAA,EAAA,eAAA,EAAA,EAAA,CAAA,uBAAA,CAAA,MAAA,EAAA,CAAA;;4FAIxC,yCAAyC,EAAA,UAAA,EAAA,CAAA;kBAfrD,SAAS;+BAEE,sCAAsC,EAAA,UAAA,EAEpC,IAAI,EACP,OAAA,EAAA;wBACP,eAAe;wBACf,sCAAsC;wBACtC,6BAA6B;wBAC7B,oDAAoD;wBACpD,gCAAgC;wBAChC;qBACD,EACgB,eAAA,EAAA,uBAAuB,CAAC,MAAM,EAAA,QAAA,EAAA,qvVAAA,EAAA;;;AExBjD;;AAEG;;;;"}
|
|
1
|
+
{"version":3,"file":"libs-ui-components-inputs-calculator.mjs","sources":["../../../../../../libs-ui/components/inputs/calculator/src/pipes/get-field-selected.pipe.ts","../../../../../../libs-ui/components/inputs/calculator/src/pipes/get-width-input.pipe.ts","../../../../../../libs-ui/components/inputs/calculator/src/calculator.component.ts","../../../../../../libs-ui/components/inputs/calculator/src/calculator.component.html","../../../../../../libs-ui/components/inputs/calculator/src/libs-ui-components-inputs-calculator.ts"],"sourcesContent":["import { Pipe, PipeTransform } from '@angular/core';\nimport { IInputCalculatorField } from '../interfaces';\n\n@Pipe({\n name: 'LibsUiComponentsInputsCalculatorGetFieldSelectedPipe',\n standalone: true\n})\n\nexport class LibsUiComponentsInputsCalculatorGetFieldSelectedPipe implements PipeTransform {\n\n transform(fieldId: string | number, getFieldSelected?: (key: string) => IInputCalculatorField | undefined): IInputCalculatorField | undefined {\n\n\n return getFieldSelected?.(typeof fieldId === 'number' ? fieldId.toString() : fieldId);\n }\n\n}\n","import { Pipe, PipeTransform } from '@angular/core';\n\n@Pipe({\n name: 'LibsUiComponentsInputsCalculatorGetWidthInputPipe',\n standalone: true\n})\n\nexport class LibsUiComponentsInputsCalculatorGetWidthInputPipe implements PipeTransform {\n\n transform(text: string, element: HTMLDivElement): number {\n if (!text) {\n return 8;\n }\n const div = document.createElement('span');\n\n div.textContent = text;\n element.appendChild(div);\n const width = div.offsetWidth + 8;\n\n div.remove();\n\n return width;\n }\n\n}\n","import { ChangeDetectionStrategy, Component, ElementRef, input, OnInit, output, signal, viewChildren } from \"@angular/core\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';\nimport { IListDataEmitMultiKey, LibsUiComponentsListComponent } from '@libs-ui/components-list';\nimport { IInputCalculatorConfigField, IInputCalculatorExpression } from \"./interfaces\";\nimport { IEvent } from \"@libs-ui/interfaces-types\";\nimport { cloneDeep, UtilsKeyCodeConstant } from \"@libs-ui/utils\";\nimport { IPopoverFunctionControlEvent, LibsUiComponentsPopoverComponent } from \"@libs-ui/components-popover\";\nimport { LibsUiComponentsInputsCalculatorGetFieldSelectedPipe } from \"./pipes/get-field-selected.pipe\";\nimport { LibsUiComponentsInputsCalculatorGetWidthInputPipe } from \"./pipes/get-width-input.pipe\";\n\n@Component({\n // eslint-disable-next-line @angular-eslint/component-selector\n selector: 'libs_ui-components-inputs-calculator',\n templateUrl: './calculator.component.html',\n standalone: true,\n imports: [\n TranslateModule,\n LibsUiComponentsButtonsButtonComponent,\n LibsUiComponentsListComponent,\n LibsUiComponentsInputsCalculatorGetFieldSelectedPipe,\n LibsUiComponentsPopoverComponent,\n LibsUiComponentsInputsCalculatorGetWidthInputPipe\n ],\n changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class LibsUiComponentsInputsCalculatorComponent implements OnInit {\n protected indexFocus = signal<number | undefined>(undefined);\n protected isFocus = signal<boolean>(false);\n protected listExpressions = signal<Array<IInputCalculatorExpression>>([]);\n protected isChangeExpression = signal<boolean>(false);\n\n private inputRef = viewChildren<ElementRef>('inputRef');\n private timeOut = signal<number | undefined>(undefined);\n private tooltipFunctionControl = signal<Map<number, IPopoverFunctionControlEvent>>(new Map());\n\n readonly expressions = input<Array<IInputCalculatorExpression>>([]);\n readonly zIndex = input<number>(10);\n readonly placeholder = input<string>('i18n_enter_params');\n readonly labelButtonSave = input<string>('i18n_save_calculation');\n readonly configField = input<IInputCalculatorConfigField>();\n readonly ignoreButtonSave = input<boolean>(false);\n readonly classInclude = input<string, string | undefined>('', { transform: (value) => value || '' });\n readonly classContainerInput = input<string, string | undefined>('', { transform: (value) => value || '' });\n readonly classContainerButton = input<string, string | undefined>('', { transform: (value) => value || '' });\n\n readonly outChangeExpressions = output<Array<IInputCalculatorExpression>>();\n\n ngOnInit() {\n this.listExpressions.set(cloneDeep(this.expressions()));\n }\n\n protected handlerClick(event: Event, button: '+' | '-' | '*' | '/' | 'c' | '.' | '(' | ')' | '0' | '1' | '2' | '3' | '4' | '5' | '6' | '7' | '8' | '9') {\n event.stopPropagation();\n const expression: IInputCalculatorExpression = { type: 'field', data: button };\n\n if (button === 'c') {\n if (!this.listExpressions().length || this.indexFocus() === 0) {\n return;\n }\n return this.updateExpressions(undefined, typeof this.indexFocus() !== 'undefined' ? ((this.indexFocus() || 1) - 1) : (this.listExpressions().length - 1));\n }\n switch (button) {\n case '+':\n case '-':\n case '*':\n case '/':\n expression.type = 'operation';\n break;\n default:\n expression.type = 'value';\n }\n this.updateExpressions(expression, typeof this.indexFocus() !== 'undefined' ? (this.indexFocus() || 0) : this.listExpressions().length);\n }\n\n private updateExpressions(item: IInputCalculatorExpression | undefined, position: number, isDelete?: boolean) {\n this.isChangeExpression.set(true);\n this.listExpressions.update((value) => {\n if (item) {\n value.splice(position || 0, 0, item);\n }\n if (!item) {\n value.splice(position || 0, 1);\n }\n\n return [...value];\n })\n\n this.indexFocus.update(value => {\n if (!item) {\n if (value) {\n value = isDelete ? value : value - 1;\n }\n\n return value ? value : position;\n }\n if (typeof value === 'undefined') {\n value = this.listExpressions().length;\n\n return value;\n }\n value++;\n\n return value;\n })\n const indexFocus = this.indexFocus();\n\n setTimeout(() => {\n if (typeof indexFocus !== 'undefined') {\n this.inputRef()[indexFocus]?.nativeElement.focus();\n }\n }, 100)\n }\n\n protected handlerEventKeyUpInput(event: Event) {\n const keyCode = (event as IEvent).keyCode;\n const value = (event as IEvent).target.value;\n const shiftKey = (event as IEvent).shiftKey;\n\n if ((([UtilsKeyCodeConstant.EQUALS, UtilsKeyCodeConstant.EIGHT].includes(keyCode) && shiftKey) || ([UtilsKeyCodeConstant.DASH, UtilsKeyCodeConstant.SLASH].includes(keyCode) && !shiftKey)) && value.length === 1) {\n (event as IEvent).target.value = '';\n\n return this.updateExpressions({ type: 'operation', data: value }, this.indexFocus() || this.listExpressions().length);\n }\n }\n\n protected handlerEventKeyInput(event: Event) {\n const keyCode = (event as IEvent).keyCode;\n const value = (event as IEvent).target.value;\n\n if (keyCode === UtilsKeyCodeConstant.BACKSPACE) {\n if (!value && this.listExpressions().length && (this.indexFocus() || 0) > 0) {\n return this.updateExpressions(undefined, (this.indexFocus() || 0) - 1);\n }\n }\n if (keyCode === UtilsKeyCodeConstant.DELETE) {\n if (!value && this.listExpressions().length && (this.indexFocus() || 0) < this.listExpressions().length) {\n return this.updateExpressions(undefined, (this.indexFocus() || 0), true);\n }\n }\n if (keyCode === UtilsKeyCodeConstant.ENTER) {\n if (value) {\n (event as IEvent).target.value = '';\n\n return this.updateExpressions({ type: 'value', data: value }, this.indexFocus() || this.listExpressions().length);\n }\n }\n }\n\n protected handlerFocusAndBlurInput(index: number | undefined) {\n if (typeof index !== 'undefined') {\n this.indexFocus.set(index);\n this.isFocus.set(true);\n clearTimeout(this.timeOut());\n\n return;\n }\n this.timeOut.set(setTimeout(() => {\n this.isFocus.set(false);\n }, 250))\n }\n\n protected handlerClickInput(event: Event) {\n event.stopPropagation();\n if (!this.isFocus()) {\n this.inputRef()[this.inputRef().length - 1].nativeElement.focus();\n }\n }\n\n protected handlerSave(event: Event) {\n event.stopPropagation();\n this.isChangeExpression.set(false);\n this.outChangeExpressions.emit(cloneDeep(this.listExpressions()));\n }\n\n protected handlerSelectedField(event: IListDataEmitMultiKey | undefined, index: number) {\n if (!event?.keys.length) {\n return;\n }\n if (index >= 0) {\n this.listExpressions.update(value => {\n value.forEach((item, i) => {\n if (i === index) {\n if (item.data !== event.keys[0]) {\n this.tooltipFunctionControl().get(index)?.removePopoverOverlay();\n }\n item.data = event.keys[0] as string\n }\n })\n\n return [...value];\n })\n\n return;\n }\n this.updateExpressions({ type: 'field', data: event.keys[0] as string }, typeof this.indexFocus() !== 'undefined' ? (this.indexFocus() || 0) : this.listExpressions().length);\n this.tooltipFunctionControl().get(index)?.removePopoverOverlay();\n }\n\n protected handlerFunctionControlButton(event: IPopoverFunctionControlEvent, index: number) {\n this.tooltipFunctionControl.update(value => {\n value.set(index, event);\n\n return value;\n })\n }\n}","<div class=\"w-full\">\n <div class=\"p-[8px] rounded-[12px] bg-[#f8f9fa] {{ classInclude() }}\">\n <div #calculatorInput\n class=\"py-[10px] px-[12px] libs-ui-font-h5r rounded-[8px] bg-[#ffffff] min-h-[160px] mb-[8px] border-[1px] {{ isFocus() ? 'border-[var(--libs-ui-color-light-1)]' : 'border-[#ffffff]' }} {{ classContainerInput() }}\"\n (mouseup)=\"handlerClickInput($event)\">\n <ul class=\"before:content-[''] before:table after:content-[''] after:table after:clear-both\">\n @for (item of listExpressions(); track $index; let i = $index) {\n <li class=\"float-left mb-[8px]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none text-center\"\n [class.ml-[-8px]]=\"i === 0\"\n [style.width.px]=\"inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(i)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n @switch (item.type) {\n @case ('operation') {\n <li class=\"float-left mb-[8px] text-center w-[24px] rounded-[4px] p-[4px] bg-[var(--libs-ui-color-light-2)]\">{{ item.data }}</li>\n }\n @case ('value') {\n <li class=\"float-left mb-[8px] text-center rounded-[4px] py-[4px] px-[8px] bg-[#E6E7EA] flex max-w-[calc(100%-8px)]\">\n <libs_ui-components-popover [type]=\"'text'\">{{ item.data }}</libs_ui-components-popover>\n </li>\n }\n @case ('field') {\n @if (item.data | LibsUiComponentsInputsCalculatorGetFieldSelectedPipe:configField()?.getFieldSelected; as fieldSelected) {\n <li class=\"float-left mb-[8px]\">\n <libs_ui-components-buttons-button class=\"max-w-[150px] block\"\n [label]=\"fieldSelected.name || ''\"\n [classInclude]=\"'!justify-center !py-[3px] !px-[7px] !w-full'\"\n [classIconLeft]=\"fieldSelected.icon || ''\"\n [classIconRight]=\"'libs-ui-icon-move-right rotate-90'\"\n [classLabel]=\"'libs-ui-font-h5r'\"\n [zIndex]=\" zIndex()\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:false,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: i, key: item.data},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, i)\" />\n </li>\n }\n }\n }\n }\n <li class=\"float-left mb-[8px] max-w-[100%]\">\n <input #inputRef\n type=\"text\"\n class=\"inline-block h-[24px] outline-none max-w-[100%] {{ listExpressions().length ? 'text-center' : '' }}\"\n [style.width.px]=\"listExpressions().length ? (inputRef.value | LibsUiComponentsInputsCalculatorGetWidthInputPipe:calculatorInput) : 150\"\n [placeholder]=\"!listExpressions().length ? (placeholder() | translate) : ''\"\n (keydown)=\"handlerEventKeyInput($event)\"\n (keyup)=\"handlerEventKeyUpInput($event)\"\n (focus)=\"handlerFocusAndBlurInput(listExpressions().length)\"\n (blur)=\"handlerFocusAndBlurInput(undefined)\" />\n </li>\n </ul>\n </div>\n <div class=\"grid grid-cols-4 gap-[8px] {{ classContainerButton() }}\">\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"configField()?.label || 'i18n_select_field'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n zIndex: zIndex(),\n animationConfig: {},\n widthByParent:true,\n parentBorderWidth: 0,\n maxHeight:2048,\n maxWidth: 2048,\n direction: 'bottom',\n directionDistance:2,\n template: listViewRef,\n itemContext: {index: -1},\n whiteTheme:true,\n ignoreArrow:true,\n classInclude:'!rounded-[4px] !w-[272px]',\n position:{ mode:'start',distance:0 },\n }\n }\"\n (outFunctionsControl)=\"handlerFunctionControlButton($event, -1)\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-violet'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'Fx'\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-danger-high'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'C'\"\n (outClick)=\"handlerClick($event, 'c')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'('\"\n (outClick)=\"handlerClick($event, '(')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"')'\"\n (outClick)=\"handlerClick($event, ')')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'/'\"\n (outClick)=\"handlerClick($event, '/')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'1'\"\n (outClick)=\"handlerClick($event, '1')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'2'\"\n (outClick)=\"handlerClick($event, '2')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'3'\"\n (outClick)=\"handlerClick($event, '3')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-close'\"\n (outClick)=\"handlerClick($event, '*')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'4'\"\n (outClick)=\"handlerClick($event, '4')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'5'\"\n (outClick)=\"handlerClick($event, '5')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'6'\"\n (outClick)=\"handlerClick($event, '6')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'-'\"\n (outClick)=\"handlerClick($event, '-')\" />\n </div>\n <div class=\"col-[1]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'7'\"\n (outClick)=\"handlerClick($event, '7')\" />\n </div>\n <div class=\"col-[2]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'8'\"\n (outClick)=\"handlerClick($event, '8')\" />\n </div>\n <div class=\"col-[3]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'9'\"\n (outClick)=\"handlerClick($event, '9')\" />\n </div>\n <div class=\"col-[4]\">\n <libs_ui-components-buttons-button [type]=\"'button-secondary'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-add'\"\n (outClick)=\"handlerClick($event, '+')\" />\n </div>\n <div class=\"col-[1/4]\">\n <libs_ui-components-buttons-button [label]=\"'0'\"\n [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n (outClick)=\"handlerClick($event, '0')\" />\n </div>\n <div class=\"col-[4/4]\">\n <libs_ui-components-buttons-button [type]=\"'button-third'\"\n [classInclude]=\"'!w-full !justify-center'\"\n [label]=\"'.'\"\n (outClick)=\"handlerClick($event, '.')\" />\n </div>\n </div>\n </div>\n @if (!ignoreButtonSave()) {\n <div class=\"mt-[16px]\">\n <libs_ui-components-buttons-button [label]=\"labelButtonSave()\"\n [disable]=\"!isChangeExpression()\"\n [classInclude]=\"'justify-center w-full'\"\n (outClick)=\"handlerSave($event)\" />\n </div>\n }\n</div>\n\n<ng-template #listViewRef\n let-data='itemContext'>\n <libs_ui-components-list [zIndex]=\"zIndex()\"\n [config]=\"configField()?.listConfig\"\n [maxItemShow]=\"6\"\n [clickExactly]=\"false\"\n [searchConfig]=\"{noBorder: true, placeholder: configField()?.placeholderInputList || 'i18n_search'}\"\n [multiKeySelected]=\"data.key ? [data.key] : []\"\n (outSelectMultiKey)=\"handlerSelectedField($event, data.index)\">\n </libs_ui-components-list>\n</ng-template>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libs-ui/components-inputs-calculator",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.177",
|
|
4
4
|
"peerDependencies": {
|
|
5
5
|
"@angular/core": "^18.2.0",
|
|
6
6
|
"@ngx-translate/core": "^15.0.0",
|
|
7
|
-
"@libs-ui/components-buttons-button": "^0.2.
|
|
8
|
-
"@libs-ui/components-list": "^0.2.
|
|
9
|
-
"@libs-ui/interfaces-types": "^0.2.
|
|
10
|
-
"@libs-ui/utils": "^0.2.
|
|
11
|
-
"@libs-ui/components-popover": "^0.2.
|
|
7
|
+
"@libs-ui/components-buttons-button": "^0.2.177",
|
|
8
|
+
"@libs-ui/components-list": "^0.2.177",
|
|
9
|
+
"@libs-ui/interfaces-types": "^0.2.177",
|
|
10
|
+
"@libs-ui/utils": "^0.2.177",
|
|
11
|
+
"@libs-ui/components-popover": "^0.2.177"
|
|
12
12
|
},
|
|
13
13
|
"sideEffects": false,
|
|
14
14
|
"module": "fesm2022/libs-ui-components-inputs-calculator.mjs",
|