@leanix/components 0.2.229 → 0.2.232
Sign up to get free protection for your applications and to get access to all the features.
- package/esm2020/index.mjs +119 -0
- package/esm2020/leanix-components.mjs +5 -0
- package/esm2020/lib/core-ui/annotations/required.mjs +33 -0
- package/esm2020/lib/core-ui/components/badge/badge.component.mjs +25 -0
- package/esm2020/lib/core-ui/components/button/button.component.mjs +72 -0
- package/esm2020/lib/core-ui/components/button-group/button-group.component.mjs +28 -0
- package/esm2020/lib/core-ui/components/card/card.component.mjs +19 -0
- package/esm2020/lib/core-ui/components/collapsible/collapsible.component.mjs +53 -0
- package/esm2020/lib/core-ui/components/colored-label/colored-label.component.mjs +34 -0
- package/esm2020/lib/core-ui/components/ellipsis/ellipsis.component.mjs +70 -0
- package/esm2020/lib/core-ui/components/icon-scale/icon-scale.component.mjs +40 -0
- package/esm2020/lib/core-ui/components/spinner/spinner.component.mjs +26 -0
- package/esm2020/lib/core-ui/components/table/table-header/table-header.component.mjs +55 -0
- package/esm2020/lib/core-ui/components/table/table.component.mjs +69 -0
- package/esm2020/lib/core-ui/components/tiny-spinner/tiny-spinner.component.mjs +11 -0
- package/esm2020/lib/core-ui/core-ui.constants.mjs +13 -0
- package/esm2020/lib/core-ui/core-ui.module.mjs +177 -0
- package/esm2020/lib/core-ui/directives/after-view-init.directive.mjs +30 -0
- package/esm2020/lib/core-ui/directives/autoclose-group.service.mjs +38 -0
- package/esm2020/lib/core-ui/directives/autoclose.directive.mjs +40 -0
- package/esm2020/lib/core-ui/directives/autofocus.directive.mjs +27 -0
- package/esm2020/lib/core-ui/directives/html.directive.mjs +29 -0
- package/esm2020/lib/core-ui/functions/core-css.helpers.mjs +35 -0
- package/esm2020/lib/core-ui/pipes/br.pipe.mjs +23 -0
- package/esm2020/lib/core-ui/pipes/contrast-color.pipe.mjs +20 -0
- package/esm2020/lib/core-ui/pipes/custom-date.pipe.mjs +27 -0
- package/esm2020/lib/core-ui/pipes/highlight-range.pipe.mjs +21 -0
- package/esm2020/lib/core-ui/pipes/highlight-term.pipe.mjs +38 -0
- package/esm2020/lib/core-ui/pipes/lx-is-uuid.pipe.mjs +21 -0
- package/esm2020/lib/core-ui/pipes/lx-time-ago.pipe.mjs +25 -0
- package/esm2020/lib/core-ui/pipes/lx-translate.pipe.mjs +45 -0
- package/esm2020/lib/core-ui/pipes/markdown.pipe.mjs +29 -0
- package/esm2020/lib/core-ui/pipes/nbsp.pipe.mjs +14 -0
- package/esm2020/lib/core-ui/pipes/sort.pipe.mjs +52 -0
- package/esm2020/lib/core-ui/pipes/translation-after.pipe.mjs +28 -0
- package/esm2020/lib/core-ui/pipes/translation-before.pipe.mjs +53 -0
- package/esm2020/lib/core-ui/pipes/translation-between.pipe.mjs +67 -0
- package/esm2020/lib/core-ui/pipes/unescape-curly-braces.pipe.mjs +16 -0
- package/esm2020/lib/core-ui/tooltip/to-cdk-position.function.mjs +74 -0
- package/esm2020/lib/core-ui/tooltip/tooltip-position.interface.mjs +7 -0
- package/esm2020/lib/core-ui/tooltip/tooltip.component.mjs +26 -0
- package/esm2020/lib/core-ui/tooltip/tooltip.directive.mjs +102 -0
- package/esm2020/lib/core-ui/tooltip/tooltip.module.mjs +21 -0
- package/esm2020/lib/forms-ui/components/basic-dropdown/basic-dropdown.component.mjs +103 -0
- package/esm2020/lib/forms-ui/components/basic-dropdown-item/basic-dropdown-item.component.mjs +33 -0
- package/esm2020/lib/forms-ui/components/cdk-options-dropdown/cdk-options-dropdown.component.mjs +216 -0
- package/esm2020/lib/forms-ui/components/cdk-options-sub-dropdown/cdk-options-sub-dropdown.component.mjs +136 -0
- package/esm2020/lib/forms-ui/components/currency/currency-input.component.mjs +141 -0
- package/esm2020/lib/forms-ui/components/currency/currency-symbol-map.constant.mjs +105 -0
- package/esm2020/lib/forms-ui/components/currency/currency-symbol.component.mjs +25 -0
- package/esm2020/lib/forms-ui/components/date-input/date-input.component.mjs +270 -0
- package/esm2020/lib/forms-ui/components/drag-and-drop-list/constants.mjs +5 -0
- package/esm2020/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list-item/drag-and-drop-list-item.component.mjs +49 -0
- package/esm2020/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.component.mjs +102 -0
- package/esm2020/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.module.mjs +25 -0
- package/esm2020/lib/forms-ui/components/drag-and-drop-list/keyboard-sortable-item/keyboard-sortable-item.directive.mjs +133 -0
- package/esm2020/lib/forms-ui/components/drag-and-drop-list/keyboard-sortable-list/keyboard-sortable-list.directive.mjs +37 -0
- package/esm2020/lib/forms-ui/components/error-message/error-message.component.mjs +24 -0
- package/esm2020/lib/forms-ui/components/form-error/form-error.component.mjs +40 -0
- package/esm2020/lib/forms-ui/components/icon/icon.component.mjs +44 -0
- package/esm2020/lib/forms-ui/components/input/input.component.mjs +44 -0
- package/esm2020/lib/forms-ui/components/keyboard-select.directive.mjs +116 -0
- package/esm2020/lib/forms-ui/components/multi-select/multi-select.component.mjs +251 -0
- package/esm2020/lib/forms-ui/components/option/option.component.mjs +81 -0
- package/esm2020/lib/forms-ui/components/option-group/option-group.component.mjs +29 -0
- package/esm2020/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.mjs +100 -0
- package/esm2020/lib/forms-ui/components/options-dropdown/options-dropdown.component.mjs +163 -0
- package/esm2020/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.mjs +92 -0
- package/esm2020/lib/forms-ui/components/picker/picker-trigger.directive.mjs +36 -0
- package/esm2020/lib/forms-ui/components/picker/picker.component.mjs +201 -0
- package/esm2020/lib/forms-ui/components/picker-option/picker-option.component.mjs +118 -0
- package/esm2020/lib/forms-ui/components/pill-item/pill-item.component.mjs +33 -0
- package/esm2020/lib/forms-ui/components/pill-list/pill-list.component.mjs +59 -0
- package/esm2020/lib/forms-ui/components/responsive-input/responsive-input.component.mjs +97 -0
- package/esm2020/lib/forms-ui/components/single-select/single-select.component.mjs +274 -0
- package/esm2020/lib/forms-ui/components/slider-toggle/slider-toggle.component.mjs +42 -0
- package/esm2020/lib/forms-ui/components/sorting-dropdown/sorting-dropdown.component.mjs +52 -0
- package/esm2020/lib/forms-ui/components/sorting-dropdown-trigger/sorting-dropdown-trigger.component.mjs +21 -0
- package/esm2020/lib/forms-ui/directives/form-error.directive.mjs +109 -0
- package/esm2020/lib/forms-ui/directives/form-submit.directive.mjs +28 -0
- package/esm2020/lib/forms-ui/directives/keyboard-action-source.directive.mjs +53 -0
- package/esm2020/lib/forms-ui/directives/mark-invalid.directive.mjs +38 -0
- package/esm2020/lib/forms-ui/directives/select-dropdown.directive.mjs +31 -0
- package/esm2020/lib/forms-ui/directives/selectable-item.directive.mjs +33 -0
- package/esm2020/lib/forms-ui/directives/selected-option.directive.mjs +26 -0
- package/esm2020/lib/forms-ui/forms-ui.module.mjs +236 -0
- package/esm2020/lib/forms-ui/helpers/key-codes.constants.mjs +11 -0
- package/esm2020/lib/forms-ui/helpers/keyboard-navigation.helpers.mjs +38 -0
- package/esm2020/lib/forms-ui/models/base-select.directive.mjs +148 -0
- package/esm2020/lib/forms-ui/models/dropdown-item.interface.mjs +2 -0
- package/esm2020/lib/forms-ui/models/single-select-padding.interface.mjs +2 -0
- package/esm2020/lib/forms-ui/models/sorting.interface.mjs +7 -0
- package/esm2020/lib/forms-ui/pipes/filter-selection.pipe.mjs +30 -0
- package/esm2020/lib/forms-ui/pipes/filter-term.pipe.mjs +26 -0
- package/esm2020/lib/forms-ui/pipes/format-number.pipe.mjs +65 -0
- package/esm2020/lib/forms-ui/validators/date-in-foreseeable-future.validator.mjs +26 -0
- package/esm2020/lib/modal-ui/components/modal/modal.component.mjs +205 -0
- package/esm2020/lib/modal-ui/components/modal-footer/modal-footer.component.mjs +11 -0
- package/esm2020/lib/modal-ui/components/modal-header/modal-header.component.mjs +23 -0
- package/esm2020/lib/modal-ui/directives/modal-content.directive.mjs +13 -0
- package/esm2020/lib/modal-ui/modal.constants.mjs +3 -0
- package/esm2020/lib/modal-ui/modal.module.mjs +26 -0
- package/esm2020/lib/popover-ui/components/popover/popover.component.mjs +199 -0
- package/esm2020/lib/popover-ui/directives/popover-click.directive.mjs +51 -0
- package/esm2020/lib/popover-ui/directives/popover-content.directive.mjs +16 -0
- package/esm2020/lib/popover-ui/directives/popover-hover.directive.mjs +87 -0
- package/esm2020/lib/popover-ui/popover-ui.module.mjs +22 -0
- package/esm2020/lib/shared/date-helpers.mjs +35 -0
- package/esm2020/lib/shared/misc-helpers.mjs +34 -0
- package/esm2020/lib/shared/observe.mjs +40 -0
- package/esm2020/lib/tab-ui/components/tab/tab.component.mjs +70 -0
- package/esm2020/lib/tab-ui/components/tab-group/tab-group.component.mjs +71 -0
- package/esm2020/lib/tab-ui/tab-ui.module.mjs +22 -0
- package/fesm2015/{leanix-components.js → leanix-components.mjs} +436 -633
- package/fesm2015/leanix-components.mjs.map +1 -0
- package/fesm2020/leanix-components.mjs +6207 -0
- package/fesm2020/leanix-components.mjs.map +1 -0
- package/package.json +23 -9
- package/bundles/leanix-components.umd.js +0 -7364
- package/bundles/leanix-components.umd.js.map +0 -1
- package/esm2015/index.js +0 -119
- package/esm2015/index.js.map +0 -1
- package/esm2015/leanix-components.js +0 -5
- package/esm2015/leanix-components.js.map +0 -1
- package/esm2015/lib/core-ui/annotations/required.js +0 -33
- package/esm2015/lib/core-ui/annotations/required.js.map +0 -1
- package/esm2015/lib/core-ui/components/badge/badge.component.js +0 -29
- package/esm2015/lib/core-ui/components/badge/badge.component.js.map +0 -1
- package/esm2015/lib/core-ui/components/button/button.component.js +0 -78
- package/esm2015/lib/core-ui/components/button/button.component.js.map +0 -1
- package/esm2015/lib/core-ui/components/button-group/button-group.component.js +0 -32
- package/esm2015/lib/core-ui/components/button-group/button-group.component.js.map +0 -1
- package/esm2015/lib/core-ui/components/card/card.component.js +0 -23
- package/esm2015/lib/core-ui/components/card/card.component.js.map +0 -1
- package/esm2015/lib/core-ui/components/collapsible/collapsible.component.js +0 -58
- package/esm2015/lib/core-ui/components/collapsible/collapsible.component.js.map +0 -1
- package/esm2015/lib/core-ui/components/colored-label/colored-label.component.js +0 -39
- package/esm2015/lib/core-ui/components/colored-label/colored-label.component.js.map +0 -1
- package/esm2015/lib/core-ui/components/ellipsis/ellipsis.component.js +0 -74
- package/esm2015/lib/core-ui/components/ellipsis/ellipsis.component.js.map +0 -1
- package/esm2015/lib/core-ui/components/icon-scale/icon-scale.component.js +0 -46
- package/esm2015/lib/core-ui/components/icon-scale/icon-scale.component.js.map +0 -1
- package/esm2015/lib/core-ui/components/spinner/spinner.component.js +0 -30
- package/esm2015/lib/core-ui/components/spinner/spinner.component.js.map +0 -1
- package/esm2015/lib/core-ui/components/table/table-header/table-header.component.js +0 -60
- package/esm2015/lib/core-ui/components/table/table-header/table-header.component.js.map +0 -1
- package/esm2015/lib/core-ui/components/table/table.component.js +0 -70
- package/esm2015/lib/core-ui/components/table/table.component.js.map +0 -1
- package/esm2015/lib/core-ui/components/tiny-spinner/tiny-spinner.component.js +0 -14
- package/esm2015/lib/core-ui/components/tiny-spinner/tiny-spinner.component.js.map +0 -1
- package/esm2015/lib/core-ui/core-ui.constants.js +0 -13
- package/esm2015/lib/core-ui/core-ui.constants.js.map +0 -1
- package/esm2015/lib/core-ui/core-ui.module.js +0 -177
- package/esm2015/lib/core-ui/core-ui.module.js.map +0 -1
- package/esm2015/lib/core-ui/directives/after-view-init.directive.js +0 -30
- package/esm2015/lib/core-ui/directives/after-view-init.directive.js.map +0 -1
- package/esm2015/lib/core-ui/directives/autoclose-group.service.js +0 -38
- package/esm2015/lib/core-ui/directives/autoclose-group.service.js.map +0 -1
- package/esm2015/lib/core-ui/directives/autoclose.directive.js +0 -40
- package/esm2015/lib/core-ui/directives/autoclose.directive.js.map +0 -1
- package/esm2015/lib/core-ui/directives/autofocus.directive.js +0 -27
- package/esm2015/lib/core-ui/directives/autofocus.directive.js.map +0 -1
- package/esm2015/lib/core-ui/directives/html.directive.js +0 -30
- package/esm2015/lib/core-ui/directives/html.directive.js.map +0 -1
- package/esm2015/lib/core-ui/functions/core-css.helpers.js +0 -35
- package/esm2015/lib/core-ui/functions/core-css.helpers.js.map +0 -1
- package/esm2015/lib/core-ui/pipes/br.pipe.js +0 -23
- package/esm2015/lib/core-ui/pipes/br.pipe.js.map +0 -1
- package/esm2015/lib/core-ui/pipes/contrast-color.pipe.js +0 -20
- package/esm2015/lib/core-ui/pipes/contrast-color.pipe.js.map +0 -1
- package/esm2015/lib/core-ui/pipes/custom-date.pipe.js +0 -27
- package/esm2015/lib/core-ui/pipes/custom-date.pipe.js.map +0 -1
- package/esm2015/lib/core-ui/pipes/highlight-range.pipe.js +0 -21
- package/esm2015/lib/core-ui/pipes/highlight-range.pipe.js.map +0 -1
- package/esm2015/lib/core-ui/pipes/highlight-term.pipe.js +0 -38
- package/esm2015/lib/core-ui/pipes/highlight-term.pipe.js.map +0 -1
- package/esm2015/lib/core-ui/pipes/lx-is-uuid.pipe.js +0 -21
- package/esm2015/lib/core-ui/pipes/lx-is-uuid.pipe.js.map +0 -1
- package/esm2015/lib/core-ui/pipes/lx-time-ago.pipe.js +0 -25
- package/esm2015/lib/core-ui/pipes/lx-time-ago.pipe.js.map +0 -1
- package/esm2015/lib/core-ui/pipes/lx-translate.pipe.js +0 -46
- package/esm2015/lib/core-ui/pipes/lx-translate.pipe.js.map +0 -1
- package/esm2015/lib/core-ui/pipes/markdown.pipe.js +0 -29
- package/esm2015/lib/core-ui/pipes/markdown.pipe.js.map +0 -1
- package/esm2015/lib/core-ui/pipes/nbsp.pipe.js +0 -14
- package/esm2015/lib/core-ui/pipes/nbsp.pipe.js.map +0 -1
- package/esm2015/lib/core-ui/pipes/sort.pipe.js +0 -52
- package/esm2015/lib/core-ui/pipes/sort.pipe.js.map +0 -1
- package/esm2015/lib/core-ui/pipes/translation-after.pipe.js +0 -28
- package/esm2015/lib/core-ui/pipes/translation-after.pipe.js.map +0 -1
- package/esm2015/lib/core-ui/pipes/translation-before.pipe.js +0 -53
- package/esm2015/lib/core-ui/pipes/translation-before.pipe.js.map +0 -1
- package/esm2015/lib/core-ui/pipes/translation-between.pipe.js +0 -67
- package/esm2015/lib/core-ui/pipes/translation-between.pipe.js.map +0 -1
- package/esm2015/lib/core-ui/pipes/unescape-curly-braces.pipe.js +0 -16
- package/esm2015/lib/core-ui/pipes/unescape-curly-braces.pipe.js.map +0 -1
- package/esm2015/lib/core-ui/tooltip/to-cdk-position.function.js +0 -74
- package/esm2015/lib/core-ui/tooltip/to-cdk-position.function.js.map +0 -1
- package/esm2015/lib/core-ui/tooltip/tooltip-position.interface.js +0 -7
- package/esm2015/lib/core-ui/tooltip/tooltip-position.interface.js.map +0 -1
- package/esm2015/lib/core-ui/tooltip/tooltip.component.js +0 -30
- package/esm2015/lib/core-ui/tooltip/tooltip.component.js.map +0 -1
- package/esm2015/lib/core-ui/tooltip/tooltip.directive.js +0 -107
- package/esm2015/lib/core-ui/tooltip/tooltip.directive.js.map +0 -1
- package/esm2015/lib/core-ui/tooltip/tooltip.module.js +0 -21
- package/esm2015/lib/core-ui/tooltip/tooltip.module.js.map +0 -1
- package/esm2015/lib/forms-ui/components/basic-dropdown/basic-dropdown.component.js +0 -108
- package/esm2015/lib/forms-ui/components/basic-dropdown/basic-dropdown.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/basic-dropdown-item/basic-dropdown-item.component.js +0 -38
- package/esm2015/lib/forms-ui/components/basic-dropdown-item/basic-dropdown-item.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/cdk-options-dropdown/cdk-options-dropdown.component.js +0 -223
- package/esm2015/lib/forms-ui/components/cdk-options-dropdown/cdk-options-dropdown.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/cdk-options-sub-dropdown/cdk-options-sub-dropdown.component.js +0 -140
- package/esm2015/lib/forms-ui/components/cdk-options-sub-dropdown/cdk-options-sub-dropdown.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/currency/currency-input.component.js +0 -147
- package/esm2015/lib/forms-ui/components/currency/currency-input.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/currency/currency-symbol-map.constant.js +0 -105
- package/esm2015/lib/forms-ui/components/currency/currency-symbol-map.constant.js.map +0 -1
- package/esm2015/lib/forms-ui/components/currency/currency-symbol.component.js +0 -28
- package/esm2015/lib/forms-ui/components/currency/currency-symbol.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/date-input/date-input.component.js +0 -276
- package/esm2015/lib/forms-ui/components/date-input/date-input.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/drag-and-drop-list/constants.js +0 -5
- package/esm2015/lib/forms-ui/components/drag-and-drop-list/constants.js.map +0 -1
- package/esm2015/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list-item/drag-and-drop-list-item.component.js +0 -54
- package/esm2015/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list-item/drag-and-drop-list-item.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.component.js +0 -107
- package/esm2015/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.module.js +0 -25
- package/esm2015/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.module.js.map +0 -1
- package/esm2015/lib/forms-ui/components/drag-and-drop-list/keyboard-sortable-item/keyboard-sortable-item.directive.js +0 -133
- package/esm2015/lib/forms-ui/components/drag-and-drop-list/keyboard-sortable-item/keyboard-sortable-item.directive.js.map +0 -1
- package/esm2015/lib/forms-ui/components/drag-and-drop-list/keyboard-sortable-list/keyboard-sortable-list.directive.js +0 -37
- package/esm2015/lib/forms-ui/components/drag-and-drop-list/keyboard-sortable-list/keyboard-sortable-list.directive.js.map +0 -1
- package/esm2015/lib/forms-ui/components/error-message/error-message.component.js +0 -29
- package/esm2015/lib/forms-ui/components/error-message/error-message.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/form-error/form-error.component.js +0 -44
- package/esm2015/lib/forms-ui/components/form-error/form-error.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/icon/icon.component.js +0 -49
- package/esm2015/lib/forms-ui/components/icon/icon.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/input/input.component.js +0 -51
- package/esm2015/lib/forms-ui/components/input/input.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/keyboard-select.directive.js +0 -117
- package/esm2015/lib/forms-ui/components/keyboard-select.directive.js.map +0 -1
- package/esm2015/lib/forms-ui/components/multi-select/multi-select.component.js +0 -257
- package/esm2015/lib/forms-ui/components/multi-select/multi-select.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/option/option.component.js +0 -85
- package/esm2015/lib/forms-ui/components/option/option.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/option-group/option-group.component.js +0 -34
- package/esm2015/lib/forms-ui/components/option-group/option-group.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.js +0 -105
- package/esm2015/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/options-dropdown/options-dropdown.component.js +0 -169
- package/esm2015/lib/forms-ui/components/options-dropdown/options-dropdown.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.js +0 -96
- package/esm2015/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/picker/picker-trigger.directive.js +0 -36
- package/esm2015/lib/forms-ui/components/picker/picker-trigger.directive.js.map +0 -1
- package/esm2015/lib/forms-ui/components/picker/picker.component.js +0 -210
- package/esm2015/lib/forms-ui/components/picker/picker.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/picker-option/picker-option.component.js +0 -124
- package/esm2015/lib/forms-ui/components/picker-option/picker-option.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/pill-item/pill-item.component.js +0 -37
- package/esm2015/lib/forms-ui/components/pill-item/pill-item.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/pill-list/pill-list.component.js +0 -64
- package/esm2015/lib/forms-ui/components/pill-list/pill-list.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/responsive-input/responsive-input.component.js +0 -104
- package/esm2015/lib/forms-ui/components/responsive-input/responsive-input.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/single-select/single-select.component.js +0 -279
- package/esm2015/lib/forms-ui/components/single-select/single-select.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/slider-toggle/slider-toggle.component.js +0 -47
- package/esm2015/lib/forms-ui/components/slider-toggle/slider-toggle.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/sorting-dropdown/sorting-dropdown.component.js +0 -56
- package/esm2015/lib/forms-ui/components/sorting-dropdown/sorting-dropdown.component.js.map +0 -1
- package/esm2015/lib/forms-ui/components/sorting-dropdown-trigger/sorting-dropdown-trigger.component.js +0 -25
- package/esm2015/lib/forms-ui/components/sorting-dropdown-trigger/sorting-dropdown-trigger.component.js.map +0 -1
- package/esm2015/lib/forms-ui/directives/form-error.directive.js +0 -111
- package/esm2015/lib/forms-ui/directives/form-error.directive.js.map +0 -1
- package/esm2015/lib/forms-ui/directives/form-submit.directive.js +0 -28
- package/esm2015/lib/forms-ui/directives/form-submit.directive.js.map +0 -1
- package/esm2015/lib/forms-ui/directives/keyboard-action-source.directive.js +0 -53
- package/esm2015/lib/forms-ui/directives/keyboard-action-source.directive.js.map +0 -1
- package/esm2015/lib/forms-ui/directives/mark-invalid.directive.js +0 -38
- package/esm2015/lib/forms-ui/directives/mark-invalid.directive.js.map +0 -1
- package/esm2015/lib/forms-ui/directives/select-dropdown.directive.js +0 -31
- package/esm2015/lib/forms-ui/directives/select-dropdown.directive.js.map +0 -1
- package/esm2015/lib/forms-ui/directives/selectable-item.directive.js +0 -33
- package/esm2015/lib/forms-ui/directives/selectable-item.directive.js.map +0 -1
- package/esm2015/lib/forms-ui/directives/selected-option.directive.js +0 -26
- package/esm2015/lib/forms-ui/directives/selected-option.directive.js.map +0 -1
- package/esm2015/lib/forms-ui/forms-ui.module.js +0 -236
- package/esm2015/lib/forms-ui/forms-ui.module.js.map +0 -1
- package/esm2015/lib/forms-ui/helpers/key-codes.constants.js +0 -11
- package/esm2015/lib/forms-ui/helpers/key-codes.constants.js.map +0 -1
- package/esm2015/lib/forms-ui/helpers/keyboard-navigation.helpers.js +0 -38
- package/esm2015/lib/forms-ui/helpers/keyboard-navigation.helpers.js.map +0 -1
- package/esm2015/lib/forms-ui/models/base-select.directive.js +0 -148
- package/esm2015/lib/forms-ui/models/base-select.directive.js.map +0 -1
- package/esm2015/lib/forms-ui/models/dropdown-item.interface.js +0 -2
- package/esm2015/lib/forms-ui/models/dropdown-item.interface.js.map +0 -1
- package/esm2015/lib/forms-ui/models/single-select-padding.interface.js +0 -2
- package/esm2015/lib/forms-ui/models/single-select-padding.interface.js.map +0 -1
- package/esm2015/lib/forms-ui/models/sorting.interface.js +0 -7
- package/esm2015/lib/forms-ui/models/sorting.interface.js.map +0 -1
- package/esm2015/lib/forms-ui/pipes/filter-selection.pipe.js +0 -30
- package/esm2015/lib/forms-ui/pipes/filter-selection.pipe.js.map +0 -1
- package/esm2015/lib/forms-ui/pipes/filter-term.pipe.js +0 -26
- package/esm2015/lib/forms-ui/pipes/filter-term.pipe.js.map +0 -1
- package/esm2015/lib/forms-ui/pipes/format-number.pipe.js +0 -65
- package/esm2015/lib/forms-ui/pipes/format-number.pipe.js.map +0 -1
- package/esm2015/lib/forms-ui/validators/date-in-foreseeable-future.validator.js +0 -26
- package/esm2015/lib/forms-ui/validators/date-in-foreseeable-future.validator.js.map +0 -1
- package/esm2015/lib/modal-ui/components/modal/modal.component.js +0 -214
- package/esm2015/lib/modal-ui/components/modal/modal.component.js.map +0 -1
- package/esm2015/lib/modal-ui/components/modal-footer/modal-footer.component.js +0 -15
- package/esm2015/lib/modal-ui/components/modal-footer/modal-footer.component.js.map +0 -1
- package/esm2015/lib/modal-ui/components/modal-header/modal-header.component.js +0 -27
- package/esm2015/lib/modal-ui/components/modal-header/modal-header.component.js.map +0 -1
- package/esm2015/lib/modal-ui/directives/modal-content.directive.js +0 -13
- package/esm2015/lib/modal-ui/directives/modal-content.directive.js.map +0 -1
- package/esm2015/lib/modal-ui/modal.constants.js +0 -3
- package/esm2015/lib/modal-ui/modal.constants.js.map +0 -1
- package/esm2015/lib/modal-ui/modal.module.js +0 -26
- package/esm2015/lib/modal-ui/modal.module.js.map +0 -1
- package/esm2015/lib/popover-ui/components/popover/popover.component.js +0 -203
- package/esm2015/lib/popover-ui/components/popover/popover.component.js.map +0 -1
- package/esm2015/lib/popover-ui/directives/popover-click.directive.js +0 -51
- package/esm2015/lib/popover-ui/directives/popover-click.directive.js.map +0 -1
- package/esm2015/lib/popover-ui/directives/popover-content.directive.js +0 -16
- package/esm2015/lib/popover-ui/directives/popover-content.directive.js.map +0 -1
- package/esm2015/lib/popover-ui/directives/popover-hover.directive.js +0 -87
- package/esm2015/lib/popover-ui/directives/popover-hover.directive.js.map +0 -1
- package/esm2015/lib/popover-ui/popover-ui.module.js +0 -22
- package/esm2015/lib/popover-ui/popover-ui.module.js.map +0 -1
- package/esm2015/lib/shared/date-helpers.js +0 -35
- package/esm2015/lib/shared/date-helpers.js.map +0 -1
- package/esm2015/lib/shared/misc-helpers.js +0 -34
- package/esm2015/lib/shared/misc-helpers.js.map +0 -1
- package/esm2015/lib/shared/observe.js +0 -40
- package/esm2015/lib/shared/observe.js.map +0 -1
- package/esm2015/lib/tab-ui/components/tab/tab.component.js +0 -75
- package/esm2015/lib/tab-ui/components/tab/tab.component.js.map +0 -1
- package/esm2015/lib/tab-ui/components/tab-group/tab-group.component.js +0 -78
- package/esm2015/lib/tab-ui/components/tab-group/tab-group.component.js.map +0 -1
- package/esm2015/lib/tab-ui/tab-ui.module.js +0 -22
- package/esm2015/lib/tab-ui/tab-ui.module.js.map +0 -1
- package/fesm2015/leanix-components.js.map +0 -1
@@ -0,0 +1,105 @@
|
|
1
|
+
// Currency symbol map extracted from: http://symbologic.info/currency.htm
|
2
|
+
// Using custom symbology since Angular 2 currency pipe does not support all currency symbols:
|
3
|
+
// https://github.com/angular/angular/issues/6724
|
4
|
+
export const CURRENCY_SYMBOL_MAP = {
|
5
|
+
AFA: '؋',
|
6
|
+
AWG: 'ƒ',
|
7
|
+
AUD: 'AU$',
|
8
|
+
ARS: 'ARS',
|
9
|
+
AZN: 'ман',
|
10
|
+
BSD: 'B$',
|
11
|
+
BDT: '৳',
|
12
|
+
BBD: 'Bds$',
|
13
|
+
BYR: 'Br',
|
14
|
+
BOB: 'Bs.',
|
15
|
+
BRL: 'R$',
|
16
|
+
GBP: '£',
|
17
|
+
BGN: 'лв',
|
18
|
+
KHR: '៛',
|
19
|
+
CAD: 'CA$',
|
20
|
+
KYD: 'KY$',
|
21
|
+
CLP: '$',
|
22
|
+
CNY: 'CN¥',
|
23
|
+
COP: 'COP',
|
24
|
+
CRC: '₡',
|
25
|
+
HRK: 'kn',
|
26
|
+
CPY: 'CPY',
|
27
|
+
CZK: 'Kč',
|
28
|
+
DKK: 'DKK',
|
29
|
+
DOP: 'RD$',
|
30
|
+
XCD: 'EC$',
|
31
|
+
EGP: 'E£',
|
32
|
+
ERN: 'Nfa',
|
33
|
+
EEK: 'EEK',
|
34
|
+
EUR: '€',
|
35
|
+
GEL: 'ლ',
|
36
|
+
GHC: 'GHC',
|
37
|
+
GIP: 'GIP',
|
38
|
+
GTQ: 'Q',
|
39
|
+
HNL: 'L',
|
40
|
+
HKD: 'HK$',
|
41
|
+
HUF: 'Ft',
|
42
|
+
ISK: 'ISK',
|
43
|
+
INR: '₹',
|
44
|
+
IDR: 'Rp',
|
45
|
+
ILS: '₪',
|
46
|
+
JMD: 'J$',
|
47
|
+
JPY: '¥',
|
48
|
+
KZT: '₸',
|
49
|
+
KES: 'KSh',
|
50
|
+
KWD: 'د.ك',
|
51
|
+
LVL: 'Ls',
|
52
|
+
LBP: 'L£',
|
53
|
+
LTL: 'Lt',
|
54
|
+
MOP: 'P',
|
55
|
+
MKD: 'ден',
|
56
|
+
MGA: 'Ar',
|
57
|
+
MYR: 'RM',
|
58
|
+
BAM: 'KM',
|
59
|
+
MUR: 'Ɍs',
|
60
|
+
MXN: 'MX$',
|
61
|
+
MZM: 'MT',
|
62
|
+
NPR: 'NɌs',
|
63
|
+
ANG: 'ƒ',
|
64
|
+
TWD: 'NT$',
|
65
|
+
NZD: 'NZ$',
|
66
|
+
NIO: 'C$',
|
67
|
+
NGN: '₦',
|
68
|
+
KPW: '₩',
|
69
|
+
NOK: 'NOK',
|
70
|
+
OMR: 'ر.ع.',
|
71
|
+
PKR: 'Ɍs',
|
72
|
+
PYG: '₲',
|
73
|
+
PEN: 'S/.',
|
74
|
+
PHP: '₱',
|
75
|
+
QAR: 'ر.ق',
|
76
|
+
RON: 'L',
|
77
|
+
RUB: 'руб',
|
78
|
+
SAR: 'ر.س',
|
79
|
+
CSD: 'CSD',
|
80
|
+
SCR: 'Ɍs',
|
81
|
+
SGD: 'S$',
|
82
|
+
SKK: 'SKK',
|
83
|
+
SIT: 'SIT',
|
84
|
+
ZAR: 'R',
|
85
|
+
KRW: 'KRW',
|
86
|
+
LKR: 'Ɍs',
|
87
|
+
SRD: '$',
|
88
|
+
SEK: 'SEK',
|
89
|
+
CHF: 'Fr',
|
90
|
+
TZS: 'TSh',
|
91
|
+
THB: '฿',
|
92
|
+
TTD: 'TT$',
|
93
|
+
TRY: 'TL',
|
94
|
+
AED: 'د.إ',
|
95
|
+
USD: '$',
|
96
|
+
UGX: 'USh',
|
97
|
+
UAH: '₴',
|
98
|
+
UYU: '$U',
|
99
|
+
UZS: 'лв',
|
100
|
+
VEB: 'VEB',
|
101
|
+
VND: '₫',
|
102
|
+
AMK: 'AMK',
|
103
|
+
ZWD: 'ZWD'
|
104
|
+
};
|
105
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VycmVuY3ktc3ltYm9sLW1hcC5jb25zdGFudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2Zvcm1zLXVpL2NvbXBvbmVudHMvY3VycmVuY3kvY3VycmVuY3ktc3ltYm9sLW1hcC5jb25zdGFudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSwwRUFBMEU7QUFDMUUsOEZBQThGO0FBQzlGLGlEQUFpRDtBQUNqRCxNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBOEI7SUFDNUQsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsR0FBRztJQUNSLEdBQUcsRUFBRSxLQUFLO0lBQ1YsR0FBRyxFQUFFLEtBQUs7SUFDVixHQUFHLEVBQUUsdUJBQXVCO0lBQzVCLEdBQUcsRUFBRSxJQUFJO0lBQ1QsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsTUFBTTtJQUNYLEdBQUcsRUFBRSxJQUFJO0lBQ1QsR0FBRyxFQUFFLEtBQUs7SUFDVixHQUFHLEVBQUUsSUFBSTtJQUNULEdBQUcsRUFBRSxHQUFHO0lBQ1IsR0FBRyxFQUFFLGdCQUFnQjtJQUNyQixHQUFHLEVBQUUsU0FBUztJQUNkLEdBQUcsRUFBRSxLQUFLO0lBQ1YsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsT0FBTztJQUNaLEdBQUcsRUFBRSxLQUFLO0lBQ1YsR0FBRyxFQUFFLEtBQUs7SUFDVixHQUFHLEVBQUUsU0FBUztJQUNkLEdBQUcsRUFBRSxJQUFJO0lBQ1QsR0FBRyxFQUFFLEtBQUs7SUFDVixHQUFHLEVBQUUsU0FBUztJQUNkLEdBQUcsRUFBRSxLQUFLO0lBQ1YsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsS0FBSztJQUNWLEdBQUcsRUFBRSxVQUFVO0lBQ2YsR0FBRyxFQUFFLEtBQUs7SUFDVixHQUFHLEVBQUUsS0FBSztJQUNWLEdBQUcsRUFBRSxRQUFRO0lBQ2IsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsS0FBSztJQUNWLEdBQUcsRUFBRSxLQUFLO0lBQ1YsR0FBRyxFQUFFLEdBQUc7SUFDUixHQUFHLEVBQUUsR0FBRztJQUNSLEdBQUcsRUFBRSxLQUFLO0lBQ1YsR0FBRyxFQUFFLElBQUk7SUFDVCxHQUFHLEVBQUUsS0FBSztJQUNWLEdBQUcsRUFBRSxHQUFHO0lBQ1IsR0FBRyxFQUFFLElBQUk7SUFDVCxHQUFHLEVBQUUsR0FBRztJQUNSLEdBQUcsRUFBRSxJQUFJO0lBQ1QsR0FBRyxFQUFFLEdBQUc7SUFDUixHQUFHLEVBQUUsVUFBVTtJQUNmLEdBQUcsRUFBRSxLQUFLO0lBQ1YsR0FBRyxFQUFFLGlCQUFpQjtJQUN0QixHQUFHLEVBQUUsSUFBSTtJQUNULEdBQUcsRUFBRSxVQUFVO0lBQ2YsR0FBRyxFQUFFLElBQUk7SUFDVCxHQUFHLEVBQUUsR0FBRztJQUNSLEdBQUcsRUFBRSx1QkFBdUI7SUFDNUIsR0FBRyxFQUFFLElBQUk7SUFDVCxHQUFHLEVBQUUsSUFBSTtJQUNULEdBQUcsRUFBRSxJQUFJO0lBQ1QsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsS0FBSztJQUNWLEdBQUcsRUFBRSxJQUFJO0lBQ1QsR0FBRyxFQUFFLFVBQVU7SUFDZixHQUFHLEVBQUUsUUFBUTtJQUNiLEdBQUcsRUFBRSxLQUFLO0lBQ1YsR0FBRyxFQUFFLEtBQUs7SUFDVixHQUFHLEVBQUUsUUFBUTtJQUNiLEdBQUcsRUFBRSxTQUFTO0lBQ2QsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsS0FBSztJQUNWLEdBQUcsRUFBRSxrQkFBa0I7SUFDdkIsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsU0FBUztJQUNkLEdBQUcsRUFBRSxLQUFLO0lBQ1YsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsaUJBQWlCO0lBQ3RCLEdBQUcsRUFBRSxHQUFHO0lBQ1IsR0FBRyxFQUFFLHVCQUF1QjtJQUM1QixHQUFHLEVBQUUsaUJBQWlCO0lBQ3RCLEdBQUcsRUFBRSxLQUFLO0lBQ1YsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsUUFBUTtJQUNiLEdBQUcsRUFBRSxLQUFLO0lBQ1YsR0FBRyxFQUFFLEtBQUs7SUFDVixHQUFHLEVBQUUsR0FBRztJQUNSLEdBQUcsRUFBRSxLQUFLO0lBQ1YsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsT0FBTztJQUNaLEdBQUcsRUFBRSxLQUFLO0lBQ1YsR0FBRyxFQUFFLElBQUk7SUFDVCxHQUFHLEVBQUUsS0FBSztJQUNWLEdBQUcsRUFBRSxTQUFTO0lBQ2QsR0FBRyxFQUFFLFNBQVM7SUFDZCxHQUFHLEVBQUUsSUFBSTtJQUNULEdBQUcsRUFBRSxpQkFBaUI7SUFDdEIsR0FBRyxFQUFFLEdBQUc7SUFDUixHQUFHLEVBQUUsS0FBSztJQUNWLEdBQUcsRUFBRSxTQUFTO0lBQ2QsR0FBRyxFQUFFLFFBQVE7SUFDYixHQUFHLEVBQUUsZ0JBQWdCO0lBQ3JCLEdBQUcsRUFBRSxLQUFLO0lBQ1YsR0FBRyxFQUFFLEdBQUc7SUFDUixHQUFHLEVBQUUsS0FBSztJQUNWLEdBQUcsRUFBRSxLQUFLO0NBQ1gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEN1cnJlbmN5IHN5bWJvbCBtYXAgZXh0cmFjdGVkIGZyb206IGh0dHA6Ly9zeW1ib2xvZ2ljLmluZm8vY3VycmVuY3kuaHRtXG4vLyBVc2luZyBjdXN0b20gc3ltYm9sb2d5IHNpbmNlIEFuZ3VsYXIgMiBjdXJyZW5jeSBwaXBlIGRvZXMgbm90IHN1cHBvcnQgYWxsIGN1cnJlbmN5IHN5bWJvbHM6XG4vLyBodHRwczovL2dpdGh1Yi5jb20vYW5ndWxhci9hbmd1bGFyL2lzc3Vlcy82NzI0XG5leHBvcnQgY29uc3QgQ1VSUkVOQ1lfU1lNQk9MX01BUDogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfSA9IHtcbiAgQUZBOiAnJiN4NjBiOycsXG4gIEFXRzogJ8aSJyxcbiAgQVVEOiAnQVUkJyxcbiAgQVJTOiAnQVJTJyxcbiAgQVpOOiAnJiMxMDg0OyYjMTA3MjsmIzEwODU7JyxcbiAgQlNEOiAnQiQnLFxuICBCRFQ6ICcmIzI1NDc7JyxcbiAgQkJEOiAnQmRzJCcsXG4gIEJZUjogJ0JyJyxcbiAgQk9COiAnQnMuJyxcbiAgQlJMOiAnUiQnLFxuICBHQlA6ICfCoycsXG4gIEJHTjogJyYjMTA4MzsmIzEwNzQ7JyxcbiAgS0hSOiAnJiM2MTA3OycsXG4gIENBRDogJ0NBJCcsXG4gIEtZRDogJ0tZJiMzNjsnLFxuICBDTFA6ICcmIzM2OycsXG4gIENOWTogJ0NOwqUnLFxuICBDT1A6ICdDT1AnLFxuICBDUkM6ICcmIzgzNTM7JyxcbiAgSFJLOiAna24nLFxuICBDUFk6ICdDUFknLFxuICBDWks6ICdLJiMyNjk7JyxcbiAgREtLOiAnREtLJyxcbiAgRE9QOiAnUkQmIzM2OycsXG4gIFhDRDogJ0VDJCcsXG4gIEVHUDogJ0UmcG91bmQ7JyxcbiAgRVJOOiAnTmZhJyxcbiAgRUVLOiAnRUVLJyxcbiAgRVVSOiAnJmV1cm87JyxcbiAgR0VMOiAnJiM0MzE0OycsXG4gIEdIQzogJ0dIQycsXG4gIEdJUDogJ0dJUCcsXG4gIEdUUTogJ1EnLFxuICBITkw6ICdMJyxcbiAgSEtEOiAnSEskJyxcbiAgSFVGOiAnRnQnLFxuICBJU0s6ICdJU0snLFxuICBJTlI6ICfigrknLFxuICBJRFI6ICdScCcsXG4gIElMUzogJ+KCqicsXG4gIEpNRDogJ0okJyxcbiAgSlBZOiAnwqUnLFxuICBLWlQ6ICcmI3gyMGI4OycsXG4gIEtFUzogJ0tTaCcsXG4gIEtXRDogJyYjMTU4MzsuJiMxNjAzOycsXG4gIExWTDogJ0xzJyxcbiAgTEJQOiAnTCZwb3VuZDsnLFxuICBMVEw6ICdMdCcsXG4gIE1PUDogJ1AnLFxuICBNS0Q6ICcmIzEwNzY7JiMxMDc3OyYjMTA4NTsnLFxuICBNR0E6ICdBcicsXG4gIE1ZUjogJ1JNJyxcbiAgQkFNOiAnS00nLFxuICBNVVI6ICcmIzU4ODtzJyxcbiAgTVhOOiAnTVgkJyxcbiAgTVpNOiAnTVQnLFxuICBOUFI6ICdOJiM1ODg7cycsXG4gIEFORzogJyYjMTMxOycsXG4gIFRXRDogJ05UJCcsXG4gIE5aRDogJ05aJCcsXG4gIE5JTzogJ0MmIzM2OycsXG4gIE5HTjogJyYjODM1ODsnLFxuICBLUFc6ICcmIzgzNjE7JyxcbiAgTk9LOiAnTk9LJyxcbiAgT01SOiAnJiMxNTg1Oy4mIzE1OTM7LicsXG4gIFBLUjogJyYjNTg4O3MnLFxuICBQWUc6ICcmIzgzNzA7JyxcbiAgUEVOOiAnUy8uJyxcbiAgUEhQOiAnJiM4MzY5OycsXG4gIFFBUjogJyYjMTU4NTsuJiMxNjAyOycsXG4gIFJPTjogJ0wnLFxuICBSVUI6ICcmIzEwODg7JiMxMDkxOyYjMTA3MzsnLFxuICBTQVI6ICcmIzE1ODU7LiYjMTU4NzsnLFxuICBDU0Q6ICdDU0QnLFxuICBTQ1I6ICcmIzU4ODtzJyxcbiAgU0dEOiAnUyYjMzY7JyxcbiAgU0tLOiAnU0tLJyxcbiAgU0lUOiAnU0lUJyxcbiAgWkFSOiAnUicsXG4gIEtSVzogJ0tSVycsXG4gIExLUjogJyYjNTg4O3MnLFxuICBTUkQ6ICcmIzM2OycsXG4gIFNFSzogJ1NFSycsXG4gIENIRjogJ0ZyJyxcbiAgVFpTOiAnVFNoJyxcbiAgVEhCOiAnJiMzNjQ3OycsXG4gIFRURDogJ1RUJiMzNjsnLFxuICBUUlk6ICdUTCcsXG4gIEFFRDogJyYjMTU4MzsuJiMxNTczOycsXG4gIFVTRDogJyQnLFxuICBVR1g6ICdVU2gnLFxuICBVQUg6ICcmIzgzNzI7JyxcbiAgVVlVOiAnJiMzNjtVJyxcbiAgVVpTOiAnJiMxMDgzOyYjMTA3NDsnLFxuICBWRUI6ICdWRUInLFxuICBWTkQ6ICfigqsnLFxuICBBTUs6ICdBTUsnLFxuICBaV0Q6ICdaV0QnXG59O1xuIl19
|
@@ -0,0 +1,25 @@
|
|
1
|
+
import { __decorate } from "tslib";
|
2
|
+
import { Component, Input } from '@angular/core';
|
3
|
+
import { map } from 'rxjs/operators';
|
4
|
+
import { Observe } from '../../../shared/observe';
|
5
|
+
import { CURRENCY_SYMBOL_MAP } from './currency-symbol-map.constant';
|
6
|
+
import * as i0 from "@angular/core";
|
7
|
+
import * as i1 from "../../../core-ui/directives/html.directive";
|
8
|
+
import * as i2 from "@angular/common";
|
9
|
+
export class CurrencySymbolComponent {
|
10
|
+
ngOnInit() {
|
11
|
+
this.currency$ = this.code$.pipe(map((code) => CURRENCY_SYMBOL_MAP[code] || code));
|
12
|
+
}
|
13
|
+
}
|
14
|
+
CurrencySymbolComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: CurrencySymbolComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
15
|
+
CurrencySymbolComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.5", type: CurrencySymbolComponent, selector: "lx-currency-symbol", inputs: { code: "code" }, ngImport: i0, template: "<span [lxHtml]=\"currency$ | async\"></span>\n", directives: [{ type: i1.HtmlDirective, selector: "[lxHtml]", inputs: ["lxHtml"] }], pipes: { "async": i2.AsyncPipe } });
|
16
|
+
__decorate([
|
17
|
+
Observe('code')
|
18
|
+
], CurrencySymbolComponent.prototype, "code$", void 0);
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: CurrencySymbolComponent, decorators: [{
|
20
|
+
type: Component,
|
21
|
+
args: [{ selector: 'lx-currency-symbol', template: "<span [lxHtml]=\"currency$ | async\"></span>\n" }]
|
22
|
+
}], propDecorators: { code: [{
|
23
|
+
type: Input
|
24
|
+
}], code$: [] } });
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VycmVuY3ktc3ltYm9sLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2Zvcm1zLXVpL2NvbXBvbmVudHMvY3VycmVuY3kvY3VycmVuY3ktc3ltYm9sLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2Zvcm1zLXVpL2NvbXBvbmVudHMvY3VycmVuY3kvY3VycmVuY3ktc3ltYm9sLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUV6RCxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckMsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ2xELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDOzs7O0FBTXJFLE1BQU0sT0FBTyx1QkFBdUI7SUFLbEMsUUFBUTtRQUNOLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQ3JGLENBQUM7O29IQVBVLHVCQUF1Qjt3R0FBdkIsdUJBQXVCLG9GQ1ZwQyxnREFDQTtBRFdtQjtJQUFoQixPQUFPLENBQUMsTUFBTSxDQUFDO3NEQUE0QjsyRkFGakMsdUJBQXVCO2tCQUpuQyxTQUFTOytCQUNFLG9CQUFvQjs4QkFJckIsSUFBSTtzQkFBWixLQUFLO2dCQUNXLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IG1hcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7IE9ic2VydmUgfSBmcm9tICcuLi8uLi8uLi9zaGFyZWQvb2JzZXJ2ZSc7XG5pbXBvcnQgeyBDVVJSRU5DWV9TWU1CT0xfTUFQIH0gZnJvbSAnLi9jdXJyZW5jeS1zeW1ib2wtbWFwLmNvbnN0YW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbHgtY3VycmVuY3ktc3ltYm9sJyxcbiAgdGVtcGxhdGVVcmw6ICdjdXJyZW5jeS1zeW1ib2wuY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIEN1cnJlbmN5U3ltYm9sQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgY29kZSE6IHN0cmluZztcbiAgQE9ic2VydmUoJ2NvZGUnKSBjb2RlJCE6IE9ic2VydmFibGU8c3RyaW5nPjtcbiAgY3VycmVuY3kkITogT2JzZXJ2YWJsZTxzdHJpbmc+O1xuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuY3VycmVuY3kkID0gdGhpcy5jb2RlJC5waXBlKG1hcCgoY29kZSkgPT4gQ1VSUkVOQ1lfU1lNQk9MX01BUFtjb2RlXSB8fCBjb2RlKSk7XG4gIH1cbn1cbiIsIjxzcGFuIFtseEh0bWxdPVwiY3VycmVuY3kkIHwgYXN5bmNcIj48L3NwYW4+XG4iXX0=
|
@@ -0,0 +1,270 @@
|
|
1
|
+
import { __decorate } from "tslib";
|
2
|
+
import { Component, EventEmitter, forwardRef, Inject, Input, Optional, Output, ViewChild } from '@angular/core';
|
3
|
+
import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
|
4
|
+
import { format, startOfDay } from 'date-fns';
|
5
|
+
import { DateFormatter, DatePickerComponent } from 'ngx-bootstrap/datepicker';
|
6
|
+
import { Subject } from 'rxjs';
|
7
|
+
import { takeUntil } from 'rxjs/operators';
|
8
|
+
import { DATE_FN_LOCALE, DATE_FORMATS } from '../../../core-ui/core-ui.constants';
|
9
|
+
import { convertDateToLocaleDateString, createDateFromDateString, isValidDateString } from '../../../shared/date-helpers';
|
10
|
+
import { Observe } from '../../../shared/observe';
|
11
|
+
import * as i0 from "@angular/core";
|
12
|
+
import * as i1 from "ngx-bootstrap/datepicker";
|
13
|
+
import * as i2 from "@angular/common";
|
14
|
+
import * as i3 from "@angular/forms";
|
15
|
+
import * as i4 from "../../../core-ui/pipes/custom-date.pipe";
|
16
|
+
const DEFAULT_MIN_DATE = new Date('0000-01-01');
|
17
|
+
const DEFAULT_MAX_DATE = new Date('9999-12-31');
|
18
|
+
export class DateInputComponent {
|
19
|
+
constructor(cd, dateFormatsProvider, getDateFnLocale) {
|
20
|
+
this.cd = cd;
|
21
|
+
this.dateFormatsProvider = dateFormatsProvider;
|
22
|
+
this.getDateFnLocale = getDateFnLocale;
|
23
|
+
this.date = null; // main date input; this is also the one used for ngModel & formControl!
|
24
|
+
this.dateChange = new EventEmitter(); // triggered whenever the date changes
|
25
|
+
this.dateString = null; // secondary, alternative input with date string
|
26
|
+
this.dateStringChange = new EventEmitter(); // triggered whenever the date changes
|
27
|
+
// Determine whether formGroup's value accessor is accessing the selected IDs or the selected objects
|
28
|
+
this.valueAccessor = 'date';
|
29
|
+
this.inputId = ''; // id to be set on input to correspond to outside label
|
30
|
+
this.renderingStyle = 'INPUT';
|
31
|
+
this.placeholder = 'yyyy-mm-dd';
|
32
|
+
//--- Inputs replicated from datepicker; (selectionDone) is not needed, as (dateChange) is equivalen
|
33
|
+
this.datepickerMode = 'day'; // sets datepicker mode, supports: day, month, year
|
34
|
+
this.minDate = DEFAULT_MIN_DATE; // oldest selectable date
|
35
|
+
this.maxDate = DEFAULT_MAX_DATE; // latest selectable date
|
36
|
+
this.minMode = 'day'; // set lower datepicker mode, supports: day, month, year
|
37
|
+
this.maxMode = 'year'; // sets upper datepicker mode, supports: day, month, year
|
38
|
+
this.showWeeks = true; // if false week numbers will be hidden
|
39
|
+
this.formatDay = 'DD'; // format of day in month
|
40
|
+
this.formatMonth = 'MMMM'; // format of month in year
|
41
|
+
this.formatYear = 'YYYY'; // format of year in year range
|
42
|
+
this.formatDayHeader = 'dd'; // format of day in week header
|
43
|
+
this.formatDayTitle = 'MMMM YYYY'; // format of title when selecting day
|
44
|
+
this.formatMonthTitle = 'YYYY'; // format of title when selecting month
|
45
|
+
this.startingDay = 0; // starting day of the week from 0-6 (0=Sunday, ..., 6=Saturday) public
|
46
|
+
this.yearRange = 20; // number of years displayed in year selection
|
47
|
+
this.onlyCurrentMonth = false; // if true only dates from the currently displayed month will be shown
|
48
|
+
this.shortcutPropagation = false; // if true shortcut`s event propagation will be disabled
|
49
|
+
this.customClass = []; // array of custom css classes to be applied to
|
50
|
+
this.dateDisabled = []; // array of disabled dates if mode is day, or years, etc.
|
51
|
+
this.showDatepicker = false;
|
52
|
+
this.destroyed$ = new Subject();
|
53
|
+
this.hasError = false;
|
54
|
+
this.propagateChange = (_date) => { };
|
55
|
+
this.dateFormat = this.dateFormatsProvider.getDateFormat();
|
56
|
+
// Patch DatePicker until https://github.com/valor-software/ng2-bootstrap/issues/1385 is resolved
|
57
|
+
const writeValue = DatePickerComponent.prototype.writeValue;
|
58
|
+
DatePickerComponent.prototype.writeValue = function (value) {
|
59
|
+
if (value !== null) {
|
60
|
+
return writeValue.apply(this, arguments);
|
61
|
+
}
|
62
|
+
};
|
63
|
+
// Somehow datepicker does use a separate moment instance than we do. That one runs on locale en by default.
|
64
|
+
// So we patch the format function here to use our moment instance.
|
65
|
+
// Maybe it will be fixed with: https://github.com/valor-software/ngx-bootstrap/issues/455
|
66
|
+
const locale = this.getDateFnLocale ? this.getDateFnLocale() : null;
|
67
|
+
DateFormatter.prototype.format = function (date, f) {
|
68
|
+
return format(date, f, { locale });
|
69
|
+
};
|
70
|
+
}
|
71
|
+
ngOnInit() {
|
72
|
+
this.initDateString$.pipe(takeUntil(this.destroyed$)).subscribe((date) => {
|
73
|
+
this.initDate = createDateFromDateString(date) ?? startOfDay(new Date());
|
74
|
+
});
|
75
|
+
}
|
76
|
+
ngOnChanges(changes) {
|
77
|
+
if (changes['date']) {
|
78
|
+
this.dateString = this.date ? convertDateToLocaleDateString(this.date) : null;
|
79
|
+
}
|
80
|
+
else if (changes['dateString']) {
|
81
|
+
this.onDateStringChange(this.dateString, false);
|
82
|
+
}
|
83
|
+
}
|
84
|
+
ngOnDestroy() {
|
85
|
+
this.destroyed$.next();
|
86
|
+
}
|
87
|
+
focus() {
|
88
|
+
this.input.nativeElement.focus();
|
89
|
+
}
|
90
|
+
showPopup() {
|
91
|
+
this.showDatepicker = true;
|
92
|
+
this.cd.detectChanges();
|
93
|
+
}
|
94
|
+
togglePopup() {
|
95
|
+
this.showDatepicker = !this.showDatepicker;
|
96
|
+
}
|
97
|
+
hidePopup() {
|
98
|
+
if (this.showDatepicker) {
|
99
|
+
this.showDatepicker = false;
|
100
|
+
}
|
101
|
+
}
|
102
|
+
onTab(forward) {
|
103
|
+
if (forward && this.showDatepicker) {
|
104
|
+
this.hidePopup();
|
105
|
+
return false; // Prevent tab for now as ng2-bootstrap datepicker has a tabstop: 2 tabs needed to navigate for now
|
106
|
+
// TODO: Check again in new version
|
107
|
+
}
|
108
|
+
this.hidePopup();
|
109
|
+
return true;
|
110
|
+
}
|
111
|
+
onDateStringChange(newDateString, emit = true) {
|
112
|
+
if (isValidDateString(newDateString)) {
|
113
|
+
const date = createDateFromDateString(newDateString);
|
114
|
+
this.updateDate(date, emit);
|
115
|
+
}
|
116
|
+
else if (newDateString === null || newDateString === '') {
|
117
|
+
this.updateDate(null, emit);
|
118
|
+
}
|
119
|
+
else {
|
120
|
+
this.hasError = true;
|
121
|
+
if (this.formControl) {
|
122
|
+
this.formControl.updateValueAndValidity();
|
123
|
+
}
|
124
|
+
}
|
125
|
+
}
|
126
|
+
onSelectionDone(newDate) {
|
127
|
+
this.updateDate(newDate);
|
128
|
+
this.hidePopup();
|
129
|
+
}
|
130
|
+
onBlur() {
|
131
|
+
if (this.onTouched) {
|
132
|
+
this.onTouched();
|
133
|
+
}
|
134
|
+
}
|
135
|
+
updateDate(date, emit = true) {
|
136
|
+
this.date = date;
|
137
|
+
this.dateString = this.date ? convertDateToLocaleDateString(this.date) : '';
|
138
|
+
if (emit) {
|
139
|
+
this.dateChange.emit(date);
|
140
|
+
this.dateStringChange.emit(this.dateString);
|
141
|
+
}
|
142
|
+
this.propagateChange(date);
|
143
|
+
this.recheckErrors();
|
144
|
+
}
|
145
|
+
recheckErrors() {
|
146
|
+
this.hasError = false;
|
147
|
+
if (this.formControl) {
|
148
|
+
this.formControl.updateValueAndValidity();
|
149
|
+
}
|
150
|
+
}
|
151
|
+
//--- Implement ControlValueAccessor
|
152
|
+
/** Write a new value to the element. */
|
153
|
+
writeValue(newDate) {
|
154
|
+
if (this.valueAccessor === 'date') {
|
155
|
+
this.date = newDate;
|
156
|
+
this.dateString = convertDateToLocaleDateString(this.date);
|
157
|
+
}
|
158
|
+
else {
|
159
|
+
this.dateString = newDate;
|
160
|
+
this.onDateStringChange(this.dateString, false);
|
161
|
+
}
|
162
|
+
}
|
163
|
+
/** Set the function to be called when the control receives a change event. */
|
164
|
+
registerOnChange(fn) {
|
165
|
+
if (this.valueAccessor === 'date') {
|
166
|
+
this.dateChange.pipe(takeUntil(this.destroyed$)).subscribe(fn);
|
167
|
+
}
|
168
|
+
else if (this.valueAccessor === 'dateString') {
|
169
|
+
this.dateStringChange.pipe(takeUntil(this.destroyed$)).subscribe(fn);
|
170
|
+
}
|
171
|
+
}
|
172
|
+
/** Set the function to be called when the control receives a touch event. */
|
173
|
+
registerOnTouched(fn) {
|
174
|
+
this.onTouched = fn;
|
175
|
+
}
|
176
|
+
validate(c) {
|
177
|
+
this.formControl = c;
|
178
|
+
return this.hasError
|
179
|
+
? {
|
180
|
+
dateFormatError: {
|
181
|
+
given: this.dateString,
|
182
|
+
format: 'yyyy-mm-dd'
|
183
|
+
}
|
184
|
+
}
|
185
|
+
: null;
|
186
|
+
}
|
187
|
+
}
|
188
|
+
DateInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: DateInputComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: DATE_FORMATS }, { token: DATE_FN_LOCALE, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
189
|
+
DateInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.5", type: DateInputComponent, selector: "lx-date-input", inputs: { date: "date", dateString: "dateString", valueAccessor: "valueAccessor", inputId: "inputId", renderingStyle: "renderingStyle", placeholder: "placeholder", datepickerMode: "datepickerMode", initDateString: "initDateString", minDate: "minDate", maxDate: "maxDate", minMode: "minMode", maxMode: "maxMode", showWeeks: "showWeeks", formatDay: "formatDay", formatMonth: "formatMonth", formatYear: "formatYear", formatDayHeader: "formatDayHeader", formatDayTitle: "formatDayTitle", formatMonthTitle: "formatMonthTitle", startingDay: "startingDay", yearRange: "yearRange", onlyCurrentMonth: "onlyCurrentMonth", shortcutPropagation: "shortcutPropagation", customClass: "customClass", disabled: "disabled", dateDisabled: "dateDisabled" }, outputs: { dateChange: "dateChange", dateStringChange: "dateStringChange" }, providers: [
|
190
|
+
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DateInputComponent), multi: true },
|
191
|
+
{ provide: NG_VALIDATORS, useExisting: forwardRef(() => DateInputComponent), multi: true }
|
192
|
+
], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"backdrop\" *ngIf=\"showDatepicker\" (click)=\"hidePopup()\"></div>\n<span class=\"wrapper\" [class.forLink]=\"renderingStyle === 'LINK'\" [class.has-error]=\"hasError\">\n <input\n #input\n class=\"form-control dateControl\"\n placeholder=\"{{ placeholder }}\"\n [id]=\"inputId\"\n [(ngModel)]=\"dateString\"\n [disabled]=\"disabled\"\n (ngModelChange)=\"onDateStringChange($event)\"\n (focus)=\"showPopup()\"\n (blur)=\"onBlur()\"\n (keydown.enter)=\"hidePopup()\"\n (keydown.escape)=\"hidePopup()\"\n (keydown.tab)=\"onTab(true)\"\n (keydown.shift.tab)=\"onTab(false)\"\n [class.text-danger]=\"hasError\"\n *ngIf=\"renderingStyle === 'INPUT'\"\n />\n <a class=\"dateControl\" (click)=\"togglePopup()\" *ngIf=\"renderingStyle === 'LINK'\">{{ date | lxDate: dateFormat }}</a>\n <div class=\"datepickerContainer\">\n <div class=\"calendar\">\n <datepicker\n class=\"popup\"\n *ngIf=\"showDatepicker\"\n (selectionDone)=\"onSelectionDone($event)\"\n [ngModel]=\"date\"\n [datepickerMode]=\"datepickerMode\"\n [initDate]=\"initDate\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [minMode]=\"minMode\"\n [maxMode]=\"maxMode\"\n [showWeeks]=\"showWeeks\"\n [formatDay]=\"formatDay\"\n [formatMonth]=\"formatMonth\"\n [formatYear]=\"formatYear\"\n [formatDayHeader]=\"formatDayHeader\"\n [formatDayTitle]=\"formatDayTitle\"\n [formatMonthTitle]=\"formatMonthTitle\"\n [startingDay]=\"startingDay\"\n [yearRange]=\"yearRange\"\n [onlyCurrentMonth]=\"onlyCurrentMonth\"\n [shortcutPropagation]=\"shortcutPropagation\"\n [customClass]=\"customClass\"\n [dateDisabled]=\"dateDisabled\"\n >\n </datepicker>\n </div>\n </div>\n</span>\n", styles: [".backdrop{position:fixed;top:0;right:0;bottom:0;left:0}.datepickerContainer{position:absolute;z-index:700}.wrapper .forLink .popup{top:15px}.dateControl,.calendar{position:relative}.popup{position:relative;left:0;z-index:700;border-radius:3px}.popup ::ng-deep .text-info{color:#2a303d}.popup ::ng-deep .text-muted{color:#99a5bb}.popup ::ng-deep .btn.active,.popup ::ng-deep .btn.active .text-info{color:#fff;background-color:#2a303d}.popup ::ng-deep .well{margin:0;border:1px solid #2a303d}:host-context(.input-group) .datepickerContainer{top:100%}\n"], components: [{ type: i1.DatePickerComponent, selector: "datepicker", inputs: ["datepickerMode", "showWeeks", "activeDate", "initDate", "minDate", "maxDate", "minMode", "maxMode", "formatDay", "formatMonth", "formatYear", "formatDayHeader", "formatDayTitle", "formatMonthTitle", "startingDay", "yearRange", "onlyCurrentMonth", "shortcutPropagation", "monthColLimit", "yearColLimit", "customClass", "dateDisabled", "dayDisabled"], outputs: ["selectionDone", "activeDateChange"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "lxDate": i4.CustomDatePipe } });
|
193
|
+
__decorate([
|
194
|
+
Observe('initDateString')
|
195
|
+
], DateInputComponent.prototype, "initDateString$", void 0);
|
196
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: DateInputComponent, decorators: [{
|
197
|
+
type: Component,
|
198
|
+
args: [{ selector: 'lx-date-input', providers: [
|
199
|
+
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DateInputComponent), multi: true },
|
200
|
+
{ provide: NG_VALIDATORS, useExisting: forwardRef(() => DateInputComponent), multi: true }
|
201
|
+
], template: "<div class=\"backdrop\" *ngIf=\"showDatepicker\" (click)=\"hidePopup()\"></div>\n<span class=\"wrapper\" [class.forLink]=\"renderingStyle === 'LINK'\" [class.has-error]=\"hasError\">\n <input\n #input\n class=\"form-control dateControl\"\n placeholder=\"{{ placeholder }}\"\n [id]=\"inputId\"\n [(ngModel)]=\"dateString\"\n [disabled]=\"disabled\"\n (ngModelChange)=\"onDateStringChange($event)\"\n (focus)=\"showPopup()\"\n (blur)=\"onBlur()\"\n (keydown.enter)=\"hidePopup()\"\n (keydown.escape)=\"hidePopup()\"\n (keydown.tab)=\"onTab(true)\"\n (keydown.shift.tab)=\"onTab(false)\"\n [class.text-danger]=\"hasError\"\n *ngIf=\"renderingStyle === 'INPUT'\"\n />\n <a class=\"dateControl\" (click)=\"togglePopup()\" *ngIf=\"renderingStyle === 'LINK'\">{{ date | lxDate: dateFormat }}</a>\n <div class=\"datepickerContainer\">\n <div class=\"calendar\">\n <datepicker\n class=\"popup\"\n *ngIf=\"showDatepicker\"\n (selectionDone)=\"onSelectionDone($event)\"\n [ngModel]=\"date\"\n [datepickerMode]=\"datepickerMode\"\n [initDate]=\"initDate\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [minMode]=\"minMode\"\n [maxMode]=\"maxMode\"\n [showWeeks]=\"showWeeks\"\n [formatDay]=\"formatDay\"\n [formatMonth]=\"formatMonth\"\n [formatYear]=\"formatYear\"\n [formatDayHeader]=\"formatDayHeader\"\n [formatDayTitle]=\"formatDayTitle\"\n [formatMonthTitle]=\"formatMonthTitle\"\n [startingDay]=\"startingDay\"\n [yearRange]=\"yearRange\"\n [onlyCurrentMonth]=\"onlyCurrentMonth\"\n [shortcutPropagation]=\"shortcutPropagation\"\n [customClass]=\"customClass\"\n [dateDisabled]=\"dateDisabled\"\n >\n </datepicker>\n </div>\n </div>\n</span>\n", styles: [".backdrop{position:fixed;top:0;right:0;bottom:0;left:0}.datepickerContainer{position:absolute;z-index:700}.wrapper .forLink .popup{top:15px}.dateControl,.calendar{position:relative}.popup{position:relative;left:0;z-index:700;border-radius:3px}.popup ::ng-deep .text-info{color:#2a303d}.popup ::ng-deep .text-muted{color:#99a5bb}.popup ::ng-deep .btn.active,.popup ::ng-deep .btn.active .text-info{color:#fff;background-color:#2a303d}.popup ::ng-deep .well{margin:0;border:1px solid #2a303d}:host-context(.input-group) .datepickerContainer{top:100%}\n"] }]
|
202
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
|
203
|
+
type: Inject,
|
204
|
+
args: [DATE_FORMATS]
|
205
|
+
}] }, { type: Function, decorators: [{
|
206
|
+
type: Optional
|
207
|
+
}, {
|
208
|
+
type: Inject,
|
209
|
+
args: [DATE_FN_LOCALE]
|
210
|
+
}] }]; }, propDecorators: { date: [{
|
211
|
+
type: Input
|
212
|
+
}], dateChange: [{
|
213
|
+
type: Output
|
214
|
+
}], dateString: [{
|
215
|
+
type: Input
|
216
|
+
}], dateStringChange: [{
|
217
|
+
type: Output
|
218
|
+
}], valueAccessor: [{
|
219
|
+
type: Input
|
220
|
+
}], inputId: [{
|
221
|
+
type: Input
|
222
|
+
}], renderingStyle: [{
|
223
|
+
type: Input
|
224
|
+
}], placeholder: [{
|
225
|
+
type: Input
|
226
|
+
}], datepickerMode: [{
|
227
|
+
type: Input
|
228
|
+
}], initDateString: [{
|
229
|
+
type: Input
|
230
|
+
}], initDateString$: [], minDate: [{
|
231
|
+
type: Input
|
232
|
+
}], maxDate: [{
|
233
|
+
type: Input
|
234
|
+
}], minMode: [{
|
235
|
+
type: Input
|
236
|
+
}], maxMode: [{
|
237
|
+
type: Input
|
238
|
+
}], showWeeks: [{
|
239
|
+
type: Input
|
240
|
+
}], formatDay: [{
|
241
|
+
type: Input
|
242
|
+
}], formatMonth: [{
|
243
|
+
type: Input
|
244
|
+
}], formatYear: [{
|
245
|
+
type: Input
|
246
|
+
}], formatDayHeader: [{
|
247
|
+
type: Input
|
248
|
+
}], formatDayTitle: [{
|
249
|
+
type: Input
|
250
|
+
}], formatMonthTitle: [{
|
251
|
+
type: Input
|
252
|
+
}], startingDay: [{
|
253
|
+
type: Input
|
254
|
+
}], yearRange: [{
|
255
|
+
type: Input
|
256
|
+
}], onlyCurrentMonth: [{
|
257
|
+
type: Input
|
258
|
+
}], shortcutPropagation: [{
|
259
|
+
type: Input
|
260
|
+
}], customClass: [{
|
261
|
+
type: Input
|
262
|
+
}], disabled: [{
|
263
|
+
type: Input
|
264
|
+
}], dateDisabled: [{
|
265
|
+
type: Input
|
266
|
+
}], input: [{
|
267
|
+
type: ViewChild,
|
268
|
+
args: ['input']
|
269
|
+
}] } });
|
270
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-input.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/date-input/date-input.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/date-input/date-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, FormControl, NG_VALIDATORS, NG_VALUE_ACCESSOR, Validator } from '@angular/forms';\nimport { format, startOfDay } from 'date-fns';\nimport { DateFormatter, DatePickerComponent } from 'ngx-bootstrap/datepicker';\nimport { Observable, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { DATE_FN_LOCALE, DATE_FORMATS, DateFormatsProvider } from '../../../core-ui/core-ui.constants';\nimport { convertDateToLocaleDateString, createDateFromDateString, isValidDateString } from '../../../shared/date-helpers';\nimport { Observe } from '../../../shared/observe';\n\n// Input + ng2-bootstrap datepicker\nexport type DateInputRenderingStyle = 'INPUT' | 'LINK';\n\nconst DEFAULT_MIN_DATE = new Date('0000-01-01');\nconst DEFAULT_MAX_DATE = new Date('9999-12-31');\n\n@Component({\n  selector: 'lx-date-input',\n  templateUrl: 'date-input.component.html',\n  styleUrls: ['date-input.component.scss'],\n  providers: [\n    { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DateInputComponent), multi: true },\n    { provide: NG_VALIDATORS, useExisting: forwardRef(() => DateInputComponent), multi: true }\n  ]\n})\nexport class DateInputComponent implements OnChanges, OnInit, OnDestroy, ControlValueAccessor, Validator {\n  @Input() public date: Date | null = null; // main date input; this is also the one used for ngModel & formControl!\n  @Output() dateChange = new EventEmitter<Date | null>(); // triggered whenever the date changes\n  @Input() public dateString: string | null = null; // secondary, alternative input with date string\n  @Output() dateStringChange = new EventEmitter<string | null>(); // triggered whenever the date changes\n  // Determine whether formGroup's value accessor is accessing the selected IDs or the selected objects\n  @Input() public valueAccessor: 'date' | 'dateString' = 'date';\n\n  @Input() public inputId: string = ''; // id to be set on input to correspond to outside label\n  @Input() public renderingStyle: DateInputRenderingStyle = 'INPUT';\n  @Input() public placeholder: string = 'yyyy-mm-dd';\n\n  //--- Inputs replicated from datepicker; (selectionDone) is not needed, as (dateChange) is equivalen\n  @Input() public datepickerMode: string = 'day'; // sets datepicker mode, supports: day, month, year\n  @Input() initDateString!: string; // default date to show if ng-model value is not specified\n  @Observe('initDateString') initDateString$!: Observable<string>; // default date to show if ng-model value is not specified\n  @Input() public minDate = DEFAULT_MIN_DATE; // oldest selectable date\n  @Input() public maxDate = DEFAULT_MAX_DATE; // latest selectable date\n  @Input() public minMode: string = 'day'; // set lower datepicker mode, supports: day, month, year\n  @Input() public maxMode: string = 'year'; // sets upper datepicker mode, supports: day, month, year\n  @Input() public showWeeks: boolean = true; // if false week numbers will be hidden\n  @Input() public formatDay: string = 'DD'; // format of day in month\n  @Input() public formatMonth: string = 'MMMM'; // format of month in year\n  @Input() public formatYear: string = 'YYYY'; // format of year in year range\n  @Input() public formatDayHeader: string = 'dd'; // format of day in week header\n  @Input() public formatDayTitle: string = 'MMMM YYYY'; // format of title when selecting day\n  @Input() public formatMonthTitle: string = 'YYYY'; // format of title when selecting month\n  @Input() startingDay: number = 0; // starting day of the week from 0-6 (0=Sunday, ..., 6=Saturday) public\n  @Input() public yearRange: number = 20; // number of years displayed in year selection\n  @Input() public onlyCurrentMonth: boolean = false; // if true only dates from the currently displayed month will be shown\n  @Input() public shortcutPropagation: boolean = false; //  if true shortcut`s event propagation will be disabled\n  @Input() public customClass: { date: Date; mode: string; clazz: string }[] = []; // array of custom css classes to be applied to\n  // targeted dates\n  @Input() public disabled!: boolean;\n  @Input() public dateDisabled: { date: Date; mode: string }[] = []; // array of disabled dates if mode is day, or years, etc.\n\n  @ViewChild('input') input!: ElementRef<HTMLInputElement>;\n\n  showDatepicker: boolean = false;\n  dateFormat: string;\n  initDate!: Date;\n\n  readonly destroyed$ = new Subject<void>();\n\n  //-- Implement ControlValueAccessor\n  private formControl!: FormControl;\n  hasError: boolean = false;\n  onTouched!: () => void;\n\n  propagateChange = (_date: Date | null) => {};\n\n  constructor(\n    private cd: ChangeDetectorRef,\n    @Inject(DATE_FORMATS) private dateFormatsProvider: DateFormatsProvider,\n    @Optional() @Inject(DATE_FN_LOCALE) private getDateFnLocale?: Function\n  ) {\n    this.dateFormat = this.dateFormatsProvider.getDateFormat();\n    // Patch DatePicker until https://github.com/valor-software/ng2-bootstrap/issues/1385 is resolved\n    const writeValue = DatePickerComponent.prototype.writeValue;\n    DatePickerComponent.prototype.writeValue = function (value) {\n      if (value !== null) {\n        return writeValue.apply(this, arguments as any);\n      }\n    };\n\n    // Somehow datepicker does use a separate moment instance than we do. That one runs on locale en by default.\n    // So we patch the format function here to use our moment instance.\n    // Maybe it will be fixed with: https://github.com/valor-software/ngx-bootstrap/issues/455\n    const locale = this.getDateFnLocale ? this.getDateFnLocale() : null;\n    DateFormatter.prototype.format = function (date: Date, f: string) {\n      return format(date, f, { locale });\n    };\n  }\n\n  ngOnInit() {\n    this.initDateString$.pipe(takeUntil(this.destroyed$)).subscribe((date) => {\n      this.initDate = createDateFromDateString(date) ?? startOfDay(new Date());\n    });\n  }\n\n  public ngOnChanges(changes: SimpleChanges) {\n    if (changes['date']) {\n      this.dateString = this.date ? convertDateToLocaleDateString(this.date) : null;\n    } else if (changes['dateString']) {\n      this.onDateStringChange(this.dateString, false);\n    }\n  }\n\n  public ngOnDestroy() {\n    this.destroyed$.next();\n  }\n\n  public focus() {\n    this.input.nativeElement.focus();\n  }\n\n  public showPopup() {\n    this.showDatepicker = true;\n    this.cd.detectChanges();\n  }\n\n  public togglePopup() {\n    this.showDatepicker = !this.showDatepicker;\n  }\n\n  public hidePopup() {\n    if (this.showDatepicker) {\n      this.showDatepicker = false;\n    }\n  }\n\n  onTab(forward: boolean) {\n    if (forward && this.showDatepicker) {\n      this.hidePopup();\n      return false; // Prevent tab for now as ng2-bootstrap datepicker has a tabstop: 2 tabs needed to navigate for now\n      // TODO: Check again in new version\n    }\n    this.hidePopup();\n    return true;\n  }\n\n  onDateStringChange(newDateString: string | null, emit: boolean = true) {\n    if (isValidDateString(newDateString)) {\n      const date = createDateFromDateString(newDateString);\n      this.updateDate(date, emit);\n    } else if (newDateString === null || newDateString === '') {\n      this.updateDate(null, emit);\n    } else {\n      this.hasError = true;\n      if (this.formControl) {\n        this.formControl.updateValueAndValidity();\n      }\n    }\n  }\n\n  onSelectionDone(newDate: Date) {\n    this.updateDate(newDate);\n    this.hidePopup();\n  }\n\n  onBlur() {\n    if (this.onTouched) {\n      this.onTouched();\n    }\n  }\n\n  private updateDate(date: Date | null, emit: boolean = true) {\n    this.date = date;\n    this.dateString = this.date ? convertDateToLocaleDateString(this.date) : '';\n    if (emit) {\n      this.dateChange.emit(date);\n      this.dateStringChange.emit(this.dateString);\n    }\n    this.propagateChange(date);\n    this.recheckErrors();\n  }\n\n  private recheckErrors() {\n    this.hasError = false;\n    if (this.formControl) {\n      this.formControl.updateValueAndValidity();\n    }\n  }\n\n  //--- Implement ControlValueAccessor\n  /** Write a new value to the element. */\n  writeValue(newDate: Date | string) {\n    if (this.valueAccessor === 'date') {\n      this.date = newDate as Date;\n      this.dateString = convertDateToLocaleDateString(this.date);\n    } else {\n      this.dateString = newDate as string;\n      this.onDateStringChange(this.dateString, false);\n    }\n  }\n\n  /** Set the function to be called when the control receives a change event. */\n  registerOnChange(fn: any) {\n    if (this.valueAccessor === 'date') {\n      this.dateChange.pipe(takeUntil(this.destroyed$)).subscribe(fn);\n    } else if (this.valueAccessor === 'dateString') {\n      this.dateStringChange.pipe(takeUntil(this.destroyed$)).subscribe(fn);\n    }\n  }\n\n  /** Set the function to be called when the control receives a touch event. */\n  registerOnTouched(fn: () => void) {\n    this.onTouched = fn;\n  }\n\n  validate(c: FormControl) {\n    this.formControl = c;\n    return this.hasError\n      ? {\n          dateFormatError: {\n            given: this.dateString,\n            format: 'yyyy-mm-dd'\n          }\n        }\n      : null;\n  }\n}\n","<div class=\"backdrop\" *ngIf=\"showDatepicker\" (click)=\"hidePopup()\"></div>\n<span class=\"wrapper\" [class.forLink]=\"renderingStyle === 'LINK'\" [class.has-error]=\"hasError\">\n  <input\n    #input\n    class=\"form-control dateControl\"\n    placeholder=\"{{ placeholder }}\"\n    [id]=\"inputId\"\n    [(ngModel)]=\"dateString\"\n    [disabled]=\"disabled\"\n    (ngModelChange)=\"onDateStringChange($event)\"\n    (focus)=\"showPopup()\"\n    (blur)=\"onBlur()\"\n    (keydown.enter)=\"hidePopup()\"\n    (keydown.escape)=\"hidePopup()\"\n    (keydown.tab)=\"onTab(true)\"\n    (keydown.shift.tab)=\"onTab(false)\"\n    [class.text-danger]=\"hasError\"\n    *ngIf=\"renderingStyle === 'INPUT'\"\n  />\n  <a class=\"dateControl\" (click)=\"togglePopup()\" *ngIf=\"renderingStyle === 'LINK'\">{{ date | lxDate: dateFormat }}</a>\n  <div class=\"datepickerContainer\">\n    <div class=\"calendar\">\n      <datepicker\n        class=\"popup\"\n        *ngIf=\"showDatepicker\"\n        (selectionDone)=\"onSelectionDone($event)\"\n        [ngModel]=\"date\"\n        [datepickerMode]=\"datepickerMode\"\n        [initDate]=\"initDate\"\n        [minDate]=\"minDate\"\n        [maxDate]=\"maxDate\"\n        [minMode]=\"minMode\"\n        [maxMode]=\"maxMode\"\n        [showWeeks]=\"showWeeks\"\n        [formatDay]=\"formatDay\"\n        [formatMonth]=\"formatMonth\"\n        [formatYear]=\"formatYear\"\n        [formatDayHeader]=\"formatDayHeader\"\n        [formatDayTitle]=\"formatDayTitle\"\n        [formatMonthTitle]=\"formatMonthTitle\"\n        [startingDay]=\"startingDay\"\n        [yearRange]=\"yearRange\"\n        [onlyCurrentMonth]=\"onlyCurrentMonth\"\n        [shortcutPropagation]=\"shortcutPropagation\"\n        [customClass]=\"customClass\"\n        [dateDisabled]=\"dateDisabled\"\n      >\n      </datepicker>\n    </div>\n  </div>\n</span>\n"]}
|
@@ -0,0 +1,5 @@
|
|
1
|
+
/**
|
2
|
+
* Used in the DragAndDropListComponent and KeyboardSortableListDirective
|
3
|
+
*/
|
4
|
+
export const DRAG_AND_DROP_LIST_TRANSLATION_NAME = 'DragAndDropListComponent';
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvZm9ybXMtdWkvY29tcG9uZW50cy9kcmFnLWFuZC1kcm9wLWxpc3QvY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sbUNBQW1DLEdBQUcsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFVzZWQgaW4gdGhlIERyYWdBbmREcm9wTGlzdENvbXBvbmVudCBhbmQgS2V5Ym9hcmRTb3J0YWJsZUxpc3REaXJlY3RpdmVcbiAqL1xuZXhwb3J0IGNvbnN0IERSQUdfQU5EX0RST1BfTElTVF9UUkFOU0xBVElPTl9OQU1FID0gJ0RyYWdBbmREcm9wTGlzdENvbXBvbmVudCc7XG4iXX0=
|
@@ -0,0 +1,49 @@
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, HostBinding, Input, Output } from '@angular/core';
|
2
|
+
import * as i0 from "@angular/core";
|
3
|
+
import * as i1 from "../../../../core-ui/components/button/button.component";
|
4
|
+
import * as i2 from "@angular/common";
|
5
|
+
export class DragAndDropListItemComponent {
|
6
|
+
constructor(element) {
|
7
|
+
this.element = element;
|
8
|
+
this.NAME = 'DragAndDropListItemComponent';
|
9
|
+
this.draggable = true;
|
10
|
+
this.action = new EventEmitter();
|
11
|
+
this.customTemplateRef = null;
|
12
|
+
}
|
13
|
+
get draggingDisabled() {
|
14
|
+
return !this.draggable;
|
15
|
+
}
|
16
|
+
get hasCustomTemplate() {
|
17
|
+
return !!this.customTemplateRef;
|
18
|
+
}
|
19
|
+
trackByAction(_index, action) {
|
20
|
+
return action.id;
|
21
|
+
}
|
22
|
+
focus() {
|
23
|
+
this.element.nativeElement.focus();
|
24
|
+
}
|
25
|
+
}
|
26
|
+
DragAndDropListItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: DragAndDropListItemComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
27
|
+
DragAndDropListItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.5", type: DragAndDropListItemComponent, selector: "lx-drag-and-drop-list-item", inputs: { item: "item", draggable: "draggable", actions: "actions" }, outputs: { action: "action" }, host: { properties: { "class.draggingDisabled": "this.draggingDisabled", "class.customTemplate": "this.hasCustomTemplate" } }, queries: [{ propertyName: "customTemplateRef", first: true, predicate: ["customTemplate"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"customTemplateRef; else defaultTemplate\">\n <ng-container *ngTemplateOutlet=\"customTemplateRef\"></ng-container>\n</ng-container>\n<ng-template #defaultTemplate>\n <div class=\"drag-item-wrappper\">\n <i *ngIf=\"draggable\" class=\"far fa-bars drag-handle\"></i>\n <span [attr.title]=\"item\" class=\"itemWrapperForTruncation truncate\">{{ item }}</span>\n </div>\n <div class=\"left-button-container\" align=\"left\">\n <div class=\"action-buttons-wrapper\" *ngIf=\"!!actions\">\n <button\n lx-button\n *ngFor=\"let act of actions; trackBy: trackByAction\"\n (click)=\"action.emit({ actionId: act.id, item: item })\"\n [title]=\"act.label\"\n [square]=\"true\"\n mode=\"ghost\"\n size=\"small\"\n class=\"action-button\"\n [class.show-on-hover-button]=\"act.showOnlyOnHover ? true : false\"\n >\n <i class=\"far {{ act.icon }} actionIcon\"></i>\n </button>\n </div>\n </div>\n</ng-template>\n", styles: [":host:not(.customTemplate){padding:6px 8px;display:flex;flex-direction:row;align-items:center;justify-content:space-between;box-sizing:border-box;background:#fff;border-radius:3px}:host:not(.customTemplate):hover .show-on-hover-button{opacity:1}:host.draggingDisabled{background:#eaedf1}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drag-handle{padding-right:4px}.actionIcon{padding:0 2px}.drag-item-wrappper{display:flex;min-width:0;align-items:baseline}.left-button-container,.action-buttons-wrapper{display:flex;flex-direction:row;flex-wrap:nowrap}.show-on-hover-button{opacity:0}.show-on-hover-button:focus{opacity:1}lx-option i{margin-right:8px}\n"], components: [{ type: i1.ButtonComponent, selector: "button[lx-button]", inputs: ["size", "color", "mode", "pressed", "selected", "square", "circle", "disabled", "showSpinner"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImport: i0, type: DragAndDropListItemComponent, decorators: [{
|
29
|
+
type: Component,
|
30
|
+
args: [{ selector: 'lx-drag-and-drop-list-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"customTemplateRef; else defaultTemplate\">\n <ng-container *ngTemplateOutlet=\"customTemplateRef\"></ng-container>\n</ng-container>\n<ng-template #defaultTemplate>\n <div class=\"drag-item-wrappper\">\n <i *ngIf=\"draggable\" class=\"far fa-bars drag-handle\"></i>\n <span [attr.title]=\"item\" class=\"itemWrapperForTruncation truncate\">{{ item }}</span>\n </div>\n <div class=\"left-button-container\" align=\"left\">\n <div class=\"action-buttons-wrapper\" *ngIf=\"!!actions\">\n <button\n lx-button\n *ngFor=\"let act of actions; trackBy: trackByAction\"\n (click)=\"action.emit({ actionId: act.id, item: item })\"\n [title]=\"act.label\"\n [square]=\"true\"\n mode=\"ghost\"\n size=\"small\"\n class=\"action-button\"\n [class.show-on-hover-button]=\"act.showOnlyOnHover ? true : false\"\n >\n <i class=\"far {{ act.icon }} actionIcon\"></i>\n </button>\n </div>\n </div>\n</ng-template>\n", styles: [":host:not(.customTemplate){padding:6px 8px;display:flex;flex-direction:row;align-items:center;justify-content:space-between;box-sizing:border-box;background:#fff;border-radius:3px}:host:not(.customTemplate):hover .show-on-hover-button{opacity:1}:host.draggingDisabled{background:#eaedf1}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drag-handle{padding-right:4px}.actionIcon{padding:0 2px}.drag-item-wrappper{display:flex;min-width:0;align-items:baseline}.left-button-container,.action-buttons-wrapper{display:flex;flex-direction:row;flex-wrap:nowrap}.show-on-hover-button{opacity:0}.show-on-hover-button:focus{opacity:1}lx-option i{margin-right:8px}\n"] }]
|
31
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { item: [{
|
32
|
+
type: Input
|
33
|
+
}], draggable: [{
|
34
|
+
type: Input
|
35
|
+
}], actions: [{
|
36
|
+
type: Input
|
37
|
+
}], action: [{
|
38
|
+
type: Output
|
39
|
+
}], draggingDisabled: [{
|
40
|
+
type: HostBinding,
|
41
|
+
args: ['class.draggingDisabled']
|
42
|
+
}], hasCustomTemplate: [{
|
43
|
+
type: HostBinding,
|
44
|
+
args: ['class.customTemplate']
|
45
|
+
}], customTemplateRef: [{
|
46
|
+
type: ContentChild,
|
47
|
+
args: ['customTemplate']
|
48
|
+
}] } });
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1hbmQtZHJvcC1saXN0LWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvZm9ybXMtdWkvY29tcG9uZW50cy9kcmFnLWFuZC1kcm9wLWxpc3QvZHJhZy1hbmQtZHJvcC1saXN0LWl0ZW0vZHJhZy1hbmQtZHJvcC1saXN0LWl0ZW0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvZm9ybXMtdWkvY29tcG9uZW50cy9kcmFnLWFuZC1kcm9wLWxpc3QvZHJhZy1hbmQtZHJvcC1saXN0LWl0ZW0vZHJhZy1hbmQtZHJvcC1saXN0LWl0ZW0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUVaLFlBQVksRUFDWixXQUFXLEVBQ1gsS0FBSyxFQUNMLE1BQU0sRUFFUCxNQUFNLGVBQWUsQ0FBQzs7OztBQW9CdkIsTUFBTSxPQUFPLDRCQUE0QjtJQXNCdkMsWUFBb0IsT0FBbUI7UUFBbkIsWUFBTyxHQUFQLE9BQU8sQ0FBWTtRQXJCOUIsU0FBSSxHQUFHLDhCQUE4QixDQUFDO1FBR3RDLGNBQVMsR0FBWSxJQUFJLENBQUM7UUFNekIsV0FBTSxHQUFHLElBQUksWUFBWSxFQUE4QixDQUFDO1FBVWxDLHNCQUFpQixHQUE0QixJQUFJLENBQUM7SUFFeEMsQ0FBQztJQVYzQyxJQUEyQyxnQkFBZ0I7UUFDekQsT0FBTyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDekIsQ0FBQztJQUVELElBQXlDLGlCQUFpQjtRQUN4RCxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUM7SUFDbEMsQ0FBQztJQU1ELGFBQWEsQ0FBQyxNQUFjLEVBQUUsTUFBNkI7UUFDekQsT0FBTyxNQUFNLENBQUMsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFFRCxLQUFLO1FBQ0gsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDckMsQ0FBQzs7eUhBOUJVLDRCQUE0Qjs2R0FBNUIsNEJBQTRCLHVaQzlCekMsNi9CQTBCQTsyRkRJYSw0QkFBNEI7a0JBTnhDLFNBQVM7K0JBQ0UsNEJBQTRCLG1CQUdyQix1QkFBdUIsQ0FBQyxNQUFNO2lHQUt0QyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFLRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0ksTUFBTTtzQkFBZixNQUFNO2dCQUVvQyxnQkFBZ0I7c0JBQTFELFdBQVc7dUJBQUMsd0JBQXdCO2dCQUlJLGlCQUFpQjtzQkFBekQsV0FBVzt1QkFBQyxzQkFBc0I7Z0JBSUgsaUJBQWlCO3NCQUFoRCxZQUFZO3VCQUFDLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIENvbnRlbnRDaGlsZCxcbiAgRWxlbWVudFJlZixcbiAgRXZlbnRFbWl0dGVyLFxuICBIb3N0QmluZGluZyxcbiAgSW5wdXQsXG4gIE91dHB1dCxcbiAgVGVtcGxhdGVSZWZcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRHJhZ0FuZERyb3BMaXN0QWN0aW9uIHtcbiAgaWQ6IHN0cmluZztcbiAgbGFiZWw6IHN0cmluZztcbiAgaWNvbjogc3RyaW5nO1xuICBzaG93T25seU9uSG92ZXI/OiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERyYWdBbmREcm9wTGlzdEFjdGlvbkV2ZW50IHtcbiAgYWN0aW9uSWQ6IHN0cmluZztcbiAgaXRlbTogc3RyaW5nO1xufVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdseC1kcmFnLWFuZC1kcm9wLWxpc3QtaXRlbScsXG4gIHRlbXBsYXRlVXJsOiAnZHJhZy1hbmQtZHJvcC1saXN0LWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnZHJhZy1hbmQtZHJvcC1saXN0LWl0ZW0uY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRHJhZ0FuZERyb3BMaXN0SXRlbUNvbXBvbmVudCB7XG4gIHJlYWRvbmx5IE5BTUUgPSAnRHJhZ0FuZERyb3BMaXN0SXRlbUNvbXBvbmVudCc7XG5cbiAgQElucHV0KCkgaXRlbSE6IHN0cmluZztcbiAgQElucHV0KCkgZHJhZ2dhYmxlOiBib29sZWFuID0gdHJ1ZTtcbiAgLyoqXG4gICAqIEFuIGFycmF5IG9mIERyYWdBbmREcm9wTGlzdEFjdGlvbnNcbiAgICogV2hlbiB0aGlzIGFycmF5IGlzIGRlZmluZWQsIHRoZSBkcmFnIGhhbmRsZSBpcyBzaG93biBhdCB0aGUgc3RhcnQgb2YgYW4gaXRlbSBhbmQgdGhlIGFjdGlvbiBidXR0b25zIGFyZSByZW5kZXJlZCBpbiB0aGVpciBwcm92aWRlZCBvcmRlciBhdCB0aGUgcmlnaHQgZW5kIG9mIGFuIGl0ZW0uXG4gICAqL1xuICBASW5wdXQoKSBhY3Rpb25zPzogRHJhZ0FuZERyb3BMaXN0QWN0aW9uW107XG4gIEBPdXRwdXQoKSBhY3Rpb24gPSBuZXcgRXZlbnRFbWl0dGVyPERyYWdBbmREcm9wTGlzdEFjdGlvbkV2ZW50PigpO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MuZHJhZ2dpbmdEaXNhYmxlZCcpIGdldCBkcmFnZ2luZ0Rpc2FibGVkKCkge1xuICAgIHJldHVybiAhdGhpcy5kcmFnZ2FibGU7XG4gIH1cblxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLmN1c3RvbVRlbXBsYXRlJykgZ2V0IGhhc0N1c3RvbVRlbXBsYXRlKCkge1xuICAgIHJldHVybiAhIXRoaXMuY3VzdG9tVGVtcGxhdGVSZWY7XG4gIH1cblxuICBAQ29udGVudENoaWxkKCdjdXN0b21UZW1wbGF0ZScpIGN1c3RvbVRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+IHwgbnVsbCA9IG51bGw7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBlbGVtZW50OiBFbGVtZW50UmVmKSB7fVxuXG4gIHRyYWNrQnlBY3Rpb24oX2luZGV4OiBudW1iZXIsIGFjdGlvbjogRHJhZ0FuZERyb3BMaXN0QWN0aW9uKSB7XG4gICAgcmV0dXJuIGFjdGlvbi5pZDtcbiAgfVxuXG4gIGZvY3VzKCk6IHZvaWQge1xuICAgIHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50LmZvY3VzKCk7XG4gIH1cbn1cbiIsIjxuZy1jb250YWluZXIgKm5nSWY9XCJjdXN0b21UZW1wbGF0ZVJlZjsgZWxzZSBkZWZhdWx0VGVtcGxhdGVcIj5cbiAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImN1c3RvbVRlbXBsYXRlUmVmXCI+PC9uZy1jb250YWluZXI+XG48L25nLWNvbnRhaW5lcj5cbjxuZy10ZW1wbGF0ZSAjZGVmYXVsdFRlbXBsYXRlPlxuICA8ZGl2IGNsYXNzPVwiZHJhZy1pdGVtLXdyYXBwcGVyXCI+XG4gICAgPGkgKm5nSWY9XCJkcmFnZ2FibGVcIiBjbGFzcz1cImZhciBmYS1iYXJzIGRyYWctaGFuZGxlXCI+PC9pPlxuICAgIDxzcGFuIFthdHRyLnRpdGxlXT1cIml0ZW1cIiBjbGFzcz1cIml0ZW1XcmFwcGVyRm9yVHJ1bmNhdGlvbiB0cnVuY2F0ZVwiPnt7IGl0ZW0gfX08L3NwYW4+XG4gIDwvZGl2PlxuICA8ZGl2IGNsYXNzPVwibGVmdC1idXR0b24tY29udGFpbmVyXCIgYWxpZ249XCJsZWZ0XCI+XG4gICAgPGRpdiBjbGFzcz1cImFjdGlvbi1idXR0b25zLXdyYXBwZXJcIiAqbmdJZj1cIiEhYWN0aW9uc1wiPlxuICAgICAgPGJ1dHRvblxuICAgICAgICBseC1idXR0b25cbiAgICAgICAgKm5nRm9yPVwibGV0IGFjdCBvZiBhY3Rpb25zOyB0cmFja0J5OiB0cmFja0J5QWN0aW9uXCJcbiAgICAgICAgKGNsaWNrKT1cImFjdGlvbi5lbWl0KHsgYWN0aW9uSWQ6IGFjdC5pZCwgaXRlbTogaXRlbSB9KVwiXG4gICAgICAgIFt0aXRsZV09XCJhY3QubGFiZWxcIlxuICAgICAgICBbc3F1YXJlXT1cInRydWVcIlxuICAgICAgICBtb2RlPVwiZ2hvc3RcIlxuICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICBjbGFzcz1cImFjdGlvbi1idXR0b25cIlxuICAgICAgICBbY2xhc3Muc2hvdy1vbi1ob3Zlci1idXR0b25dPVwiYWN0LnNob3dPbmx5T25Ib3ZlciA/IHRydWUgOiBmYWxzZVwiXG4gICAgICA+XG4gICAgICAgIDxpIGNsYXNzPVwiZmFyIHt7IGFjdC5pY29uIH19IGFjdGlvbkljb25cIj48L2k+XG4gICAgICA8L2J1dHRvbj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L25nLXRlbXBsYXRlPlxuIl19
|