@ecodev/natural 41.3.0 → 42.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/ecodev-natural.d.ts +1 -9
- package/esm2020/ecodev-natural.mjs +5 -0
- package/esm2020/lib/classes/abstract-controller.mjs +30 -0
- package/esm2020/lib/classes/abstract-detail.mjs +152 -0
- package/esm2020/lib/classes/abstract-editable-list.mjs +96 -0
- package/esm2020/lib/classes/abstract-list.mjs +406 -0
- package/esm2020/lib/classes/abstract-navigable-list.mjs +126 -0
- package/{esm2015/lib/classes/apollo-utils.js → esm2020/lib/classes/apollo-utils.mjs} +0 -0
- package/esm2020/lib/classes/data-source.mjs +76 -0
- package/{esm2015/lib/classes/query-variable-manager-utils.js → esm2020/lib/classes/query-variable-manager-utils.mjs} +0 -0
- package/esm2020/lib/classes/query-variable-manager.mjs +172 -0
- package/{esm2015/lib/classes/rxjs.js → esm2020/lib/classes/rxjs.mjs} +0 -0
- package/{esm2015/lib/classes/tld.js → esm2020/lib/classes/tld.mjs} +0 -0
- package/{esm2015/lib/classes/utility.js → esm2020/lib/classes/utility.mjs} +0 -0
- package/esm2020/lib/classes/validators.mjs +179 -0
- package/esm2020/lib/directives/http-prefix.directive.mjs +50 -0
- package/esm2020/lib/modules/alert/alert.module.mjs +20 -0
- package/esm2020/lib/modules/alert/alert.service.mjs +55 -0
- package/esm2020/lib/modules/alert/confirm.component.mjs +20 -0
- package/{esm2015/lib/modules/alert/public-api.js → esm2020/lib/modules/alert/public-api.mjs} +0 -0
- package/esm2020/lib/modules/avatar/avatar.module.mjs +19 -0
- package/esm2020/lib/modules/avatar/component/avatar.component.mjs +190 -0
- package/{esm2015/lib/modules/avatar/public-api.js → esm2020/lib/modules/avatar/public-api.mjs} +0 -0
- package/esm2020/lib/modules/avatar/service/avatar.service.mjs +66 -0
- package/esm2020/lib/modules/avatar/sources/gravatar.mjs +29 -0
- package/{esm2015/lib/modules/avatar/sources/image.js → esm2020/lib/modules/avatar/sources/image.mjs} +0 -0
- package/{esm2015/lib/modules/avatar/sources/initials.js → esm2020/lib/modules/avatar/sources/initials.mjs} +0 -0
- package/{esm2015/lib/modules/avatar/sources/source.js → esm2020/lib/modules/avatar/sources/source.mjs} +1 -1
- package/esm2020/lib/modules/columns-picker/columns-picker-column.directive.mjs +43 -0
- package/esm2020/lib/modules/columns-picker/columns-picker.component.mjs +84 -0
- package/esm2020/lib/modules/columns-picker/columns-picker.module.mjs +47 -0
- package/{esm2015/lib/modules/columns-picker/public-api.js → esm2020/lib/modules/columns-picker/public-api.mjs} +0 -0
- package/esm2020/lib/modules/common/common-module.mjs +50 -0
- package/esm2020/lib/modules/common/directives/linkable-tab.directive.mjs +79 -0
- package/esm2020/lib/modules/common/directives/src-density.directive.mjs +62 -0
- package/esm2020/lib/modules/common/pipes/capitalize.pipe.mjs +18 -0
- package/esm2020/lib/modules/common/pipes/ellipsis.pipe.mjs +14 -0
- package/esm2020/lib/modules/common/pipes/enum.pipe.mjs +25 -0
- package/esm2020/lib/modules/common/pipes/swiss-date.pipe.mjs +20 -0
- package/esm2020/lib/modules/common/public-api.mjs +13 -0
- package/esm2020/lib/modules/common/services/memory-storage.mjs +112 -0
- package/esm2020/lib/modules/common/services/seo.service.mjs +114 -0
- package/esm2020/lib/modules/detail-header/detail-header.component.mjs +76 -0
- package/esm2020/lib/modules/detail-header/detail-header.module.mjs +21 -0
- package/{esm2015/lib/modules/detail-header/public-api.js → esm2020/lib/modules/detail-header/public-api.mjs} +0 -0
- package/esm2020/lib/modules/dialog-trigger/dialog-trigger.component.mjs +69 -0
- package/esm2020/lib/modules/dialog-trigger/dialog-trigger.module.mjs +19 -0
- package/{esm2015/lib/modules/dialog-trigger/public-api.js → esm2020/lib/modules/dialog-trigger/public-api.mjs} +0 -0
- package/esm2020/lib/modules/dropdown-components/abstract-association-select-component.directive.mjs +98 -0
- package/esm2020/lib/modules/dropdown-components/natural-dropdown-components.module.mjs +92 -0
- package/{esm2015/lib/modules/dropdown-components/public-api.js → esm2020/lib/modules/dropdown-components/public-api.mjs} +0 -0
- package/esm2020/lib/modules/dropdown-components/type-date/type-date.component.mjs +133 -0
- package/esm2020/lib/modules/dropdown-components/type-date-range/type-date-range.component.mjs +137 -0
- package/esm2020/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.mjs +69 -0
- package/esm2020/lib/modules/dropdown-components/type-natural-select/type-natural-select.component.mjs +38 -0
- package/esm2020/lib/modules/dropdown-components/type-number/type-number.component.mjs +104 -0
- package/esm2020/lib/modules/dropdown-components/type-select/type-select.component.mjs +169 -0
- package/esm2020/lib/modules/dropdown-components/type-text/type-text.component.mjs +57 -0
- package/{esm2015/lib/modules/dropdown-components/types.js → esm2020/lib/modules/dropdown-components/types.mjs} +0 -0
- package/{esm2015/lib/modules/dropdown-components/utils.js → esm2020/lib/modules/dropdown-components/utils.mjs} +0 -0
- package/esm2020/lib/modules/file/abstract-file.mjs +231 -0
- package/esm2020/lib/modules/file/component/file.component.mjs +143 -0
- package/esm2020/lib/modules/file/file-drop.directive.mjs +110 -0
- package/esm2020/lib/modules/file/file-select.directive.mjs +28 -0
- package/esm2020/lib/modules/file/file.module.mjs +24 -0
- package/esm2020/lib/modules/file/file.service.mjs +48 -0
- package/{esm2015/lib/modules/file/public-api.js → esm2020/lib/modules/file/public-api.mjs} +0 -0
- package/{esm2015/lib/modules/file/types.js → esm2020/lib/modules/file/types.mjs} +0 -0
- package/{esm2015/lib/modules/file/utils.js → esm2020/lib/modules/file/utils.mjs} +3 -4
- package/esm2020/lib/modules/fixed-button/fixed-button.component.mjs +27 -0
- package/esm2020/lib/modules/fixed-button/fixed-button.module.mjs +21 -0
- package/{esm2015/lib/modules/fixed-button/public-api.js → esm2020/lib/modules/fixed-button/public-api.mjs} +0 -0
- package/esm2020/lib/modules/fixed-button-detail/fixed-button-detail.component.mjs +36 -0
- package/esm2020/lib/modules/fixed-button-detail/fixed-button-detail.module.mjs +20 -0
- package/{esm2015/lib/modules/fixed-button-detail/public-api.js → esm2020/lib/modules/fixed-button-detail/public-api.mjs} +0 -0
- package/{esm2015/lib/modules/hierarchic-selector/classes/flat-node.js → esm2020/lib/modules/hierarchic-selector/classes/flat-node.mjs} +1 -1
- package/{esm2015/lib/modules/hierarchic-selector/classes/hierarchic-configuration.js → esm2020/lib/modules/hierarchic-selector/classes/hierarchic-configuration.mjs} +0 -0
- package/{esm2015/lib/modules/hierarchic-selector/classes/hierarchic-filters-configuration.js → esm2020/lib/modules/hierarchic-selector/classes/hierarchic-filters-configuration.mjs} +0 -0
- package/{esm2015/lib/modules/hierarchic-selector/classes/model-node.js → esm2020/lib/modules/hierarchic-selector/classes/model-node.mjs} +1 -1
- package/esm2020/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.mjs +364 -0
- package/esm2020/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.mjs +258 -0
- package/esm2020/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.mjs +31 -0
- package/esm2020/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.mjs +23 -0
- package/esm2020/lib/modules/hierarchic-selector/hierarchic-selector.module.mjs +81 -0
- package/{esm2015/lib/modules/hierarchic-selector/public-api.js → esm2020/lib/modules/hierarchic-selector/public-api.mjs} +0 -0
- package/esm2020/lib/modules/icon/icon.component.mjs +92 -0
- package/esm2020/lib/modules/icon/icon.module.mjs +30 -0
- package/{esm2015/lib/modules/icon/public-api.js → esm2020/lib/modules/icon/public-api.mjs} +0 -0
- package/esm2020/lib/modules/matomo/matomo-module.module.mjs +12 -0
- package/esm2020/lib/modules/matomo/matomo.service.mjs +105 -0
- package/{esm2015/lib/modules/matomo/public-api.js → esm2020/lib/modules/matomo/public-api.mjs} +0 -0
- package/esm2020/lib/modules/panels/abstract-panel.mjs +56 -0
- package/{esm2015/lib/modules/panels/fallback-if-no-opened-panels.urlmatcher.js → esm2020/lib/modules/panels/fallback-if-no-opened-panels.urlmatcher.mjs} +0 -0
- package/esm2020/lib/modules/panels/panels.component.mjs +26 -0
- package/esm2020/lib/modules/panels/panels.module.mjs +33 -0
- package/esm2020/lib/modules/panels/panels.service.mjs +325 -0
- package/{esm2015/lib/modules/panels/panels.urlmatcher.js → esm2020/lib/modules/panels/panels.urlmatcher.mjs} +0 -0
- package/{esm2015/lib/modules/panels/public-api.js → esm2020/lib/modules/panels/public-api.mjs} +0 -0
- package/{esm2015/lib/modules/panels/types.js → esm2020/lib/modules/panels/types.mjs} +0 -0
- package/{esm2015/lib/modules/relations/public-api.js → esm2020/lib/modules/relations/public-api.mjs} +0 -0
- package/esm2020/lib/modules/relations/relations.component.mjs +198 -0
- package/esm2020/lib/modules/relations/relations.module.mjs +58 -0
- package/{esm2015/lib/modules/search/classes/graphql-doctrine.js → esm2020/lib/modules/search/classes/graphql-doctrine.mjs} +0 -0
- package/{esm2015/lib/modules/search/classes/graphql-doctrine.types.js → esm2020/lib/modules/search/classes/graphql-doctrine.types.mjs} +0 -0
- package/{esm2015/lib/modules/search/classes/transformers.js → esm2020/lib/modules/search/classes/transformers.mjs} +0 -0
- package/{esm2015/lib/modules/search/classes/url.js → esm2020/lib/modules/search/classes/url.mjs} +0 -0
- package/{esm2015/lib/modules/search/classes/utils.js → esm2020/lib/modules/search/classes/utils.mjs} +0 -0
- package/{esm2015/lib/modules/search/dropdown-container/dropdown-container-animations.js → esm2020/lib/modules/search/dropdown-container/dropdown-container-animations.mjs} +0 -0
- package/esm2020/lib/modules/search/dropdown-container/dropdown-container.component.mjs +88 -0
- package/{esm2015/lib/modules/search/dropdown-container/dropdown-ref.js → esm2020/lib/modules/search/dropdown-container/dropdown-ref.mjs} +1 -1
- package/esm2020/lib/modules/search/dropdown-container/dropdown.service.mjs +93 -0
- package/esm2020/lib/modules/search/facet-selector/facet-selector.component.mjs +50 -0
- package/esm2020/lib/modules/search/group/group.component.mjs +45 -0
- package/esm2020/lib/modules/search/input/input.component.mjs +328 -0
- package/{esm2015/lib/modules/search/public-api.js → esm2020/lib/modules/search/public-api.mjs} +0 -0
- package/esm2020/lib/modules/search/search/search.component.mjs +78 -0
- package/esm2020/lib/modules/search/search.module.mjs +84 -0
- package/{esm2015/lib/modules/search/types/dropdown-component.js → esm2020/lib/modules/search/types/dropdown-component.mjs} +0 -0
- package/{esm2015/lib/modules/search/types/facet.js → esm2020/lib/modules/search/types/facet.mjs} +0 -0
- package/{esm2015/lib/modules/search/types/values.js → esm2020/lib/modules/search/types/values.mjs} +0 -0
- package/esm2020/lib/modules/select/abstract-select.component.mjs +186 -0
- package/{esm2015/lib/modules/select/public-api.js → esm2020/lib/modules/select/public-api.mjs} +0 -0
- package/esm2020/lib/modules/select/select/select.component.mjs +207 -0
- package/esm2020/lib/modules/select/select-enum/select-enum.component.mjs +47 -0
- package/esm2020/lib/modules/select/select-hierarchic/select-hierarchic.component.mjs +127 -0
- package/esm2020/lib/modules/select/select.module.mjs +68 -0
- package/{esm2015/lib/modules/sidenav/public-api.js → esm2020/lib/modules/sidenav/public-api.mjs} +0 -0
- package/esm2020/lib/modules/sidenav/sidenav/sidenav.component.mjs +15 -0
- package/esm2020/lib/modules/sidenav/sidenav-container/sidenav-container.component.mjs +87 -0
- package/esm2020/lib/modules/sidenav/sidenav-content/sidenav-content.component.mjs +12 -0
- package/esm2020/lib/modules/sidenav/sidenav-stack.service.mjs +52 -0
- package/esm2020/lib/modules/sidenav/sidenav.module.mjs +25 -0
- package/esm2020/lib/modules/sidenav/sidenav.service.mjs +195 -0
- package/{esm2015/lib/modules/stamp/public-api.js → esm2020/lib/modules/stamp/public-api.mjs} +0 -0
- package/esm2020/lib/modules/stamp/stamp-module.module.mjs +18 -0
- package/esm2020/lib/modules/stamp/stamp.component.mjs +14 -0
- package/{esm2015/lib/modules/table-button/public-api.js → esm2020/lib/modules/table-button/public-api.mjs} +0 -0
- package/esm2020/lib/modules/table-button/table-button.component.mjs +48 -0
- package/esm2020/lib/modules/table-button/table-button.module.mjs +21 -0
- package/esm2020/lib/services/abstract-model.service.mjs +509 -0
- package/esm2020/lib/services/enum.service.mjs +67 -0
- package/esm2020/lib/services/link-mutation.service.mjs +153 -0
- package/esm2020/lib/services/persistence.service.mjs +113 -0
- package/esm2020/lib/services/swiss-parsing-date-adapter.service.mjs +55 -0
- package/{esm2015/lib/types/types.js → esm2020/lib/types/types.mjs} +0 -0
- package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
- package/fesm2015/{ecodev-natural.js → ecodev-natural.mjs} +2808 -2392
- package/fesm2015/ecodev-natural.mjs.map +1 -0
- package/fesm2020/ecodev-natural.mjs +10495 -0
- package/fesm2020/ecodev-natural.mjs.map +1 -0
- package/lib/classes/abstract-controller.d.ts +3 -0
- package/lib/classes/abstract-detail.d.ts +3 -0
- package/lib/classes/abstract-editable-list.d.ts +3 -0
- package/lib/classes/abstract-list.d.ts +3 -0
- package/lib/classes/abstract-navigable-list.d.ts +3 -0
- package/lib/classes/query-variable-manager.d.ts +19 -8
- package/lib/directives/http-prefix.directive.d.ts +3 -0
- package/lib/modules/alert/alert.module.d.ts +9 -0
- package/lib/modules/alert/alert.service.d.ts +3 -0
- package/lib/modules/alert/confirm.component.d.ts +3 -0
- package/lib/modules/avatar/avatar.module.d.ts +6 -0
- package/lib/modules/avatar/component/avatar.component.d.ts +4 -0
- package/lib/modules/avatar/service/avatar.service.d.ts +3 -0
- package/lib/modules/columns-picker/columns-picker-column.directive.d.ts +3 -0
- package/lib/modules/columns-picker/columns-picker.component.d.ts +3 -0
- package/lib/modules/columns-picker/columns-picker.module.d.ts +13 -0
- package/lib/modules/common/common-module.d.ts +15 -0
- package/lib/modules/common/directives/linkable-tab.directive.d.ts +3 -0
- package/lib/modules/common/directives/src-density.directive.d.ts +3 -0
- package/lib/modules/common/pipes/capitalize.pipe.d.ts +3 -0
- package/lib/modules/common/pipes/ellipsis.pipe.d.ts +3 -0
- package/lib/modules/common/pipes/enum.pipe.d.ts +3 -0
- package/lib/modules/common/pipes/swiss-date.pipe.d.ts +3 -0
- package/lib/modules/common/public-api.d.ts +0 -1
- package/lib/modules/common/services/memory-storage.d.ts +3 -0
- package/lib/modules/common/services/seo.service.d.ts +3 -0
- package/lib/modules/detail-header/detail-header.component.d.ts +3 -0
- package/lib/modules/detail-header/detail-header.module.d.ts +9 -0
- package/lib/modules/dialog-trigger/dialog-trigger.component.d.ts +3 -0
- package/lib/modules/dialog-trigger/dialog-trigger.module.d.ts +7 -0
- package/lib/modules/dropdown-components/abstract-association-select-component.directive.d.ts +3 -0
- package/lib/modules/dropdown-components/natural-dropdown-components.module.d.ts +22 -0
- package/lib/modules/dropdown-components/type-date/type-date.component.d.ts +3 -0
- package/lib/modules/dropdown-components/type-date-range/type-date-range.component.d.ts +3 -0
- package/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.d.ts +3 -0
- package/lib/modules/dropdown-components/type-natural-select/type-natural-select.component.d.ts +3 -0
- package/lib/modules/dropdown-components/type-number/type-number.component.d.ts +3 -0
- package/lib/modules/dropdown-components/type-select/type-select.component.d.ts +3 -0
- package/lib/modules/dropdown-components/type-text/type-text.component.d.ts +3 -0
- package/lib/modules/file/abstract-file.d.ts +3 -0
- package/lib/modules/file/component/file.component.d.ts +3 -0
- package/lib/modules/file/file-drop.directive.d.ts +3 -0
- package/lib/modules/file/file-select.directive.d.ts +3 -0
- package/lib/modules/file/file.module.d.ts +11 -0
- package/lib/modules/file/file.service.d.ts +3 -0
- package/lib/modules/fixed-button/fixed-button.component.d.ts +3 -0
- package/lib/modules/fixed-button/fixed-button.module.d.ts +9 -0
- package/lib/modules/fixed-button-detail/fixed-button-detail.component.d.ts +3 -0
- package/lib/modules/fixed-button-detail/fixed-button-detail.module.d.ts +8 -0
- package/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.d.ts +3 -0
- package/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.d.ts +3 -0
- package/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.d.ts +3 -0
- package/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.d.ts +3 -0
- package/lib/modules/hierarchic-selector/hierarchic-selector.module.d.ts +21 -0
- package/lib/modules/icon/icon.component.d.ts +3 -0
- package/lib/modules/icon/icon.module.d.ts +7 -0
- package/lib/modules/matomo/matomo-module.module.d.ts +4 -0
- package/lib/modules/matomo/matomo.service.d.ts +3 -0
- package/lib/modules/panels/abstract-panel.d.ts +3 -0
- package/lib/modules/panels/panels.component.d.ts +3 -0
- package/lib/modules/panels/panels.module.d.ts +8 -0
- package/lib/modules/panels/panels.service.d.ts +3 -0
- package/lib/modules/relations/relations.component.d.ts +3 -0
- package/lib/modules/relations/relations.module.d.ts +15 -0
- package/lib/modules/search/dropdown-container/dropdown-container.component.d.ts +3 -0
- package/lib/modules/search/dropdown-container/dropdown-ref.d.ts +1 -1
- package/lib/modules/search/dropdown-container/dropdown.service.d.ts +3 -0
- package/lib/modules/search/facet-selector/facet-selector.component.d.ts +3 -0
- package/lib/modules/search/group/group.component.d.ts +3 -0
- package/lib/modules/search/input/input.component.d.ts +3 -0
- package/lib/modules/search/search/search.component.d.ts +3 -0
- package/lib/modules/search/search.module.d.ts +19 -0
- package/lib/modules/select/abstract-select.component.d.ts +4 -1
- package/lib/modules/select/select/select.component.d.ts +3 -0
- package/lib/modules/select/select-enum/select-enum.component.d.ts +9 -2
- package/lib/modules/select/select-hierarchic/select-hierarchic.component.d.ts +3 -0
- package/lib/modules/select/select.module.d.ts +19 -0
- package/lib/modules/sidenav/sidenav/sidenav.component.d.ts +3 -0
- package/lib/modules/sidenav/sidenav-container/sidenav-container.component.d.ts +3 -0
- package/lib/modules/sidenav/sidenav-content/sidenav-content.component.d.ts +3 -0
- package/lib/modules/sidenav/sidenav-stack.service.d.ts +4 -1
- package/lib/modules/sidenav/sidenav.module.d.ts +11 -0
- package/lib/modules/sidenav/sidenav.service.d.ts +3 -0
- package/lib/modules/stamp/stamp-module.module.d.ts +6 -0
- package/lib/modules/stamp/stamp.component.d.ts +3 -0
- package/lib/modules/table-button/table-button.component.d.ts +3 -0
- package/lib/modules/table-button/table-button.module.d.ts +9 -0
- package/lib/services/enum.service.d.ts +3 -0
- package/lib/services/link-mutation.service.d.ts +3 -0
- package/lib/services/persistence.service.d.ts +3 -0
- package/lib/services/swiss-parsing-date-adapter.service.d.ts +4 -1
- package/package.json +25 -12
- package/src/lib/modules/alert/_alert.theme.scss +1 -1
- package/src/lib/modules/file/component/_file.theme.scss +1 -1
- package/src/lib/modules/icon/_icon.theme.scss +1 -1
- package/src/lib/modules/search/dropdown-container/_dropdown-container.theme.scss +1 -1
- package/src/lib/modules/table-button/_table-button.theme.scss +1 -1
- package/src/lib/styles/_table.scss +1 -1
- package/theming/_natural.theme.scss +1 -1
- package/bundles/ecodev-natural.umd.js +0 -11318
- package/bundles/ecodev-natural.umd.js.map +0 -1
- package/ecodev-natural.metadata.json +0 -1
- package/esm2015/ecodev-natural.js +0 -14
- package/esm2015/lib/classes/abstract-controller.js +0 -29
- package/esm2015/lib/classes/abstract-detail.js +0 -157
- package/esm2015/lib/classes/abstract-editable-list.js +0 -97
- package/esm2015/lib/classes/abstract-list.js +0 -409
- package/esm2015/lib/classes/abstract-navigable-list.js +0 -126
- package/esm2015/lib/classes/data-source.js +0 -76
- package/esm2015/lib/classes/query-variable-manager.js +0 -161
- package/esm2015/lib/classes/validators.js +0 -176
- package/esm2015/lib/directives/http-prefix.directive.js +0 -46
- package/esm2015/lib/modules/alert/alert.module.js +0 -15
- package/esm2015/lib/modules/alert/alert.service.js +0 -59
- package/esm2015/lib/modules/alert/confirm.component.js +0 -17
- package/esm2015/lib/modules/avatar/avatar.module.js +0 -14
- package/esm2015/lib/modules/avatar/component/avatar.component.js +0 -158
- package/esm2015/lib/modules/avatar/service/avatar.service.js +0 -65
- package/esm2015/lib/modules/avatar/sources/gravatar.js +0 -29
- package/esm2015/lib/modules/columns-picker/columns-picker-column.directive.js +0 -41
- package/esm2015/lib/modules/columns-picker/columns-picker.component.js +0 -82
- package/esm2015/lib/modules/columns-picker/columns-picker.module.js +0 -28
- package/esm2015/lib/modules/common/common-module.js +0 -35
- package/esm2015/lib/modules/common/directives/linkable-tab.directive.js +0 -82
- package/esm2015/lib/modules/common/directives/reactive-asterisk.directive.js +0 -31
- package/esm2015/lib/modules/common/directives/src-density.directive.js +0 -63
- package/esm2015/lib/modules/common/pipes/capitalize.pipe.js +0 -14
- package/esm2015/lib/modules/common/pipes/ellipsis.pipe.js +0 -10
- package/esm2015/lib/modules/common/pipes/enum.pipe.js +0 -24
- package/esm2015/lib/modules/common/pipes/swiss-date.pipe.js +0 -16
- package/esm2015/lib/modules/common/public-api.js +0 -14
- package/esm2015/lib/modules/common/services/memory-storage.js +0 -110
- package/esm2015/lib/modules/common/services/seo.service.js +0 -120
- package/esm2015/lib/modules/detail-header/detail-header.component.js +0 -63
- package/esm2015/lib/modules/detail-header/detail-header.module.js +0 -16
- package/esm2015/lib/modules/dialog-trigger/dialog-trigger.component.js +0 -68
- package/esm2015/lib/modules/dialog-trigger/dialog-trigger.module.js +0 -14
- package/esm2015/lib/modules/dropdown-components/abstract-association-select-component.directive.js +0 -96
- package/esm2015/lib/modules/dropdown-components/natural-dropdown-components.module.js +0 -51
- package/esm2015/lib/modules/dropdown-components/type-date/type-date.component.js +0 -123
- package/esm2015/lib/modules/dropdown-components/type-date-range/type-date-range.component.js +0 -128
- package/esm2015/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.js +0 -63
- package/esm2015/lib/modules/dropdown-components/type-natural-select/type-natural-select.component.js +0 -31
- package/esm2015/lib/modules/dropdown-components/type-number/type-number.component.js +0 -99
- package/esm2015/lib/modules/dropdown-components/type-select/type-select.component.js +0 -161
- package/esm2015/lib/modules/dropdown-components/type-text/type-text.component.js +0 -53
- package/esm2015/lib/modules/file/abstract-file.js +0 -223
- package/esm2015/lib/modules/file/component/file.component.js +0 -133
- package/esm2015/lib/modules/file/file-drop.directive.js +0 -99
- package/esm2015/lib/modules/file/file-select.directive.js +0 -25
- package/esm2015/lib/modules/file/file.module.js +0 -19
- package/esm2015/lib/modules/file/file.service.js +0 -47
- package/esm2015/lib/modules/fixed-button/fixed-button.component.js +0 -23
- package/esm2015/lib/modules/fixed-button/fixed-button.module.js +0 -16
- package/esm2015/lib/modules/fixed-button-detail/fixed-button-detail.component.js +0 -31
- package/esm2015/lib/modules/fixed-button-detail/fixed-button-detail.module.js +0 -15
- package/esm2015/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.js +0 -351
- package/esm2015/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.js +0 -258
- package/esm2015/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.js +0 -28
- package/esm2015/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.js +0 -23
- package/esm2015/lib/modules/hierarchic-selector/hierarchic-selector.module.js +0 -46
- package/esm2015/lib/modules/icon/icon.component.js +0 -78
- package/esm2015/lib/modules/icon/icon.module.js +0 -25
- package/esm2015/lib/modules/matomo/matomo-module.module.js +0 -7
- package/esm2015/lib/modules/matomo/matomo.service.js +0 -106
- package/esm2015/lib/modules/panels/abstract-panel.js +0 -50
- package/esm2015/lib/modules/panels/panels.component.js +0 -26
- package/esm2015/lib/modules/panels/panels.module.js +0 -28
- package/esm2015/lib/modules/panels/panels.service.js +0 -331
- package/esm2015/lib/modules/relations/relations.component.js +0 -181
- package/esm2015/lib/modules/relations/relations.module.js +0 -33
- package/esm2015/lib/modules/search/dropdown-container/dropdown-container.component.js +0 -87
- package/esm2015/lib/modules/search/dropdown-container/dropdown.service.js +0 -95
- package/esm2015/lib/modules/search/facet-selector/facet-selector.component.js +0 -47
- package/esm2015/lib/modules/search/group/group.component.js +0 -39
- package/esm2015/lib/modules/search/input/input.component.js +0 -316
- package/esm2015/lib/modules/search/search/search.component.js +0 -71
- package/esm2015/lib/modules/search/search.module.js +0 -52
- package/esm2015/lib/modules/select/abstract-select.component.js +0 -176
- package/esm2015/lib/modules/select/select/select.component.js +0 -190
- package/esm2015/lib/modules/select/select-enum/select-enum.component.js +0 -34
- package/esm2015/lib/modules/select/select-hierarchic/select-hierarchic.component.js +0 -120
- package/esm2015/lib/modules/select/select.module.js +0 -39
- package/esm2015/lib/modules/sidenav/sidenav/sidenav.component.js +0 -12
- package/esm2015/lib/modules/sidenav/sidenav-container/sidenav-container.component.js +0 -79
- package/esm2015/lib/modules/sidenav/sidenav-content/sidenav-content.component.js +0 -13
- package/esm2015/lib/modules/sidenav/sidenav-stack.service.js +0 -50
- package/esm2015/lib/modules/sidenav/sidenav.module.js +0 -20
- package/esm2015/lib/modules/sidenav/sidenav.service.js +0 -199
- package/esm2015/lib/modules/stamp/stamp-module.module.js +0 -13
- package/esm2015/lib/modules/stamp/stamp.component.js +0 -13
- package/esm2015/lib/modules/table-button/table-button.component.js +0 -38
- package/esm2015/lib/modules/table-button/table-button.module.js +0 -16
- package/esm2015/lib/services/abstract-model.service.js +0 -509
- package/esm2015/lib/services/enum.service.js +0 -68
- package/esm2015/lib/services/link-mutation.service.js +0 -155
- package/esm2015/lib/services/persistence.service.js +0 -114
- package/esm2015/lib/services/swiss-parsing-date-adapter.service.js +0 -55
- package/fesm2015/ecodev-natural.js.map +0 -1
- package/lib/modules/common/directives/reactive-asterisk.directive.d.ts +0 -10
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject } from 'rxjs';
|
|
3
|
+
import { NATURAL_DROPDOWN_DATA } from '../../search/dropdown-container/dropdown.service';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../../search/dropdown-container/dropdown-ref";
|
|
6
|
+
import * as i2 from "@angular/material/list";
|
|
7
|
+
import * as i3 from "@angular/common";
|
|
8
|
+
import * as i4 from "@angular/material/core";
|
|
9
|
+
export class FacetSelectorComponent {
|
|
10
|
+
constructor(data, dropdownRef) {
|
|
11
|
+
this.dropdownRef = dropdownRef;
|
|
12
|
+
// Never has a real value
|
|
13
|
+
this.renderedValue = new BehaviorSubject('');
|
|
14
|
+
this.selection = null;
|
|
15
|
+
this.facets = data.configuration.facets;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Get value, including rich object types
|
|
19
|
+
*/
|
|
20
|
+
getCondition() {
|
|
21
|
+
return {};
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Allow to close the dropdown with a valid value
|
|
25
|
+
*/
|
|
26
|
+
close() {
|
|
27
|
+
if (this.selection) {
|
|
28
|
+
this.dropdownRef.close({
|
|
29
|
+
condition: {},
|
|
30
|
+
facet: this.selection,
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
isValid() {
|
|
35
|
+
return !!this.selection;
|
|
36
|
+
}
|
|
37
|
+
isDirty() {
|
|
38
|
+
return true;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
FacetSelectorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: FacetSelectorComponent, deps: [{ token: NATURAL_DROPDOWN_DATA }, { token: i1.NaturalDropdownRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
42
|
+
FacetSelectorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.0", type: FacetSelectorComponent, selector: "ng-component", ngImport: i0, template: "<mat-nav-list>\n <mat-list-item (click)=\"selection = facet; close()\" *ngFor=\"let facet of facets\">\n <a matLine>{{ facet.display }}</a>\n </mat-list-item>\n</mat-nav-list>\n", styles: [":host .mat-nav-list{padding:0}\n"], components: [{ type: i2.MatNavList, selector: "mat-nav-list", inputs: ["disableRipple", "disabled"], exportAs: ["matNavList"] }, { type: i2.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["disableRipple", "disabled"], exportAs: ["matListItem"] }], directives: [{ type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.MatLine, selector: "[mat-line], [matLine]" }] });
|
|
43
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: FacetSelectorComponent, decorators: [{
|
|
44
|
+
type: Component,
|
|
45
|
+
args: [{ template: "<mat-nav-list>\n <mat-list-item (click)=\"selection = facet; close()\" *ngFor=\"let facet of facets\">\n <a matLine>{{ facet.display }}</a>\n </mat-list-item>\n</mat-nav-list>\n", styles: [":host .mat-nav-list{padding:0}\n"] }]
|
|
46
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
47
|
+
type: Inject,
|
|
48
|
+
args: [NATURAL_DROPDOWN_DATA]
|
|
49
|
+
}] }, { type: i1.NaturalDropdownRef }]; } });
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFjZXQtc2VsZWN0b3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvc2VhcmNoL2ZhY2V0LXNlbGVjdG9yL2ZhY2V0LXNlbGVjdG9yLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlYXJjaC9mYWNldC1zZWxlY3Rvci9mYWNldC1zZWxlY3Rvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNoRCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBR3JDLE9BQU8sRUFBQyxxQkFBcUIsRUFBc0IsTUFBTSxrREFBa0QsQ0FBQzs7Ozs7O0FBZTVHLE1BQU0sT0FBTyxzQkFBc0I7SUFNL0IsWUFDbUMsSUFBcUQsRUFDMUUsV0FBK0I7UUFBL0IsZ0JBQVcsR0FBWCxXQUFXLENBQW9CO1FBUDdDLHlCQUF5QjtRQUNsQixrQkFBYSxHQUFHLElBQUksZUFBZSxDQUFTLEVBQUUsQ0FBQyxDQUFDO1FBRWhELGNBQVMsR0FBaUIsSUFBSSxDQUFDO1FBTWxDLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUM7SUFDNUMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksWUFBWTtRQUNmLE9BQU8sRUFBRSxDQUFDO0lBQ2QsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSztRQUNSLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRTtZQUNoQixJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQztnQkFDbkIsU0FBUyxFQUFFLEVBQUU7Z0JBQ2IsS0FBSyxFQUFFLElBQUksQ0FBQyxTQUFTO2FBQ3hCLENBQUMsQ0FBQztTQUNOO0lBQ0wsQ0FBQztJQUVNLE9BQU87UUFDVixPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQzVCLENBQUM7SUFFTSxPQUFPO1FBQ1YsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQzs7bUhBdENRLHNCQUFzQixrQkFPbkIscUJBQXFCO3VHQVB4QixzQkFBc0Isb0RDbkJuQyxnTUFLQTsyRkRjYSxzQkFBc0I7a0JBSmxDLFNBQVM7OzswQkFXRCxNQUFNOzJCQUFDLHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbmplY3R9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtCZWhhdmlvclN1YmplY3R9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtGaWx0ZXJHcm91cENvbmRpdGlvbkZpZWxkfSBmcm9tICcuLi8uLi9zZWFyY2gvY2xhc3Nlcy9ncmFwaHFsLWRvY3RyaW5lLnR5cGVzJztcbmltcG9ydCB7TmF0dXJhbERyb3Bkb3duUmVmfSBmcm9tICcuLi8uLi9zZWFyY2gvZHJvcGRvd24tY29udGFpbmVyL2Ryb3Bkb3duLXJlZic7XG5pbXBvcnQge05BVFVSQUxfRFJPUERPV05fREFUQSwgTmF0dXJhbERyb3Bkb3duRGF0YX0gZnJvbSAnLi4vLi4vc2VhcmNoL2Ryb3Bkb3duLWNvbnRhaW5lci9kcm9wZG93bi5zZXJ2aWNlJztcbmltcG9ydCB7RHJvcGRvd25Db21wb25lbnR9IGZyb20gJy4uL3R5cGVzL2Ryb3Bkb3duLWNvbXBvbmVudCc7XG5pbXBvcnQge0ZhY2V0LCBOYXR1cmFsU2VhcmNoRmFjZXRzfSBmcm9tICcuLi90eXBlcy9mYWNldCc7XG5cbi8qKlxuICogQ29uZmlndXJhdGlvbiBmb3IgZmFjZXQgc2VsZWN0aW9uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRmFjZXRTZWxlY3RvckNvbmZpZ3VyYXRpb24ge1xuICAgIGZhY2V0czogTmF0dXJhbFNlYXJjaEZhY2V0cztcbn1cblxuQENvbXBvbmVudCh7XG4gICAgdGVtcGxhdGVVcmw6ICcuL2ZhY2V0LXNlbGVjdG9yLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9mYWNldC1zZWxlY3Rvci5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBGYWNldFNlbGVjdG9yQ29tcG9uZW50IGltcGxlbWVudHMgRHJvcGRvd25Db21wb25lbnQge1xuICAgIC8vIE5ldmVyIGhhcyBhIHJlYWwgdmFsdWVcbiAgICBwdWJsaWMgcmVuZGVyZWRWYWx1ZSA9IG5ldyBCZWhhdmlvclN1YmplY3Q8c3RyaW5nPignJyk7XG4gICAgcHVibGljIGZhY2V0czogTmF0dXJhbFNlYXJjaEZhY2V0cztcbiAgICBwdWJsaWMgc2VsZWN0aW9uOiBGYWNldCB8IG51bGwgPSBudWxsO1xuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKFxuICAgICAgICBASW5qZWN0KE5BVFVSQUxfRFJPUERPV05fREFUQSkgZGF0YTogTmF0dXJhbERyb3Bkb3duRGF0YTxGYWNldFNlbGVjdG9yQ29uZmlndXJhdGlvbj4sXG4gICAgICAgIHByb3RlY3RlZCBkcm9wZG93blJlZjogTmF0dXJhbERyb3Bkb3duUmVmLFxuICAgICkge1xuICAgICAgICB0aGlzLmZhY2V0cyA9IGRhdGEuY29uZmlndXJhdGlvbi5mYWNldHM7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogR2V0IHZhbHVlLCBpbmNsdWRpbmcgcmljaCBvYmplY3QgdHlwZXNcbiAgICAgKi9cbiAgICBwdWJsaWMgZ2V0Q29uZGl0aW9uKCk6IEZpbHRlckdyb3VwQ29uZGl0aW9uRmllbGQge1xuICAgICAgICByZXR1cm4ge307XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQWxsb3cgdG8gY2xvc2UgdGhlIGRyb3Bkb3duIHdpdGggYSB2YWxpZCB2YWx1ZVxuICAgICAqL1xuICAgIHB1YmxpYyBjbG9zZSgpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuc2VsZWN0aW9uKSB7XG4gICAgICAgICAgICB0aGlzLmRyb3Bkb3duUmVmLmNsb3NlKHtcbiAgICAgICAgICAgICAgICBjb25kaXRpb246IHt9LFxuICAgICAgICAgICAgICAgIGZhY2V0OiB0aGlzLnNlbGVjdGlvbixcbiAgICAgICAgICAgIH0pO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHVibGljIGlzVmFsaWQoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiAhIXRoaXMuc2VsZWN0aW9uO1xuICAgIH1cblxuICAgIHB1YmxpYyBpc0RpcnR5KCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG59XG4iLCI8bWF0LW5hdi1saXN0PlxuICAgIDxtYXQtbGlzdC1pdGVtIChjbGljayk9XCJzZWxlY3Rpb24gPSBmYWNldDsgY2xvc2UoKVwiICpuZ0Zvcj1cImxldCBmYWNldCBvZiBmYWNldHNcIj5cbiAgICAgICAgPGEgbWF0TGluZT57eyBmYWNldC5kaXNwbGF5IH19PC9hPlxuICAgIDwvbWF0LWxpc3QtaXRlbT5cbjwvbWF0LW5hdi1saXN0PlxuIl19
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { deepClone } from '../classes/utils';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../input/input.component";
|
|
5
|
+
import * as i2 from "@angular/common";
|
|
6
|
+
export class NaturalGroupComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.selectionChange = new EventEmitter();
|
|
9
|
+
this.innerSelections = [];
|
|
10
|
+
}
|
|
11
|
+
set selections(selection) {
|
|
12
|
+
this.innerSelections = deepClone(selection);
|
|
13
|
+
}
|
|
14
|
+
updateInput(selection, index) {
|
|
15
|
+
this.innerSelections[index] = selection;
|
|
16
|
+
this.selectionChange.emit(this.innerSelections);
|
|
17
|
+
}
|
|
18
|
+
addInput(selection) {
|
|
19
|
+
this.newValueInput.clear();
|
|
20
|
+
this.innerSelections.push(selection);
|
|
21
|
+
this.selectionChange.emit(this.innerSelections);
|
|
22
|
+
}
|
|
23
|
+
removeInput(index) {
|
|
24
|
+
this.innerSelections.splice(index, 1);
|
|
25
|
+
this.selectionChange.emit(this.innerSelections);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
NaturalGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
29
|
+
NaturalGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.0", type: NaturalGroupComponent, selector: "natural-group", inputs: { placeholder: "placeholder", facets: "facets", selections: "selections" }, outputs: { selectionChange: "selectionChange" }, viewQueries: [{ propertyName: "newValueInput", first: true, predicate: ["newValueInput"], descendants: true }], ngImport: i0, template: "<natural-input\n (cleared)=\"removeInput(i)\"\n (selectionChange)=\"updateInput($event, i)\"\n *ngFor=\"let selection of innerSelections; let i = index\"\n [facets]=\"facets\"\n [selection]=\"selection\"\n></natural-input>\n\n<natural-input\n #newValueInput\n (selectionChange)=\"addInput($event)\"\n [facets]=\"facets\"\n [placeholder]=\"placeholder\"\n tabIndex=\"10\"\n cdkFocusInitial\n></natural-input>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:wrap}:host natural-input{flex:none;display:inline-flex;margin-right:10px}:host natural-input:last-of-type{flex:1;margin-right:0;min-width:250px}\n"], components: [{ type: i1.NaturalInputComponent, selector: "natural-input", inputs: ["placeholder", "searchFieldName", "selection", "facets"], outputs: ["selectionChange", "cleared"] }], directives: [{ type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalGroupComponent, decorators: [{
|
|
31
|
+
type: Component,
|
|
32
|
+
args: [{ selector: 'natural-group', template: "<natural-input\n (cleared)=\"removeInput(i)\"\n (selectionChange)=\"updateInput($event, i)\"\n *ngFor=\"let selection of innerSelections; let i = index\"\n [facets]=\"facets\"\n [selection]=\"selection\"\n></natural-input>\n\n<natural-input\n #newValueInput\n (selectionChange)=\"addInput($event)\"\n [facets]=\"facets\"\n [placeholder]=\"placeholder\"\n tabIndex=\"10\"\n cdkFocusInitial\n></natural-input>\n", styles: [":host{display:flex;flex-direction:row;flex-wrap:wrap}:host natural-input{flex:none;display:inline-flex;margin-right:10px}:host natural-input:last-of-type{flex:1;margin-right:0;min-width:250px}\n"] }]
|
|
33
|
+
}], propDecorators: { newValueInput: [{
|
|
34
|
+
type: ViewChild,
|
|
35
|
+
args: ['newValueInput']
|
|
36
|
+
}], placeholder: [{
|
|
37
|
+
type: Input
|
|
38
|
+
}], facets: [{
|
|
39
|
+
type: Input
|
|
40
|
+
}], selectionChange: [{
|
|
41
|
+
type: Output
|
|
42
|
+
}], selections: [{
|
|
43
|
+
type: Input
|
|
44
|
+
}] } });
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvc2VhcmNoL2dyb3VwL2dyb3VwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlYXJjaC9ncm91cC9ncm91cC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNoRixPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sa0JBQWtCLENBQUM7Ozs7QUFVM0MsTUFBTSxPQUFPLHFCQUFxQjtJQUxsQztRQVU4QixvQkFBZSxHQUFHLElBQUksWUFBWSxFQUFtQixDQUFDO1FBQ3pFLG9CQUFlLEdBQW9CLEVBQUUsQ0FBQztLQXFCaEQ7SUFuQkcsSUFBb0IsVUFBVSxDQUFDLFNBQTBCO1FBQ3JELElBQUksQ0FBQyxlQUFlLEdBQUcsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ2hELENBQUM7SUFFTSxXQUFXLENBQUMsU0FBaUMsRUFBRSxLQUFhO1FBQy9ELElBQUksQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLEdBQUcsU0FBUyxDQUFDO1FBQ3hDLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBRU0sUUFBUSxDQUFDLFNBQWlDO1FBQzdDLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDM0IsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDckMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFTSxXQUFXLENBQUMsS0FBYTtRQUM1QixJQUFJLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDdEMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDO0lBQ3BELENBQUM7O2tIQTFCUSxxQkFBcUI7c0dBQXJCLHFCQUFxQiwwU0NYbEMsNGJBZ0JBOzJGRExhLHFCQUFxQjtrQkFMakMsU0FBUzsrQkFDSSxlQUFlOzhCQUtVLGFBQWE7c0JBQS9DLFNBQVM7dUJBQUMsZUFBZTtnQkFFVixXQUFXO3NCQUExQixLQUFLO2dCQUNVLE1BQU07c0JBQXJCLEtBQUs7Z0JBQ29CLGVBQWU7c0JBQXhDLE1BQU07Z0JBR2EsVUFBVTtzQkFBN0IsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQsIFZpZXdDaGlsZH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge2RlZXBDbG9uZX0gZnJvbSAnLi4vY2xhc3Nlcy91dGlscyc7XG5pbXBvcnQge05hdHVyYWxJbnB1dENvbXBvbmVudH0gZnJvbSAnLi4vaW5wdXQvaW5wdXQuY29tcG9uZW50JztcbmltcG9ydCB7TmF0dXJhbFNlYXJjaEZhY2V0c30gZnJvbSAnLi4vdHlwZXMvZmFjZXQnO1xuaW1wb3J0IHtHcm91cFNlbGVjdGlvbnMsIE5hdHVyYWxTZWFyY2hTZWxlY3Rpb259IGZyb20gJy4uL3R5cGVzL3ZhbHVlcyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbmF0dXJhbC1ncm91cCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2dyb3VwLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9ncm91cC5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBOYXR1cmFsR3JvdXBDb21wb25lbnQge1xuICAgIEBWaWV3Q2hpbGQoJ25ld1ZhbHVlSW5wdXQnKSBwdWJsaWMgbmV3VmFsdWVJbnB1dCE6IE5hdHVyYWxJbnB1dENvbXBvbmVudDtcblxuICAgIEBJbnB1dCgpIHB1YmxpYyBwbGFjZWhvbGRlciE6IHN0cmluZztcbiAgICBASW5wdXQoKSBwdWJsaWMgZmFjZXRzITogTmF0dXJhbFNlYXJjaEZhY2V0cztcbiAgICBAT3V0cHV0KCkgcHVibGljIHJlYWRvbmx5IHNlbGVjdGlvbkNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8R3JvdXBTZWxlY3Rpb25zPigpO1xuICAgIHB1YmxpYyBpbm5lclNlbGVjdGlvbnM6IEdyb3VwU2VsZWN0aW9ucyA9IFtdO1xuXG4gICAgQElucHV0KCkgcHVibGljIHNldCBzZWxlY3Rpb25zKHNlbGVjdGlvbjogR3JvdXBTZWxlY3Rpb25zKSB7XG4gICAgICAgIHRoaXMuaW5uZXJTZWxlY3Rpb25zID0gZGVlcENsb25lKHNlbGVjdGlvbik7XG4gICAgfVxuXG4gICAgcHVibGljIHVwZGF0ZUlucHV0KHNlbGVjdGlvbjogTmF0dXJhbFNlYXJjaFNlbGVjdGlvbiwgaW5kZXg6IG51bWJlcik6IHZvaWQge1xuICAgICAgICB0aGlzLmlubmVyU2VsZWN0aW9uc1tpbmRleF0gPSBzZWxlY3Rpb247XG4gICAgICAgIHRoaXMuc2VsZWN0aW9uQ2hhbmdlLmVtaXQodGhpcy5pbm5lclNlbGVjdGlvbnMpO1xuICAgIH1cblxuICAgIHB1YmxpYyBhZGRJbnB1dChzZWxlY3Rpb246IE5hdHVyYWxTZWFyY2hTZWxlY3Rpb24pOiB2b2lkIHtcbiAgICAgICAgdGhpcy5uZXdWYWx1ZUlucHV0LmNsZWFyKCk7XG4gICAgICAgIHRoaXMuaW5uZXJTZWxlY3Rpb25zLnB1c2goc2VsZWN0aW9uKTtcbiAgICAgICAgdGhpcy5zZWxlY3Rpb25DaGFuZ2UuZW1pdCh0aGlzLmlubmVyU2VsZWN0aW9ucyk7XG4gICAgfVxuXG4gICAgcHVibGljIHJlbW92ZUlucHV0KGluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pbm5lclNlbGVjdGlvbnMuc3BsaWNlKGluZGV4LCAxKTtcbiAgICAgICAgdGhpcy5zZWxlY3Rpb25DaGFuZ2UuZW1pdCh0aGlzLmlubmVyU2VsZWN0aW9ucyk7XG4gICAgfVxufVxuIiwiPG5hdHVyYWwtaW5wdXRcbiAgICAoY2xlYXJlZCk9XCJyZW1vdmVJbnB1dChpKVwiXG4gICAgKHNlbGVjdGlvbkNoYW5nZSk9XCJ1cGRhdGVJbnB1dCgkZXZlbnQsIGkpXCJcbiAgICAqbmdGb3I9XCJsZXQgc2VsZWN0aW9uIG9mIGlubmVyU2VsZWN0aW9uczsgbGV0IGkgPSBpbmRleFwiXG4gICAgW2ZhY2V0c109XCJmYWNldHNcIlxuICAgIFtzZWxlY3Rpb25dPVwic2VsZWN0aW9uXCJcbj48L25hdHVyYWwtaW5wdXQ+XG5cbjxuYXR1cmFsLWlucHV0XG4gICAgI25ld1ZhbHVlSW5wdXRcbiAgICAoc2VsZWN0aW9uQ2hhbmdlKT1cImFkZElucHV0KCRldmVudClcIlxuICAgIFtmYWNldHNdPVwiZmFjZXRzXCJcbiAgICBbcGxhY2Vob2xkZXJdPVwicGxhY2Vob2xkZXJcIlxuICAgIHRhYkluZGV4PVwiMTBcIlxuICAgIGNka0ZvY3VzSW5pdGlhbFxuPjwvbmF0dXJhbC1pbnB1dD5cbiJdfQ==
|
|
@@ -0,0 +1,328 @@
|
|
|
1
|
+
import { Component, EventEmitter, HostListener, Injector, Input, Output, ViewChild, } from '@angular/core';
|
|
2
|
+
import { FormControl } from '@angular/forms';
|
|
3
|
+
import { MatRipple } from '@angular/material/core';
|
|
4
|
+
import { getFacetFromSelection } from '../classes/utils';
|
|
5
|
+
import { NaturalDropdownRef } from '../dropdown-container/dropdown-ref';
|
|
6
|
+
import { NATURAL_DROPDOWN_DATA, } from '../dropdown-container/dropdown.service';
|
|
7
|
+
import { FacetSelectorComponent } from '../facet-selector/facet-selector.component';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "../dropdown-container/dropdown.service";
|
|
10
|
+
import * as i2 from "@angular/material/form-field";
|
|
11
|
+
import * as i3 from "../../icon/icon.component";
|
|
12
|
+
import * as i4 from "@angular/material/button";
|
|
13
|
+
import * as i5 from "@angular/material/core";
|
|
14
|
+
import * as i6 from "@angular/common";
|
|
15
|
+
import * as i7 from "@angular/material/input";
|
|
16
|
+
import * as i8 from "@angular/forms";
|
|
17
|
+
// Required to check invalid fields when initializing natural-search
|
|
18
|
+
export class AlwaysErrorStateMatcher {
|
|
19
|
+
isErrorState(control, form) {
|
|
20
|
+
return !!control && control.invalid;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
function isComponentValid(component) {
|
|
24
|
+
return () => {
|
|
25
|
+
if (!component.isValid()) {
|
|
26
|
+
return { component: true };
|
|
27
|
+
}
|
|
28
|
+
return null;
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
export class NaturalInputComponent {
|
|
32
|
+
constructor(element, dropdownService, injector, componentFactoryResolver) {
|
|
33
|
+
this.element = element;
|
|
34
|
+
this.dropdownService = dropdownService;
|
|
35
|
+
this.injector = injector;
|
|
36
|
+
this.componentFactoryResolver = componentFactoryResolver;
|
|
37
|
+
/**
|
|
38
|
+
* Name of the field on which do a global search (without facet)
|
|
39
|
+
*/
|
|
40
|
+
this.searchFieldName = 'search';
|
|
41
|
+
/**
|
|
42
|
+
* Selected setted for this component
|
|
43
|
+
*/
|
|
44
|
+
this.selection = null;
|
|
45
|
+
/**
|
|
46
|
+
* Emits when user a added/updated/deleted a search (from global context or from facet)
|
|
47
|
+
*/
|
|
48
|
+
this.selectionChange = new EventEmitter();
|
|
49
|
+
/**
|
|
50
|
+
* Emits when user removes the search by pressing the cross icon
|
|
51
|
+
*/
|
|
52
|
+
this.cleared = new EventEmitter();
|
|
53
|
+
/**
|
|
54
|
+
* Selected facet from the list of available facets
|
|
55
|
+
*/
|
|
56
|
+
this.facet = null;
|
|
57
|
+
/**
|
|
58
|
+
* Controller for the input field
|
|
59
|
+
*/
|
|
60
|
+
this.formCtrl = new FormControl();
|
|
61
|
+
/**
|
|
62
|
+
* Customer error matcher that should validate on each change (including initialisation)
|
|
63
|
+
*/
|
|
64
|
+
this.errorMatcher = new AlwaysErrorStateMatcher();
|
|
65
|
+
/**
|
|
66
|
+
* Reference of the opened dropdown container
|
|
67
|
+
*/
|
|
68
|
+
this.dropdownRef = null;
|
|
69
|
+
/**
|
|
70
|
+
* Reference of the component inside the dropdown container
|
|
71
|
+
*/
|
|
72
|
+
this.dropdownComponentRef = null;
|
|
73
|
+
/**
|
|
74
|
+
* Minimum input length (number of chars)
|
|
75
|
+
* See length attribute
|
|
76
|
+
*/
|
|
77
|
+
this.minLength = 5;
|
|
78
|
+
/**
|
|
79
|
+
* Size of the input (number of chars)
|
|
80
|
+
* Match the input.size attribute
|
|
81
|
+
*/
|
|
82
|
+
this.length = this.minLength;
|
|
83
|
+
/**
|
|
84
|
+
* Flag, that, if marked as yes, prevents the opening of the dropdown
|
|
85
|
+
* Is used to prevent dropdown opening when natural-search takes the focus from parent context (like on modal opening)
|
|
86
|
+
*/
|
|
87
|
+
this.neutralizeDropdownOpening = false;
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Custom management for taking the focus from parent context
|
|
91
|
+
* When focusing manually on the <input>, a dropdown is opened
|
|
92
|
+
* But when the focus is given from angular in a parent context (like a dialog) the dropdown would open and we don't want it.
|
|
93
|
+
*/
|
|
94
|
+
focus() {
|
|
95
|
+
this.neutralizeDropdownOpening = true;
|
|
96
|
+
this.input.nativeElement.focus();
|
|
97
|
+
this.neutralizeDropdownOpening = false;
|
|
98
|
+
}
|
|
99
|
+
ngOnInit() {
|
|
100
|
+
this.input.nativeElement.addEventListener('focus', () => {
|
|
101
|
+
this.openDropdown();
|
|
102
|
+
});
|
|
103
|
+
this.input.nativeElement.addEventListener('keyup', () => {
|
|
104
|
+
if (!this.dropdownRef) {
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
if (this.formCtrl.value !== '') {
|
|
108
|
+
this.dropdownRef.close();
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
if (!this.placeholder) {
|
|
112
|
+
this.placeholder = $localize `Recherche`;
|
|
113
|
+
}
|
|
114
|
+
const placeholderSize = (this.facet ? this.facet.display.length : this.placeholder.length) * 0.66;
|
|
115
|
+
this.length = Math.max(this.minLength, Math.ceil(placeholderSize));
|
|
116
|
+
}
|
|
117
|
+
ngOnDestroy() {
|
|
118
|
+
if (this.dropdownComponentRef) {
|
|
119
|
+
this.dropdownComponentRef.destroy();
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
ngOnChanges(changes) {
|
|
123
|
+
if (!this.facets && this.selection) {
|
|
124
|
+
setTimeout(() => this.clear());
|
|
125
|
+
}
|
|
126
|
+
else if (this.facets && this.selection) {
|
|
127
|
+
this.facet = getFacetFromSelection(this.facets, this.selection);
|
|
128
|
+
if (this.isDropdown()) {
|
|
129
|
+
const dropdownComponent = this.createComponent(this.facet);
|
|
130
|
+
this.formCtrl.setValidators([isComponentValid(dropdownComponent)]);
|
|
131
|
+
dropdownComponent.renderedValue.subscribe(value => {
|
|
132
|
+
this.formCtrl.setValue(value);
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
else if (this.isFlag()) {
|
|
136
|
+
this.formCtrl.setValue('');
|
|
137
|
+
}
|
|
138
|
+
else if (this.selection &&
|
|
139
|
+
this.selection.field === this.searchFieldName &&
|
|
140
|
+
this.selection.condition.like) {
|
|
141
|
+
// global search mode
|
|
142
|
+
this.formCtrl.setValue(this.selection.condition.like.value);
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
// If component is invalid (no facet and not a global search), clear from result and destroy component
|
|
146
|
+
setTimeout(() => this.clear());
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
search(event) {
|
|
151
|
+
event.stopPropagation();
|
|
152
|
+
event.preventDefault();
|
|
153
|
+
if (!this.formCtrl.value) {
|
|
154
|
+
return;
|
|
155
|
+
}
|
|
156
|
+
if (this.isDropdown()) {
|
|
157
|
+
return;
|
|
158
|
+
}
|
|
159
|
+
if (this.formCtrl.valid && this.formCtrl.dirty) {
|
|
160
|
+
this.selectionChange.emit(this.getSelection({ like: { value: this.formCtrl.value } }));
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
clear() {
|
|
164
|
+
this.facet = null;
|
|
165
|
+
this.selection = null;
|
|
166
|
+
this.formCtrl.setValue(null);
|
|
167
|
+
this.cleared.emit(this);
|
|
168
|
+
}
|
|
169
|
+
openDropdown() {
|
|
170
|
+
if (this.dropdownRef || this.neutralizeDropdownOpening) {
|
|
171
|
+
// Prevent to open multiple dropdowns.
|
|
172
|
+
// Happens as we open on "focus", and alt+tab re-activate focus on an element that already had
|
|
173
|
+
// focus when leaving window with another alt+tab
|
|
174
|
+
return;
|
|
175
|
+
}
|
|
176
|
+
this.launchRipple();
|
|
177
|
+
// If there is no facet and no string typed, show panel to select the facet
|
|
178
|
+
if (!this.facet && !this.formCtrl.value) {
|
|
179
|
+
this.openFacetSelectorDropdown();
|
|
180
|
+
}
|
|
181
|
+
else {
|
|
182
|
+
// If a facet is selected, open specific component dropdown
|
|
183
|
+
this.openTypeDropdown();
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
isDropdown() {
|
|
187
|
+
return !!(this.facet && this.facet.component);
|
|
188
|
+
}
|
|
189
|
+
isFlag() {
|
|
190
|
+
return !!(this.facet && this.facet.condition);
|
|
191
|
+
}
|
|
192
|
+
createComponent(facet) {
|
|
193
|
+
// Always destroy and recreate component
|
|
194
|
+
// Todo : test if facet has changed, if not re-use the component
|
|
195
|
+
if (this.dropdownComponentRef) {
|
|
196
|
+
this.dropdownComponentRef.destroy();
|
|
197
|
+
}
|
|
198
|
+
const condition = this.selection ? this.selection.condition : null;
|
|
199
|
+
const data = {
|
|
200
|
+
condition: condition,
|
|
201
|
+
configuration: facet.configuration,
|
|
202
|
+
};
|
|
203
|
+
const injector = Injector.create({ providers: this.createProviders(data), parent: this.injector });
|
|
204
|
+
const factory = this.componentFactoryResolver.resolveComponentFactory(facet.component);
|
|
205
|
+
this.dropdownComponentRef = factory.create(injector);
|
|
206
|
+
return this.dropdownComponentRef.instance;
|
|
207
|
+
}
|
|
208
|
+
createProviders(data) {
|
|
209
|
+
// Customize injector to allow data and dropdown reference injection in component
|
|
210
|
+
return [
|
|
211
|
+
{
|
|
212
|
+
provide: NaturalDropdownRef,
|
|
213
|
+
useValue: null,
|
|
214
|
+
},
|
|
215
|
+
{
|
|
216
|
+
provide: NATURAL_DROPDOWN_DATA,
|
|
217
|
+
useValue: data,
|
|
218
|
+
},
|
|
219
|
+
];
|
|
220
|
+
}
|
|
221
|
+
launchRipple() {
|
|
222
|
+
const rippleRef = this.ripple.launch({
|
|
223
|
+
persistent: true,
|
|
224
|
+
centered: true,
|
|
225
|
+
});
|
|
226
|
+
rippleRef.fadeOut();
|
|
227
|
+
}
|
|
228
|
+
openFacetSelectorDropdown() {
|
|
229
|
+
if (!this.facets || (this.facets && !this.facets.length)) {
|
|
230
|
+
return;
|
|
231
|
+
}
|
|
232
|
+
const data = {
|
|
233
|
+
condition: {},
|
|
234
|
+
configuration: {
|
|
235
|
+
facets: this.facets,
|
|
236
|
+
},
|
|
237
|
+
};
|
|
238
|
+
const injectorTokens = this.createProviders(data);
|
|
239
|
+
this.dropdownRef = this.dropdownService.open(FacetSelectorComponent, this.element, injectorTokens, false);
|
|
240
|
+
this.dropdownRef.closed.subscribe(result => {
|
|
241
|
+
this.dropdownRef = null;
|
|
242
|
+
if (result !== undefined) {
|
|
243
|
+
if (result.facet) {
|
|
244
|
+
this.setFacet(result.facet);
|
|
245
|
+
}
|
|
246
|
+
else if (result.condition) {
|
|
247
|
+
this.setValue(result);
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
});
|
|
251
|
+
}
|
|
252
|
+
openTypeDropdown() {
|
|
253
|
+
if (!this.isDropdown()) {
|
|
254
|
+
return;
|
|
255
|
+
}
|
|
256
|
+
const dropdownFacet = this.facet;
|
|
257
|
+
const data = {
|
|
258
|
+
condition: this.selection ? this.selection.condition : null,
|
|
259
|
+
configuration: dropdownFacet.configuration,
|
|
260
|
+
};
|
|
261
|
+
const injectorTokens = this.createProviders(data);
|
|
262
|
+
const component = dropdownFacet.component;
|
|
263
|
+
this.dropdownRef = this.dropdownService.open(component, this.element, injectorTokens, dropdownFacet.showValidateButton || false);
|
|
264
|
+
this.dropdownRef.closed.subscribe(result => {
|
|
265
|
+
this.dropdownRef = null;
|
|
266
|
+
if (result !== undefined) {
|
|
267
|
+
this.setValue(result);
|
|
268
|
+
}
|
|
269
|
+
});
|
|
270
|
+
}
|
|
271
|
+
setFacet(facet) {
|
|
272
|
+
this.facet = facet;
|
|
273
|
+
if (this.isDropdown()) {
|
|
274
|
+
this.openTypeDropdown();
|
|
275
|
+
}
|
|
276
|
+
else if (this.isFlag()) {
|
|
277
|
+
this.setValue({
|
|
278
|
+
condition: facet.condition,
|
|
279
|
+
});
|
|
280
|
+
}
|
|
281
|
+
else {
|
|
282
|
+
this.input.nativeElement.focus();
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
setValue(result) {
|
|
286
|
+
if (this.facet) {
|
|
287
|
+
this.selectionChange.emit(this.getSelection(result.condition));
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
getSelection(condition) {
|
|
291
|
+
const selection = {
|
|
292
|
+
field: this.facet ? this.facet.field : this.searchFieldName,
|
|
293
|
+
condition: condition,
|
|
294
|
+
};
|
|
295
|
+
if (this.facet && this.facet.name) {
|
|
296
|
+
selection.name = this.facet.name;
|
|
297
|
+
}
|
|
298
|
+
return selection;
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
NaturalInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalInputComponent, deps: [{ token: i0.ElementRef }, { token: i1.NaturalDropdownService }, { token: i0.Injector }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Component });
|
|
302
|
+
NaturalInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.0", type: NaturalInputComponent, selector: "natural-input", inputs: { placeholder: "placeholder", searchFieldName: "searchFieldName", selection: "selection", facets: "facets" }, outputs: { selectionChange: "selectionChange", cleared: "cleared" }, host: { listeners: { "focus": "focus()" } }, viewQueries: [{ propertyName: "ripple", first: true, predicate: MatRipple, descendants: true, static: true }, { propertyName: "input", first: true, predicate: ["input"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<!-- click condition should match to allow click action only when no other button is visible -->\n<mat-form-field #field matRipple (click)=\"!selection && !(facet && !selection) ? openDropdown() : null\">\n <mat-label *ngIf=\"facet\">{{ facet.display }}</mat-label>\n <mat-label *ngIf=\"!facet\">{{ placeholder }}</mat-label>\n\n <input\n #input\n (blur)=\"search($event)\"\n (keydown.enter)=\"search($event)\"\n [attr.size]=\"length\"\n [errorStateMatcher]=\"errorMatcher\"\n [formControl]=\"formCtrl\"\n [readonly]=\"(isDropdown() && !!selection) || isFlag()\"\n autocomplete=\"off\"\n matInput\n type=\"text\"\n />\n\n <!-- TODO : replace this void button -->\n <div *ngIf=\"!facet && !selection\" class=\"search-icon\" matPrefix>\n <natural-icon name=\"search\"></natural-icon>\n </div>\n\n <button (click)=\"clear()\" *ngIf=\"selection\" mat-icon-button matSuffix>\n <natural-icon name=\"close\"></natural-icon>\n </button>\n\n <button (click)=\"clear()\" *ngIf=\"facet && !selection\" mat-icon-button matSuffix>\n <natural-icon name=\"undo\"></natural-icon>\n </button>\n</mat-form-field>\n<div class=\"hide\">{{ formCtrl.value ? formCtrl.value : facet ? facet.display : placeholder }}</div>\n", styles: [":host{position:relative;overflow:hidden;border-top-left-radius:4px;border-top-right-radius:4px;display:flex;flex-direction:column}:host .mat-menu-ripple{top:0;left:0;right:0;bottom:0;position:absolute;pointer-events:none}:host .hide{color:transparent;height:0;margin:0 50px 0 10px;font-size:inherit;white-space:nowrap;font-family:Roboto,Helvetica Neue,sans-serif}:host .search-icon{display:block;width:35px;height:35px}:host .search-icon natural-icon{margin:5px auto 0}\n"], components: [{ type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i3.NaturalIconComponent, selector: "natural-icon", inputs: ["label", "labelColor", "labelPosition", "name", "size"] }, { type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i5.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatLabel, selector: "mat-label" }, { type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { type: i8.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: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatPrefix, selector: "[matPrefix]" }, { type: i2.MatSuffix, selector: "[matSuffix]" }] });
|
|
303
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalInputComponent, decorators: [{
|
|
304
|
+
type: Component,
|
|
305
|
+
args: [{ selector: 'natural-input', template: "<!-- click condition should match to allow click action only when no other button is visible -->\n<mat-form-field #field matRipple (click)=\"!selection && !(facet && !selection) ? openDropdown() : null\">\n <mat-label *ngIf=\"facet\">{{ facet.display }}</mat-label>\n <mat-label *ngIf=\"!facet\">{{ placeholder }}</mat-label>\n\n <input\n #input\n (blur)=\"search($event)\"\n (keydown.enter)=\"search($event)\"\n [attr.size]=\"length\"\n [errorStateMatcher]=\"errorMatcher\"\n [formControl]=\"formCtrl\"\n [readonly]=\"(isDropdown() && !!selection) || isFlag()\"\n autocomplete=\"off\"\n matInput\n type=\"text\"\n />\n\n <!-- TODO : replace this void button -->\n <div *ngIf=\"!facet && !selection\" class=\"search-icon\" matPrefix>\n <natural-icon name=\"search\"></natural-icon>\n </div>\n\n <button (click)=\"clear()\" *ngIf=\"selection\" mat-icon-button matSuffix>\n <natural-icon name=\"close\"></natural-icon>\n </button>\n\n <button (click)=\"clear()\" *ngIf=\"facet && !selection\" mat-icon-button matSuffix>\n <natural-icon name=\"undo\"></natural-icon>\n </button>\n</mat-form-field>\n<div class=\"hide\">{{ formCtrl.value ? formCtrl.value : facet ? facet.display : placeholder }}</div>\n", styles: [":host{position:relative;overflow:hidden;border-top-left-radius:4px;border-top-right-radius:4px;display:flex;flex-direction:column}:host .mat-menu-ripple{top:0;left:0;right:0;bottom:0;position:absolute;pointer-events:none}:host .hide{color:transparent;height:0;margin:0 50px 0 10px;font-size:inherit;white-space:nowrap;font-family:Roboto,Helvetica Neue,sans-serif}:host .search-icon{display:block;width:35px;height:35px}:host .search-icon natural-icon{margin:5px auto 0}\n"] }]
|
|
306
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.NaturalDropdownService }, { type: i0.Injector }, { type: i0.ComponentFactoryResolver }]; }, propDecorators: { ripple: [{
|
|
307
|
+
type: ViewChild,
|
|
308
|
+
args: [MatRipple, { static: true }]
|
|
309
|
+
}], input: [{
|
|
310
|
+
type: ViewChild,
|
|
311
|
+
args: ['input', { static: true }]
|
|
312
|
+
}], placeholder: [{
|
|
313
|
+
type: Input
|
|
314
|
+
}], searchFieldName: [{
|
|
315
|
+
type: Input
|
|
316
|
+
}], selection: [{
|
|
317
|
+
type: Input
|
|
318
|
+
}], facets: [{
|
|
319
|
+
type: Input
|
|
320
|
+
}], selectionChange: [{
|
|
321
|
+
type: Output
|
|
322
|
+
}], cleared: [{
|
|
323
|
+
type: Output
|
|
324
|
+
}], focus: [{
|
|
325
|
+
type: HostListener,
|
|
326
|
+
args: ['focus']
|
|
327
|
+
}] } });
|
|
328
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/search/input/input.component.ts","../../../../../../../projects/natural/src/lib/modules/search/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ComponentFactoryResolver,\n    ComponentRef,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Injector,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n    StaticProvider,\n    ViewChild,\n} from '@angular/core';\nimport {FormControl, FormGroupDirective, NgForm, ValidationErrors, ValidatorFn} from '@angular/forms';\nimport {ErrorStateMatcher, MatRipple} from '@angular/material/core';\nimport {FilterGroupConditionField} from '../classes/graphql-doctrine.types';\nimport {getFacetFromSelection} from '../classes/utils';\nimport {NaturalDropdownRef} from '../dropdown-container/dropdown-ref';\nimport {\n    NATURAL_DROPDOWN_DATA,\n    NaturalDropdownData,\n    NaturalDropdownService,\n} from '../dropdown-container/dropdown.service';\nimport {FacetSelectorComponent, FacetSelectorConfiguration} from '../facet-selector/facet-selector.component';\nimport {DropdownComponent} from '../types/dropdown-component';\nimport {DropdownFacet, Facet, FlagFacet, NaturalSearchFacets} from '../types/facet';\nimport {DropdownResult, NaturalSearchSelection} from '../types/values';\n\n// Required to check invalid fields when initializing natural-search\nexport class AlwaysErrorStateMatcher implements ErrorStateMatcher {\n    public isErrorState(control: FormControl | null, form: FormGroupDirective | NgForm | null): boolean {\n        return !!control && control.invalid;\n    }\n}\n\nfunction isComponentValid(component: DropdownComponent): ValidatorFn {\n    return (): ValidationErrors | null => {\n        if (!component.isValid()) {\n            return {component: true};\n        }\n\n        return null;\n    };\n}\n\n@Component({\n    selector: 'natural-input',\n    templateUrl: './input.component.html',\n    styleUrls: ['./input.component.scss'],\n})\nexport class NaturalInputComponent implements OnInit, OnChanges, OnDestroy {\n    /**\n     * Controls the ripple effect, used when opening a dropdown\n     */\n    @ViewChild(MatRipple, {static: true}) public ripple!: MatRipple;\n\n    /**\n     * Native element ref for <input> related to this <natural-input> component\n     */\n    @ViewChild('input', {static: true}) public input!: ElementRef;\n\n    /**\n     * Label for this field\n     */\n    @Input() public placeholder?: string;\n\n    /**\n     * Name of the field on which do a global search (without facet)\n     */\n    @Input() public searchFieldName = 'search';\n\n    /**\n     * Selected setted for this component\n     */\n    @Input() public selection: NaturalSearchSelection | null = null;\n\n    /**\n     * Available facets, allows the user to pick one, than generated then a selection\n     */\n    @Input() public facets!: NaturalSearchFacets;\n\n    /**\n     * Emits when user a added/updated/deleted a search (from global context or from facet)\n     */\n    @Output() public readonly selectionChange = new EventEmitter<NaturalSearchSelection>();\n\n    /**\n     * Emits when user removes the search by pressing the cross icon\n     */\n    @Output() public readonly cleared = new EventEmitter<NaturalInputComponent>();\n\n    /**\n     * Selected facet from the list of available facets\n     */\n    public facet: Facet | null = null;\n\n    /**\n     * Controller for the input field\n     */\n    public formCtrl: FormControl = new FormControl();\n\n    /**\n     * Customer error matcher that should validate on each change (including initialisation)\n     */\n    public errorMatcher = new AlwaysErrorStateMatcher();\n\n    /**\n     * Reference of the opened dropdown container\n     */\n    private dropdownRef: NaturalDropdownRef | null = null;\n\n    /**\n     * Reference of the component inside the dropdown container\n     */\n    private dropdownComponentRef: ComponentRef<DropdownComponent> | null = null;\n\n    /**\n     *  Minimum input length (number of chars)\n     *  See length attribute\n     */\n    private readonly minLength = 5;\n\n    /**\n     * Size of the input (number of chars)\n     * Match the input.size attribute\n     */\n    public length = this.minLength;\n\n    /**\n     * Flag, that, if marked as yes, prevents the opening of the dropdown\n     * Is used to prevent dropdown opening when natural-search takes the focus from parent context (like on modal opening)\n     */\n    private neutralizeDropdownOpening = false;\n\n    /**\n     * Custom management for taking the focus from parent context\n     * When focusing manually on the <input>, a dropdown is opened\n     * But when the focus is given from angular in a parent context (like a dialog) the dropdown would open and we don't want it.\n     */\n    @HostListener('focus')\n    public focus(): void {\n        this.neutralizeDropdownOpening = true;\n        this.input.nativeElement.focus();\n        this.neutralizeDropdownOpening = false;\n    }\n\n    public constructor(\n        private readonly element: ElementRef,\n        private readonly dropdownService: NaturalDropdownService,\n        private readonly injector: Injector,\n        private readonly componentFactoryResolver: ComponentFactoryResolver,\n    ) {}\n\n    public ngOnInit(): void {\n        this.input.nativeElement.addEventListener('focus', () => {\n            this.openDropdown();\n        });\n\n        this.input.nativeElement.addEventListener('keyup', () => {\n            if (!this.dropdownRef) {\n                return;\n            }\n\n            if (this.formCtrl.value !== '') {\n                this.dropdownRef.close();\n            }\n        });\n\n        if (!this.placeholder) {\n            this.placeholder = $localize`Recherche`;\n        }\n\n        const placeholderSize = (this.facet ? this.facet.display.length : this.placeholder.length) * 0.66;\n        this.length = Math.max(this.minLength, Math.ceil(placeholderSize));\n    }\n\n    public ngOnDestroy(): void {\n        if (this.dropdownComponentRef) {\n            this.dropdownComponentRef.destroy();\n        }\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (!this.facets && this.selection) {\n            setTimeout(() => this.clear());\n        } else if (this.facets && this.selection) {\n            this.facet = getFacetFromSelection(this.facets, this.selection);\n\n            if (this.isDropdown()) {\n                const dropdownComponent = this.createComponent(this.facet as DropdownFacet<FacetSelectorConfiguration>);\n\n                this.formCtrl.setValidators([isComponentValid(dropdownComponent)]);\n                dropdownComponent.renderedValue.subscribe(value => {\n                    this.formCtrl.setValue(value);\n                });\n            } else if (this.isFlag()) {\n                this.formCtrl.setValue('');\n            } else if (\n                this.selection &&\n                this.selection.field === this.searchFieldName &&\n                this.selection.condition.like\n            ) {\n                // global search mode\n                this.formCtrl.setValue(this.selection.condition.like.value);\n            } else {\n                // If component is invalid (no facet and not a global search), clear from result and destroy component\n                setTimeout(() => this.clear());\n            }\n        }\n    }\n\n    public search(event: Event): void {\n        event.stopPropagation();\n        event.preventDefault();\n\n        if (!this.formCtrl.value) {\n            return;\n        }\n\n        if (this.isDropdown()) {\n            return;\n        }\n\n        if (this.formCtrl.valid && this.formCtrl.dirty) {\n            this.selectionChange.emit(this.getSelection({like: {value: this.formCtrl.value}}));\n        }\n    }\n\n    public clear(): void {\n        this.facet = null;\n        this.selection = null;\n        this.formCtrl.setValue(null);\n        this.cleared.emit(this);\n    }\n\n    public openDropdown(): void {\n        if (this.dropdownRef || this.neutralizeDropdownOpening) {\n            // Prevent to open multiple dropdowns.\n            // Happens as we open on \"focus\", and alt+tab re-activate focus on an element that already had\n            // focus when leaving window with another alt+tab\n            return;\n        }\n\n        this.launchRipple();\n\n        // If there is no facet and no string typed, show panel to select the facet\n        if (!this.facet && !this.formCtrl.value) {\n            this.openFacetSelectorDropdown();\n        } else {\n            // If a facet is selected, open specific component dropdown\n            this.openTypeDropdown();\n        }\n    }\n\n    public isDropdown(): boolean {\n        return !!(this.facet && (this.facet as DropdownFacet<unknown>).component);\n    }\n\n    public isFlag(): boolean {\n        return !!(this.facet && (this.facet as FlagFacet).condition);\n    }\n\n    private createComponent(facet: DropdownFacet<unknown>): DropdownComponent {\n        // Always destroy and recreate component\n        // Todo : test if facet has changed, if not re-use the component\n        if (this.dropdownComponentRef) {\n            this.dropdownComponentRef.destroy();\n        }\n\n        const condition = this.selection ? (this.selection.condition as FilterGroupConditionField) : null;\n        const data: NaturalDropdownData = {\n            condition: condition,\n            configuration: facet.configuration,\n        };\n\n        const injector = Injector.create({providers: this.createProviders(data), parent: this.injector});\n        const factory = this.componentFactoryResolver.resolveComponentFactory<DropdownComponent>(facet.component);\n        this.dropdownComponentRef = factory.create(injector);\n\n        return this.dropdownComponentRef.instance;\n    }\n\n    private createProviders(data: NaturalDropdownData): StaticProvider[] {\n        // Customize injector to allow data and dropdown reference injection in component\n        return [\n            {\n                provide: NaturalDropdownRef,\n                useValue: null,\n            },\n            {\n                provide: NATURAL_DROPDOWN_DATA,\n                useValue: data,\n            },\n        ];\n    }\n\n    private launchRipple(): void {\n        const rippleRef = this.ripple.launch({\n            persistent: true,\n            centered: true,\n        });\n\n        rippleRef.fadeOut();\n    }\n\n    private openFacetSelectorDropdown(): void {\n        if (!this.facets || (this.facets && !this.facets.length)) {\n            return;\n        }\n\n        const data: NaturalDropdownData<FacetSelectorConfiguration> = {\n            condition: {},\n            configuration: {\n                facets: this.facets,\n            },\n        };\n\n        const injectorTokens = this.createProviders(data);\n        this.dropdownRef = this.dropdownService.open(FacetSelectorComponent, this.element, injectorTokens, false);\n        this.dropdownRef.closed.subscribe(result => {\n            this.dropdownRef = null;\n            if (result !== undefined) {\n                if (result.facet) {\n                    this.setFacet(result.facet);\n                } else if (result.condition) {\n                    this.setValue(result);\n                }\n            }\n        });\n    }\n\n    private openTypeDropdown(): void {\n        if (!this.isDropdown()) {\n            return;\n        }\n\n        const dropdownFacet = this.facet as DropdownFacet<unknown>;\n\n        const data: NaturalDropdownData = {\n            condition: this.selection ? this.selection.condition : null,\n            configuration: dropdownFacet.configuration,\n        };\n\n        const injectorTokens = this.createProviders(data);\n        const component = dropdownFacet.component;\n        this.dropdownRef = this.dropdownService.open(\n            component,\n            this.element,\n            injectorTokens,\n            dropdownFacet.showValidateButton || false,\n        );\n\n        this.dropdownRef.closed.subscribe(result => {\n            this.dropdownRef = null;\n            if (result !== undefined) {\n                this.setValue(result);\n            }\n        });\n    }\n\n    private setFacet(facet: Facet): void {\n        this.facet = facet;\n\n        if (this.isDropdown()) {\n            this.openTypeDropdown();\n        } else if (this.isFlag()) {\n            this.setValue({\n                condition: (facet as FlagFacet).condition,\n            });\n        } else {\n            this.input.nativeElement.focus();\n        }\n    }\n\n    private setValue(result: DropdownResult): void {\n        if (this.facet) {\n            this.selectionChange.emit(this.getSelection(result.condition));\n        }\n    }\n\n    private getSelection(condition: NaturalSearchSelection['condition']): NaturalSearchSelection {\n        const selection: NaturalSearchSelection = {\n            field: this.facet ? this.facet.field : this.searchFieldName,\n            condition: condition,\n        };\n\n        if (this.facet && this.facet.name) {\n            selection.name = this.facet.name;\n        }\n\n        return selection;\n    }\n}\n","<!-- click condition should match to allow click action only when no other button is visible -->\n<mat-form-field #field matRipple (click)=\"!selection && !(facet && !selection) ? openDropdown() : null\">\n    <mat-label *ngIf=\"facet\">{{ facet.display }}</mat-label>\n    <mat-label *ngIf=\"!facet\">{{ placeholder }}</mat-label>\n\n    <input\n        #input\n        (blur)=\"search($event)\"\n        (keydown.enter)=\"search($event)\"\n        [attr.size]=\"length\"\n        [errorStateMatcher]=\"errorMatcher\"\n        [formControl]=\"formCtrl\"\n        [readonly]=\"(isDropdown() && !!selection) || isFlag()\"\n        autocomplete=\"off\"\n        matInput\n        type=\"text\"\n    />\n\n    <!-- TODO : replace this void button -->\n    <div *ngIf=\"!facet && !selection\" class=\"search-icon\" matPrefix>\n        <natural-icon name=\"search\"></natural-icon>\n    </div>\n\n    <button (click)=\"clear()\" *ngIf=\"selection\" mat-icon-button matSuffix>\n        <natural-icon name=\"close\"></natural-icon>\n    </button>\n\n    <button (click)=\"clear()\" *ngIf=\"facet && !selection\" mat-icon-button matSuffix>\n        <natural-icon name=\"undo\"></natural-icon>\n    </button>\n</mat-form-field>\n<div class=\"hide\">{{ formCtrl.value ? formCtrl.value : facet ? facet.display : placeholder }}</div>\n"]}
|
package/{esm2015/lib/modules/search/public-api.js → esm2020/lib/modules/search/public-api.mjs}
RENAMED
|
File without changes
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { deepClone } from '../classes/utils';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../group/group.component";
|
|
5
|
+
import * as i2 from "@angular/material/button";
|
|
6
|
+
import * as i3 from "../../icon/icon.component";
|
|
7
|
+
import * as i4 from "@angular/common";
|
|
8
|
+
export class NaturalSearchComponent {
|
|
9
|
+
constructor() {
|
|
10
|
+
/**
|
|
11
|
+
* Placeholder for last input (the free search input)
|
|
12
|
+
*/
|
|
13
|
+
this.placeholder = $localize `Rechercher`;
|
|
14
|
+
/**
|
|
15
|
+
* Exhaustive list of facets to be used in this <natural-search>
|
|
16
|
+
*/
|
|
17
|
+
this.facets = [];
|
|
18
|
+
/**
|
|
19
|
+
* Whether to allow end-user to create multiple `OR` groups
|
|
20
|
+
*/
|
|
21
|
+
this.multipleGroups = false;
|
|
22
|
+
/**
|
|
23
|
+
* Emits when some selection has been setted by the user
|
|
24
|
+
*/
|
|
25
|
+
this.selectionChange = new EventEmitter();
|
|
26
|
+
/**
|
|
27
|
+
* Cleaned inputted selections. Allow valid selections to be manipulated inside component
|
|
28
|
+
*/
|
|
29
|
+
this.innerSelections = [[]];
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Input to display at component initialisation
|
|
33
|
+
*/
|
|
34
|
+
set selections(selections) {
|
|
35
|
+
this.innerSelections = selections && selections[0] ? deepClone(selections) : [[]];
|
|
36
|
+
}
|
|
37
|
+
ngOnChanges(changes) {
|
|
38
|
+
if (!this.facets) {
|
|
39
|
+
this.facets = [];
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
updateGroup(groupSelections, groupIndex) {
|
|
43
|
+
for (let i = 0; i < groupSelections.length; i++) {
|
|
44
|
+
this.innerSelections[groupIndex][i] = groupSelections[i];
|
|
45
|
+
}
|
|
46
|
+
this.innerSelections[groupIndex].length = groupSelections.length;
|
|
47
|
+
this.selectionChange.emit(this.innerSelections);
|
|
48
|
+
}
|
|
49
|
+
addGroup() {
|
|
50
|
+
this.innerSelections.push([]);
|
|
51
|
+
this.selectionChange.emit(this.innerSelections);
|
|
52
|
+
}
|
|
53
|
+
removeGroup(index) {
|
|
54
|
+
this.innerSelections.splice(index, 1);
|
|
55
|
+
this.selectionChange.emit(this.innerSelections);
|
|
56
|
+
}
|
|
57
|
+
clear() {
|
|
58
|
+
this.innerSelections = [[]];
|
|
59
|
+
this.selectionChange.emit([[]]);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
NaturalSearchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalSearchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
63
|
+
NaturalSearchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.0", type: NaturalSearchComponent, selector: "natural-search", inputs: { placeholder: "placeholder", facets: "facets", multipleGroups: "multipleGroups", selections: "selections" }, outputs: { selectionChange: "selectionChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"natural-search\">\n <div class=\"groupsWrapper\">\n <div *ngFor=\"let groupSelections of innerSelections; let i = index; let last = last\" class=\"groupWrapper\">\n <natural-group\n (selectionChange)=\"updateGroup($event, i)\"\n [facets]=\"facets\"\n [placeholder]=\"placeholder\"\n [selections]=\"groupSelections\"\n ></natural-group>\n\n <div class=\"endOfRowButton\">\n <button (click)=\"removeGroup(i)\" *ngIf=\"innerSelections.length > 1\" mat-icon-button>\n <natural-icon name=\"remove\"></natural-icon>\n </button>\n </div>\n\n <div class=\"endOfRowButton\">\n <button (click)=\"addGroup()\" *ngIf=\"last && multipleGroups\" mat-icon-button>\n <natural-icon name=\"add\"></natural-icon>\n </button>\n </div>\n\n <!-- Spaceholder to keep fields alignment (prevent to push until end of line)--->\n <div *ngIf=\"!last\" class=\"spacer\"></div>\n </div>\n </div>\n\n <div class=\"endOfRowButton\">\n <button (click)=\"clear()\" mat-icon-button>\n <natural-icon name=\"close\"></natural-icon>\n </button>\n <ng-content></ng-content>\n </div>\n</div>\n", styles: [":host .natural-search{display:flex;flex-direction:row;align-items:flex-end}:host .natural-search .groupsWrapper{display:flex;flex-direction:column;flex:1}:host .natural-search .groupWrapper{display:flex;flex-direction:row;margin-bottom:10px}:host .natural-search .groupWrapper natural-group{flex:1}:host .natural-search .groupWrapper:last-of-type{margin-bottom:0}:host .natural-search .groupWrapper .spacer{width:40px;height:40px}:host .natural-search .endOfRowButton{height:53px;display:flex;flex-direction:row;align-items:center}\n"], components: [{ type: i1.NaturalGroupComponent, selector: "natural-group", inputs: ["placeholder", "facets", "selections"], outputs: ["selectionChange"] }, { type: i2.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i3.NaturalIconComponent, selector: "natural-icon", inputs: ["label", "labelColor", "labelPosition", "name", "size"] }], directives: [{ type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
64
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.0", ngImport: i0, type: NaturalSearchComponent, decorators: [{
|
|
65
|
+
type: Component,
|
|
66
|
+
args: [{ selector: 'natural-search', template: "<div class=\"natural-search\">\n <div class=\"groupsWrapper\">\n <div *ngFor=\"let groupSelections of innerSelections; let i = index; let last = last\" class=\"groupWrapper\">\n <natural-group\n (selectionChange)=\"updateGroup($event, i)\"\n [facets]=\"facets\"\n [placeholder]=\"placeholder\"\n [selections]=\"groupSelections\"\n ></natural-group>\n\n <div class=\"endOfRowButton\">\n <button (click)=\"removeGroup(i)\" *ngIf=\"innerSelections.length > 1\" mat-icon-button>\n <natural-icon name=\"remove\"></natural-icon>\n </button>\n </div>\n\n <div class=\"endOfRowButton\">\n <button (click)=\"addGroup()\" *ngIf=\"last && multipleGroups\" mat-icon-button>\n <natural-icon name=\"add\"></natural-icon>\n </button>\n </div>\n\n <!-- Spaceholder to keep fields alignment (prevent to push until end of line)--->\n <div *ngIf=\"!last\" class=\"spacer\"></div>\n </div>\n </div>\n\n <div class=\"endOfRowButton\">\n <button (click)=\"clear()\" mat-icon-button>\n <natural-icon name=\"close\"></natural-icon>\n </button>\n <ng-content></ng-content>\n </div>\n</div>\n", styles: [":host .natural-search{display:flex;flex-direction:row;align-items:flex-end}:host .natural-search .groupsWrapper{display:flex;flex-direction:column;flex:1}:host .natural-search .groupWrapper{display:flex;flex-direction:row;margin-bottom:10px}:host .natural-search .groupWrapper natural-group{flex:1}:host .natural-search .groupWrapper:last-of-type{margin-bottom:0}:host .natural-search .groupWrapper .spacer{width:40px;height:40px}:host .natural-search .endOfRowButton{height:53px;display:flex;flex-direction:row;align-items:center}\n"] }]
|
|
67
|
+
}], propDecorators: { placeholder: [{
|
|
68
|
+
type: Input
|
|
69
|
+
}], facets: [{
|
|
70
|
+
type: Input
|
|
71
|
+
}], multipleGroups: [{
|
|
72
|
+
type: Input
|
|
73
|
+
}], selectionChange: [{
|
|
74
|
+
type: Output
|
|
75
|
+
}], selections: [{
|
|
76
|
+
type: Input
|
|
77
|
+
}] } });
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlYXJjaC9zZWFyY2gvc2VhcmNoLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL3NlYXJjaC9zZWFyY2gvc2VhcmNoLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBYSxNQUFNLEVBQWdCLE1BQU0sZUFBZSxDQUFDO0FBQy9GLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSxrQkFBa0IsQ0FBQzs7Ozs7O0FBUzNDLE1BQU0sT0FBTyxzQkFBc0I7SUFMbkM7UUFNSTs7V0FFRztRQUNhLGdCQUFXLEdBQUcsU0FBUyxDQUFBLFlBQVksQ0FBQztRQUVwRDs7V0FFRztRQUNhLFdBQU0sR0FBd0IsRUFBRSxDQUFDO1FBRWpEOztXQUVHO1FBQ2EsbUJBQWMsR0FBRyxLQUFLLENBQUM7UUFFdkM7O1dBRUc7UUFDdUIsb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBMkIsQ0FBQztRQUV4Rjs7V0FFRztRQUNJLG9CQUFlLEdBQTRCLENBQUMsRUFBRSxDQUFDLENBQUM7S0FxQzFEO0lBbkNHOztPQUVHO0lBQ0gsSUFBb0IsVUFBVSxDQUFDLFVBQW1DO1FBQzlELElBQUksQ0FBQyxlQUFlLEdBQUcsVUFBVSxJQUFJLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3RGLENBQUM7SUFFTSxXQUFXLENBQUMsT0FBc0I7UUFDckMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDZCxJQUFJLENBQUMsTUFBTSxHQUFHLEVBQUUsQ0FBQztTQUNwQjtJQUNMLENBQUM7SUFFTSxXQUFXLENBQUMsZUFBZ0MsRUFBRSxVQUFrQjtRQUNuRSxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsZUFBZSxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRTtZQUM3QyxJQUFJLENBQUMsZUFBZSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLGVBQWUsQ0FBQyxDQUFDLENBQUMsQ0FBQztTQUM1RDtRQUNELElBQUksQ0FBQyxlQUFlLENBQUMsVUFBVSxDQUFDLENBQUMsTUFBTSxHQUFHLGVBQWUsQ0FBQyxNQUFNLENBQUM7UUFDakUsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFTSxRQUFRO1FBQ1gsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDOUIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFTSxXQUFXLENBQUMsS0FBYTtRQUM1QixJQUFJLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDdEMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFTSxLQUFLO1FBQ1IsSUFBSSxDQUFDLGVBQWUsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQzVCLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUNwQyxDQUFDOzttSEE1RFEsc0JBQXNCO3VHQUF0QixzQkFBc0Isa1BDVm5DLDQxQ0FrQ0E7MkZEeEJhLHNCQUFzQjtrQkFMbEMsU0FBUzsrQkFDSSxnQkFBZ0I7OEJBUVYsV0FBVztzQkFBMUIsS0FBSztnQkFLVSxNQUFNO3NCQUFyQixLQUFLO2dCQUtVLGNBQWM7c0JBQTdCLEtBQUs7Z0JBS29CLGVBQWU7c0JBQXhDLE1BQU07Z0JBVWEsVUFBVTtzQkFBN0IsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkNoYW5nZXMsIE91dHB1dCwgU2ltcGxlQ2hhbmdlc30gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge2RlZXBDbG9uZX0gZnJvbSAnLi4vY2xhc3Nlcy91dGlscyc7XG5pbXBvcnQge05hdHVyYWxTZWFyY2hGYWNldHN9IGZyb20gJy4uL3R5cGVzL2ZhY2V0JztcbmltcG9ydCB7R3JvdXBTZWxlY3Rpb25zLCBOYXR1cmFsU2VhcmNoU2VsZWN0aW9uc30gZnJvbSAnLi4vdHlwZXMvdmFsdWVzJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICduYXR1cmFsLXNlYXJjaCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3NlYXJjaC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vc2VhcmNoLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIE5hdHVyYWxTZWFyY2hDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xuICAgIC8qKlxuICAgICAqIFBsYWNlaG9sZGVyIGZvciBsYXN0IGlucHV0ICh0aGUgZnJlZSBzZWFyY2ggaW5wdXQpXG4gICAgICovXG4gICAgQElucHV0KCkgcHVibGljIHBsYWNlaG9sZGVyID0gJGxvY2FsaXplYFJlY2hlcmNoZXJgO1xuXG4gICAgLyoqXG4gICAgICogRXhoYXVzdGl2ZSBsaXN0IG9mIGZhY2V0cyB0byBiZSB1c2VkIGluIHRoaXMgPG5hdHVyYWwtc2VhcmNoPlxuICAgICAqL1xuICAgIEBJbnB1dCgpIHB1YmxpYyBmYWNldHM6IE5hdHVyYWxTZWFyY2hGYWNldHMgPSBbXTtcblxuICAgIC8qKlxuICAgICAqIFdoZXRoZXIgdG8gYWxsb3cgZW5kLXVzZXIgdG8gY3JlYXRlIG11bHRpcGxlIGBPUmAgZ3JvdXBzXG4gICAgICovXG4gICAgQElucHV0KCkgcHVibGljIG11bHRpcGxlR3JvdXBzID0gZmFsc2U7XG5cbiAgICAvKipcbiAgICAgKiBFbWl0cyB3aGVuIHNvbWUgc2VsZWN0aW9uIGhhcyBiZWVuIHNldHRlZCBieSB0aGUgdXNlclxuICAgICAqL1xuICAgIEBPdXRwdXQoKSBwdWJsaWMgcmVhZG9ubHkgc2VsZWN0aW9uQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxOYXR1cmFsU2VhcmNoU2VsZWN0aW9ucz4oKTtcblxuICAgIC8qKlxuICAgICAqIENsZWFuZWQgaW5wdXR0ZWQgc2VsZWN0aW9ucy4gQWxsb3cgdmFsaWQgc2VsZWN0aW9ucyB0byBiZSBtYW5pcHVsYXRlZCBpbnNpZGUgY29tcG9uZW50XG4gICAgICovXG4gICAgcHVibGljIGlubmVyU2VsZWN0aW9uczogTmF0dXJhbFNlYXJjaFNlbGVjdGlvbnMgPSBbW11dO1xuXG4gICAgLyoqXG4gICAgICogSW5wdXQgdG8gZGlzcGxheSBhdCBjb21wb25lbnQgaW5pdGlhbGlzYXRpb25cbiAgICAgKi9cbiAgICBASW5wdXQoKSBwdWJsaWMgc2V0IHNlbGVjdGlvbnMoc2VsZWN0aW9uczogTmF0dXJhbFNlYXJjaFNlbGVjdGlvbnMpIHtcbiAgICAgICAgdGhpcy5pbm5lclNlbGVjdGlvbnMgPSBzZWxlY3Rpb25zICYmIHNlbGVjdGlvbnNbMF0gPyBkZWVwQ2xvbmUoc2VsZWN0aW9ucykgOiBbW11dO1xuICAgIH1cblxuICAgIHB1YmxpYyBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgICAgIGlmICghdGhpcy5mYWNldHMpIHtcbiAgICAgICAgICAgIHRoaXMuZmFjZXRzID0gW107XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwdWJsaWMgdXBkYXRlR3JvdXAoZ3JvdXBTZWxlY3Rpb25zOiBHcm91cFNlbGVjdGlvbnMsIGdyb3VwSW5kZXg6IG51bWJlcik6IHZvaWQge1xuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IGdyb3VwU2VsZWN0aW9ucy5sZW5ndGg7IGkrKykge1xuICAgICAgICAgICAgdGhpcy5pbm5lclNlbGVjdGlvbnNbZ3JvdXBJbmRleF1baV0gPSBncm91cFNlbGVjdGlvbnNbaV07XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5pbm5lclNlbGVjdGlvbnNbZ3JvdXBJbmRleF0ubGVuZ3RoID0gZ3JvdXBTZWxlY3Rpb25zLmxlbmd0aDtcbiAgICAgICAgdGhpcy5zZWxlY3Rpb25DaGFuZ2UuZW1pdCh0aGlzLmlubmVyU2VsZWN0aW9ucyk7XG4gICAgfVxuXG4gICAgcHVibGljIGFkZEdyb3VwKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmlubmVyU2VsZWN0aW9ucy5wdXNoKFtdKTtcbiAgICAgICAgdGhpcy5zZWxlY3Rpb25DaGFuZ2UuZW1pdCh0aGlzLmlubmVyU2VsZWN0aW9ucyk7XG4gICAgfVxuXG4gICAgcHVibGljIHJlbW92ZUdyb3VwKGluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pbm5lclNlbGVjdGlvbnMuc3BsaWNlKGluZGV4LCAxKTtcbiAgICAgICAgdGhpcy5zZWxlY3Rpb25DaGFuZ2UuZW1pdCh0aGlzLmlubmVyU2VsZWN0aW9ucyk7XG4gICAgfVxuXG4gICAgcHVibGljIGNsZWFyKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmlubmVyU2VsZWN0aW9ucyA9IFtbXV07XG4gICAgICAgIHRoaXMuc2VsZWN0aW9uQ2hhbmdlLmVtaXQoW1tdXSk7XG4gICAgfVxufVxuIiwiPGRpdiBjbGFzcz1cIm5hdHVyYWwtc2VhcmNoXCI+XG4gICAgPGRpdiBjbGFzcz1cImdyb3Vwc1dyYXBwZXJcIj5cbiAgICAgICAgPGRpdiAqbmdGb3I9XCJsZXQgZ3JvdXBTZWxlY3Rpb25zIG9mIGlubmVyU2VsZWN0aW9uczsgbGV0IGkgPSBpbmRleDsgbGV0IGxhc3QgPSBsYXN0XCIgY2xhc3M9XCJncm91cFdyYXBwZXJcIj5cbiAgICAgICAgICAgIDxuYXR1cmFsLWdyb3VwXG4gICAgICAgICAgICAgICAgKHNlbGVjdGlvbkNoYW5nZSk9XCJ1cGRhdGVHcm91cCgkZXZlbnQsIGkpXCJcbiAgICAgICAgICAgICAgICBbZmFjZXRzXT1cImZhY2V0c1wiXG4gICAgICAgICAgICAgICAgW3BsYWNlaG9sZGVyXT1cInBsYWNlaG9sZGVyXCJcbiAgICAgICAgICAgICAgICBbc2VsZWN0aW9uc109XCJncm91cFNlbGVjdGlvbnNcIlxuICAgICAgICAgICAgPjwvbmF0dXJhbC1ncm91cD5cblxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImVuZE9mUm93QnV0dG9uXCI+XG4gICAgICAgICAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVwicmVtb3ZlR3JvdXAoaSlcIiAqbmdJZj1cImlubmVyU2VsZWN0aW9ucy5sZW5ndGggPiAxXCIgbWF0LWljb24tYnV0dG9uPlxuICAgICAgICAgICAgICAgICAgICA8bmF0dXJhbC1pY29uIG5hbWU9XCJyZW1vdmVcIj48L25hdHVyYWwtaWNvbj5cbiAgICAgICAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgICAgIDwvZGl2PlxuXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZW5kT2ZSb3dCdXR0b25cIj5cbiAgICAgICAgICAgICAgICA8YnV0dG9uIChjbGljayk9XCJhZGRHcm91cCgpXCIgKm5nSWY9XCJsYXN0ICYmIG11bHRpcGxlR3JvdXBzXCIgbWF0LWljb24tYnV0dG9uPlxuICAgICAgICAgICAgICAgICAgICA8bmF0dXJhbC1pY29uIG5hbWU9XCJhZGRcIj48L25hdHVyYWwtaWNvbj5cbiAgICAgICAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgICAgIDwvZGl2PlxuXG4gICAgICAgICAgICA8IS0tIFNwYWNlaG9sZGVyIHRvIGtlZXAgZmllbGRzIGFsaWdubWVudCAocHJldmVudCB0byBwdXNoIHVudGlsIGVuZCBvZiBsaW5lKS0tLT5cbiAgICAgICAgICAgIDxkaXYgKm5nSWY9XCIhbGFzdFwiIGNsYXNzPVwic3BhY2VyXCI+PC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuXG4gICAgPGRpdiBjbGFzcz1cImVuZE9mUm93QnV0dG9uXCI+XG4gICAgICAgIDxidXR0b24gKGNsaWNrKT1cImNsZWFyKClcIiBtYXQtaWNvbi1idXR0b24+XG4gICAgICAgICAgICA8bmF0dXJhbC1pY29uIG5hbWU9XCJjbG9zZVwiPjwvbmF0dXJhbC1pY29uPlxuICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgIDwvZGl2PlxuPC9kaXY+XG4iXX0=
|