primeng 18.0.0 → 18.0.2-patch.1
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/accordion/accordion.d.ts +7 -7
- package/autocomplete/autocomplete.d.ts +21 -8
- package/badge/badge.d.ts +1 -3
- package/basecomponent/basecomponent.d.ts +2 -5
- package/blockui/blockui.d.ts +10 -5
- package/breadcrumb/breadcrumb.d.ts +9 -6
- package/button/button.d.ts +10 -4
- package/calendar/calendar.d.ts +29 -15
- package/card/card.d.ts +12 -5
- package/carousel/carousel.d.ts +10 -4
- package/cascadeselect/cascadeselect.d.ts +18 -8
- package/checkbox/checkbox.d.ts +8 -4
- package/chip/chip.d.ts +9 -7
- package/chips/chips.d.ts +237 -0
- package/chips/chips.interface.d.ts +66 -0
- package/chips/index.d.ts +5 -0
- package/chips/public_api.d.ts +2 -0
- package/chips/style/chipsstyle.d.ts +69 -0
- package/confirmdialog/confirmdialog.d.ts +14 -5
- package/confirmpopup/confirmpopup.d.ts +11 -5
- package/contextmenu/contextmenu.d.ts +10 -6
- package/datepicker/datepicker.d.ts +113 -33
- package/dialog/dialog.d.ts +15 -4
- package/divider/divider.d.ts +1 -1
- package/dock/dock.d.ts +7 -4
- package/drawer/drawer.d.ts +18 -10
- package/dropdown/dropdown.d.ts +4 -3
- package/dynamicdialog/dynamicdialog.d.ts +1 -0
- package/editor/editor.d.ts +7 -3
- package/esm2022/accordion/accordion.mjs +58 -43
- package/esm2022/autocomplete/autocomplete.mjs +153 -92
- package/esm2022/badge/badge.mjs +39 -32
- package/esm2022/basecomponent/basecomponent.mjs +3 -26
- package/esm2022/blockui/blockui.mjs +38 -18
- package/esm2022/breadcrumb/breadcrumb.mjs +50 -32
- package/esm2022/button/button.mjs +55 -28
- package/esm2022/calendar/calendar.mjs +207 -143
- package/esm2022/card/card.mjs +96 -46
- package/esm2022/carousel/carousel.mjs +74 -42
- package/esm2022/cascadeselect/cascadeselect.mjs +100 -62
- package/esm2022/checkbox/checkbox.mjs +32 -14
- package/esm2022/chip/chip.mjs +117 -96
- package/esm2022/chips/chips.interface.mjs +2 -0
- package/esm2022/chips/chips.mjs +827 -0
- package/esm2022/chips/primeng-chips.mjs +5 -0
- package/esm2022/chips/public_api.mjs +3 -0
- package/esm2022/chips/style/chipsstyle.mjs +175 -0
- package/esm2022/confirmdialog/confirmdialog.mjs +96 -57
- package/esm2022/confirmpopup/confirmpopup.mjs +57 -29
- package/esm2022/contextmenu/contextmenu.mjs +51 -20
- package/esm2022/datepicker/datepicker.mjs +198 -156
- package/esm2022/dialog/dialog.mjs +98 -52
- package/esm2022/divider/divider.mjs +2 -4
- package/esm2022/dock/dock.mjs +31 -13
- package/esm2022/drawer/drawer.mjs +112 -70
- package/esm2022/dropdown/dropdown.mjs +13 -5
- package/esm2022/dynamicdialog/dynamicdialog-config.mjs +13 -13
- package/esm2022/dynamicdialog/dynamicdialog.mjs +9 -5
- package/esm2022/editor/editor.mjs +27 -11
- package/esm2022/fieldset/fieldset.mjs +61 -33
- package/esm2022/fileupload/fileupload.mjs +139 -89
- package/esm2022/galleria/galleria.mjs +18 -9
- package/esm2022/image/image.mjs +113 -66
- package/esm2022/imagecompare/imagecompare.mjs +31 -11
- package/esm2022/inplace/inplace.mjs +49 -24
- package/esm2022/inputmask/inputmask.mjs +30 -14
- package/esm2022/inputmask/style/inputmaskstyle.mjs +2 -2
- package/esm2022/inputnumber/inputnumber.mjs +55 -47
- package/esm2022/inputotp/inputotp.mjs +30 -11
- package/esm2022/listbox/listbox.mjs +137 -78
- package/esm2022/megamenu/megamenu.mjs +105 -59
- package/esm2022/menu/menu.mjs +26 -26
- package/esm2022/menubar/menubar.mjs +70 -35
- package/esm2022/message/message.mjs +50 -26
- package/esm2022/messages/messages.mjs +13 -4
- package/esm2022/metergroup/metergroup.mjs +63 -31
- package/esm2022/multiselect/multiselect.mjs +247 -156
- package/esm2022/orderlist/orderlist.mjs +125 -70
- package/esm2022/organizationchart/organizationchart.mjs +30 -14
- package/esm2022/overlay/overlay.mjs +27 -7
- package/esm2022/overlaypanel/overlaypanel.mjs +33 -10
- package/esm2022/paginator/paginator.mjs +92 -60
- package/esm2022/panel/panel.mjs +160 -100
- package/esm2022/panelmenu/panelmenu.mjs +55 -32
- package/esm2022/password/password.mjs +88 -49
- package/esm2022/picklist/picklist.mjs +363 -259
- package/esm2022/popover/popover.mjs +29 -12
- package/esm2022/progressbar/progressbar.mjs +27 -9
- package/esm2022/rating/rating.mjs +46 -22
- package/esm2022/scroller/scroller.mjs +47 -37
- package/esm2022/scrollpanel/scrollpanel.mjs +28 -9
- package/esm2022/scrolltop/scrolltop.mjs +17 -10
- package/esm2022/select/select.mjs +198 -119
- package/esm2022/selectbutton/selectbutton.mjs +26 -11
- package/esm2022/sidebar/sidebar.mjs +82 -60
- package/esm2022/speeddial/speeddial.mjs +54 -29
- package/esm2022/splitbutton/splitbutton.mjs +41 -18
- package/esm2022/splitter/splitter.mjs +5 -5
- package/esm2022/stepper/stepper.mjs +27 -13
- package/esm2022/table/table.mjs +107 -96
- package/esm2022/tabmenu/tabmenu.mjs +54 -27
- package/esm2022/tabs/tablist.mjs +28 -20
- package/esm2022/tabview/tabview.mjs +106 -54
- package/esm2022/tag/tag.mjs +68 -44
- package/esm2022/tieredmenu/tieredmenu.mjs +44 -21
- package/esm2022/timeline/timeline.mjs +41 -17
- package/esm2022/toast/toast.mjs +31 -9
- package/esm2022/togglebutton/togglebutton.mjs +45 -30
- package/esm2022/toggleswitch/toggleswitch.mjs +28 -9
- package/esm2022/toolbar/toolbar.mjs +47 -21
- package/esm2022/tooltip/tooltip.mjs +35 -70
- package/esm2022/tree/tree.mjs +114 -97
- package/esm2022/treeselect/treeselect.mjs +156 -89
- package/esm2022/treetable/treetable.mjs +31 -12
- package/esm2022/usestyle/usestyle.mjs +2 -2
- package/fesm2022/primeng-accordion.mjs +59 -44
- package/fesm2022/primeng-accordion.mjs.map +1 -1
- package/fesm2022/primeng-animateonscroll.mjs +1 -1
- package/fesm2022/primeng-api.mjs +1 -1
- package/fesm2022/primeng-autocomplete.mjs +152 -91
- package/fesm2022/primeng-autocomplete.mjs.map +1 -1
- package/fesm2022/primeng-avatar.mjs +1 -1
- package/fesm2022/primeng-avatargroup.mjs +1 -1
- package/fesm2022/primeng-badge.mjs +40 -33
- package/fesm2022/primeng-badge.mjs.map +1 -1
- package/fesm2022/primeng-basecomponent.mjs +2 -25
- package/fesm2022/primeng-basecomponent.mjs.map +1 -1
- package/fesm2022/primeng-blockui.mjs +37 -17
- package/fesm2022/primeng-blockui.mjs.map +1 -1
- package/fesm2022/primeng-breadcrumb.mjs +49 -31
- package/fesm2022/primeng-breadcrumb.mjs.map +1 -1
- package/fesm2022/primeng-button.mjs +54 -27
- package/fesm2022/primeng-button.mjs.map +1 -1
- package/fesm2022/primeng-buttongroup.mjs +1 -1
- package/fesm2022/primeng-calendar.mjs +207 -143
- package/fesm2022/primeng-calendar.mjs.map +1 -1
- package/fesm2022/primeng-card.mjs +95 -45
- package/fesm2022/primeng-card.mjs.map +1 -1
- package/fesm2022/primeng-carousel.mjs +73 -41
- package/fesm2022/primeng-carousel.mjs.map +1 -1
- package/fesm2022/primeng-cascadeselect.mjs +99 -61
- package/fesm2022/primeng-cascadeselect.mjs.map +1 -1
- package/fesm2022/primeng-chart.mjs +1 -1
- package/fesm2022/primeng-checkbox.mjs +31 -13
- package/fesm2022/primeng-checkbox.mjs.map +1 -1
- package/fesm2022/primeng-chip.mjs +116 -95
- package/fesm2022/primeng-chip.mjs.map +1 -1
- package/fesm2022/primeng-chips.mjs +1006 -0
- package/fesm2022/primeng-chips.mjs.map +1 -0
- package/fesm2022/primeng-colorpicker.mjs +1 -1
- package/fesm2022/primeng-confirmdialog.mjs +95 -56
- package/fesm2022/primeng-confirmdialog.mjs.map +1 -1
- package/fesm2022/primeng-confirmpopup.mjs +57 -29
- package/fesm2022/primeng-confirmpopup.mjs.map +1 -1
- package/fesm2022/primeng-contextmenu.mjs +50 -19
- package/fesm2022/primeng-contextmenu.mjs.map +1 -1
- package/fesm2022/primeng-dataview.mjs +2 -2
- package/fesm2022/primeng-datepicker.mjs +198 -156
- package/fesm2022/primeng-datepicker.mjs.map +1 -1
- package/fesm2022/primeng-defer.mjs +1 -1
- package/fesm2022/primeng-dialog.mjs +97 -51
- package/fesm2022/primeng-dialog.mjs.map +1 -1
- package/fesm2022/primeng-divider.mjs +2 -4
- package/fesm2022/primeng-divider.mjs.map +1 -1
- package/fesm2022/primeng-dock.mjs +30 -12
- package/fesm2022/primeng-dock.mjs.map +1 -1
- package/fesm2022/primeng-dragdrop.mjs +1 -1
- package/fesm2022/primeng-drawer.mjs +111 -69
- package/fesm2022/primeng-drawer.mjs.map +1 -1
- package/fesm2022/primeng-dropdown.mjs +12 -4
- package/fesm2022/primeng-dropdown.mjs.map +1 -1
- package/fesm2022/primeng-dynamicdialog.mjs +21 -17
- package/fesm2022/primeng-dynamicdialog.mjs.map +1 -1
- package/fesm2022/primeng-editor.mjs +26 -10
- package/fesm2022/primeng-editor.mjs.map +1 -1
- package/fesm2022/primeng-fieldset.mjs +61 -33
- package/fesm2022/primeng-fieldset.mjs.map +1 -1
- package/fesm2022/primeng-fileupload.mjs +138 -88
- package/fesm2022/primeng-fileupload.mjs.map +1 -1
- package/fesm2022/primeng-floatlabel.mjs +1 -1
- package/fesm2022/primeng-fluid.mjs +1 -1
- package/fesm2022/primeng-galleria.mjs +17 -8
- package/fesm2022/primeng-galleria.mjs.map +1 -1
- package/fesm2022/primeng-iconfield.mjs +1 -1
- package/fesm2022/primeng-icons-baseicon.mjs +1 -1
- package/fesm2022/primeng-iftalabel.mjs +1 -1
- package/fesm2022/primeng-image.mjs +112 -65
- package/fesm2022/primeng-image.mjs.map +1 -1
- package/fesm2022/primeng-imagecompare.mjs +30 -10
- package/fesm2022/primeng-imagecompare.mjs.map +1 -1
- package/fesm2022/primeng-inplace.mjs +48 -23
- package/fesm2022/primeng-inplace.mjs.map +1 -1
- package/fesm2022/primeng-inputgroupaddon.mjs +1 -1
- package/fesm2022/primeng-inputicon.mjs +1 -1
- package/fesm2022/primeng-inputmask.mjs +30 -14
- package/fesm2022/primeng-inputmask.mjs.map +1 -1
- package/fesm2022/primeng-inputnumber.mjs +54 -46
- package/fesm2022/primeng-inputnumber.mjs.map +1 -1
- package/fesm2022/primeng-inputotp.mjs +29 -10
- package/fesm2022/primeng-inputotp.mjs.map +1 -1
- package/fesm2022/primeng-inputswitch.mjs +1 -1
- package/fesm2022/primeng-inputtext.mjs +1 -1
- package/fesm2022/primeng-inputtextarea.mjs +1 -1
- package/fesm2022/primeng-keyfilter.mjs +1 -1
- package/fesm2022/primeng-knob.mjs +1 -1
- package/fesm2022/primeng-listbox.mjs +136 -77
- package/fesm2022/primeng-listbox.mjs.map +1 -1
- package/fesm2022/primeng-megamenu.mjs +104 -58
- package/fesm2022/primeng-megamenu.mjs.map +1 -1
- package/fesm2022/primeng-menu.mjs +26 -26
- package/fesm2022/primeng-menu.mjs.map +1 -1
- package/fesm2022/primeng-menubar.mjs +69 -34
- package/fesm2022/primeng-menubar.mjs.map +1 -1
- package/fesm2022/primeng-message.mjs +49 -25
- package/fesm2022/primeng-message.mjs.map +1 -1
- package/fesm2022/primeng-messages.mjs +12 -3
- package/fesm2022/primeng-messages.mjs.map +1 -1
- package/fesm2022/primeng-metergroup.mjs +62 -30
- package/fesm2022/primeng-metergroup.mjs.map +1 -1
- package/fesm2022/primeng-multiselect.mjs +246 -155
- package/fesm2022/primeng-multiselect.mjs.map +1 -1
- package/fesm2022/primeng-orderlist.mjs +124 -69
- package/fesm2022/primeng-orderlist.mjs.map +1 -1
- package/fesm2022/primeng-organizationchart.mjs +30 -14
- package/fesm2022/primeng-organizationchart.mjs.map +1 -1
- package/fesm2022/primeng-overlay.mjs +26 -6
- package/fesm2022/primeng-overlay.mjs.map +1 -1
- package/fesm2022/primeng-overlaybadge.mjs +1 -1
- package/fesm2022/primeng-overlaypanel.mjs +33 -10
- package/fesm2022/primeng-overlaypanel.mjs.map +1 -1
- package/fesm2022/primeng-paginator.mjs +91 -59
- package/fesm2022/primeng-paginator.mjs.map +1 -1
- package/fesm2022/primeng-panel.mjs +160 -100
- package/fesm2022/primeng-panel.mjs.map +1 -1
- package/fesm2022/primeng-panelmenu.mjs +55 -32
- package/fesm2022/primeng-panelmenu.mjs.map +1 -1
- package/fesm2022/primeng-password.mjs +87 -48
- package/fesm2022/primeng-password.mjs.map +1 -1
- package/fesm2022/primeng-picklist.mjs +362 -258
- package/fesm2022/primeng-picklist.mjs.map +1 -1
- package/fesm2022/primeng-popover.mjs +29 -12
- package/fesm2022/primeng-popover.mjs.map +1 -1
- package/fesm2022/primeng-progressbar.mjs +26 -8
- package/fesm2022/primeng-progressbar.mjs.map +1 -1
- package/fesm2022/primeng-progressspinner.mjs +1 -1
- package/fesm2022/primeng-radiobutton.mjs +1 -1
- package/fesm2022/primeng-rating.mjs +45 -21
- package/fesm2022/primeng-rating.mjs.map +1 -1
- package/fesm2022/primeng-scroller.mjs +46 -36
- package/fesm2022/primeng-scroller.mjs.map +1 -1
- package/fesm2022/primeng-scrollpanel.mjs +27 -8
- package/fesm2022/primeng-scrollpanel.mjs.map +1 -1
- package/fesm2022/primeng-scrolltop.mjs +17 -10
- package/fesm2022/primeng-scrolltop.mjs.map +1 -1
- package/fesm2022/primeng-select.mjs +197 -118
- package/fesm2022/primeng-select.mjs.map +1 -1
- package/fesm2022/primeng-selectbutton.mjs +25 -10
- package/fesm2022/primeng-selectbutton.mjs.map +1 -1
- package/fesm2022/primeng-sidebar.mjs +81 -59
- package/fesm2022/primeng-sidebar.mjs.map +1 -1
- package/fesm2022/primeng-skeleton.mjs +1 -1
- package/fesm2022/primeng-slider.mjs +1 -1
- package/fesm2022/primeng-speeddial.mjs +53 -28
- package/fesm2022/primeng-speeddial.mjs.map +1 -1
- package/fesm2022/primeng-splitbutton.mjs +40 -17
- package/fesm2022/primeng-splitbutton.mjs.map +1 -1
- package/fesm2022/primeng-splitter.mjs +6 -6
- package/fesm2022/primeng-splitter.mjs.map +1 -1
- package/fesm2022/primeng-stepper.mjs +27 -13
- package/fesm2022/primeng-stepper.mjs.map +1 -1
- package/fesm2022/primeng-steps.mjs +1 -1
- package/fesm2022/primeng-styleclass.mjs +1 -1
- package/fesm2022/primeng-table.mjs +107 -96
- package/fesm2022/primeng-table.mjs.map +1 -1
- package/fesm2022/primeng-tabmenu.mjs +53 -26
- package/fesm2022/primeng-tabmenu.mjs.map +1 -1
- package/fesm2022/primeng-tabs.mjs +27 -19
- package/fesm2022/primeng-tabs.mjs.map +1 -1
- package/fesm2022/primeng-tabview.mjs +106 -54
- package/fesm2022/primeng-tabview.mjs.map +1 -1
- package/fesm2022/primeng-tag.mjs +67 -43
- package/fesm2022/primeng-tag.mjs.map +1 -1
- package/fesm2022/primeng-terminal.mjs +1 -1
- package/fesm2022/primeng-textarea.mjs +1 -1
- package/fesm2022/primeng-tieredmenu.mjs +43 -20
- package/fesm2022/primeng-tieredmenu.mjs.map +1 -1
- package/fesm2022/primeng-timeline.mjs +40 -16
- package/fesm2022/primeng-timeline.mjs.map +1 -1
- package/fesm2022/primeng-toast.mjs +31 -9
- package/fesm2022/primeng-toast.mjs.map +1 -1
- package/fesm2022/primeng-togglebutton.mjs +44 -29
- package/fesm2022/primeng-togglebutton.mjs.map +1 -1
- package/fesm2022/primeng-toggleswitch.mjs +27 -8
- package/fesm2022/primeng-toggleswitch.mjs.map +1 -1
- package/fesm2022/primeng-toolbar.mjs +46 -20
- package/fesm2022/primeng-toolbar.mjs.map +1 -1
- package/fesm2022/primeng-tooltip.mjs +35 -70
- package/fesm2022/primeng-tooltip.mjs.map +1 -1
- package/fesm2022/primeng-tree.mjs +114 -97
- package/fesm2022/primeng-tree.mjs.map +1 -1
- package/fesm2022/primeng-treeselect.mjs +155 -88
- package/fesm2022/primeng-treeselect.mjs.map +1 -1
- package/fesm2022/primeng-treetable.mjs +30 -11
- package/fesm2022/primeng-treetable.mjs.map +1 -1
- package/fesm2022/primeng-usestyle.mjs +1 -1
- package/fesm2022/primeng-usestyle.mjs.map +1 -1
- package/fieldset/fieldset.d.ts +12 -6
- package/fileupload/fileupload.d.ts +19 -8
- package/galleria/galleria.d.ts +3 -2
- package/image/image.d.ts +18 -7
- package/imagecompare/imagecompare.d.ts +7 -2
- package/inplace/inplace.d.ts +12 -6
- package/inputmask/inputmask.d.ts +8 -4
- package/inputnumber/inputnumber.d.ts +11 -6
- package/inputotp/inputotp.d.ts +7 -2
- package/listbox/listbox.d.ts +17 -4
- package/megamenu/megamenu.d.ts +16 -7
- package/menu/menu.d.ts +6 -6
- package/menubar/menubar.d.ts +13 -6
- package/message/message.d.ts +10 -4
- package/messages/messages.d.ts +4 -3
- package/metergroup/metergroup.d.ts +11 -3
- package/multiselect/multiselect.d.ts +36 -17
- package/orderlist/orderlist.d.ts +23 -11
- package/organizationchart/organizationchart.d.ts +6 -4
- package/overlay/overlay.d.ts +6 -3
- package/overlaypanel/overlaypanel.d.ts +6 -3
- package/package.json +171 -165
- package/paginator/paginator.d.ts +15 -8
- package/panel/panel.d.ts +14 -5
- package/panelmenu/panelmenu.d.ts +8 -4
- package/password/password.d.ts +15 -7
- package/picklist/picklist.d.ts +23 -3
- package/popover/popover.d.ts +8 -5
- package/progressbar/progressbar.d.ts +7 -3
- package/rating/rating.d.ts +11 -5
- package/scroller/scroller.d.ts +9 -4
- package/scrollpanel/scrollpanel.d.ts +7 -3
- package/scrolltop/scrolltop.d.ts +7 -4
- package/select/select.d.ts +31 -13
- package/selectbutton/selectbutton.d.ts +7 -3
- package/sidebar/sidebar.d.ts +9 -2
- package/speeddial/speeddial.d.ts +9 -4
- package/splitbutton/splitbutton.d.ts +9 -5
- package/splitter/splitter.d.ts +4 -4
- package/stepper/stepper.d.ts +8 -3
- package/table/table.d.ts +2 -2
- package/tabmenu/tabmenu.d.ts +12 -7
- package/tabs/tablist.d.ts +6 -2
- package/tabview/tabview.d.ts +16 -7
- package/tag/tag.d.ts +8 -9
- package/tieredmenu/tieredmenu.d.ts +10 -6
- package/timeline/timeline.d.ts +7 -2
- package/toast/toast.d.ts +7 -3
- package/togglebutton/togglebutton.d.ts +8 -3
- package/toggleswitch/toggleswitch.d.ts +6 -2
- package/toolbar/toolbar.d.ts +9 -4
- package/tooltip/tooltip.d.ts +2 -1
- package/tree/tree.d.ts +23 -10
- package/treeselect/treeselect.d.ts +26 -12
- package/treetable/treetable.d.ts +7 -5
@@ -0,0 +1,827 @@
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
2
|
+
import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, NgModule, Output, ViewChild, ViewEncapsulation, booleanAttribute, forwardRef, inject, numberAttribute } from '@angular/core';
|
3
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
4
|
+
import { PrimeTemplate, SharedModule } from 'primeng/api';
|
5
|
+
import { AutoFocusModule } from 'primeng/autofocus';
|
6
|
+
import { TimesIcon } from 'primeng/icons/times';
|
7
|
+
import { TimesCircleIcon } from 'primeng/icons/timescircle';
|
8
|
+
import { InputTextModule } from 'primeng/inputtext';
|
9
|
+
import { UniqueComponentId } from 'primeng/utils';
|
10
|
+
import { ChipsStyle } from './style/chipsstyle';
|
11
|
+
import { BaseComponent } from 'primeng/basecomponent';
|
12
|
+
import { ChipModule } from 'primeng/chip';
|
13
|
+
import * as i0 from "@angular/core";
|
14
|
+
import * as i1 from "primeng/config";
|
15
|
+
import * as i2 from "@angular/common";
|
16
|
+
import * as i3 from "primeng/autofocus";
|
17
|
+
import * as i4 from "primeng/chip";
|
18
|
+
const _c0 = ["inputtext"];
|
19
|
+
const _c1 = ["container"];
|
20
|
+
const _c2 = (a0, a1, a2, a3) => ({ "p-inputchips p-component p-input-wrapper": true, "p-disabled": a0, "p-focus": a1, "p-inputwrapper-filled": a2, "p-inputwrapper-focus": a3 });
|
21
|
+
const _c3 = a0 => ({ "p-chips-clearable": a0 });
|
22
|
+
const _c4 = a0 => ({ "p-inputchips-chip-item": true, "p-focus": a0 });
|
23
|
+
const _c5 = a0 => ({ $implicit: a0 });
|
24
|
+
const _c6 = a0 => ({ removeItem: a0 });
|
25
|
+
function Chips_li_3_ng_container_2_Template(rf, ctx) { if (rf & 1) {
|
26
|
+
i0.ɵɵelementContainer(0);
|
27
|
+
} }
|
28
|
+
function Chips_li_3_p_chip_3_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
29
|
+
i0.ɵɵelementContainer(0);
|
30
|
+
} }
|
31
|
+
function Chips_li_3_p_chip_3_ng_template_2_ng_container_0_TimesCircleIcon_1_Template(rf, ctx) { if (rf & 1) {
|
32
|
+
const _r7 = i0.ɵɵgetCurrentView();
|
33
|
+
i0.ɵɵelementStart(0, "TimesCircleIcon", 16);
|
34
|
+
i0.ɵɵlistener("click", function Chips_li_3_p_chip_3_ng_template_2_ng_container_0_TimesCircleIcon_1_Template_TimesCircleIcon_click_0_listener($event) { i0.ɵɵrestoreView(_r7); const i_r6 = i0.ɵɵnextContext(4).index; const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.removeItem($event, i_r6)); });
|
35
|
+
i0.ɵɵelementEnd();
|
36
|
+
} if (rf & 2) {
|
37
|
+
i0.ɵɵproperty("styleClass", "p-chips-token-icon");
|
38
|
+
i0.ɵɵattribute("data-pc-section", "removeTokenIcon")("aria-hidden", true);
|
39
|
+
} }
|
40
|
+
function Chips_li_3_p_chip_3_ng_template_2_ng_container_0_span_2_1_ng_template_0_Template(rf, ctx) { }
|
41
|
+
function Chips_li_3_p_chip_3_ng_template_2_ng_container_0_span_2_1_Template(rf, ctx) { if (rf & 1) {
|
42
|
+
i0.ɵɵtemplate(0, Chips_li_3_p_chip_3_ng_template_2_ng_container_0_span_2_1_ng_template_0_Template, 0, 0, "ng-template");
|
43
|
+
} }
|
44
|
+
function Chips_li_3_p_chip_3_ng_template_2_ng_container_0_span_2_Template(rf, ctx) { if (rf & 1) {
|
45
|
+
const _r8 = i0.ɵɵgetCurrentView();
|
46
|
+
i0.ɵɵelementStart(0, "span", 17);
|
47
|
+
i0.ɵɵlistener("click", function Chips_li_3_p_chip_3_ng_template_2_ng_container_0_span_2_Template_span_click_0_listener($event) { i0.ɵɵrestoreView(_r8); const i_r6 = i0.ɵɵnextContext(4).index; const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.removeItem($event, i_r6)); });
|
48
|
+
i0.ɵɵtemplate(1, Chips_li_3_p_chip_3_ng_template_2_ng_container_0_span_2_1_Template, 1, 0, null, 11);
|
49
|
+
i0.ɵɵelementEnd();
|
50
|
+
} if (rf & 2) {
|
51
|
+
const ctx_r3 = i0.ɵɵnextContext(5);
|
52
|
+
i0.ɵɵattribute("data-pc-section", "removeTokenIcon")("aria-hidden", true);
|
53
|
+
i0.ɵɵadvance();
|
54
|
+
i0.ɵɵproperty("ngTemplateOutlet", ctx_r3.removeTokenIconTemplate)("ngTemplateOutletContext", i0.ɵɵpureFunction1(4, _c6, ctx_r3.removeItem.bind(ctx_r3)));
|
55
|
+
} }
|
56
|
+
function Chips_li_3_p_chip_3_ng_template_2_ng_container_0_Template(rf, ctx) { if (rf & 1) {
|
57
|
+
i0.ɵɵelementContainerStart(0);
|
58
|
+
i0.ɵɵtemplate(1, Chips_li_3_p_chip_3_ng_template_2_ng_container_0_TimesCircleIcon_1_Template, 1, 3, "TimesCircleIcon", 14)(2, Chips_li_3_p_chip_3_ng_template_2_ng_container_0_span_2_Template, 2, 6, "span", 15);
|
59
|
+
i0.ɵɵelementContainerEnd();
|
60
|
+
} if (rf & 2) {
|
61
|
+
const ctx_r3 = i0.ɵɵnextContext(4);
|
62
|
+
i0.ɵɵadvance();
|
63
|
+
i0.ɵɵproperty("ngIf", !ctx_r3.removeTokenIconTemplate);
|
64
|
+
i0.ɵɵadvance();
|
65
|
+
i0.ɵɵproperty("ngIf", ctx_r3.removeTokenIconTemplate);
|
66
|
+
} }
|
67
|
+
function Chips_li_3_p_chip_3_ng_template_2_Template(rf, ctx) { if (rf & 1) {
|
68
|
+
i0.ɵɵtemplate(0, Chips_li_3_p_chip_3_ng_template_2_ng_container_0_Template, 3, 2, "ng-container", 9);
|
69
|
+
} if (rf & 2) {
|
70
|
+
const ctx_r3 = i0.ɵɵnextContext(3);
|
71
|
+
i0.ɵɵproperty("ngIf", !ctx_r3.disabled);
|
72
|
+
} }
|
73
|
+
function Chips_li_3_p_chip_3_Template(rf, ctx) { if (rf & 1) {
|
74
|
+
const _r5 = i0.ɵɵgetCurrentView();
|
75
|
+
i0.ɵɵelementStart(0, "p-chip", 13);
|
76
|
+
i0.ɵɵlistener("onRemove", function Chips_li_3_p_chip_3_Template_p_chip_onRemove_0_listener($event) { i0.ɵɵrestoreView(_r5); const i_r6 = i0.ɵɵnextContext().index; const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.removeItem($event, i_r6)); });
|
77
|
+
i0.ɵɵtemplate(1, Chips_li_3_p_chip_3_ng_container_1_Template, 1, 0, "ng-container", 11)(2, Chips_li_3_p_chip_3_ng_template_2_Template, 1, 1, "ng-template", null, 3, i0.ɵɵtemplateRefExtractor);
|
78
|
+
i0.ɵɵelementEnd();
|
79
|
+
} if (rf & 2) {
|
80
|
+
const item_r3 = i0.ɵɵnextContext().$implicit;
|
81
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
82
|
+
i0.ɵɵproperty("label", ctx_r3.field ? ctx_r3.resolveFieldData(item_r3, ctx_r3.field) : item_r3)("removeIcon", ctx_r3.chipIcon);
|
83
|
+
i0.ɵɵadvance();
|
84
|
+
i0.ɵɵproperty("ngTemplateOutlet", ctx_r3.itemTemplate)("ngTemplateOutletContext", i0.ɵɵpureFunction1(4, _c5, item_r3));
|
85
|
+
} }
|
86
|
+
function Chips_li_3_Template(rf, ctx) { if (rf & 1) {
|
87
|
+
const _r2 = i0.ɵɵgetCurrentView();
|
88
|
+
i0.ɵɵelementStart(0, "li", 10, 2);
|
89
|
+
i0.ɵɵlistener("click", function Chips_li_3_Template_li_click_0_listener($event) { const item_r3 = i0.ɵɵrestoreView(_r2).$implicit; const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.onItemClick($event, item_r3)); })("contextmenu", function Chips_li_3_Template_li_contextmenu_0_listener($event) { const item_r3 = i0.ɵɵrestoreView(_r2).$implicit; const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.onItemContextMenu($event, item_r3)); });
|
90
|
+
i0.ɵɵtemplate(2, Chips_li_3_ng_container_2_Template, 1, 0, "ng-container", 11)(3, Chips_li_3_p_chip_3_Template, 4, 6, "p-chip", 12);
|
91
|
+
i0.ɵɵelementEnd();
|
92
|
+
} if (rf & 2) {
|
93
|
+
const item_r3 = ctx.$implicit;
|
94
|
+
const i_r6 = ctx.index;
|
95
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
96
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(11, _c4, ctx_r3.focusedIndex === i_r6));
|
97
|
+
i0.ɵɵattribute("id", ctx_r3.id + "_chips_item_" + i_r6)("ariaLabel", item_r3)("aria-selected", true)("aria-setsize", ctx_r3.value.length)("aria-posinset", i_r6 + 1)("data-p-focused", ctx_r3.focusedIndex === i_r6)("data-pc-section", "token");
|
98
|
+
i0.ɵɵadvance(2);
|
99
|
+
i0.ɵɵproperty("ngTemplateOutlet", ctx_r3.itemTemplate)("ngTemplateOutletContext", i0.ɵɵpureFunction1(13, _c5, item_r3));
|
100
|
+
i0.ɵɵadvance();
|
101
|
+
i0.ɵɵproperty("ngIf", !ctx_r3.itemTemplate);
|
102
|
+
} }
|
103
|
+
function Chips_li_7_TimesIcon_1_Template(rf, ctx) { if (rf & 1) {
|
104
|
+
const _r9 = i0.ɵɵgetCurrentView();
|
105
|
+
i0.ɵɵelementStart(0, "TimesIcon", 16);
|
106
|
+
i0.ɵɵlistener("click", function Chips_li_7_TimesIcon_1_Template_TimesIcon_click_0_listener() { i0.ɵɵrestoreView(_r9); const ctx_r3 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r3.clear()); });
|
107
|
+
i0.ɵɵelementEnd();
|
108
|
+
} if (rf & 2) {
|
109
|
+
i0.ɵɵproperty("styleClass", "p-chips-clear-icon");
|
110
|
+
} }
|
111
|
+
function Chips_li_7_span_2_1_ng_template_0_Template(rf, ctx) { }
|
112
|
+
function Chips_li_7_span_2_1_Template(rf, ctx) { if (rf & 1) {
|
113
|
+
i0.ɵɵtemplate(0, Chips_li_7_span_2_1_ng_template_0_Template, 0, 0, "ng-template");
|
114
|
+
} }
|
115
|
+
function Chips_li_7_span_2_Template(rf, ctx) { if (rf & 1) {
|
116
|
+
const _r10 = i0.ɵɵgetCurrentView();
|
117
|
+
i0.ɵɵelementStart(0, "span", 19);
|
118
|
+
i0.ɵɵlistener("click", function Chips_li_7_span_2_Template_span_click_0_listener() { i0.ɵɵrestoreView(_r10); const ctx_r3 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r3.clear()); });
|
119
|
+
i0.ɵɵtemplate(1, Chips_li_7_span_2_1_Template, 1, 0, null, 20);
|
120
|
+
i0.ɵɵelementEnd();
|
121
|
+
} if (rf & 2) {
|
122
|
+
const ctx_r3 = i0.ɵɵnextContext(2);
|
123
|
+
i0.ɵɵadvance();
|
124
|
+
i0.ɵɵproperty("ngTemplateOutlet", ctx_r3.clearIconTemplate);
|
125
|
+
} }
|
126
|
+
function Chips_li_7_Template(rf, ctx) { if (rf & 1) {
|
127
|
+
i0.ɵɵelementStart(0, "li");
|
128
|
+
i0.ɵɵtemplate(1, Chips_li_7_TimesIcon_1_Template, 1, 1, "TimesIcon", 14)(2, Chips_li_7_span_2_Template, 2, 1, "span", 18);
|
129
|
+
i0.ɵɵelementEnd();
|
130
|
+
} if (rf & 2) {
|
131
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
132
|
+
i0.ɵɵadvance();
|
133
|
+
i0.ɵɵproperty("ngIf", !ctx_r3.clearIconTemplate);
|
134
|
+
i0.ɵɵadvance();
|
135
|
+
i0.ɵɵproperty("ngIf", ctx_r3.clearIconTemplate);
|
136
|
+
} }
|
137
|
+
export const CHIPS_VALUE_ACCESSOR = {
|
138
|
+
provide: NG_VALUE_ACCESSOR,
|
139
|
+
useExisting: forwardRef(() => Chips),
|
140
|
+
multi: true
|
141
|
+
};
|
142
|
+
/**
|
143
|
+
* Chips groups a collection of contents in tabs.
|
144
|
+
* @group Components
|
145
|
+
*/
|
146
|
+
export class Chips extends BaseComponent {
|
147
|
+
el;
|
148
|
+
cd;
|
149
|
+
config;
|
150
|
+
/**
|
151
|
+
* Inline style of the element.
|
152
|
+
* @group Props
|
153
|
+
*/
|
154
|
+
style;
|
155
|
+
/**
|
156
|
+
* Style class of the element.
|
157
|
+
* @group Props
|
158
|
+
*/
|
159
|
+
styleClass;
|
160
|
+
/**
|
161
|
+
* When present, it specifies that the element should be disabled.
|
162
|
+
* @group Props
|
163
|
+
*/
|
164
|
+
disabled;
|
165
|
+
/**
|
166
|
+
* Name of the property to display on a chip.
|
167
|
+
* @group Props
|
168
|
+
*/
|
169
|
+
field;
|
170
|
+
/**
|
171
|
+
* Advisory information to display on input.
|
172
|
+
* @group Props
|
173
|
+
*/
|
174
|
+
placeholder;
|
175
|
+
/**
|
176
|
+
* Maximum number of entries allowed.
|
177
|
+
* @group Props
|
178
|
+
*/
|
179
|
+
max;
|
180
|
+
/**
|
181
|
+
* Maximum length of a chip.
|
182
|
+
* @group Props
|
183
|
+
*/
|
184
|
+
maxLength;
|
185
|
+
/**
|
186
|
+
* Defines a string that labels the input for accessibility.
|
187
|
+
* @group Props
|
188
|
+
*/
|
189
|
+
ariaLabel;
|
190
|
+
/**
|
191
|
+
* Establishes relationships between the component and label(s) where its value should be one or more element IDs.
|
192
|
+
* @group Props
|
193
|
+
*/
|
194
|
+
ariaLabelledBy;
|
195
|
+
/**
|
196
|
+
* Index of the element in tabbing order.
|
197
|
+
* @group Props
|
198
|
+
*/
|
199
|
+
tabindex;
|
200
|
+
/**
|
201
|
+
* Identifier of the focus input to match a label defined for the component.
|
202
|
+
* @group Props
|
203
|
+
*/
|
204
|
+
inputId;
|
205
|
+
/**
|
206
|
+
* Whether to allow duplicate values or not.
|
207
|
+
* @group Props
|
208
|
+
*/
|
209
|
+
allowDuplicate = true;
|
210
|
+
/**
|
211
|
+
* Defines whether duplication check should be case-sensitive
|
212
|
+
* @group Props
|
213
|
+
*/
|
214
|
+
caseSensitiveDuplication = true;
|
215
|
+
/**
|
216
|
+
* Inline style of the input field.
|
217
|
+
* @group Props
|
218
|
+
*/
|
219
|
+
inputStyle;
|
220
|
+
/**
|
221
|
+
* Style class of the input field.
|
222
|
+
* @group Props
|
223
|
+
*/
|
224
|
+
inputStyleClass;
|
225
|
+
/**
|
226
|
+
* Icon to display in chip remove action..
|
227
|
+
* @group Props
|
228
|
+
*/
|
229
|
+
chipIcon;
|
230
|
+
/**
|
231
|
+
* Whether to add an item on tab key press.
|
232
|
+
* @group Props
|
233
|
+
*/
|
234
|
+
addOnTab;
|
235
|
+
/**
|
236
|
+
* Whether to add an item when the input loses focus.
|
237
|
+
* @group Props
|
238
|
+
*/
|
239
|
+
addOnBlur;
|
240
|
+
/**
|
241
|
+
* Separator char to add an item when pressed in addition to the enter key.
|
242
|
+
* @group Props
|
243
|
+
*/
|
244
|
+
separator;
|
245
|
+
/**
|
246
|
+
* When enabled, a clear icon is displayed to clear the value.
|
247
|
+
* @group Props
|
248
|
+
*/
|
249
|
+
showClear = false;
|
250
|
+
/**
|
251
|
+
* When present, it specifies that the component should automatically get focus on load.
|
252
|
+
* @group Props
|
253
|
+
*/
|
254
|
+
autofocus;
|
255
|
+
/**
|
256
|
+
* Specifies the input variant of the component.
|
257
|
+
* @group Props
|
258
|
+
*/
|
259
|
+
variant = 'outlined';
|
260
|
+
/**
|
261
|
+
* Callback to invoke on chip add.
|
262
|
+
* @param {ChipsAddEvent} event - Custom chip add event.
|
263
|
+
* @group Emits
|
264
|
+
*/
|
265
|
+
onAdd = new EventEmitter();
|
266
|
+
/**
|
267
|
+
* Callback to invoke on chip remove.
|
268
|
+
* @param {ChipsRemoveEvent} event - Custom chip remove event.
|
269
|
+
* @group Emits
|
270
|
+
*/
|
271
|
+
onRemove = new EventEmitter();
|
272
|
+
/**
|
273
|
+
* Callback to invoke on focus of input field.
|
274
|
+
* @param {Event} event - Browser event.
|
275
|
+
* @group Emits
|
276
|
+
*/
|
277
|
+
onFocus = new EventEmitter();
|
278
|
+
/**
|
279
|
+
* Callback to invoke on blur of input field.
|
280
|
+
* @param {Event} event - Browser event.
|
281
|
+
* @group Emits
|
282
|
+
*/
|
283
|
+
onBlur = new EventEmitter();
|
284
|
+
/**
|
285
|
+
* Callback to invoke on chip clicked.
|
286
|
+
* @param {ChipsClickEvent} event - Custom chip click event.
|
287
|
+
* @group Emits
|
288
|
+
*/
|
289
|
+
onChipClick = new EventEmitter();
|
290
|
+
/**
|
291
|
+
* Callback to invoke on chip contextmenu.
|
292
|
+
* @param {ChipsClickEvent} event - Custom chip contextmenu event.
|
293
|
+
* @group Emits
|
294
|
+
*/
|
295
|
+
onChipContextMenu = new EventEmitter();
|
296
|
+
/**
|
297
|
+
* Callback to invoke on clear token clicked.
|
298
|
+
* @group Emits
|
299
|
+
*/
|
300
|
+
onClear = new EventEmitter();
|
301
|
+
inputViewChild;
|
302
|
+
containerViewChild;
|
303
|
+
templates;
|
304
|
+
itemTemplate;
|
305
|
+
removeTokenIconTemplate;
|
306
|
+
clearIconTemplate;
|
307
|
+
value;
|
308
|
+
onModelChange = () => { };
|
309
|
+
onModelTouched = () => { };
|
310
|
+
valueChanged;
|
311
|
+
id = UniqueComponentId();
|
312
|
+
focused;
|
313
|
+
focusedIndex;
|
314
|
+
filled;
|
315
|
+
_componentStyle = inject(ChipsStyle);
|
316
|
+
get focusedOptionId() {
|
317
|
+
return this.focusedIndex !== null ? `${this.id}_chips_item_${this.focusedIndex}` : null;
|
318
|
+
}
|
319
|
+
get isMaxedOut() {
|
320
|
+
return this.max && this.value && this.max === this.value.length;
|
321
|
+
}
|
322
|
+
constructor(el, cd, config) {
|
323
|
+
super();
|
324
|
+
this.el = el;
|
325
|
+
this.cd = cd;
|
326
|
+
this.config = config;
|
327
|
+
console.log('Deprecated since v18. Use AutoComplete component instead with its typeahead property.');
|
328
|
+
}
|
329
|
+
ngAfterContentInit() {
|
330
|
+
this.templates.forEach((item) => {
|
331
|
+
switch (item.getType()) {
|
332
|
+
case 'item':
|
333
|
+
this.itemTemplate = item.template;
|
334
|
+
break;
|
335
|
+
case 'removetokenicon':
|
336
|
+
this.removeTokenIconTemplate = item.template;
|
337
|
+
break;
|
338
|
+
case 'clearicon':
|
339
|
+
this.clearIconTemplate = item.template;
|
340
|
+
break;
|
341
|
+
default:
|
342
|
+
this.itemTemplate = item.template;
|
343
|
+
break;
|
344
|
+
}
|
345
|
+
});
|
346
|
+
this.updateFilledState();
|
347
|
+
}
|
348
|
+
onWrapperClick() {
|
349
|
+
this.inputViewChild?.nativeElement.focus();
|
350
|
+
}
|
351
|
+
onContainerFocus() {
|
352
|
+
this.focused = true;
|
353
|
+
}
|
354
|
+
onContainerBlur() {
|
355
|
+
this.focusedIndex = -1;
|
356
|
+
this.focused = false;
|
357
|
+
}
|
358
|
+
onContainerKeyDown(event) {
|
359
|
+
switch (event.code) {
|
360
|
+
case 'ArrowLeft':
|
361
|
+
this.onArrowLeftKeyOn();
|
362
|
+
break;
|
363
|
+
case 'ArrowRight':
|
364
|
+
this.onArrowRightKeyOn();
|
365
|
+
break;
|
366
|
+
case 'Backspace':
|
367
|
+
this.onBackspaceKeyOn(event);
|
368
|
+
break;
|
369
|
+
case 'Space':
|
370
|
+
if (this.focusedIndex !== null && this.value && this.value.length > 0) {
|
371
|
+
this.onItemClick(event, this.value[this.focusedIndex]);
|
372
|
+
}
|
373
|
+
break;
|
374
|
+
default:
|
375
|
+
break;
|
376
|
+
}
|
377
|
+
}
|
378
|
+
onArrowLeftKeyOn() {
|
379
|
+
if (this.inputViewChild.nativeElement.value.length === 0 && this.value && this.value.length > 0) {
|
380
|
+
this.focusedIndex = this.focusedIndex === null ? this.value.length - 1 : this.focusedIndex - 1;
|
381
|
+
if (this.focusedIndex < 0)
|
382
|
+
this.focusedIndex = 0;
|
383
|
+
}
|
384
|
+
}
|
385
|
+
onArrowRightKeyOn() {
|
386
|
+
if (this.inputViewChild.nativeElement.value.length === 0 && this.value && this.value.length > 0) {
|
387
|
+
if (this.focusedIndex === this.value.length - 1) {
|
388
|
+
this.focusedIndex = null;
|
389
|
+
this.inputViewChild?.nativeElement.focus();
|
390
|
+
}
|
391
|
+
else {
|
392
|
+
this.focusedIndex++;
|
393
|
+
}
|
394
|
+
}
|
395
|
+
}
|
396
|
+
onBackspaceKeyOn(event) {
|
397
|
+
if (this.focusedIndex !== null) {
|
398
|
+
this.removeItem(event, this.focusedIndex);
|
399
|
+
}
|
400
|
+
}
|
401
|
+
onInput() {
|
402
|
+
this.updateFilledState();
|
403
|
+
this.focusedIndex = null;
|
404
|
+
}
|
405
|
+
onPaste(event) {
|
406
|
+
if (!this.disabled) {
|
407
|
+
if (this.separator) {
|
408
|
+
const pastedData = (event.clipboardData || this.document.defaultView['clipboardData']).getData('Text');
|
409
|
+
pastedData.split(this.separator).forEach((val) => {
|
410
|
+
this.addItem(event, val, true);
|
411
|
+
});
|
412
|
+
this.inputViewChild.nativeElement.value = '';
|
413
|
+
}
|
414
|
+
this.updateFilledState();
|
415
|
+
}
|
416
|
+
}
|
417
|
+
updateFilledState() {
|
418
|
+
if (!this.value || this.value.length === 0) {
|
419
|
+
this.filled = this.inputViewChild && this.inputViewChild.nativeElement && this.inputViewChild.nativeElement.value != '';
|
420
|
+
}
|
421
|
+
else {
|
422
|
+
this.filled = true;
|
423
|
+
}
|
424
|
+
}
|
425
|
+
onItemClick(event, item) {
|
426
|
+
this.onChipClick.emit({
|
427
|
+
originalEvent: event,
|
428
|
+
value: item
|
429
|
+
});
|
430
|
+
}
|
431
|
+
onItemContextMenu(event, item) {
|
432
|
+
this.onChipContextMenu.emit({
|
433
|
+
originalEvent: event,
|
434
|
+
value: item
|
435
|
+
});
|
436
|
+
}
|
437
|
+
writeValue(value) {
|
438
|
+
this.value = value;
|
439
|
+
this.updateMaxedOut();
|
440
|
+
this.updateFilledState();
|
441
|
+
this.cd.markForCheck();
|
442
|
+
}
|
443
|
+
registerOnChange(fn) {
|
444
|
+
this.onModelChange = fn;
|
445
|
+
}
|
446
|
+
registerOnTouched(fn) {
|
447
|
+
this.onModelTouched = fn;
|
448
|
+
}
|
449
|
+
setDisabledState(val) {
|
450
|
+
this.disabled = val;
|
451
|
+
this.cd.markForCheck();
|
452
|
+
}
|
453
|
+
resolveFieldData(data, field) {
|
454
|
+
if (data && field) {
|
455
|
+
if (field.indexOf('.') == -1) {
|
456
|
+
return data[field];
|
457
|
+
}
|
458
|
+
else {
|
459
|
+
let fields = field.split('.');
|
460
|
+
let value = data;
|
461
|
+
for (var i = 0, len = fields.length; i < len; ++i) {
|
462
|
+
value = value[fields[i]];
|
463
|
+
}
|
464
|
+
return value;
|
465
|
+
}
|
466
|
+
}
|
467
|
+
else {
|
468
|
+
return null;
|
469
|
+
}
|
470
|
+
}
|
471
|
+
onInputFocus(event) {
|
472
|
+
this.focused = true;
|
473
|
+
this.focusedIndex = null;
|
474
|
+
this.onFocus.emit(event);
|
475
|
+
}
|
476
|
+
onInputBlur(event) {
|
477
|
+
this.focused = false;
|
478
|
+
this.focusedIndex = null;
|
479
|
+
if (this.addOnBlur && this.inputViewChild.nativeElement.value) {
|
480
|
+
this.addItem(event, this.inputViewChild.nativeElement.value, false);
|
481
|
+
}
|
482
|
+
this.onModelTouched();
|
483
|
+
this.onBlur.emit(event);
|
484
|
+
}
|
485
|
+
removeItem(event, index) {
|
486
|
+
if (this.disabled) {
|
487
|
+
return;
|
488
|
+
}
|
489
|
+
let removedItem = this.value[index];
|
490
|
+
this.value = this.value.filter((val, i) => i != index);
|
491
|
+
this.focusedIndex = null;
|
492
|
+
this.inputViewChild.nativeElement.focus();
|
493
|
+
this.onModelChange(this.value);
|
494
|
+
this.onRemove.emit({
|
495
|
+
originalEvent: event,
|
496
|
+
value: removedItem
|
497
|
+
});
|
498
|
+
this.updateFilledState();
|
499
|
+
this.updateMaxedOut();
|
500
|
+
}
|
501
|
+
addItem(event, item, preventDefault) {
|
502
|
+
this.value = this.value || [];
|
503
|
+
if (item && item.trim().length) {
|
504
|
+
const newItemIsDuplicate = this.caseSensitiveDuplication ? this.value.includes(item) : this.value.some((val) => val.toLowerCase() === item.toLowerCase());
|
505
|
+
if ((this.allowDuplicate || !newItemIsDuplicate) && !this.isMaxedOut) {
|
506
|
+
this.value = [...this.value, item];
|
507
|
+
this.onModelChange(this.value);
|
508
|
+
this.onAdd.emit({
|
509
|
+
originalEvent: event,
|
510
|
+
value: item
|
511
|
+
});
|
512
|
+
}
|
513
|
+
}
|
514
|
+
this.updateFilledState();
|
515
|
+
this.updateMaxedOut();
|
516
|
+
this.inputViewChild.nativeElement.value = '';
|
517
|
+
if (preventDefault) {
|
518
|
+
event.preventDefault();
|
519
|
+
}
|
520
|
+
}
|
521
|
+
/**
|
522
|
+
* Callback to invoke on filter reset.
|
523
|
+
* @group Method
|
524
|
+
*/
|
525
|
+
clear() {
|
526
|
+
this.value = null;
|
527
|
+
this.updateFilledState();
|
528
|
+
this.onModelChange(this.value);
|
529
|
+
this.updateMaxedOut();
|
530
|
+
this.onClear.emit();
|
531
|
+
}
|
532
|
+
onKeyDown(event) {
|
533
|
+
const inputValue = event.target.value;
|
534
|
+
switch (event.code) {
|
535
|
+
case 'Backspace':
|
536
|
+
if (inputValue.length === 0 && this.value && this.value.length > 0) {
|
537
|
+
if (this.focusedIndex !== null) {
|
538
|
+
this.removeItem(event, this.focusedIndex);
|
539
|
+
}
|
540
|
+
else
|
541
|
+
this.removeItem(event, this.value.length - 1);
|
542
|
+
}
|
543
|
+
break;
|
544
|
+
case 'Enter':
|
545
|
+
case 'NumpadEnter':
|
546
|
+
if (inputValue && inputValue.trim().length && !this.isMaxedOut) {
|
547
|
+
this.addItem(event, inputValue, true);
|
548
|
+
}
|
549
|
+
break;
|
550
|
+
case 'Tab':
|
551
|
+
if (this.addOnTab && inputValue && inputValue.trim().length && !this.isMaxedOut) {
|
552
|
+
this.addItem(event, inputValue, true);
|
553
|
+
event.preventDefault();
|
554
|
+
}
|
555
|
+
break;
|
556
|
+
case 'ArrowLeft':
|
557
|
+
if (inputValue.length === 0 && this.value && this.value.length > 0) {
|
558
|
+
this.containerViewChild?.nativeElement.focus();
|
559
|
+
}
|
560
|
+
break;
|
561
|
+
case 'ArrowRight':
|
562
|
+
event.stopPropagation();
|
563
|
+
break;
|
564
|
+
default:
|
565
|
+
if (this.separator) {
|
566
|
+
if (this.separator === event.key || event.key.match(this.separator)) {
|
567
|
+
this.addItem(event, inputValue, true);
|
568
|
+
}
|
569
|
+
}
|
570
|
+
break;
|
571
|
+
}
|
572
|
+
}
|
573
|
+
updateMaxedOut() {
|
574
|
+
if (this.inputViewChild && this.inputViewChild.nativeElement) {
|
575
|
+
if (this.isMaxedOut) {
|
576
|
+
// Calling `blur` is necessary because firefox does not call `onfocus` events
|
577
|
+
// for disabled inputs, unlike chromium browsers.
|
578
|
+
this.inputViewChild.nativeElement.blur();
|
579
|
+
this.inputViewChild.nativeElement.disabled = true;
|
580
|
+
}
|
581
|
+
else {
|
582
|
+
if (this.disabled) {
|
583
|
+
this.inputViewChild.nativeElement.blur();
|
584
|
+
}
|
585
|
+
this.inputViewChild.nativeElement.disabled = this.disabled || false;
|
586
|
+
}
|
587
|
+
}
|
588
|
+
}
|
589
|
+
static ɵfac = function Chips_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || Chips)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.PrimeNG)); };
|
590
|
+
static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: Chips, selectors: [["p-chips"]], contentQueries: function Chips_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
|
591
|
+
i0.ɵɵcontentQuery(dirIndex, PrimeTemplate, 4);
|
592
|
+
} if (rf & 2) {
|
593
|
+
let _t;
|
594
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.templates = _t);
|
595
|
+
} }, viewQuery: function Chips_Query(rf, ctx) { if (rf & 1) {
|
596
|
+
i0.ɵɵviewQuery(_c0, 5);
|
597
|
+
i0.ɵɵviewQuery(_c1, 5);
|
598
|
+
} if (rf & 2) {
|
599
|
+
let _t;
|
600
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.inputViewChild = _t.first);
|
601
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.containerViewChild = _t.first);
|
602
|
+
} }, hostAttrs: [1, "p-element", "p-inputwrapper"], hostVars: 6, hostBindings: function Chips_HostBindings(rf, ctx) { if (rf & 2) {
|
603
|
+
i0.ɵɵclassProp("p-inputwrapper-filled", ctx.filled)("p-inputwrapper-focus", ctx.focused)("p-chips-clearable", ctx.showClear);
|
604
|
+
} }, inputs: { style: "style", styleClass: "styleClass", disabled: [2, "disabled", "disabled", booleanAttribute], field: "field", placeholder: "placeholder", max: [2, "max", "max", numberAttribute], maxLength: "maxLength", ariaLabel: "ariaLabel", ariaLabelledBy: "ariaLabelledBy", tabindex: [2, "tabindex", "tabindex", numberAttribute], inputId: "inputId", allowDuplicate: [2, "allowDuplicate", "allowDuplicate", booleanAttribute], caseSensitiveDuplication: [2, "caseSensitiveDuplication", "caseSensitiveDuplication", booleanAttribute], inputStyle: "inputStyle", inputStyleClass: "inputStyleClass", chipIcon: "chipIcon", addOnTab: [2, "addOnTab", "addOnTab", booleanAttribute], addOnBlur: [2, "addOnBlur", "addOnBlur", booleanAttribute], separator: "separator", showClear: [2, "showClear", "showClear", booleanAttribute], autofocus: [2, "autofocus", "autofocus", booleanAttribute], variant: "variant" }, outputs: { onAdd: "onAdd", onRemove: "onRemove", onFocus: "onFocus", onBlur: "onBlur", onChipClick: "onChipClick", onChipContextMenu: "onChipContextMenu", onClear: "onClear" }, standalone: true, features: [i0.ɵɵProvidersFeature([CHIPS_VALUE_ACCESSOR, ChipsStyle]), i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls: 8, vars: 31, consts: [["container", ""], ["inputtext", ""], ["token", ""], ["removeicon", ""], [3, "ngClass", "ngStyle"], ["tabindex", "-1", "role", "listbox", 1, "p-inputchips-input", 3, "click", "focus", "blur", "keydown"], ["role", "option", 3, "ngClass", "click", "contextmenu", 4, "ngFor", "ngForOf"], ["role", "option", 1, "p-inputchips-input-item", 3, "ngClass"], ["type", "text", "pAutoFocus", "", 1, "test", 3, "keydown", "input", "paste", "focus", "blur", "disabled", "ngStyle", "autofocus"], [4, "ngIf"], ["role", "option", 3, "click", "contextmenu", "ngClass"], [4, "ngTemplateOutlet", "ngTemplateOutletContext"], ["class", "p-inputchips-chip", "removable", "", 3, "label", "removeIcon", "onRemove", 4, "ngIf"], ["removable", "", 1, "p-inputchips-chip", 3, "onRemove", "label", "removeIcon"], [3, "styleClass", "click", 4, "ngIf"], ["class", "p-chips-token-icon", 3, "click", 4, "ngIf"], [3, "click", "styleClass"], [1, "p-chips-token-icon", 3, "click"], ["class", "p-chips-clear-icon", 3, "click", 4, "ngIf"], [1, "p-chips-clear-icon", 3, "click"], [4, "ngTemplateOutlet"]], template: function Chips_Template(rf, ctx) { if (rf & 1) {
|
605
|
+
const _r1 = i0.ɵɵgetCurrentView();
|
606
|
+
i0.ɵɵelementStart(0, "div", 4)(1, "ul", 5, 0);
|
607
|
+
i0.ɵɵlistener("click", function Chips_Template_ul_click_1_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onWrapperClick()); })("focus", function Chips_Template_ul_focus_1_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onContainerFocus()); })("blur", function Chips_Template_ul_blur_1_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onContainerBlur()); })("keydown", function Chips_Template_ul_keydown_1_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onContainerKeyDown($event)); });
|
608
|
+
i0.ɵɵtemplate(3, Chips_li_3_Template, 4, 15, "li", 6);
|
609
|
+
i0.ɵɵelementStart(4, "li", 7)(5, "input", 8, 1);
|
610
|
+
i0.ɵɵlistener("keydown", function Chips_Template_input_keydown_5_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onKeyDown($event)); })("input", function Chips_Template_input_input_5_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onInput()); })("paste", function Chips_Template_input_paste_5_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onPaste($event)); })("focus", function Chips_Template_input_focus_5_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onInputFocus($event)); })("blur", function Chips_Template_input_blur_5_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onInputBlur($event)); });
|
611
|
+
i0.ɵɵelementEnd()();
|
612
|
+
i0.ɵɵtemplate(7, Chips_li_7_Template, 3, 2, "li", 9);
|
613
|
+
i0.ɵɵelementEnd()();
|
614
|
+
} if (rf & 2) {
|
615
|
+
i0.ɵɵclassMap(ctx.styleClass);
|
616
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction4(24, _c2, ctx.disabled, ctx.focused, ctx.value && ctx.value.length || (ctx.inputViewChild == null ? null : ctx.inputViewChild.nativeElement.value) && (ctx.inputViewChild == null ? null : ctx.inputViewChild.nativeElement.value.length), ctx.focused))("ngStyle", ctx.style);
|
617
|
+
i0.ɵɵattribute("data-pc-name", "chips")("data-pc-section", "root");
|
618
|
+
i0.ɵɵadvance();
|
619
|
+
i0.ɵɵattribute("aria-labelledby", ctx.ariaLabelledBy)("aria-label", ctx.ariaLabel)("aria-activedescendant", ctx.focused ? ctx.focusedOptionId : undefined)("aria-orientation", "horizontal")("data-pc-section", "container");
|
620
|
+
i0.ɵɵadvance(2);
|
621
|
+
i0.ɵɵproperty("ngForOf", ctx.value);
|
622
|
+
i0.ɵɵadvance();
|
623
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(29, _c3, ctx.showClear && !ctx.disabled));
|
624
|
+
i0.ɵɵattribute("data-pc-section", "inputToken");
|
625
|
+
i0.ɵɵadvance();
|
626
|
+
i0.ɵɵclassMap(ctx.inputStyleClass);
|
627
|
+
i0.ɵɵproperty("disabled", ctx.disabled || ctx.isMaxedOut)("ngStyle", ctx.inputStyle)("autofocus", ctx.autofocus);
|
628
|
+
i0.ɵɵattribute("id", ctx.inputId)("maxlength", ctx.maxLength)("placeholder", ctx.value && ctx.value.length ? null : ctx.placeholder)("tabindex", ctx.tabindex);
|
629
|
+
i0.ɵɵadvance(2);
|
630
|
+
i0.ɵɵproperty("ngIf", ctx.value != null && ctx.filled && !ctx.disabled && ctx.showClear);
|
631
|
+
} }, dependencies: [CommonModule, i2.NgClass, i2.NgForOf, i2.NgIf, i2.NgTemplateOutlet, i2.NgStyle, InputTextModule, SharedModule, AutoFocusModule, i3.AutoFocus, TimesCircleIcon, TimesIcon, ChipModule, i4.Chip], encapsulation: 2, changeDetection: 0 });
|
632
|
+
}
|
633
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(Chips, [{
|
634
|
+
type: Component,
|
635
|
+
args: [{
|
636
|
+
selector: 'p-chips',
|
637
|
+
standalone: true,
|
638
|
+
imports: [CommonModule, InputTextModule, SharedModule, AutoFocusModule, TimesCircleIcon, TimesIcon, ChipModule],
|
639
|
+
template: `
|
640
|
+
<div
|
641
|
+
[ngClass]="{
|
642
|
+
'p-inputchips p-component p-input-wrapper': true,
|
643
|
+
'p-disabled': disabled,
|
644
|
+
'p-focus': focused,
|
645
|
+
'p-inputwrapper-filled': (value && value.length) || (this.inputViewChild?.nativeElement.value && this.inputViewChild?.nativeElement.value.length),
|
646
|
+
'p-inputwrapper-focus': focused
|
647
|
+
}"
|
648
|
+
[ngStyle]="style"
|
649
|
+
[class]="styleClass"
|
650
|
+
[attr.data-pc-name]="'chips'"
|
651
|
+
[attr.data-pc-section]="'root'"
|
652
|
+
>
|
653
|
+
<ul
|
654
|
+
#container
|
655
|
+
class="p-inputchips-input"
|
656
|
+
tabindex="-1"
|
657
|
+
role="listbox"
|
658
|
+
[attr.aria-labelledby]="ariaLabelledBy"
|
659
|
+
[attr.aria-label]="ariaLabel"
|
660
|
+
[attr.aria-activedescendant]="focused ? focusedOptionId : undefined"
|
661
|
+
[attr.aria-orientation]="'horizontal'"
|
662
|
+
(click)="onWrapperClick()"
|
663
|
+
(focus)="onContainerFocus()"
|
664
|
+
(blur)="onContainerBlur()"
|
665
|
+
(keydown)="onContainerKeyDown($event)"
|
666
|
+
[attr.data-pc-section]="'container'"
|
667
|
+
>
|
668
|
+
<li
|
669
|
+
#token
|
670
|
+
*ngFor="let item of value; let i = index"
|
671
|
+
[attr.id]="id + '_chips_item_' + i"
|
672
|
+
role="option"
|
673
|
+
[attr.ariaLabel]="item"
|
674
|
+
[attr.aria-selected]="true"
|
675
|
+
[attr.aria-setsize]="value.length"
|
676
|
+
[attr.aria-posinset]="i + 1"
|
677
|
+
[attr.data-p-focused]="focusedIndex === i"
|
678
|
+
[ngClass]="{ 'p-inputchips-chip-item': true, 'p-focus': focusedIndex === i }"
|
679
|
+
(click)="onItemClick($event, item)"
|
680
|
+
(contextmenu)="onItemContextMenu($event, item)"
|
681
|
+
[attr.data-pc-section]="'token'"
|
682
|
+
>
|
683
|
+
<ng-container *ngTemplateOutlet="itemTemplate; context: { $implicit: item }"></ng-container>
|
684
|
+
<p-chip *ngIf="!itemTemplate" class="p-inputchips-chip" [label]="field ? resolveFieldData(item, field) : item" [removeIcon]="chipIcon" removable (onRemove)="removeItem($event, i)">
|
685
|
+
<ng-container *ngTemplateOutlet="itemTemplate; context: { $implicit: item }"></ng-container>
|
686
|
+
<ng-template #removeicon>
|
687
|
+
<ng-container *ngIf="!disabled">
|
688
|
+
<TimesCircleIcon [styleClass]="'p-chips-token-icon'" *ngIf="!removeTokenIconTemplate" (click)="removeItem($event, i)" [attr.data-pc-section]="'removeTokenIcon'" [attr.aria-hidden]="true" />
|
689
|
+
<span *ngIf="removeTokenIconTemplate" class="p-chips-token-icon" (click)="removeItem($event, i)" [attr.data-pc-section]="'removeTokenIcon'" [attr.aria-hidden]="true">
|
690
|
+
<ng-template *ngTemplateOutlet="removeTokenIconTemplate; context: { removeItem: removeItem.bind(this) }"></ng-template>
|
691
|
+
</span>
|
692
|
+
</ng-container>
|
693
|
+
</ng-template>
|
694
|
+
</p-chip>
|
695
|
+
</li>
|
696
|
+
<li class="p-inputchips-input-item" [ngClass]="{ 'p-chips-clearable': showClear && !disabled }" [attr.data-pc-section]="'inputToken'" role="option">
|
697
|
+
<input
|
698
|
+
#inputtext
|
699
|
+
type="text"
|
700
|
+
[attr.id]="inputId"
|
701
|
+
[attr.maxlength]="maxLength"
|
702
|
+
[attr.placeholder]="value && value.length ? null : placeholder"
|
703
|
+
[attr.tabindex]="tabindex"
|
704
|
+
(keydown)="onKeyDown($event)"
|
705
|
+
(input)="onInput()"
|
706
|
+
(paste)="onPaste($event)"
|
707
|
+
(focus)="onInputFocus($event)"
|
708
|
+
(blur)="onInputBlur($event)"
|
709
|
+
[disabled]="disabled || isMaxedOut"
|
710
|
+
[ngStyle]="inputStyle"
|
711
|
+
[class]="inputStyleClass"
|
712
|
+
pAutoFocus
|
713
|
+
[autofocus]="autofocus"
|
714
|
+
class="test"
|
715
|
+
/>
|
716
|
+
</li>
|
717
|
+
<li *ngIf="value != null && filled && !disabled && showClear">
|
718
|
+
<TimesIcon *ngIf="!clearIconTemplate" [styleClass]="'p-chips-clear-icon'" (click)="clear()" />
|
719
|
+
<span *ngIf="clearIconTemplate" class="p-chips-clear-icon" (click)="clear()">
|
720
|
+
<ng-template *ngTemplateOutlet="clearIconTemplate"></ng-template>
|
721
|
+
</span>
|
722
|
+
</li>
|
723
|
+
</ul>
|
724
|
+
</div>
|
725
|
+
`,
|
726
|
+
host: {
|
727
|
+
class: 'p-element p-inputwrapper',
|
728
|
+
'[class.p-inputwrapper-filled]': 'filled',
|
729
|
+
'[class.p-inputwrapper-focus]': 'focused',
|
730
|
+
'[class.p-chips-clearable]': 'showClear'
|
731
|
+
},
|
732
|
+
providers: [CHIPS_VALUE_ACCESSOR, ChipsStyle],
|
733
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
734
|
+
encapsulation: ViewEncapsulation.None
|
735
|
+
}]
|
736
|
+
}], () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.PrimeNG }], { style: [{
|
737
|
+
type: Input
|
738
|
+
}], styleClass: [{
|
739
|
+
type: Input
|
740
|
+
}], disabled: [{
|
741
|
+
type: Input,
|
742
|
+
args: [{ transform: booleanAttribute }]
|
743
|
+
}], field: [{
|
744
|
+
type: Input
|
745
|
+
}], placeholder: [{
|
746
|
+
type: Input
|
747
|
+
}], max: [{
|
748
|
+
type: Input,
|
749
|
+
args: [{ transform: numberAttribute }]
|
750
|
+
}], maxLength: [{
|
751
|
+
type: Input
|
752
|
+
}], ariaLabel: [{
|
753
|
+
type: Input
|
754
|
+
}], ariaLabelledBy: [{
|
755
|
+
type: Input
|
756
|
+
}], tabindex: [{
|
757
|
+
type: Input,
|
758
|
+
args: [{ transform: numberAttribute }]
|
759
|
+
}], inputId: [{
|
760
|
+
type: Input
|
761
|
+
}], allowDuplicate: [{
|
762
|
+
type: Input,
|
763
|
+
args: [{ transform: booleanAttribute }]
|
764
|
+
}], caseSensitiveDuplication: [{
|
765
|
+
type: Input,
|
766
|
+
args: [{ transform: booleanAttribute }]
|
767
|
+
}], inputStyle: [{
|
768
|
+
type: Input
|
769
|
+
}], inputStyleClass: [{
|
770
|
+
type: Input
|
771
|
+
}], chipIcon: [{
|
772
|
+
type: Input
|
773
|
+
}], addOnTab: [{
|
774
|
+
type: Input,
|
775
|
+
args: [{ transform: booleanAttribute }]
|
776
|
+
}], addOnBlur: [{
|
777
|
+
type: Input,
|
778
|
+
args: [{ transform: booleanAttribute }]
|
779
|
+
}], separator: [{
|
780
|
+
type: Input
|
781
|
+
}], showClear: [{
|
782
|
+
type: Input,
|
783
|
+
args: [{ transform: booleanAttribute }]
|
784
|
+
}], autofocus: [{
|
785
|
+
type: Input,
|
786
|
+
args: [{ transform: booleanAttribute }]
|
787
|
+
}], variant: [{
|
788
|
+
type: Input
|
789
|
+
}], onAdd: [{
|
790
|
+
type: Output
|
791
|
+
}], onRemove: [{
|
792
|
+
type: Output
|
793
|
+
}], onFocus: [{
|
794
|
+
type: Output
|
795
|
+
}], onBlur: [{
|
796
|
+
type: Output
|
797
|
+
}], onChipClick: [{
|
798
|
+
type: Output
|
799
|
+
}], onChipContextMenu: [{
|
800
|
+
type: Output
|
801
|
+
}], onClear: [{
|
802
|
+
type: Output
|
803
|
+
}], inputViewChild: [{
|
804
|
+
type: ViewChild,
|
805
|
+
args: ['inputtext']
|
806
|
+
}], containerViewChild: [{
|
807
|
+
type: ViewChild,
|
808
|
+
args: ['container']
|
809
|
+
}], templates: [{
|
810
|
+
type: ContentChildren,
|
811
|
+
args: [PrimeTemplate]
|
812
|
+
}] }); })();
|
813
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(Chips, { className: "Chips" }); })();
|
814
|
+
export class ChipsModule {
|
815
|
+
static ɵfac = function ChipsModule_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ChipsModule)(); };
|
816
|
+
static ɵmod = /*@__PURE__*/ i0.ɵɵdefineNgModule({ type: ChipsModule });
|
817
|
+
static ɵinj = /*@__PURE__*/ i0.ɵɵdefineInjector({ imports: [Chips, SharedModule, SharedModule] });
|
818
|
+
}
|
819
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ChipsModule, [{
|
820
|
+
type: NgModule,
|
821
|
+
args: [{
|
822
|
+
imports: [Chips, SharedModule],
|
823
|
+
exports: [Chips, SharedModule]
|
824
|
+
}]
|
825
|
+
}], null, null); })();
|
826
|
+
(function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(ChipsModule, { imports: [Chips, SharedModule], exports: [Chips, SharedModule] }); })();
|
827
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chips.js","sourceRoot":"","sources":["../../../src/chips/chips.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    Input,\n    NgModule,\n    Output,\n    QueryList,\n    TemplateRef,\n    ViewChild,\n    ViewEncapsulation,\n    booleanAttribute,\n    forwardRef,\n    inject,\n    numberAttribute\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { PrimeTemplate, SharedModule } from 'primeng/api';\nimport { AutoFocusModule } from 'primeng/autofocus';\nimport { TimesIcon } from 'primeng/icons/times';\nimport { TimesCircleIcon } from 'primeng/icons/timescircle';\nimport { InputTextModule } from 'primeng/inputtext';\nimport { Nullable } from 'primeng/ts-helpers';\nimport { UniqueComponentId } from 'primeng/utils';\nimport { ChipsAddEvent, ChipsClickEvent, ChipsContextMenuEvent, ChipsRemoveEvent } from './chips.interface';\nimport { PrimeNG } from 'primeng/config';\nimport { ChipsStyle } from './style/chipsstyle';\nimport { BaseComponent } from 'primeng/basecomponent';\nimport { ChipModule } from 'primeng/chip';\n\nexport const CHIPS_VALUE_ACCESSOR: any = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => Chips),\n    multi: true\n};\n/**\n * Chips groups a collection of contents in tabs.\n * @group Components\n */\n@Component({\n    selector: 'p-chips',\n    standalone: true,\n    imports: [CommonModule, InputTextModule, SharedModule, AutoFocusModule, TimesCircleIcon, TimesIcon, ChipModule],\n    template: `\n        <div\n            [ngClass]=\"{\n                'p-inputchips p-component p-input-wrapper': true,\n                'p-disabled': disabled,\n                'p-focus': focused,\n                'p-inputwrapper-filled': (value && value.length) || (this.inputViewChild?.nativeElement.value && this.inputViewChild?.nativeElement.value.length),\n                'p-inputwrapper-focus': focused\n            }\"\n            [ngStyle]=\"style\"\n            [class]=\"styleClass\"\n            [attr.data-pc-name]=\"'chips'\"\n            [attr.data-pc-section]=\"'root'\"\n        >\n            <ul\n                #container\n                class=\"p-inputchips-input\"\n                tabindex=\"-1\"\n                role=\"listbox\"\n                [attr.aria-labelledby]=\"ariaLabelledBy\"\n                [attr.aria-label]=\"ariaLabel\"\n                [attr.aria-activedescendant]=\"focused ? focusedOptionId : undefined\"\n                [attr.aria-orientation]=\"'horizontal'\"\n                (click)=\"onWrapperClick()\"\n                (focus)=\"onContainerFocus()\"\n                (blur)=\"onContainerBlur()\"\n                (keydown)=\"onContainerKeyDown($event)\"\n                [attr.data-pc-section]=\"'container'\"\n            >\n                <li\n                    #token\n                    *ngFor=\"let item of value; let i = index\"\n                    [attr.id]=\"id + '_chips_item_' + i\"\n                    role=\"option\"\n                    [attr.ariaLabel]=\"item\"\n                    [attr.aria-selected]=\"true\"\n                    [attr.aria-setsize]=\"value.length\"\n                    [attr.aria-posinset]=\"i + 1\"\n                    [attr.data-p-focused]=\"focusedIndex === i\"\n                    [ngClass]=\"{ 'p-inputchips-chip-item': true, 'p-focus': focusedIndex === i }\"\n                    (click)=\"onItemClick($event, item)\"\n                    (contextmenu)=\"onItemContextMenu($event, item)\"\n                    [attr.data-pc-section]=\"'token'\"\n                >\n                    <ng-container *ngTemplateOutlet=\"itemTemplate; context: { $implicit: item }\"></ng-container>\n                    <p-chip *ngIf=\"!itemTemplate\" class=\"p-inputchips-chip\" [label]=\"field ? resolveFieldData(item, field) : item\" [removeIcon]=\"chipIcon\" removable (onRemove)=\"removeItem($event, i)\">\n                        <ng-container *ngTemplateOutlet=\"itemTemplate; context: { $implicit: item }\"></ng-container>\n                        <ng-template #removeicon>\n                            <ng-container *ngIf=\"!disabled\">\n                                <TimesCircleIcon [styleClass]=\"'p-chips-token-icon'\" *ngIf=\"!removeTokenIconTemplate\" (click)=\"removeItem($event, i)\" [attr.data-pc-section]=\"'removeTokenIcon'\" [attr.aria-hidden]=\"true\" />\n                                <span *ngIf=\"removeTokenIconTemplate\" class=\"p-chips-token-icon\" (click)=\"removeItem($event, i)\" [attr.data-pc-section]=\"'removeTokenIcon'\" [attr.aria-hidden]=\"true\">\n                                    <ng-template *ngTemplateOutlet=\"removeTokenIconTemplate; context: { removeItem: removeItem.bind(this) }\"></ng-template>\n                                </span>\n                            </ng-container>\n                        </ng-template>\n                    </p-chip>\n                </li>\n                <li class=\"p-inputchips-input-item\" [ngClass]=\"{ 'p-chips-clearable': showClear && !disabled }\" [attr.data-pc-section]=\"'inputToken'\" role=\"option\">\n                    <input\n                        #inputtext\n                        type=\"text\"\n                        [attr.id]=\"inputId\"\n                        [attr.maxlength]=\"maxLength\"\n                        [attr.placeholder]=\"value && value.length ? null : placeholder\"\n                        [attr.tabindex]=\"tabindex\"\n                        (keydown)=\"onKeyDown($event)\"\n                        (input)=\"onInput()\"\n                        (paste)=\"onPaste($event)\"\n                        (focus)=\"onInputFocus($event)\"\n                        (blur)=\"onInputBlur($event)\"\n                        [disabled]=\"disabled || isMaxedOut\"\n                        [ngStyle]=\"inputStyle\"\n                        [class]=\"inputStyleClass\"\n                        pAutoFocus\n                        [autofocus]=\"autofocus\"\n                        class=\"test\"\n                    />\n                </li>\n                <li *ngIf=\"value != null && filled && !disabled && showClear\">\n                    <TimesIcon *ngIf=\"!clearIconTemplate\" [styleClass]=\"'p-chips-clear-icon'\" (click)=\"clear()\" />\n                    <span *ngIf=\"clearIconTemplate\" class=\"p-chips-clear-icon\" (click)=\"clear()\">\n                        <ng-template *ngTemplateOutlet=\"clearIconTemplate\"></ng-template>\n                    </span>\n                </li>\n            </ul>\n        </div>\n    `,\n    host: {\n        class: 'p-element p-inputwrapper',\n        '[class.p-inputwrapper-filled]': 'filled',\n        '[class.p-inputwrapper-focus]': 'focused',\n        '[class.p-chips-clearable]': 'showClear'\n    },\n    providers: [CHIPS_VALUE_ACCESSOR, ChipsStyle],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None\n})\nexport class Chips extends BaseComponent implements AfterContentInit, ControlValueAccessor {\n    /**\n     * Inline style of the element.\n     * @group Props\n     */\n    @Input() style: { [klass: string]: any } | null | undefined;\n    /**\n     * Style class of the element.\n     * @group Props\n     */\n    @Input() styleClass: string | undefined;\n    /**\n     * When present, it specifies that the element should be disabled.\n     * @group Props\n     */\n    @Input({ transform: booleanAttribute }) disabled: boolean | undefined;\n    /**\n     * Name of the property to display on a chip.\n     * @group Props\n     */\n    @Input() field: string | undefined;\n    /**\n     * Advisory information to display on input.\n     * @group Props\n     */\n    @Input() placeholder: string | undefined;\n    /**\n     * Maximum number of entries allowed.\n     * @group Props\n     */\n    @Input({ transform: numberAttribute }) max: number | undefined;\n    /**\n     * Maximum length of a chip.\n     * @group Props\n     */\n    @Input() maxLength: number | undefined;\n    /**\n     * Defines a string that labels the input for accessibility.\n     * @group Props\n     */\n    @Input() ariaLabel: string | undefined;\n    /**\n     * Establishes relationships between the component and label(s) where its value should be one or more element IDs.\n     * @group Props\n     */\n    @Input() ariaLabelledBy: string | undefined;\n    /**\n     * Index of the element in tabbing order.\n     * @group Props\n     */\n    @Input({ transform: numberAttribute }) tabindex: number | undefined;\n    /**\n     * Identifier of the focus input to match a label defined for the component.\n     * @group Props\n     */\n    @Input() inputId: string | undefined;\n    /**\n     * Whether to allow duplicate values or not.\n     * @group Props\n     */\n    @Input({ transform: booleanAttribute }) allowDuplicate: boolean = true;\n    /**\n     * Defines whether duplication check should be case-sensitive\n     * @group Props\n     */\n    @Input({ transform: booleanAttribute }) caseSensitiveDuplication: boolean = true;\n    /**\n     * Inline style of the input field.\n     * @group Props\n     */\n    @Input() inputStyle: { [klass: string]: any } | null | undefined;\n    /**\n     * Style class of the input field.\n     * @group Props\n     */\n    @Input() inputStyleClass: string | undefined;\n    /**\n     * Icon to display in chip remove action..\n     * @group Props\n     */\n    @Input() chipIcon: string | undefined;\n    /**\n     * Whether to add an item on tab key press.\n     * @group Props\n     */\n    @Input({ transform: booleanAttribute }) addOnTab: boolean | undefined;\n    /**\n     * Whether to add an item when the input loses focus.\n     * @group Props\n     */\n    @Input({ transform: booleanAttribute }) addOnBlur: boolean | undefined;\n    /**\n     * Separator char to add an item when pressed in addition to the enter key.\n     * @group Props\n     */\n    @Input() separator: string | RegExp | undefined;\n    /**\n     * When enabled, a clear icon is displayed to clear the value.\n     * @group Props\n     */\n    @Input({ transform: booleanAttribute }) showClear: boolean = false;\n    /**\n     * When present, it specifies that the component should automatically get focus on load.\n     * @group Props\n     */\n    @Input({ transform: booleanAttribute }) autofocus: boolean | undefined;\n    /**\n     * Specifies the input variant of the component.\n     * @group Props\n     */\n    @Input() variant: 'filled' | 'outlined' = 'outlined';\n    /**\n     * Callback to invoke on chip add.\n     * @param {ChipsAddEvent} event - Custom chip add event.\n     * @group Emits\n     */\n    @Output() onAdd: EventEmitter<ChipsAddEvent> = new EventEmitter<ChipsAddEvent>();\n    /**\n     * Callback to invoke on chip remove.\n     * @param {ChipsRemoveEvent} event - Custom chip remove event.\n     * @group Emits\n     */\n    @Output() onRemove: EventEmitter<ChipsRemoveEvent> = new EventEmitter<ChipsRemoveEvent>();\n    /**\n     * Callback to invoke on focus of input field.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onFocus: EventEmitter<Event> = new EventEmitter<Event>();\n    /**\n     * Callback to invoke on blur of input field.\n     * @param {Event} event - Browser event.\n     * @group Emits\n     */\n    @Output() onBlur: EventEmitter<Event> = new EventEmitter<Event>();\n    /**\n     * Callback to invoke on chip clicked.\n     * @param {ChipsClickEvent} event - Custom chip click event.\n     * @group Emits\n     */\n    @Output() onChipClick: EventEmitter<ChipsClickEvent> = new EventEmitter<ChipsClickEvent>();\n    /**\n     * Callback to invoke on chip contextmenu.\n     * @param {ChipsClickEvent} event - Custom chip contextmenu event.\n     * @group Emits\n     */\n    @Output() onChipContextMenu: EventEmitter<ChipsContextMenuEvent> = new EventEmitter<ChipsContextMenuEvent>();\n    /**\n     * Callback to invoke on clear token clicked.\n     * @group Emits\n     */\n    @Output() onClear: EventEmitter<any> = new EventEmitter<any>();\n\n    @ViewChild('inputtext') inputViewChild!: ElementRef;\n\n    @ViewChild('container') containerViewChild!: ElementRef;\n\n    @ContentChildren(PrimeTemplate) templates!: QueryList<any>;\n\n    public itemTemplate: Nullable<TemplateRef<any>>;\n\n    removeTokenIconTemplate: Nullable<TemplateRef<any>>;\n\n    clearIconTemplate: Nullable<TemplateRef<any>>;\n\n    value: any;\n\n    onModelChange: Function = () => {};\n\n    onModelTouched: Function = () => {};\n\n    valueChanged: Nullable<boolean>;\n\n    id = UniqueComponentId();\n\n    focused: Nullable<boolean>;\n\n    focusedIndex: Nullable<number>;\n\n    filled: Nullable<boolean>;\n\n    _componentStyle = inject(ChipsStyle);\n\n    get focusedOptionId() {\n        return this.focusedIndex !== null ? `${this.id}_chips_item_${this.focusedIndex}` : null;\n    }\n\n    get isMaxedOut(): boolean {\n        return this.max && this.value && this.max === this.value.length;\n    }\n\n    constructor(\n        public el: ElementRef,\n        public cd: ChangeDetectorRef,\n        public config: PrimeNG\n    ) {\n        super();\n        console.log('Deprecated since v18. Use AutoComplete component instead with its typeahead property.');\n    }\n\n    ngAfterContentInit() {\n        this.templates.forEach((item) => {\n            switch (item.getType()) {\n                case 'item':\n                    this.itemTemplate = item.template;\n                    break;\n\n                case 'removetokenicon':\n                    this.removeTokenIconTemplate = item.template;\n                    break;\n\n                case 'clearicon':\n                    this.clearIconTemplate = item.template;\n                    break;\n\n                default:\n                    this.itemTemplate = item.template;\n                    break;\n            }\n        });\n\n        this.updateFilledState();\n    }\n\n    onWrapperClick() {\n        this.inputViewChild?.nativeElement.focus();\n    }\n\n    onContainerFocus() {\n        this.focused = true;\n    }\n\n    onContainerBlur() {\n        this.focusedIndex = -1;\n        this.focused = false;\n    }\n\n    onContainerKeyDown(event) {\n        switch (event.code) {\n            case 'ArrowLeft':\n                this.onArrowLeftKeyOn();\n                break;\n\n            case 'ArrowRight':\n                this.onArrowRightKeyOn();\n                break;\n\n            case 'Backspace':\n                this.onBackspaceKeyOn(event);\n                break;\n\n            case 'Space':\n                if (this.focusedIndex !== null && this.value && this.value.length > 0) {\n                    this.onItemClick(event, this.value[this.focusedIndex]);\n                }\n                break;\n\n            default:\n                break;\n        }\n    }\n\n    onArrowLeftKeyOn() {\n        if (this.inputViewChild.nativeElement.value.length === 0 && this.value && this.value.length > 0) {\n            this.focusedIndex = this.focusedIndex === null ? this.value.length - 1 : this.focusedIndex - 1;\n            if (this.focusedIndex < 0) this.focusedIndex = 0;\n        }\n    }\n\n    onArrowRightKeyOn() {\n        if (this.inputViewChild.nativeElement.value.length === 0 && this.value && this.value.length > 0) {\n            if (this.focusedIndex === this.value.length - 1) {\n                this.focusedIndex = null;\n                this.inputViewChild?.nativeElement.focus();\n            } else {\n                this.focusedIndex++;\n            }\n        }\n    }\n\n    onBackspaceKeyOn(event) {\n        if (this.focusedIndex !== null) {\n            this.removeItem(event, this.focusedIndex);\n        }\n    }\n\n    onInput() {\n        this.updateFilledState();\n        this.focusedIndex = null;\n    }\n\n    onPaste(event: any) {\n        if (!this.disabled) {\n            if (this.separator) {\n                const pastedData: string = (event.clipboardData || (this.document.defaultView as any)['clipboardData']).getData('Text');\n                pastedData.split(this.separator).forEach((val: any) => {\n                    this.addItem(event, val, true);\n                });\n                this.inputViewChild.nativeElement.value = '';\n            }\n\n            this.updateFilledState();\n        }\n    }\n\n    updateFilledState() {\n        if (!this.value || this.value.length === 0) {\n            this.filled = this.inputViewChild && this.inputViewChild.nativeElement && this.inputViewChild.nativeElement.value != '';\n        } else {\n            this.filled = true;\n        }\n    }\n\n    onItemClick(event: Event, item: any) {\n        this.onChipClick.emit({\n            originalEvent: event,\n            value: item\n        });\n    }\n\n    onItemContextMenu(event: Event, item: any) {\n        this.onChipContextMenu.emit({\n            originalEvent: event,\n            value: item\n        });\n    }\n\n    writeValue(value: any): void {\n        this.value = value;\n        this.updateMaxedOut();\n        this.updateFilledState();\n        this.cd.markForCheck();\n    }\n\n    registerOnChange(fn: Function): void {\n        this.onModelChange = fn;\n    }\n\n    registerOnTouched(fn: Function): void {\n        this.onModelTouched = fn;\n    }\n\n    setDisabledState(val: boolean): void {\n        this.disabled = val;\n        this.cd.markForCheck();\n    }\n\n    resolveFieldData(data: any, field: string): any {\n        if (data && field) {\n            if (field.indexOf('.') == -1) {\n                return data[field];\n            } else {\n                let fields: string[] = field.split('.');\n                let value = data;\n                for (var i = 0, len = fields.length; i < len; ++i) {\n                    value = value[fields[i]];\n                }\n                return value;\n            }\n        } else {\n            return null;\n        }\n    }\n\n    onInputFocus(event: FocusEvent) {\n        this.focused = true;\n        this.focusedIndex = null;\n        this.onFocus.emit(event);\n    }\n\n    onInputBlur(event: FocusEvent) {\n        this.focused = false;\n        this.focusedIndex = null;\n        if (this.addOnBlur && this.inputViewChild.nativeElement.value) {\n            this.addItem(event, this.inputViewChild.nativeElement.value, false);\n        }\n        this.onModelTouched();\n        this.onBlur.emit(event);\n    }\n\n    removeItem(event: Event, index: number): void {\n        if (this.disabled) {\n            return;\n        }\n\n        let removedItem = this.value[index];\n        this.value = this.value.filter((val: any, i: number) => i != index);\n        this.focusedIndex = null;\n        this.inputViewChild.nativeElement.focus();\n\n        this.onModelChange(this.value);\n        this.onRemove.emit({\n            originalEvent: event,\n            value: removedItem\n        });\n        this.updateFilledState();\n        this.updateMaxedOut();\n    }\n\n    addItem(event: Event, item: string, preventDefault: boolean): void {\n        this.value = this.value || [];\n\n        if (item && item.trim().length) {\n            const newItemIsDuplicate = this.caseSensitiveDuplication ? this.value.includes(item) : this.value.some((val) => val.toLowerCase() === item.toLowerCase());\n\n            if ((this.allowDuplicate || !newItemIsDuplicate) && !this.isMaxedOut) {\n                this.value = [...this.value, item];\n                this.onModelChange(this.value);\n                this.onAdd.emit({\n                    originalEvent: event,\n                    value: item\n                });\n            }\n        }\n\n        this.updateFilledState();\n        this.updateMaxedOut();\n        this.inputViewChild.nativeElement.value = '';\n\n        if (preventDefault) {\n            event.preventDefault();\n        }\n    }\n\n    /**\n     * Callback to invoke on filter reset.\n     * @group Method\n     */\n    public clear() {\n        this.value = null;\n        this.updateFilledState();\n        this.onModelChange(this.value);\n        this.updateMaxedOut();\n        this.onClear.emit();\n    }\n\n    onKeyDown(event) {\n        const inputValue = event.target.value;\n\n        switch (event.code) {\n            case 'Backspace':\n                if (inputValue.length === 0 && this.value && this.value.length > 0) {\n                    if (this.focusedIndex !== null) {\n                        this.removeItem(event, this.focusedIndex);\n                    } else this.removeItem(event, this.value.length - 1);\n                }\n\n                break;\n\n            case 'Enter':\n            case 'NumpadEnter':\n                if (inputValue && inputValue.trim().length && !this.isMaxedOut) {\n                    this.addItem(event, inputValue, true);\n                }\n\n                break;\n\n            case 'Tab':\n                if (this.addOnTab && inputValue && inputValue.trim().length && !this.isMaxedOut) {\n                    this.addItem(event, inputValue, true);\n                    event.preventDefault();\n                }\n\n                break;\n\n            case 'ArrowLeft':\n                if (inputValue.length === 0 && this.value && this.value.length > 0) {\n                    this.containerViewChild?.nativeElement.focus();\n                }\n\n                break;\n\n            case 'ArrowRight':\n                event.stopPropagation();\n                break;\n\n            default:\n                if (this.separator) {\n                    if (this.separator === event.key || event.key.match(this.separator)) {\n                        this.addItem(event, inputValue, true);\n                    }\n                }\n\n                break;\n        }\n    }\n\n    updateMaxedOut(): void {\n        if (this.inputViewChild && this.inputViewChild.nativeElement) {\n            if (this.isMaxedOut) {\n                // Calling `blur` is necessary because firefox does not call `onfocus` events\n                // for disabled inputs, unlike chromium browsers.\n                this.inputViewChild.nativeElement.blur();\n                this.inputViewChild.nativeElement.disabled = true;\n            } else {\n                if (this.disabled) {\n                    this.inputViewChild.nativeElement.blur();\n                }\n\n                this.inputViewChild.nativeElement.disabled = this.disabled || false;\n            }\n        }\n    }\n}\n\n@NgModule({\n    imports: [Chips, SharedModule],\n    exports: [Chips, SharedModule]\n})\nexport class ChipsModule {}\n"]}
|