primevue 3.8.2 → 3.11.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/README.md +2 -2
- package/accordion/Accordion.d.ts +74 -11
- package/accordion/accordion.esm.js +1 -1
- package/accordion/accordion.esm.min.js +1 -1
- package/accordion/accordion.js +1 -1
- package/accordiontab/AccordionTab.d.ts +37 -8
- package/accordiontab/accordiontab.esm.js +1 -1
- package/accordiontab/accordiontab.esm.min.js +1 -1
- package/accordiontab/accordiontab.js +1 -1
- package/api/Api.d.ts +292 -251
- package/api/api.cjs.js +66 -32
- package/api/api.cjs.min.js +1 -1
- package/api/api.esm.js +66 -32
- package/api/api.esm.min.js +1 -1
- package/api/api.js +67 -33
- package/api/api.min.js +1 -1
- package/autocomplete/AutoComplete.d.ts +280 -63
- package/autocomplete/AutoComplete.vue +16 -9
- package/autocomplete/autocomplete.cjs.js +23 -15
- package/autocomplete/autocomplete.cjs.min.js +1 -1
- package/autocomplete/autocomplete.esm.js +20 -12
- package/autocomplete/autocomplete.esm.min.js +1 -1
- package/autocomplete/autocomplete.js +24 -16
- package/autocomplete/autocomplete.min.js +1 -1
- package/avatar/Avatar.d.ts +57 -8
- package/avatar/avatar.esm.js +1 -1
- package/avatar/avatar.esm.min.js +1 -1
- package/avatar/avatar.js +1 -1
- package/avatargroup/AvatarGroup.d.ts +29 -3
- package/avatargroup/avatargroup.esm.js +1 -1
- package/avatargroup/avatargroup.esm.min.js +1 -1
- package/avatargroup/avatargroup.js +1 -1
- package/badge/Badge.d.ts +46 -5
- package/badge/badge.esm.js +1 -1
- package/badge/badge.esm.min.js +1 -1
- package/badge/badge.js +1 -1
- package/badgedirective/badgedirective.esm.js +1 -1
- package/badgedirective/badgedirective.esm.min.js +1 -1
- package/badgedirective/badgedirective.js +1 -1
- package/blockui/BlockUI.d.ts +52 -11
- package/blockui/blockui.esm.js +1 -1
- package/blockui/blockui.esm.min.js +1 -1
- package/blockui/blockui.js +1 -1
- package/breadcrumb/Breadcrumb.d.ts +49 -9
- package/breadcrumb/BreadcrumbItem.vue +5 -2
- package/breadcrumb/breadcrumb.cjs.js +5 -2
- package/breadcrumb/breadcrumb.cjs.min.js +1 -1
- package/breadcrumb/breadcrumb.esm.js +6 -3
- package/breadcrumb/breadcrumb.esm.min.js +1 -1
- package/breadcrumb/breadcrumb.js +6 -3
- package/breadcrumb/breadcrumb.min.js +1 -1
- package/button/Button.d.ts +68 -11
- package/button/button.cjs.js +1 -1
- package/button/button.esm.js +1 -1
- package/button/button.esm.min.js +1 -1
- package/button/button.js +2 -2
- package/calendar/Calendar.d.ts +320 -58
- package/calendar/Calendar.vue +406 -84
- package/calendar/calendar.cjs.js +521 -204
- package/calendar/calendar.cjs.min.js +1 -1
- package/calendar/calendar.esm.js +521 -203
- package/calendar/calendar.esm.min.js +1 -1
- package/calendar/calendar.js +523 -205
- package/calendar/calendar.min.js +1 -1
- package/card/Card.d.ts +43 -9
- package/card/card.esm.js +1 -1
- package/card/card.esm.min.js +1 -1
- package/card/card.js +1 -1
- package/carousel/Carousel.d.ts +121 -24
- package/carousel/Carousel.vue +2 -2
- package/carousel/carousel.cjs.js +7 -7
- package/carousel/carousel.cjs.min.js +1 -1
- package/carousel/carousel.esm.js +7 -7
- package/carousel/carousel.esm.min.js +1 -1
- package/carousel/carousel.js +8 -8
- package/carousel/carousel.min.js +1 -1
- package/cascadeselect/CascadeSelect.d.ts +172 -35
- package/cascadeselect/cascadeselect.cjs.js +2 -2
- package/cascadeselect/cascadeselect.esm.js +1 -1
- package/cascadeselect/cascadeselect.esm.min.js +1 -1
- package/cascadeselect/cascadeselect.js +3 -3
- package/chart/Chart.d.ts +104 -12
- package/chart/Chart.vue +18 -4
- package/chart/chart.cjs.js +20 -8
- package/chart/chart.cjs.min.js +1 -1
- package/chart/chart.esm.js +19 -5
- package/chart/chart.esm.min.js +1 -1
- package/chart/chart.js +19 -5
- package/chart/chart.min.js +1 -1
- package/checkbox/Checkbox.d.ts +66 -8
- package/checkbox/checkbox.esm.js +1 -1
- package/checkbox/checkbox.esm.min.js +1 -1
- package/checkbox/checkbox.js +1 -1
- package/chip/Chip.d.ts +50 -4
- package/chip/chip.esm.js +1 -1
- package/chip/chip.esm.min.js +1 -1
- package/chip/chip.js +1 -1
- package/chips/Chips.d.ts +88 -15
- package/chips/chips.esm.js +1 -1
- package/chips/chips.esm.min.js +1 -1
- package/chips/chips.js +1 -1
- package/colorpicker/ColorPicker.d.ts +105 -13
- package/colorpicker/ColorPicker.vue +6 -1
- package/colorpicker/colorpicker.cjs.js +7 -2
- package/colorpicker/colorpicker.cjs.min.js +1 -1
- package/colorpicker/colorpicker.esm.js +7 -2
- package/colorpicker/colorpicker.esm.min.js +1 -1
- package/colorpicker/colorpicker.js +8 -3
- package/colorpicker/colorpicker.min.js +1 -1
- package/column/Column.d.ts +448 -78
- package/column/column.esm.js +1 -1
- package/column/column.esm.min.js +1 -1
- package/column/column.js +1 -1
- package/columngroup/ColumnGroup.d.ts +30 -4
- package/columngroup/columngroup.esm.js +1 -1
- package/columngroup/columngroup.esm.min.js +1 -1
- package/columngroup/columngroup.js +1 -1
- package/config/config.cjs.js +1 -1
- package/config/config.esm.js +1 -2
- package/config/config.esm.min.js +1 -1
- package/config/config.js +2 -2
- package/confirmationeventbus/confirmationeventbus.esm.js +1 -1
- package/confirmationeventbus/confirmationeventbus.esm.min.js +1 -1
- package/confirmationeventbus/confirmationeventbus.js +1 -1
- package/confirmationoptions/ConfirmationOptions.d.ts +58 -0
- package/confirmationoptions/package.json +3 -0
- package/confirmationservice/ConfirmationService.d.ts +2 -1
- package/confirmationservice/confirmationservice.cjs.js +2 -2
- package/confirmationservice/confirmationservice.esm.js +1 -1
- package/confirmationservice/confirmationservice.esm.min.js +1 -1
- package/confirmationservice/confirmationservice.js +3 -3
- package/confirmdialog/ConfirmDialog.d.ts +57 -5
- package/confirmdialog/ConfirmDialog.vue +8 -2
- package/confirmdialog/confirmdialog.cjs.js +17 -10
- package/confirmdialog/confirmdialog.cjs.min.js +1 -1
- package/confirmdialog/confirmdialog.esm.js +12 -5
- package/confirmdialog/confirmdialog.esm.min.js +1 -1
- package/confirmdialog/confirmdialog.js +18 -11
- package/confirmdialog/confirmdialog.min.js +1 -1
- package/confirmpopup/ConfirmPopup.d.ts +41 -3
- package/confirmpopup/ConfirmPopup.vue +7 -4
- package/confirmpopup/confirmpopup.cjs.js +19 -11
- package/confirmpopup/confirmpopup.cjs.min.js +1 -1
- package/confirmpopup/confirmpopup.esm.js +15 -7
- package/confirmpopup/confirmpopup.esm.min.js +1 -1
- package/confirmpopup/confirmpopup.js +20 -12
- package/confirmpopup/confirmpopup.min.js +1 -1
- package/contextmenu/ContextMenu.d.ts +88 -16
- package/contextmenu/ContextMenuSub.vue +7 -4
- package/contextmenu/contextmenu.cjs.js +8 -5
- package/contextmenu/contextmenu.cjs.min.js +1 -1
- package/contextmenu/contextmenu.esm.js +8 -5
- package/contextmenu/contextmenu.esm.min.js +1 -1
- package/contextmenu/contextmenu.js +9 -6
- package/contextmenu/contextmenu.min.js +1 -1
- package/core/core.js +861 -383
- package/core/core.min.js +15 -13
- package/datatable/BodyCell.vue +27 -1
- package/datatable/ColumnFilter.vue +17 -6
- package/datatable/DataTable.d.ts +1056 -130
- package/datatable/DataTable.vue +150 -131
- package/datatable/HeaderCheckbox.vue +5 -2
- package/datatable/RowCheckbox.vue +1 -1
- package/datatable/RowRadioButton.vue +1 -1
- package/datatable/TableBody.vue +57 -14
- package/datatable/TableFooter.vue +15 -1
- package/datatable/TableHeader.vue +15 -1
- package/datatable/datatable.cjs.js +542 -381
- package/datatable/datatable.cjs.min.js +1 -1
- package/datatable/datatable.esm.js +533 -373
- package/datatable/datatable.esm.min.js +1 -1
- package/datatable/datatable.js +543 -383
- package/datatable/datatable.min.js +1 -1
- package/dataview/DataView.d.ts +198 -32
- package/dataview/DataView.vue +8 -8
- package/dataview/dataview.cjs.js +13 -13
- package/dataview/dataview.cjs.min.js +1 -1
- package/dataview/dataview.esm.js +13 -13
- package/dataview/dataview.esm.min.js +1 -1
- package/dataview/dataview.js +14 -14
- package/dataview/dataview.min.js +1 -1
- package/dataviewlayoutoptions/DataViewLayoutOptions.d.ts +34 -5
- package/dataviewlayoutoptions/dataviewlayoutoptions.esm.js +1 -1
- package/dataviewlayoutoptions/dataviewlayoutoptions.esm.min.js +1 -1
- package/dataviewlayoutoptions/dataviewlayoutoptions.js +1 -1
- package/deferredcontent/DeferredContent.d.ts +31 -6
- package/deferredcontent/deferredcontent.esm.js +1 -1
- package/deferredcontent/deferredcontent.esm.min.js +1 -1
- package/deferredcontent/deferredcontent.js +1 -1
- package/dialog/Dialog.d.ts +187 -34
- package/dialog/Dialog.vue +1 -1
- package/dialog/dialog.cjs.js +2 -3
- package/dialog/dialog.cjs.min.js +1 -1
- package/dialog/dialog.esm.js +2 -3
- package/dialog/dialog.esm.min.js +1 -1
- package/dialog/dialog.js +3 -4
- package/dialog/dialog.min.js +1 -1
- package/divider/Divider.d.ts +53 -8
- package/divider/divider.esm.js +1 -1
- package/divider/divider.esm.min.js +1 -1
- package/divider/divider.js +1 -1
- package/dock/Dock.d.ts +92 -15
- package/dock/DockSub.vue +3 -1
- package/dock/dock.cjs.js +4 -1
- package/dock/dock.cjs.min.js +1 -1
- package/dock/dock.esm.js +4 -2
- package/dock/dock.esm.min.js +1 -1
- package/dock/dock.js +5 -3
- package/dock/dock.min.js +1 -1
- package/dropdown/Dropdown.d.ts +340 -76
- package/dropdown/Dropdown.vue +1 -1
- package/dropdown/dropdown.cjs.js +4 -4
- package/dropdown/dropdown.cjs.min.js +1 -1
- package/dropdown/dropdown.esm.js +2 -2
- package/dropdown/dropdown.esm.min.js +1 -1
- package/dropdown/dropdown.js +5 -5
- package/dropdown/dropdown.min.js +1 -1
- package/editor/Editor.d.ts +78 -11
- package/editor/editor.cjs.js +1 -1
- package/editor/editor.esm.js +1 -1
- package/editor/editor.esm.min.js +1 -1
- package/editor/editor.js +2 -2
- package/fieldset/Fieldset.d.ts +63 -11
- package/fieldset/fieldset.cjs.js +1 -1
- package/fieldset/fieldset.esm.js +1 -1
- package/fieldset/fieldset.esm.min.js +1 -1
- package/fieldset/fieldset.js +2 -2
- package/fileupload/FileUpload.d.ts +255 -37
- package/fileupload/fileupload.cjs.js +4 -4
- package/fileupload/fileupload.esm.js +1 -1
- package/fileupload/fileupload.esm.min.js +1 -1
- package/fileupload/fileupload.js +5 -5
- package/fullcalendar/FullCalendar.d.ts +29 -3
- package/fullcalendar/fullcalendar.esm.js +1 -1
- package/fullcalendar/fullcalendar.esm.min.js +1 -1
- package/fullcalendar/fullcalendar.js +1 -1
- package/galleria/Galleria.d.ts +196 -46
- package/galleria/galleria.cjs.js +3 -3
- package/galleria/galleria.esm.js +1 -1
- package/galleria/galleria.esm.min.js +1 -1
- package/galleria/galleria.js +4 -4
- package/image/Image.d.ts +51 -6
- package/image/image.esm.js +1 -1
- package/image/image.esm.min.js +1 -1
- package/image/image.js +1 -1
- package/inlinemessage/InlineMessage.d.ts +34 -6
- package/inlinemessage/inlinemessage.esm.js +1 -1
- package/inlinemessage/inlinemessage.esm.min.js +1 -1
- package/inlinemessage/inlinemessage.js +1 -1
- package/inplace/Inplace.d.ts +57 -12
- package/inplace/inplace.cjs.js +1 -1
- package/inplace/inplace.esm.js +1 -1
- package/inplace/inplace.esm.min.js +1 -1
- package/inplace/inplace.js +2 -2
- package/inputmask/InputMask.d.ts +75 -15
- package/inputmask/inputmask.esm.js +1 -1
- package/inputmask/inputmask.esm.min.js +1 -1
- package/inputmask/inputmask.js +1 -1
- package/inputnumber/InputNumber.d.ts +180 -30
- package/inputnumber/InputNumber.vue +19 -3
- package/inputnumber/inputnumber.cjs.js +21 -5
- package/inputnumber/inputnumber.cjs.min.js +1 -1
- package/inputnumber/inputnumber.esm.js +20 -4
- package/inputnumber/inputnumber.esm.min.js +1 -1
- package/inputnumber/inputnumber.js +22 -6
- package/inputnumber/inputnumber.min.js +1 -1
- package/inputswitch/InputSwitch.d.ts +61 -9
- package/inputswitch/inputswitch.esm.js +1 -1
- package/inputswitch/inputswitch.esm.min.js +1 -1
- package/inputswitch/inputswitch.js +1 -1
- package/inputtext/InputText.d.ts +34 -5
- package/inputtext/InputText.vue +1 -1
- package/inputtext/inputtext.cjs.js +2 -2
- package/inputtext/inputtext.cjs.min.js +1 -1
- package/inputtext/inputtext.esm.js +4 -4
- package/inputtext/inputtext.esm.min.js +1 -1
- package/inputtext/inputtext.js +3 -3
- package/inputtext/inputtext.min.js +1 -1
- package/knob/Knob.d.ts +92 -18
- package/knob/knob.esm.js +1 -1
- package/knob/knob.esm.min.js +1 -1
- package/knob/knob.js +1 -1
- package/listbox/Listbox.d.ts +246 -56
- package/listbox/listbox.cjs.js +2 -2
- package/listbox/listbox.esm.js +1 -1
- package/listbox/listbox.esm.min.js +1 -1
- package/listbox/listbox.js +3 -3
- package/megamenu/MegaMenu.d.ts +60 -12
- package/megamenu/MegaMenu.vue +10 -7
- package/megamenu/megamenu.cjs.js +11 -8
- package/megamenu/megamenu.cjs.min.js +1 -1
- package/megamenu/megamenu.esm.js +11 -8
- package/megamenu/megamenu.esm.min.js +1 -1
- package/megamenu/megamenu.js +12 -9
- package/megamenu/megamenu.min.js +1 -1
- package/menu/Menu.d.ts +84 -15
- package/menu/Menu.vue +6 -3
- package/menu/Menuitem.vue +5 -2
- package/menu/menu.cjs.js +13 -7
- package/menu/menu.cjs.min.js +1 -1
- package/menu/menu.esm.js +12 -6
- package/menu/menu.esm.min.js +1 -1
- package/menu/menu.js +14 -8
- package/menu/menu.min.js +1 -1
- package/menubar/Menubar.d.ts +52 -11
- package/menubar/Menubar.vue +1 -0
- package/menubar/MenubarSub.vue +7 -4
- package/menubar/menubar.cjs.js +9 -6
- package/menubar/menubar.cjs.min.js +1 -1
- package/menubar/menubar.esm.js +9 -6
- package/menubar/menubar.esm.min.js +1 -1
- package/menubar/menubar.js +10 -7
- package/menubar/menubar.min.js +1 -1
- package/menuitem/MenuItem.d.ts +82 -0
- package/menuitem/package.json +3 -0
- package/message/Message.d.ts +57 -10
- package/message/Message.vue +6 -2
- package/message/message.cjs.js +7 -3
- package/message/message.cjs.min.js +1 -1
- package/message/message.esm.js +7 -3
- package/message/message.esm.min.js +1 -1
- package/message/message.js +8 -4
- package/message/message.min.js +1 -1
- package/multiselect/MultiSelect.d.ts +368 -83
- package/multiselect/multiselect.cjs.js +3 -3
- package/multiselect/multiselect.esm.js +1 -1
- package/multiselect/multiselect.esm.min.js +1 -1
- package/multiselect/multiselect.js +4 -4
- package/orderlist/OrderList.d.ts +122 -17
- package/orderlist/OrderList.vue +2 -0
- package/orderlist/orderlist.cjs.js +5 -3
- package/orderlist/orderlist.cjs.min.js +1 -1
- package/orderlist/orderlist.esm.js +4 -2
- package/orderlist/orderlist.esm.min.js +1 -1
- package/orderlist/orderlist.js +6 -4
- package/orderlist/orderlist.min.js +1 -1
- package/organizationchart/OrganizationChart.d.ts +137 -15
- package/organizationchart/OrganizationChart.vue +1 -0
- package/organizationchart/organizationchart.cjs.js +1 -1
- package/organizationchart/organizationchart.cjs.min.js +1 -1
- package/organizationchart/organizationchart.esm.js +2 -2
- package/organizationchart/organizationchart.esm.min.js +1 -1
- package/organizationchart/organizationchart.js +2 -2
- package/organizationchart/organizationchart.min.js +1 -1
- package/overlayeventbus/overlayeventbus.esm.js +1 -1
- package/overlayeventbus/overlayeventbus.esm.min.js +1 -1
- package/overlayeventbus/overlayeventbus.js +1 -1
- package/overlaypanel/OverlayPanel.d.ts +107 -12
- package/overlaypanel/overlaypanel.cjs.js +5 -5
- package/overlaypanel/overlaypanel.esm.js +1 -1
- package/overlaypanel/overlaypanel.esm.min.js +1 -1
- package/overlaypanel/overlaypanel.js +6 -6
- package/package.json +5 -1
- package/paginator/Paginator.d.ts +129 -27
- package/paginator/Paginator.vue +4 -4
- package/paginator/paginator.cjs.js +12 -12
- package/paginator/paginator.cjs.min.js +1 -1
- package/paginator/paginator.esm.js +5 -5
- package/paginator/paginator.esm.min.js +1 -1
- package/paginator/paginator.js +13 -13
- package/paginator/paginator.min.js +1 -1
- package/panel/Panel.d.ts +64 -8
- package/panel/Panel.vue +1 -1
- package/panel/panel.cjs.js +1 -1
- package/panel/panel.esm.js +1 -1
- package/panel/panel.esm.min.js +1 -1
- package/panel/panel.js +2 -2
- package/panelmenu/PanelMenu.d.ts +59 -11
- package/panelmenu/PanelMenu.vue +8 -5
- package/panelmenu/PanelMenuSub.vue +8 -5
- package/panelmenu/panelmenu.cjs.js +18 -12
- package/panelmenu/panelmenu.cjs.min.js +1 -1
- package/panelmenu/panelmenu.esm.js +19 -13
- package/panelmenu/panelmenu.esm.min.js +1 -1
- package/panelmenu/panelmenu.js +19 -13
- package/panelmenu/panelmenu.min.js +1 -1
- package/password/Password.d.ts +115 -24
- package/password/password.cjs.js +2 -2
- package/password/password.esm.js +1 -1
- package/password/password.esm.min.js +1 -1
- package/password/password.js +3 -3
- package/picklist/PickList.d.ts +199 -26
- package/picklist/PickList.vue +10 -4
- package/picklist/picklist.cjs.js +15 -9
- package/picklist/picklist.cjs.min.js +1 -1
- package/picklist/picklist.esm.js +14 -8
- package/picklist/picklist.esm.min.js +1 -1
- package/picklist/picklist.js +16 -10
- package/picklist/picklist.min.js +1 -1
- package/progressbar/ProgressBar.d.ts +43 -8
- package/progressbar/ProgressBar.vue +13 -12
- package/progressbar/progressbar.cjs.js +13 -12
- package/progressbar/progressbar.cjs.min.js +1 -1
- package/progressbar/progressbar.esm.js +15 -14
- package/progressbar/progressbar.esm.min.js +1 -1
- package/progressbar/progressbar.js +14 -13
- package/progressbar/progressbar.min.js +1 -1
- package/progressspinner/ProgressSpinner.d.ts +39 -6
- package/progressspinner/progressspinner.esm.js +1 -1
- package/progressspinner/progressspinner.esm.min.js +1 -1
- package/progressspinner/progressspinner.js +1 -1
- package/radiobutton/RadioButton.d.ts +52 -7
- package/radiobutton/radiobutton.esm.js +1 -1
- package/radiobutton/radiobutton.esm.min.js +1 -1
- package/radiobutton/radiobutton.js +1 -1
- package/rating/Rating.d.ts +67 -10
- package/rating/Rating.vue +1 -1
- package/rating/rating.cjs.js +1 -1
- package/rating/rating.cjs.min.js +1 -1
- package/rating/rating.esm.js +2 -2
- package/rating/rating.esm.min.js +1 -1
- package/rating/rating.js +2 -2
- package/rating/rating.min.js +1 -1
- package/resources/primevue.css +5 -0
- package/resources/primevue.min.css +1 -1
- package/resources/themes/arya-blue/theme.css +81 -33
- package/resources/themes/arya-green/theme.css +81 -33
- package/resources/themes/arya-orange/theme.css +81 -33
- package/resources/themes/arya-purple/theme.css +81 -33
- package/resources/themes/bootstrap4-dark-blue/theme.css +62 -21
- package/resources/themes/bootstrap4-dark-purple/theme.css +62 -21
- package/resources/themes/bootstrap4-light-blue/theme.css +62 -21
- package/resources/themes/bootstrap4-light-purple/theme.css +62 -21
- package/resources/themes/fluent-light/theme.css +81 -33
- package/resources/themes/lara-dark-blue/fonts/Inter-Bold.woff +0 -0
- package/resources/themes/lara-dark-blue/fonts/Inter-Bold.woff2 +0 -0
- package/resources/themes/lara-dark-blue/fonts/Inter-Light.woff +0 -0
- package/resources/themes/lara-dark-blue/fonts/Inter-Light.woff2 +0 -0
- package/resources/themes/lara-dark-blue/fonts/Inter-Medium.woff +0 -0
- package/resources/themes/lara-dark-blue/fonts/Inter-Medium.woff2 +0 -0
- package/resources/themes/lara-dark-blue/fonts/Inter-Regular.woff +0 -0
- package/resources/themes/lara-dark-blue/fonts/Inter-Regular.woff2 +0 -0
- package/resources/themes/lara-dark-blue/fonts/Inter-SemiBold.woff +0 -0
- package/resources/themes/lara-dark-blue/fonts/Inter-SemiBold.woff2 +0 -0
- package/resources/themes/lara-dark-blue/theme.css +5421 -0
- package/resources/themes/lara-dark-indigo/fonts/Inter-Bold.woff +0 -0
- package/resources/themes/lara-dark-indigo/fonts/Inter-Bold.woff2 +0 -0
- package/resources/themes/lara-dark-indigo/fonts/Inter-Light.woff +0 -0
- package/resources/themes/lara-dark-indigo/fonts/Inter-Light.woff2 +0 -0
- package/resources/themes/lara-dark-indigo/fonts/Inter-Medium.woff +0 -0
- package/resources/themes/lara-dark-indigo/fonts/Inter-Medium.woff2 +0 -0
- package/resources/themes/lara-dark-indigo/fonts/Inter-Regular.woff +0 -0
- package/resources/themes/lara-dark-indigo/fonts/Inter-Regular.woff2 +0 -0
- package/resources/themes/lara-dark-indigo/fonts/Inter-SemiBold.woff +0 -0
- package/resources/themes/lara-dark-indigo/fonts/Inter-SemiBold.woff2 +0 -0
- package/resources/themes/lara-dark-indigo/theme.css +5421 -0
- package/resources/themes/lara-dark-purple/fonts/Inter-Bold.woff +0 -0
- package/resources/themes/lara-dark-purple/fonts/Inter-Bold.woff2 +0 -0
- package/resources/themes/lara-dark-purple/fonts/Inter-Light.woff +0 -0
- package/resources/themes/lara-dark-purple/fonts/Inter-Light.woff2 +0 -0
- package/resources/themes/lara-dark-purple/fonts/Inter-Medium.woff +0 -0
- package/resources/themes/lara-dark-purple/fonts/Inter-Medium.woff2 +0 -0
- package/resources/themes/lara-dark-purple/fonts/Inter-Regular.woff +0 -0
- package/resources/themes/lara-dark-purple/fonts/Inter-Regular.woff2 +0 -0
- package/resources/themes/lara-dark-purple/fonts/Inter-SemiBold.woff +0 -0
- package/resources/themes/lara-dark-purple/fonts/Inter-SemiBold.woff2 +0 -0
- package/resources/themes/lara-dark-purple/theme.css +5421 -0
- package/resources/themes/lara-dark-teal/fonts/Inter-Bold.woff +0 -0
- package/resources/themes/lara-dark-teal/fonts/Inter-Bold.woff2 +0 -0
- package/resources/themes/lara-dark-teal/fonts/Inter-Light.woff +0 -0
- package/resources/themes/lara-dark-teal/fonts/Inter-Light.woff2 +0 -0
- package/resources/themes/lara-dark-teal/fonts/Inter-Medium.woff +0 -0
- package/resources/themes/lara-dark-teal/fonts/Inter-Medium.woff2 +0 -0
- package/resources/themes/lara-dark-teal/fonts/Inter-Regular.woff +0 -0
- package/resources/themes/lara-dark-teal/fonts/Inter-Regular.woff2 +0 -0
- package/resources/themes/lara-dark-teal/fonts/Inter-SemiBold.woff +0 -0
- package/resources/themes/lara-dark-teal/fonts/Inter-SemiBold.woff2 +0 -0
- package/resources/themes/lara-dark-teal/theme.css +5421 -0
- package/resources/themes/lara-light-blue/fonts/Inter-Bold.woff +0 -0
- package/resources/themes/lara-light-blue/fonts/Inter-Bold.woff2 +0 -0
- package/resources/themes/lara-light-blue/fonts/Inter-Light.woff +0 -0
- package/resources/themes/lara-light-blue/fonts/Inter-Light.woff2 +0 -0
- package/resources/themes/lara-light-blue/fonts/Inter-Medium.woff +0 -0
- package/resources/themes/lara-light-blue/fonts/Inter-Medium.woff2 +0 -0
- package/resources/themes/lara-light-blue/fonts/Inter-Regular.woff +0 -0
- package/resources/themes/lara-light-blue/fonts/Inter-Regular.woff2 +0 -0
- package/resources/themes/lara-light-blue/fonts/Inter-SemiBold.woff +0 -0
- package/resources/themes/lara-light-blue/fonts/Inter-SemiBold.woff2 +0 -0
- package/resources/themes/lara-light-blue/theme.css +5421 -0
- package/resources/themes/lara-light-indigo/fonts/Inter-Bold.woff +0 -0
- package/resources/themes/lara-light-indigo/fonts/Inter-Bold.woff2 +0 -0
- package/resources/themes/lara-light-indigo/fonts/Inter-Light.woff +0 -0
- package/resources/themes/lara-light-indigo/fonts/Inter-Light.woff2 +0 -0
- package/resources/themes/lara-light-indigo/fonts/Inter-Medium.woff +0 -0
- package/resources/themes/lara-light-indigo/fonts/Inter-Medium.woff2 +0 -0
- package/resources/themes/lara-light-indigo/fonts/Inter-Regular.woff +0 -0
- package/resources/themes/lara-light-indigo/fonts/Inter-Regular.woff2 +0 -0
- package/resources/themes/lara-light-indigo/fonts/Inter-SemiBold.woff +0 -0
- package/resources/themes/lara-light-indigo/fonts/Inter-SemiBold.woff2 +0 -0
- package/resources/themes/lara-light-indigo/theme.css +5421 -0
- package/resources/themes/lara-light-purple/fonts/Inter-Bold.woff +0 -0
- package/resources/themes/lara-light-purple/fonts/Inter-Bold.woff2 +0 -0
- package/resources/themes/lara-light-purple/fonts/Inter-Light.woff +0 -0
- package/resources/themes/lara-light-purple/fonts/Inter-Light.woff2 +0 -0
- package/resources/themes/lara-light-purple/fonts/Inter-Medium.woff +0 -0
- package/resources/themes/lara-light-purple/fonts/Inter-Medium.woff2 +0 -0
- package/resources/themes/lara-light-purple/fonts/Inter-Regular.woff +0 -0
- package/resources/themes/lara-light-purple/fonts/Inter-Regular.woff2 +0 -0
- package/resources/themes/lara-light-purple/fonts/Inter-SemiBold.woff +0 -0
- package/resources/themes/lara-light-purple/fonts/Inter-SemiBold.woff2 +0 -0
- package/resources/themes/lara-light-purple/theme.css +5421 -0
- package/resources/themes/lara-light-teal/fonts/Inter-Bold.woff +0 -0
- package/resources/themes/lara-light-teal/fonts/Inter-Bold.woff2 +0 -0
- package/resources/themes/lara-light-teal/fonts/Inter-Light.woff +0 -0
- package/resources/themes/lara-light-teal/fonts/Inter-Light.woff2 +0 -0
- package/resources/themes/lara-light-teal/fonts/Inter-Medium.woff +0 -0
- package/resources/themes/lara-light-teal/fonts/Inter-Medium.woff2 +0 -0
- package/resources/themes/lara-light-teal/fonts/Inter-Regular.woff +0 -0
- package/resources/themes/lara-light-teal/fonts/Inter-Regular.woff2 +0 -0
- package/resources/themes/lara-light-teal/fonts/Inter-SemiBold.woff +0 -0
- package/resources/themes/lara-light-teal/fonts/Inter-SemiBold.woff2 +0 -0
- package/resources/themes/lara-light-teal/theme.css +5421 -0
- package/resources/themes/luna-amber/theme.css +78 -37
- package/resources/themes/luna-blue/theme.css +78 -37
- package/resources/themes/luna-green/theme.css +78 -37
- package/resources/themes/luna-pink/theme.css +78 -37
- package/resources/themes/md-dark-deeppurple/theme.css +252 -48
- package/resources/themes/md-dark-indigo/theme.css +252 -48
- package/resources/themes/md-light-deeppurple/theme.css +252 -48
- package/resources/themes/md-light-indigo/theme.css +252 -48
- package/resources/themes/mdc-dark-deeppurple/theme.css +252 -48
- package/resources/themes/mdc-dark-indigo/theme.css +252 -48
- package/resources/themes/mdc-light-deeppurple/theme.css +252 -48
- package/resources/themes/mdc-light-indigo/theme.css +252 -48
- package/resources/themes/nova/theme.css +78 -37
- package/resources/themes/nova-accent/theme.css +78 -37
- package/resources/themes/nova-alt/theme.css +78 -37
- package/resources/themes/nova-vue/theme.css +78 -37
- package/resources/themes/rhea/theme.css +78 -37
- package/resources/themes/saga-blue/theme.css +65 -17
- package/resources/themes/saga-green/theme.css +65 -17
- package/resources/themes/saga-orange/theme.css +65 -17
- package/resources/themes/saga-purple/theme.css +65 -17
- package/resources/themes/tailwind-light/theme.css +92 -36
- package/resources/themes/vela-blue/theme.css +81 -33
- package/resources/themes/vela-green/theme.css +81 -33
- package/resources/themes/vela-orange/theme.css +81 -33
- package/resources/themes/vela-purple/theme.css +81 -33
- package/ripple/ripple.esm.js +1 -1
- package/ripple/ripple.esm.min.js +1 -1
- package/ripple/ripple.js +1 -1
- package/row/Row.d.ts +25 -3
- package/row/row.esm.js +1 -1
- package/row/row.esm.min.js +1 -1
- package/row/row.js +1 -1
- package/scrollpanel/ScrollPanel.d.ts +27 -5
- package/scrollpanel/scrollpanel.esm.js +1 -1
- package/scrollpanel/scrollpanel.esm.min.js +1 -1
- package/scrollpanel/scrollpanel.js +1 -1
- package/scrolltop/ScrollTop.d.ts +47 -7
- package/scrolltop/scrolltop.esm.js +1 -1
- package/scrolltop/scrolltop.esm.min.js +1 -1
- package/scrolltop/scrolltop.js +1 -1
- package/selectbutton/SelectButton.d.ts +108 -19
- package/selectbutton/SelectButton.vue +8 -2
- package/selectbutton/selectbutton.cjs.js +15 -10
- package/selectbutton/selectbutton.cjs.min.js +1 -1
- package/selectbutton/selectbutton.esm.js +15 -10
- package/selectbutton/selectbutton.esm.min.js +1 -1
- package/selectbutton/selectbutton.js +16 -11
- package/selectbutton/selectbutton.min.js +1 -1
- package/sidebar/Sidebar.d.ts +81 -16
- package/sidebar/sidebar.cjs.js +1 -1
- package/sidebar/sidebar.esm.js +1 -1
- package/sidebar/sidebar.esm.min.js +1 -1
- package/sidebar/sidebar.js +2 -2
- package/skeleton/Skeleton.d.ts +58 -9
- package/skeleton/skeleton.esm.js +1 -1
- package/skeleton/skeleton.esm.min.js +1 -1
- package/skeleton/skeleton.js +1 -1
- package/slider/Slider.d.ts +90 -14
- package/slider/slider.esm.js +1 -1
- package/slider/slider.esm.min.js +1 -1
- package/slider/slider.js +1 -1
- package/speeddial/SpeedDial.d.ts +166 -29
- package/speeddial/SpeedDial.vue +3 -1
- package/speeddial/speeddial.cjs.js +5 -2
- package/speeddial/speeddial.cjs.min.js +1 -1
- package/speeddial/speeddial.esm.js +4 -2
- package/speeddial/speeddial.esm.min.js +1 -1
- package/speeddial/speeddial.js +6 -4
- package/speeddial/speeddial.min.js +1 -1
- package/splitbutton/SplitButton.d.ts +76 -11
- package/splitbutton/SplitButton.vue +3 -1
- package/splitbutton/splitbutton.cjs.js +15 -13
- package/splitbutton/splitbutton.cjs.min.js +1 -1
- package/splitbutton/splitbutton.esm.js +15 -13
- package/splitbutton/splitbutton.esm.min.js +1 -1
- package/splitbutton/splitbutton.js +16 -14
- package/splitbutton/splitbutton.min.js +1 -1
- package/splitter/Splitter.d.ts +74 -7
- package/splitter/Splitter.vue +5 -5
- package/splitter/splitter.cjs.js +1 -1
- package/splitter/splitter.cjs.min.js +1 -1
- package/splitter/splitter.esm.js +2 -2
- package/splitter/splitter.esm.min.js +1 -1
- package/splitter/splitter.js +2 -2
- package/splitter/splitter.min.js +1 -1
- package/splitterpanel/SplitterPanel.d.ts +34 -7
- package/splitterpanel/splitterpanel.esm.js +1 -1
- package/splitterpanel/splitterpanel.esm.min.js +1 -1
- package/splitterpanel/splitterpanel.js +1 -1
- package/steps/Steps.d.ts +51 -11
- package/steps/Steps.vue +5 -2
- package/steps/steps.cjs.js +5 -2
- package/steps/steps.cjs.min.js +1 -1
- package/steps/steps.esm.js +6 -3
- package/steps/steps.esm.min.js +1 -1
- package/steps/steps.js +6 -3
- package/steps/steps.min.js +1 -1
- package/styleclass/styleclass.esm.js +1 -1
- package/styleclass/styleclass.esm.min.js +1 -1
- package/styleclass/styleclass.js +1 -1
- package/tabmenu/TabMenu.d.ts +63 -10
- package/tabmenu/TabMenu.vue +6 -3
- package/tabmenu/tabmenu.cjs.js +7 -4
- package/tabmenu/tabmenu.cjs.min.js +1 -1
- package/tabmenu/tabmenu.esm.js +7 -4
- package/tabmenu/tabmenu.esm.min.js +1 -1
- package/tabmenu/tabmenu.js +8 -5
- package/tabmenu/tabmenu.min.js +1 -1
- package/tabpanel/TabPanel.d.ts +38 -7
- package/tabpanel/tabpanel.esm.js +1 -1
- package/tabpanel/tabpanel.esm.min.js +1 -1
- package/tabpanel/tabpanel.js +1 -1
- package/tabview/TabView.d.ts +73 -11
- package/tabview/tabview.cjs.js +1 -1
- package/tabview/tabview.esm.js +1 -1
- package/tabview/tabview.esm.min.js +1 -1
- package/tabview/tabview.js +2 -2
- package/tag/Tag.d.ts +44 -8
- package/tag/Tag.vue +1 -1
- package/tag/tag.cjs.js +6 -6
- package/tag/tag.cjs.min.js +1 -1
- package/tag/tag.esm.js +8 -8
- package/tag/tag.esm.min.js +1 -1
- package/tag/tag.js +7 -7
- package/tag/tag.min.js +1 -1
- package/terminal/Terminal.d.ts +36 -5
- package/terminal/terminal.cjs.js +3 -3
- package/terminal/terminal.esm.js +1 -1
- package/terminal/terminal.esm.min.js +1 -1
- package/terminal/terminal.js +4 -4
- package/terminalservice/TerminalService.d.ts +9 -6
- package/terminalservice/terminalservice.esm.js +1 -1
- package/terminalservice/terminalservice.esm.min.js +1 -1
- package/terminalservice/terminalservice.js +1 -1
- package/textarea/Textarea.d.ts +38 -6
- package/textarea/textarea.esm.js +1 -1
- package/textarea/textarea.esm.min.js +1 -1
- package/textarea/textarea.js +1 -1
- package/tieredmenu/TieredMenu.d.ts +89 -15
- package/tieredmenu/TieredMenuSub.vue +7 -4
- package/tieredmenu/tieredmenu.cjs.js +9 -6
- package/tieredmenu/tieredmenu.cjs.min.js +1 -1
- package/tieredmenu/tieredmenu.esm.js +8 -5
- package/tieredmenu/tieredmenu.esm.min.js +1 -1
- package/tieredmenu/tieredmenu.js +10 -7
- package/tieredmenu/tieredmenu.min.js +1 -1
- package/timeline/Timeline.d.ts +94 -15
- package/timeline/timeline.esm.js +1 -1
- package/timeline/timeline.esm.min.js +1 -1
- package/timeline/timeline.js +1 -1
- package/toast/Toast.d.ts +118 -12
- package/toast/toast.cjs.js +7 -7
- package/toast/toast.esm.js +1 -1
- package/toast/toast.esm.min.js +1 -1
- package/toast/toast.js +8 -8
- package/toasteventbus/toasteventbus.esm.js +1 -1
- package/toasteventbus/toasteventbus.esm.min.js +1 -1
- package/toasteventbus/toasteventbus.js +1 -1
- package/toastservice/ToastService.d.ts +17 -5
- package/toastservice/toastservice.cjs.js +3 -3
- package/toastservice/toastservice.esm.js +1 -1
- package/toastservice/toastservice.esm.min.js +1 -1
- package/toastservice/toastservice.js +4 -4
- package/togglebutton/ToggleButton.d.ts +64 -11
- package/togglebutton/togglebutton.cjs.js +1 -1
- package/togglebutton/togglebutton.esm.js +1 -1
- package/togglebutton/togglebutton.esm.min.js +1 -1
- package/togglebutton/togglebutton.js +2 -2
- package/toolbar/Toolbar.d.ts +31 -6
- package/toolbar/Toolbar.vue +2 -2
- package/toolbar/toolbar.cjs.js +2 -2
- package/toolbar/toolbar.cjs.min.js +1 -1
- package/toolbar/toolbar.esm.js +3 -3
- package/toolbar/toolbar.esm.min.js +1 -1
- package/toolbar/toolbar.js +3 -3
- package/toolbar/toolbar.min.js +1 -1
- package/tooltip/tooltip.esm.js +1 -1
- package/tooltip/tooltip.esm.min.js +1 -1
- package/tooltip/tooltip.js +1 -1
- package/tree/Tree.d.ts +189 -26
- package/tree/Tree.vue +1 -0
- package/tree/TreeNode.vue +4 -1
- package/tree/tree.cjs.js +6 -3
- package/tree/tree.cjs.min.js +1 -1
- package/tree/tree.esm.js +6 -3
- package/tree/tree.esm.min.js +1 -1
- package/tree/tree.js +7 -4
- package/tree/tree.min.js +1 -1
- package/treeselect/TreeSelect.d.ts +201 -44
- package/treeselect/TreeSelect.vue +9 -0
- package/treeselect/treeselect.cjs.js +12 -3
- package/treeselect/treeselect.cjs.min.js +1 -1
- package/treeselect/treeselect.esm.js +10 -1
- package/treeselect/treeselect.esm.min.js +1 -1
- package/treeselect/treeselect.js +13 -4
- package/treeselect/treeselect.min.js +1 -1
- package/treetable/BodyCell.vue +3 -3
- package/treetable/TreeTable.d.ts +459 -63
- package/treetable/TreeTable.vue +9 -9
- package/treetable/treetable.cjs.js +17 -17
- package/treetable/treetable.cjs.min.js +1 -1
- package/treetable/treetable.esm.js +16 -16
- package/treetable/treetable.esm.min.js +1 -1
- package/treetable/treetable.js +18 -18
- package/treetable/treetable.min.js +1 -1
- package/tristatecheckbox/TriStateCheckbox.d.ts +40 -6
- package/tristatecheckbox/tristatecheckbox.esm.js +1 -1
- package/tristatecheckbox/tristatecheckbox.esm.min.js +1 -1
- package/tristatecheckbox/tristatecheckbox.js +1 -1
- package/ts-helpers.d.ts +28 -0
- package/useconfirm/UseConfirm.d.ts +5 -19
- package/useconfirm/useconfirm.js +1 -1
- package/usetoast/UseToast.d.ts +3 -5
- package/usetoast/usetoast.js +1 -1
- package/utils/Utils.d.ts +3 -0
- package/utils/utils.cjs.js +41 -4
- package/utils/utils.cjs.min.js +1 -1
- package/utils/utils.esm.js +41 -4
- package/utils/utils.esm.min.js +1 -1
- package/utils/utils.js +42 -5
- package/utils/utils.min.js +1 -1
- package/vetur-attributes.json +66 -30
- package/vetur-tags.json +16 -7
- package/virtualscroller/VirtualScroller.d.ts +294 -53
- package/virtualscroller/VirtualScroller.vue +296 -255
- package/virtualscroller/virtualscroller.cjs.js +325 -266
- package/virtualscroller/virtualscroller.cjs.min.js +1 -1
- package/virtualscroller/virtualscroller.esm.js +326 -267
- package/virtualscroller/virtualscroller.esm.min.js +1 -1
- package/virtualscroller/virtualscroller.js +326 -267
- package/virtualscroller/virtualscroller.min.js +1 -1
- package/web-types.json +296 -47
|
@@ -4,15 +4,21 @@ var vue = require('vue');
|
|
|
4
4
|
|
|
5
5
|
var script = {
|
|
6
6
|
name: 'VirtualScroller',
|
|
7
|
-
emits: ['update:numToleratedItems', 'scroll-index-change', 'lazy-load'],
|
|
7
|
+
emits: ['update:numToleratedItems', 'scroll', 'scroll-index-change', 'lazy-load'],
|
|
8
8
|
props: {
|
|
9
|
+
id: {
|
|
10
|
+
type: String,
|
|
11
|
+
default: null
|
|
12
|
+
},
|
|
13
|
+
style: null,
|
|
14
|
+
class: null,
|
|
9
15
|
items: {
|
|
10
16
|
type: Array,
|
|
11
17
|
default: null
|
|
12
18
|
},
|
|
13
19
|
itemSize: {
|
|
14
20
|
type: [Number,Array],
|
|
15
|
-
default:
|
|
21
|
+
default: 0
|
|
16
22
|
},
|
|
17
23
|
scrollHeight: null,
|
|
18
24
|
scrollWidth: null,
|
|
@@ -32,17 +38,27 @@ var script = {
|
|
|
32
38
|
type: Boolean,
|
|
33
39
|
default: false
|
|
34
40
|
},
|
|
35
|
-
|
|
41
|
+
disabled: {
|
|
42
|
+
type: Boolean,
|
|
43
|
+
default: false
|
|
44
|
+
},
|
|
45
|
+
loaderDisabled: {
|
|
36
46
|
type: Boolean,
|
|
37
47
|
default: false
|
|
38
48
|
},
|
|
49
|
+
columns: {
|
|
50
|
+
type: Array,
|
|
51
|
+
default: null
|
|
52
|
+
},
|
|
39
53
|
loading: {
|
|
40
54
|
type: Boolean,
|
|
41
55
|
default: false
|
|
42
56
|
},
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
57
|
+
showSpacer: {
|
|
58
|
+
type: Boolean,
|
|
59
|
+
default: true
|
|
60
|
+
},
|
|
61
|
+
showLoader: {
|
|
46
62
|
type: Boolean,
|
|
47
63
|
default: false
|
|
48
64
|
}
|
|
@@ -55,15 +71,19 @@ var script = {
|
|
|
55
71
|
lastScrollPos: this.isBoth() ? { top: 0, left: 0 } : 0,
|
|
56
72
|
d_numToleratedItems: this.numToleratedItems,
|
|
57
73
|
d_loading: this.loading,
|
|
58
|
-
loaderArr:
|
|
74
|
+
loaderArr: [],
|
|
75
|
+
spacerStyle: {},
|
|
76
|
+
contentStyle: {}
|
|
59
77
|
}
|
|
60
78
|
},
|
|
61
79
|
element: null,
|
|
62
80
|
content: null,
|
|
63
|
-
|
|
81
|
+
lastScrollPos: null,
|
|
64
82
|
scrollTimeout: null,
|
|
65
83
|
mounted() {
|
|
66
84
|
this.init();
|
|
85
|
+
|
|
86
|
+
this.lastScrollPos = this.isBoth() ? { top: 0, left: 0 } : 0;
|
|
67
87
|
},
|
|
68
88
|
watch: {
|
|
69
89
|
numToleratedItems(newValue) {
|
|
@@ -72,67 +92,185 @@ var script = {
|
|
|
72
92
|
loading(newValue) {
|
|
73
93
|
this.d_loading = newValue;
|
|
74
94
|
},
|
|
75
|
-
items(newValue,
|
|
76
|
-
if (!
|
|
95
|
+
items(newValue, oldValue) {
|
|
96
|
+
if (!oldValue || oldValue.length !== (newValue || []).length) {
|
|
77
97
|
this.init();
|
|
78
98
|
}
|
|
99
|
+
},
|
|
100
|
+
orientation() {
|
|
101
|
+
this.lastScrollPos = this.isBoth() ? { top: 0, left: 0 } : 0;
|
|
79
102
|
}
|
|
80
103
|
},
|
|
81
104
|
methods: {
|
|
82
105
|
init() {
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
106
|
+
this.setSize();
|
|
107
|
+
this.calculateOptions();
|
|
108
|
+
this.setSpacerSize();
|
|
109
|
+
},
|
|
110
|
+
isVertical() {
|
|
111
|
+
return this.orientation === 'vertical';
|
|
112
|
+
},
|
|
113
|
+
isHorizontal() {
|
|
114
|
+
return this.orientation === 'horizontal';
|
|
115
|
+
},
|
|
116
|
+
isBoth() {
|
|
117
|
+
return this.orientation === 'both';
|
|
118
|
+
},
|
|
119
|
+
scrollTo(options) {
|
|
120
|
+
this.element && this.element.scrollTo(options);
|
|
121
|
+
},
|
|
122
|
+
scrollToIndex(index, behavior = 'auto') {
|
|
123
|
+
const both = this.isBoth();
|
|
124
|
+
const horizontal = this.isHorizontal();
|
|
125
|
+
const contentPos = this.getContentPosition();
|
|
126
|
+
const calculateFirst = (_index = 0, _numT) => (_index <= _numT ? 0 : _index);
|
|
127
|
+
const calculateCoord = (_first, _size, _cpos) => (_first * _size) + _cpos;
|
|
128
|
+
const scrollTo = (left = 0, top = 0) => this.scrollTo({ left, top, behavior });
|
|
129
|
+
|
|
130
|
+
if (both) {
|
|
131
|
+
const newFirst = { rows: calculateFirst(index[0], this.d_numToleratedItems[0]), cols: calculateFirst(index[1], this.d_numToleratedItems[1]) };
|
|
132
|
+
if (newFirst.rows !== this.first.rows || newFirst.cols !== this.first.cols) {
|
|
133
|
+
scrollTo(calculateCoord(newFirst.cols, this.itemSize[1], contentPos.left), calculateCoord(newFirst.rows, this.itemSize[0], contentPos.top));
|
|
134
|
+
this.first = newFirst;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
else {
|
|
138
|
+
const newFirst = calculateFirst(index, this.d_numToleratedItems);
|
|
139
|
+
|
|
140
|
+
if (newFirst !== this.first) {
|
|
141
|
+
horizontal ? scrollTo(calculateCoord(newFirst, this.itemSize, contentPos.left), 0) : scrollTo(0, calculateCoord(newFirst, this.itemSize, contentPos.top));
|
|
142
|
+
this.first = newFirst;
|
|
143
|
+
}
|
|
87
144
|
}
|
|
88
145
|
},
|
|
89
|
-
|
|
90
|
-
|
|
146
|
+
scrollInView(index, to, behavior = 'auto') {
|
|
147
|
+
if (to) {
|
|
148
|
+
const both = this.isBoth();
|
|
149
|
+
const horizontal = this.isHorizontal();
|
|
150
|
+
const { first, viewport } = this.getRenderedRange();
|
|
151
|
+
const scrollTo = (left = 0, top = 0) => this.scrollTo({ left, top, behavior });
|
|
152
|
+
const isToStart = to === 'to-start';
|
|
153
|
+
const isToEnd = to === 'to-end';
|
|
154
|
+
|
|
155
|
+
if (isToStart) {
|
|
156
|
+
if (both) {
|
|
157
|
+
if (viewport.first.rows - first.rows > index[0]) {
|
|
158
|
+
scrollTo(viewport.first.cols * this.itemSize[1], (viewport.first.rows - 1) * this.itemSize[0]);
|
|
159
|
+
}
|
|
160
|
+
else if (viewport.first.cols - first.cols > index[1]) {
|
|
161
|
+
scrollTo((viewport.first.cols - 1) * this.itemSize[1], viewport.first.rows * this.itemSize[0]);
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
else {
|
|
165
|
+
if (viewport.first - first > index) {
|
|
166
|
+
const pos = (viewport.first - 1) * this.itemSize;
|
|
167
|
+
horizontal ? scrollTo(pos, 0) : scrollTo(0, pos);
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
else if (isToEnd) {
|
|
172
|
+
if (both) {
|
|
173
|
+
if (viewport.last.rows - first.rows <= index[0] + 1) {
|
|
174
|
+
scrollTo(viewport.first.cols * this.itemSize[1], (viewport.first.rows + 1) * this.itemSize[0]);
|
|
175
|
+
}
|
|
176
|
+
else if (viewport.last.cols - first.cols <= index[1] + 1) {
|
|
177
|
+
scrollTo((viewport.first.cols + 1) * this.itemSize[1], viewport.first.rows * this.itemSize[0]);
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
else {
|
|
181
|
+
if (viewport.last - first <= index + 1) {
|
|
182
|
+
const pos = (viewport.first + 1) * this.itemSize;
|
|
183
|
+
horizontal ? scrollTo(pos, 0) : scrollTo(0, pos);
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
else {
|
|
189
|
+
this.scrollToIndex(index, behavior);
|
|
190
|
+
}
|
|
191
|
+
},
|
|
192
|
+
getRenderedRange() {
|
|
193
|
+
const calculateFirstInViewport = (_pos, _size) => Math.floor(_pos / (_size || _pos));
|
|
194
|
+
|
|
195
|
+
let firstInViewport = this.first;
|
|
196
|
+
let lastInViewport = 0;
|
|
197
|
+
|
|
198
|
+
if (this.element) {
|
|
199
|
+
const both = this.isBoth();
|
|
200
|
+
const horizontal = this.isHorizontal();
|
|
201
|
+
const scrollTop = this.element.scrollTop;
|
|
202
|
+
const scrollLeft = this.element.scrollLeft;
|
|
203
|
+
|
|
204
|
+
if (both) {
|
|
205
|
+
firstInViewport = { rows: calculateFirstInViewport(scrollTop, this.itemSize[0]), cols: calculateFirstInViewport(scrollLeft, this.itemSize[1]) };
|
|
206
|
+
lastInViewport = { rows: firstInViewport.rows + this.numItemsInViewport.rows, cols: firstInViewport.cols + this.numItemsInViewport.cols };
|
|
207
|
+
}
|
|
208
|
+
else {
|
|
209
|
+
const scrollPos = horizontal ? scrollLeft : scrollTop;
|
|
210
|
+
firstInViewport = calculateFirstInViewport(scrollPos, this.itemSize);
|
|
211
|
+
lastInViewport = firstInViewport + this.numItemsInViewport;
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
return {
|
|
216
|
+
first: this.first,
|
|
217
|
+
last: this.last,
|
|
218
|
+
viewport: {
|
|
219
|
+
first: firstInViewport,
|
|
220
|
+
last: lastInViewport
|
|
221
|
+
}
|
|
222
|
+
};
|
|
91
223
|
},
|
|
92
224
|
calculateOptions() {
|
|
93
|
-
const
|
|
94
|
-
const
|
|
95
|
-
const
|
|
96
|
-
const
|
|
97
|
-
const
|
|
98
|
-
const contentWidth = this.element ? this.element.offsetWidth - contentPadding.left : 0;
|
|
99
|
-
const contentHeight = this.element ? this.element.offsetHeight - contentPadding.top : 0;
|
|
225
|
+
const both = this.isBoth();
|
|
226
|
+
const horizontal = this.isHorizontal();
|
|
227
|
+
const contentPos = this.getContentPosition();
|
|
228
|
+
const contentWidth = this.element ? this.element.offsetWidth - contentPos.left : 0;
|
|
229
|
+
const contentHeight = this.element ? this.element.offsetHeight - contentPos.top : 0;
|
|
100
230
|
const calculateNumItemsInViewport = (_contentSize, _itemSize) => Math.ceil(_contentSize / (_itemSize || _contentSize));
|
|
101
|
-
const
|
|
102
|
-
|
|
103
|
-
calculateNumItemsInViewport(
|
|
231
|
+
const calculateNumToleratedItems = (_numItems) => Math.ceil(_numItems / 2);
|
|
232
|
+
const numItemsInViewport = both ?
|
|
233
|
+
{ rows: calculateNumItemsInViewport(contentHeight, this.itemSize[0]), cols: calculateNumItemsInViewport(contentWidth, this.itemSize[1]) } :
|
|
234
|
+
calculateNumItemsInViewport((horizontal ? contentWidth : contentHeight), this.itemSize);
|
|
104
235
|
|
|
105
|
-
let numToleratedItems = this.d_numToleratedItems ||
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
236
|
+
let numToleratedItems = this.d_numToleratedItems || (both ?
|
|
237
|
+
[calculateNumToleratedItems(numItemsInViewport.rows), calculateNumToleratedItems(numItemsInViewport.cols)] :
|
|
238
|
+
calculateNumToleratedItems(numItemsInViewport));
|
|
239
|
+
|
|
240
|
+
const calculateLast = (_first, _num, _numT, _isCols) => this.getLast(_first + _num + ((_first < _numT ? 2 : 3) * _numT), _isCols);
|
|
241
|
+
const last = both ?
|
|
242
|
+
{ rows: calculateLast(this.first.rows, numItemsInViewport.rows, numToleratedItems[0]), cols: calculateLast(this.first.cols, numItemsInViewport.cols, numToleratedItems[1], true) } :
|
|
243
|
+
calculateLast(this.first, numItemsInViewport, numToleratedItems);
|
|
110
244
|
|
|
111
|
-
this.d_numToleratedItems = numToleratedItems;
|
|
112
|
-
this.$emit('update:numToleratedItems', this.d_numToleratedItems);
|
|
113
245
|
this.last = last;
|
|
114
246
|
this.numItemsInViewport = numItemsInViewport;
|
|
247
|
+
this.d_numToleratedItems = numToleratedItems;
|
|
248
|
+
this.$emit('update:numToleratedItems', this.d_numToleratedItems);
|
|
115
249
|
|
|
116
250
|
if (this.showLoader) {
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
else {
|
|
121
|
-
this.loaderArr = Array.from({ length: 1});
|
|
122
|
-
}
|
|
251
|
+
this.loaderArr = both ?
|
|
252
|
+
Array.from({ length: numItemsInViewport.rows }).map(() => Array.from({ length: numItemsInViewport.cols })) :
|
|
253
|
+
Array.from({ length: numItemsInViewport });
|
|
123
254
|
}
|
|
124
255
|
|
|
125
256
|
if (this.lazy) {
|
|
126
|
-
this.$emit('lazy-load', { first, last });
|
|
257
|
+
this.$emit('lazy-load', { first: this.first, last });
|
|
127
258
|
}
|
|
128
259
|
},
|
|
129
|
-
|
|
260
|
+
getLast(last = 0, isCols) {
|
|
261
|
+
if (this.items) {
|
|
262
|
+
return Math.min((isCols ? (this.columns || this.items[0]).length : this.items.length), last);
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
return 0;
|
|
266
|
+
},
|
|
267
|
+
getContentPosition() {
|
|
130
268
|
if (this.content) {
|
|
131
269
|
const style = getComputedStyle(this.content);
|
|
132
|
-
const left = parseInt(
|
|
133
|
-
const right = parseInt(
|
|
134
|
-
const top = parseInt(
|
|
135
|
-
const bottom = parseInt(
|
|
270
|
+
const left = parseInt(style.paddingLeft, 10) + Math.max(parseInt(style.left, 10), 0);
|
|
271
|
+
const right = parseInt(style.paddingRight, 10) + Math.max(parseInt(style.right, 10), 0);
|
|
272
|
+
const top = parseInt(style.paddingTop, 10) + Math.max(parseInt(style.top, 10), 0);
|
|
273
|
+
const bottom = parseInt(style.paddingBottom, 10) + Math.max(parseInt(style.bottom, 10), 0);
|
|
136
274
|
|
|
137
275
|
return { left, right, top, bottom, x: left + right, y: top + bottom };
|
|
138
276
|
}
|
|
@@ -141,126 +279,125 @@ var script = {
|
|
|
141
279
|
},
|
|
142
280
|
setSize() {
|
|
143
281
|
if (this.element) {
|
|
144
|
-
const
|
|
145
|
-
const
|
|
282
|
+
const both = this.isBoth();
|
|
283
|
+
const horizontal = this.isHorizontal();
|
|
146
284
|
const parentElement = this.element.parentElement;
|
|
147
285
|
const width = this.scrollWidth || `${(this.element.offsetWidth || parentElement.offsetWidth)}px`;
|
|
148
286
|
const height = this.scrollHeight || `${(this.element.offsetHeight || parentElement.offsetHeight)}px`;
|
|
149
287
|
const setProp = (_name, _value) => this.element.style[_name] = _value;
|
|
150
288
|
|
|
151
|
-
if (
|
|
289
|
+
if (both || horizontal) {
|
|
152
290
|
setProp('height', height);
|
|
153
291
|
setProp('width', width);
|
|
154
292
|
}
|
|
155
293
|
else {
|
|
156
|
-
|
|
294
|
+
setProp('height', height);
|
|
157
295
|
}
|
|
158
296
|
}
|
|
159
297
|
},
|
|
160
298
|
setSpacerSize() {
|
|
161
299
|
const items = this.items;
|
|
162
300
|
|
|
163
|
-
if (
|
|
164
|
-
const
|
|
165
|
-
const
|
|
166
|
-
const
|
|
167
|
-
const
|
|
168
|
-
const setProp = (_name, _value, _size, _padding = 0) => this.spacer.style[_name] = (((_value || []).length * _size) + _padding) + 'px';
|
|
301
|
+
if (items) {
|
|
302
|
+
const both = this.isBoth();
|
|
303
|
+
const horizontal = this.isHorizontal();
|
|
304
|
+
const contentPos = this.getContentPosition();
|
|
305
|
+
const setProp = (_name, _value, _size, _cpos = 0) => this.spacerStyle = { ...this.spacerStyle, ...{ [`${_name}`]: (((_value || []).length * _size) + _cpos) + 'px' } };
|
|
169
306
|
|
|
170
|
-
if (
|
|
171
|
-
setProp('height', items
|
|
172
|
-
setProp('width', items[1], itemSize[1],
|
|
307
|
+
if (both) {
|
|
308
|
+
setProp('height', items, this.itemSize[0], contentPos.y);
|
|
309
|
+
setProp('width', (this.columns || items[1]), this.itemSize[1], contentPos.x);
|
|
173
310
|
}
|
|
174
311
|
else {
|
|
175
|
-
|
|
312
|
+
horizontal ? setProp('width', (this.columns || items), this.itemSize, contentPos.x) : setProp('height', items, this.itemSize, contentPos.y);
|
|
176
313
|
}
|
|
177
314
|
}
|
|
178
315
|
},
|
|
179
316
|
setContentPosition(pos) {
|
|
180
317
|
if (this.content) {
|
|
181
|
-
const
|
|
182
|
-
const
|
|
183
|
-
const content = this.content;
|
|
318
|
+
const both = this.isBoth();
|
|
319
|
+
const horizontal = this.isHorizontal();
|
|
184
320
|
const first = pos ? pos.first : this.first;
|
|
185
|
-
const itemSize = this.itemSize;
|
|
186
321
|
const calculateTranslateVal = (_first, _size) => (_first * _size);
|
|
187
|
-
const setTransform = (_x = 0, _y = 0) =>
|
|
322
|
+
const setTransform = (_x = 0, _y = 0) => {
|
|
323
|
+
this.contentStyle = { ...this.contentStyle, ...{ transform: `translate3d(${_x}px, ${_y}px, 0)` } };
|
|
324
|
+
};
|
|
188
325
|
|
|
189
|
-
if (
|
|
190
|
-
setTransform(calculateTranslateVal(first.cols, itemSize[1]), calculateTranslateVal(first.rows, itemSize[0]));
|
|
326
|
+
if (both) {
|
|
327
|
+
setTransform(calculateTranslateVal(first.cols, this.itemSize[1]), calculateTranslateVal(first.rows, this.itemSize[0]));
|
|
191
328
|
}
|
|
192
329
|
else {
|
|
193
|
-
const translateVal = calculateTranslateVal(first, itemSize);
|
|
194
|
-
|
|
330
|
+
const translateVal = calculateTranslateVal(first, this.itemSize);
|
|
331
|
+
horizontal ? setTransform(translateVal, 0) : setTransform(0, translateVal);
|
|
195
332
|
}
|
|
196
333
|
}
|
|
197
334
|
},
|
|
198
335
|
onScrollPositionChange(event) {
|
|
199
336
|
const target = event.target;
|
|
200
|
-
const
|
|
201
|
-
const
|
|
202
|
-
const
|
|
203
|
-
const
|
|
204
|
-
const calculateScrollPos = (_pos, _padding) => _pos ? (_pos > _padding ? _pos - _padding : _pos) : 0;
|
|
337
|
+
const both = this.isBoth();
|
|
338
|
+
const horizontal = this.isHorizontal();
|
|
339
|
+
const contentPos = this.getContentPosition();
|
|
340
|
+
const calculateScrollPos = (_pos, _cpos) => _pos ? (_pos > _cpos ? _pos - _cpos : _pos) : 0;
|
|
205
341
|
const calculateCurrentIndex = (_pos, _size) => Math.floor(_pos / (_size || _pos));
|
|
206
|
-
const calculateTriggerIndex = (_currentIndex, _first, _last, _num, _isScrollDownOrRight) => {
|
|
207
|
-
return (_currentIndex <=
|
|
342
|
+
const calculateTriggerIndex = (_currentIndex, _first, _last, _num, _numT, _isScrollDownOrRight) => {
|
|
343
|
+
return (_currentIndex <= _numT ? _numT : (_isScrollDownOrRight ? (_last - _num - _numT) : (_first + _numT - 1)))
|
|
208
344
|
};
|
|
209
|
-
const calculateFirst = (_currentIndex, _triggerIndex, _first, _last, _num, _isScrollDownOrRight) => {
|
|
210
|
-
if (_currentIndex <=
|
|
345
|
+
const calculateFirst = (_currentIndex, _triggerIndex, _first, _last, _num, _numT, _isScrollDownOrRight) => {
|
|
346
|
+
if (_currentIndex <= _numT)
|
|
211
347
|
return 0;
|
|
212
348
|
else
|
|
213
|
-
return _isScrollDownOrRight ?
|
|
214
|
-
|
|
215
|
-
|
|
349
|
+
return Math.max(0, _isScrollDownOrRight ?
|
|
350
|
+
(_currentIndex < _triggerIndex ? _first : _currentIndex - _numT) :
|
|
351
|
+
(_currentIndex > _triggerIndex ? _first : _currentIndex - (2 * _numT)));
|
|
216
352
|
};
|
|
217
|
-
const calculateLast = (_currentIndex, _first, _last, _num, _isCols) => {
|
|
218
|
-
let lastValue = _first + _num + (2 *
|
|
353
|
+
const calculateLast = (_currentIndex, _first, _last, _num, _numT, _isCols) => {
|
|
354
|
+
let lastValue = _first + _num + (2 * _numT);
|
|
219
355
|
|
|
220
|
-
if (_currentIndex >=
|
|
221
|
-
lastValue += (
|
|
356
|
+
if (_currentIndex >= _numT) {
|
|
357
|
+
lastValue += (_numT + 1);
|
|
222
358
|
}
|
|
223
359
|
|
|
224
360
|
return this.getLast(lastValue, _isCols);
|
|
225
361
|
};
|
|
226
362
|
|
|
227
|
-
const scrollTop = calculateScrollPos(target.scrollTop,
|
|
228
|
-
const scrollLeft = calculateScrollPos(target.scrollLeft,
|
|
363
|
+
const scrollTop = calculateScrollPos(target.scrollTop, contentPos.top);
|
|
364
|
+
const scrollLeft = calculateScrollPos(target.scrollLeft, contentPos.left);
|
|
229
365
|
|
|
230
366
|
let newFirst = 0;
|
|
231
367
|
let newLast = this.last;
|
|
232
368
|
let isRangeChanged = false;
|
|
233
369
|
|
|
234
|
-
if (
|
|
370
|
+
if (both) {
|
|
235
371
|
const isScrollDown = this.lastScrollPos.top <= scrollTop;
|
|
236
372
|
const isScrollRight = this.lastScrollPos.left <= scrollLeft;
|
|
237
|
-
const currentIndex = { rows: calculateCurrentIndex(scrollTop, itemSize[0]), cols: calculateCurrentIndex(scrollLeft, itemSize[1]) };
|
|
373
|
+
const currentIndex = { rows: calculateCurrentIndex(scrollTop, this.itemSize[0]), cols: calculateCurrentIndex(scrollLeft, this.itemSize[1]) };
|
|
238
374
|
const triggerIndex = {
|
|
239
|
-
rows: calculateTriggerIndex(currentIndex.rows, this.first.rows, this.last.rows, this.numItemsInViewport.rows, isScrollDown),
|
|
240
|
-
cols: calculateTriggerIndex(currentIndex.cols, this.first.cols, this.last.cols, this.numItemsInViewport.cols, isScrollRight)
|
|
375
|
+
rows: calculateTriggerIndex(currentIndex.rows, this.first.rows, this.last.rows, this.numItemsInViewport.rows, this.d_numToleratedItems[0], isScrollDown),
|
|
376
|
+
cols: calculateTriggerIndex(currentIndex.cols, this.first.cols, this.last.cols, this.numItemsInViewport.cols, this.d_numToleratedItems[1], isScrollRight)
|
|
241
377
|
};
|
|
242
378
|
|
|
243
379
|
newFirst = {
|
|
244
|
-
rows: calculateFirst(currentIndex.rows, triggerIndex.rows, this.first.rows, this.last.rows, this.numItemsInViewport.rows, isScrollDown),
|
|
245
|
-
cols: calculateFirst(currentIndex.cols, triggerIndex.cols, this.first.cols, this.last.cols, this.numItemsInViewport.cols, isScrollRight)
|
|
380
|
+
rows: calculateFirst(currentIndex.rows, triggerIndex.rows, this.first.rows, this.last.rows, this.numItemsInViewport.rows, this.d_numToleratedItems[0], isScrollDown),
|
|
381
|
+
cols: calculateFirst(currentIndex.cols, triggerIndex.cols, this.first.cols, this.last.cols, this.numItemsInViewport.cols, this.d_numToleratedItems[1], isScrollRight)
|
|
246
382
|
};
|
|
247
383
|
newLast = {
|
|
248
|
-
rows: calculateLast(currentIndex.rows, newFirst.rows, this.last.rows, this.numItemsInViewport.rows),
|
|
249
|
-
cols: calculateLast(currentIndex.cols, newFirst.cols, this.last.cols, this.numItemsInViewport.cols, true)
|
|
384
|
+
rows: calculateLast(currentIndex.rows, newFirst.rows, this.last.rows, this.numItemsInViewport.rows, this.d_numToleratedItems[0]),
|
|
385
|
+
cols: calculateLast(currentIndex.cols, newFirst.cols, this.last.cols, this.numItemsInViewport.cols, this.d_numToleratedItems[1], true)
|
|
250
386
|
};
|
|
251
|
-
|
|
387
|
+
|
|
388
|
+
isRangeChanged = (newFirst.rows !== this.first.rows && newLast.rows !== this.last.rows) || (newFirst.cols !== this.first.cols && newLast.cols !== this.last.cols);
|
|
252
389
|
|
|
253
390
|
this.lastScrollPos = { top: scrollTop, left: scrollLeft };
|
|
254
391
|
}
|
|
255
392
|
else {
|
|
256
|
-
const scrollPos =
|
|
393
|
+
const scrollPos = horizontal ? scrollLeft : scrollTop;
|
|
257
394
|
const isScrollDownOrRight = this.lastScrollPos <= scrollPos;
|
|
258
|
-
const currentIndex = calculateCurrentIndex(scrollPos, itemSize);
|
|
259
|
-
const triggerIndex = calculateTriggerIndex(currentIndex, this.first, this.last, this.numItemsInViewport, isScrollDownOrRight);
|
|
395
|
+
const currentIndex = calculateCurrentIndex(scrollPos, this.itemSize);
|
|
396
|
+
const triggerIndex = calculateTriggerIndex(currentIndex, this.first, this.last, this.numItemsInViewport, this.d_numToleratedItems, isScrollDownOrRight);
|
|
260
397
|
|
|
261
|
-
newFirst = calculateFirst(currentIndex, triggerIndex, this.first, this.last, this.numItemsInViewport, isScrollDownOrRight);
|
|
262
|
-
newLast = calculateLast(currentIndex, newFirst, this.last, this.numItemsInViewport);
|
|
263
|
-
isRangeChanged = newFirst !== this.first
|
|
398
|
+
newFirst = calculateFirst(currentIndex, triggerIndex, this.first, this.last, this.numItemsInViewport, this.d_numToleratedItems, isScrollDownOrRight);
|
|
399
|
+
newLast = calculateLast(currentIndex, newFirst, this.last, this.numItemsInViewport, this.d_numToleratedItems);
|
|
400
|
+
isRangeChanged = newFirst !== this.first && newLast !== this.last;
|
|
264
401
|
|
|
265
402
|
this.lastScrollPos = scrollPos;
|
|
266
403
|
}
|
|
@@ -279,27 +416,27 @@ var script = {
|
|
|
279
416
|
|
|
280
417
|
this.setContentPosition(newState);
|
|
281
418
|
|
|
282
|
-
if (this.lazy) {
|
|
283
|
-
this.$emit('lazy-load', { first, last });
|
|
284
|
-
}
|
|
285
419
|
this.first = first;
|
|
286
420
|
this.last = last;
|
|
287
421
|
|
|
288
|
-
this.$emit('scroll-index-change',
|
|
422
|
+
this.$emit('scroll-index-change', newState);
|
|
423
|
+
|
|
424
|
+
if (this.lazy) {
|
|
425
|
+
this.$emit('lazy-load', newState);
|
|
426
|
+
}
|
|
289
427
|
}
|
|
290
428
|
},
|
|
291
429
|
onScroll(event) {
|
|
292
|
-
|
|
430
|
+
this.$emit('scroll', event);
|
|
431
|
+
|
|
432
|
+
if (this.delay) {
|
|
293
433
|
if (this.scrollTimeout) {
|
|
294
434
|
clearTimeout(this.scrollTimeout);
|
|
295
435
|
}
|
|
296
436
|
|
|
297
437
|
if (!this.d_loading && this.showLoader) {
|
|
298
438
|
const { isRangeChanged: changed } = this.onScrollPositionChange(event);
|
|
299
|
-
|
|
300
|
-
if (changed) {
|
|
301
|
-
this.d_loading = true;
|
|
302
|
-
}
|
|
439
|
+
changed && (this.d_loading = true);
|
|
303
440
|
}
|
|
304
441
|
|
|
305
442
|
this.scrollTimeout = setTimeout(() => {
|
|
@@ -315,8 +452,8 @@ var script = {
|
|
|
315
452
|
}
|
|
316
453
|
},
|
|
317
454
|
getOptions(renderedIndex) {
|
|
318
|
-
|
|
319
|
-
|
|
455
|
+
const count = (this.items || []).length;
|
|
456
|
+
const index = this.isBoth() ? this.first.rows + renderedIndex : this.first + renderedIndex;
|
|
320
457
|
return {
|
|
321
458
|
index,
|
|
322
459
|
count,
|
|
@@ -326,139 +463,23 @@ var script = {
|
|
|
326
463
|
odd: index % 2 !== 0
|
|
327
464
|
};
|
|
328
465
|
},
|
|
329
|
-
getLoaderOptions(index) {
|
|
466
|
+
getLoaderOptions(index, extOptions) {
|
|
330
467
|
let count = this.loaderArr.length;
|
|
331
468
|
return {
|
|
332
|
-
|
|
469
|
+
index,
|
|
470
|
+
count,
|
|
333
471
|
first: index === 0,
|
|
334
472
|
last: index === (count - 1),
|
|
335
473
|
even: index % 2 === 0,
|
|
336
|
-
odd: index % 2 !== 0
|
|
337
|
-
|
|
338
|
-
},
|
|
339
|
-
isHorizontal() {
|
|
340
|
-
return this.orientation === 'horizontal';
|
|
341
|
-
},
|
|
342
|
-
isBoth() {
|
|
343
|
-
return this.orientation === 'both';
|
|
344
|
-
},
|
|
345
|
-
scrollTo(options) {
|
|
346
|
-
if (this.element) {
|
|
347
|
-
this.element.scrollTo(options);
|
|
348
|
-
}
|
|
349
|
-
},
|
|
350
|
-
scrollToIndex(index, behavior = 'auto') {
|
|
351
|
-
const isBoth = this.isBoth();
|
|
352
|
-
const isHorizontal = this.isHorizontal();
|
|
353
|
-
const itemSize = this.itemSize;
|
|
354
|
-
const contentPadding = this.getContentPadding();
|
|
355
|
-
const calculateFirst = (_index = 0) => (_index <= this.d_numToleratedItems ? 0 : _index);
|
|
356
|
-
const calculateCoord = (_first, _size, _padding) => (_first * _size) + _padding;
|
|
357
|
-
const scrollTo = (left = 0, top = 0) => this.scrollTo({ left, top, behavior });
|
|
358
|
-
|
|
359
|
-
if (isBoth) {
|
|
360
|
-
const newFirst = { rows: calculateFirst(index[0]), cols: calculateFirst(index[1]) };
|
|
361
|
-
if (newFirst.rows !== this.first.rows || newFirst.cols !== this.first.cols)
|
|
362
|
-
scrollTo(calculateCoord(newFirst.cols, itemSize[1], contentPadding.left),calculateCoord(newFirst.rows, itemSize[0], contentPadding.top));
|
|
363
|
-
}
|
|
364
|
-
else {
|
|
365
|
-
const newFirst = calculateFirst(index);
|
|
366
|
-
|
|
367
|
-
if (newFirst !== this.first) {
|
|
368
|
-
isHorizontal ? scrollTo(calculateCoord(newFirst, itemSize, contentPadding.left), 0) : scrollTo(0, calculateCoord(newFirst, itemSize, contentPadding.top));
|
|
369
|
-
}
|
|
370
|
-
|
|
371
|
-
this.first = newFirst;
|
|
372
|
-
}
|
|
373
|
-
},
|
|
374
|
-
scrollInView(index, to, behavior = 'auto') {
|
|
375
|
-
if (to) {
|
|
376
|
-
const isBoth = this.isBoth();
|
|
377
|
-
const isHorizontal = this.isHorizontal();
|
|
378
|
-
const { first, viewport } = this.getRenderedRange();
|
|
379
|
-
const itemSize = this.itemSize;
|
|
380
|
-
const scrollTo = (left = 0, top = 0) => this.scrollTo({ left, top, behavior });
|
|
381
|
-
const isToStart = to === 'to-start';
|
|
382
|
-
const isToEnd = to === 'to-end';
|
|
383
|
-
|
|
384
|
-
if (isToStart) {
|
|
385
|
-
if (isBoth) {
|
|
386
|
-
if (viewport.first.rows - first.rows > index[0]) {
|
|
387
|
-
scrollTo(viewport.first.cols * itemSize[1], (viewport.first.rows - 1) * itemSize[0]);
|
|
388
|
-
}
|
|
389
|
-
else if (viewport.first.cols - first.cols > index[1]) {
|
|
390
|
-
scrollTo((viewport.first.cols - 1) * itemSize[1], viewport.first.rows * itemSize[0]);
|
|
391
|
-
}
|
|
392
|
-
}
|
|
393
|
-
else {
|
|
394
|
-
if (viewport.first - first > index) {
|
|
395
|
-
const pos = (viewport.first - 1) * itemSize;
|
|
396
|
-
isHorizontal ? scrollTo(pos, 0) : scrollTo(0, pos);
|
|
397
|
-
}
|
|
398
|
-
}
|
|
399
|
-
}
|
|
400
|
-
else if (isToEnd) {
|
|
401
|
-
if (isBoth) {
|
|
402
|
-
if (viewport.last.rows - first.rows <= index[0] + 1) {
|
|
403
|
-
scrollTo(viewport.first.cols * itemSize[1], (viewport.first.rows + 1) * itemSize[0]);
|
|
404
|
-
}
|
|
405
|
-
else if (viewport.last.cols - first.cols <= index[1] + 1) {
|
|
406
|
-
scrollTo((viewport.first.cols + 1) * itemSize[1], viewport.first.rows * itemSize[0]);
|
|
407
|
-
}
|
|
408
|
-
}
|
|
409
|
-
else {
|
|
410
|
-
if (viewport.last - first <= index + 1) {
|
|
411
|
-
const pos = (viewport.first + 1) * itemSize;
|
|
412
|
-
isHorizontal ? scrollTo(pos, 0) : scrollTo(0, pos);
|
|
413
|
-
}
|
|
414
|
-
}
|
|
415
|
-
}
|
|
416
|
-
}
|
|
417
|
-
else {
|
|
418
|
-
this.scrollToIndex(index, behavior);
|
|
419
|
-
}
|
|
420
|
-
},
|
|
421
|
-
getRenderedRange() {
|
|
422
|
-
const isBoth = this.isBoth();
|
|
423
|
-
const isHorizontal = this.isHorizontal();
|
|
424
|
-
const itemSize = this.itemSize;
|
|
425
|
-
const calculateFirstInViewport = (_pos, _size) => Math.floor(_pos / (_size || _pos));
|
|
426
|
-
|
|
427
|
-
let firstInViewport = this.first;
|
|
428
|
-
let lastInViewport = 0;
|
|
429
|
-
|
|
430
|
-
if (this.element) {
|
|
431
|
-
const scrollTop = this.element.scrollTop;
|
|
432
|
-
const scrollLeft = this.element.scrollLeft;
|
|
433
|
-
|
|
434
|
-
if (isBoth) {
|
|
435
|
-
firstInViewport = { rows: calculateFirstInViewport(scrollTop, itemSize[0]), cols: calculateFirstInViewport(scrollLeft, itemSize[1]) };
|
|
436
|
-
lastInViewport = { rows: firstInViewport.rows + this.numItemsInViewport.rows, cols: firstInViewport.cols + this.numItemsInViewport.cols };
|
|
437
|
-
}
|
|
438
|
-
else {
|
|
439
|
-
const scrollPos = isHorizontal ? scrollLeft : scrollTop;
|
|
440
|
-
firstInViewport = calculateFirstInViewport(scrollPos, itemSize);
|
|
441
|
-
lastInViewport = firstInViewport + this.numItemsInViewport;
|
|
442
|
-
}
|
|
474
|
+
odd: index % 2 !== 0,
|
|
475
|
+
...extOptions
|
|
443
476
|
}
|
|
444
|
-
|
|
445
|
-
return {
|
|
446
|
-
first: this.first,
|
|
447
|
-
last: this.last,
|
|
448
|
-
viewport: {
|
|
449
|
-
first: firstInViewport,
|
|
450
|
-
last: lastInViewport
|
|
451
|
-
}
|
|
452
|
-
};
|
|
453
477
|
},
|
|
454
478
|
elementRef(el) {
|
|
455
479
|
this.element = el;
|
|
456
480
|
},
|
|
457
481
|
contentRef(el) {
|
|
458
482
|
this.content = el;
|
|
459
|
-
},
|
|
460
|
-
spacerRef(el) {
|
|
461
|
-
this.spacer = el;
|
|
462
483
|
}
|
|
463
484
|
},
|
|
464
485
|
computed: {
|
|
@@ -468,6 +489,11 @@ var script = {
|
|
|
468
489
|
'p-horizontal-scroll': this.isHorizontal()
|
|
469
490
|
}, this.class];
|
|
470
491
|
},
|
|
492
|
+
contentClass() {
|
|
493
|
+
return ['p-virtualscroller-content', {
|
|
494
|
+
'p-virtualscroller-loading': this.d_loading
|
|
495
|
+
}];
|
|
496
|
+
},
|
|
471
497
|
loaderClass() {
|
|
472
498
|
return ['p-virtualscroller-loader', {
|
|
473
499
|
'p-component-overlay': !this.$slots.loader
|
|
@@ -476,27 +502,41 @@ var script = {
|
|
|
476
502
|
loadedItems() {
|
|
477
503
|
const items = this.items;
|
|
478
504
|
if (items && !this.d_loading) {
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
if (isBoth) {
|
|
482
|
-
return items.slice(this.first.rows, this.last.rows).map((item) => {
|
|
483
|
-
const items = item.slice(this.first.cols, this.last.cols);
|
|
484
|
-
return items;
|
|
485
|
-
});
|
|
486
|
-
}
|
|
487
|
-
else {
|
|
488
|
-
return items.slice(this.first, this.last).map((item) => {
|
|
489
|
-
return item;
|
|
490
|
-
});
|
|
505
|
+
if (this.isBoth()) {
|
|
506
|
+
return items.slice(this.first.rows, this.last.rows).map(item => this.columns ? item : item.slice(this.first.cols, this.last.cols));
|
|
491
507
|
}
|
|
508
|
+
else if (this.isHorizontal() && this.columns)
|
|
509
|
+
return items;
|
|
510
|
+
else
|
|
511
|
+
return items.slice(this.first, this.last);
|
|
492
512
|
}
|
|
493
513
|
|
|
494
514
|
return [];
|
|
515
|
+
},
|
|
516
|
+
loadedRows() {
|
|
517
|
+
return this.d_loading ? (this.loaderDisabled ? this.loaderArr : []) : this.loadedItems;
|
|
518
|
+
},
|
|
519
|
+
loadedColumns() {
|
|
520
|
+
if (this.columns) {
|
|
521
|
+
const both = this.isBoth();
|
|
522
|
+
const horizontal = this.isHorizontal();
|
|
523
|
+
|
|
524
|
+
if (both || horizontal) {
|
|
525
|
+
return this.d_loading && this.loaderDisabled ?
|
|
526
|
+
(both ? this.loaderArr[0] : this.loaderArr):
|
|
527
|
+
this.columns.slice((both ? this.first.cols : this.first), (both ? this.last.cols : this.last));
|
|
528
|
+
}
|
|
529
|
+
}
|
|
530
|
+
|
|
531
|
+
return this.columns;
|
|
495
532
|
}
|
|
496
533
|
}
|
|
497
534
|
};
|
|
498
535
|
|
|
499
|
-
const _hoisted_1 =
|
|
536
|
+
const _hoisted_1 = {
|
|
537
|
+
key: 1,
|
|
538
|
+
class: "p-virtualscroller-loading-icon pi pi-spinner pi-spin"
|
|
539
|
+
};
|
|
500
540
|
|
|
501
541
|
function render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
502
542
|
return (!$props.disabled)
|
|
@@ -504,18 +544,30 @@ function render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
504
544
|
key: 0,
|
|
505
545
|
ref: $options.elementRef,
|
|
506
546
|
class: $options.containerClass,
|
|
547
|
+
tabindex: 0,
|
|
507
548
|
style: $props.style,
|
|
508
549
|
onScroll: _cache[1] || (_cache[1] = (...args) => ($options.onScroll && $options.onScroll(...args)))
|
|
509
550
|
}, [
|
|
510
551
|
vue.renderSlot(_ctx.$slots, "content", {
|
|
511
|
-
styleClass:
|
|
512
|
-
contentRef: $options.contentRef,
|
|
552
|
+
styleClass: $options.contentClass,
|
|
513
553
|
items: $options.loadedItems,
|
|
514
|
-
getItemOptions: $options.getOptions
|
|
554
|
+
getItemOptions: $options.getOptions,
|
|
555
|
+
loading: $data.d_loading,
|
|
556
|
+
getLoaderOptions: $options.getLoaderOptions,
|
|
557
|
+
itemSize: $props.itemSize,
|
|
558
|
+
rows: $options.loadedRows,
|
|
559
|
+
columns: $options.loadedColumns,
|
|
560
|
+
contentRef: $options.contentRef,
|
|
561
|
+
spacerStyle: $data.spacerStyle,
|
|
562
|
+
contentStyle: $data.contentStyle,
|
|
563
|
+
vertical: $options.isVertical(),
|
|
564
|
+
horizontal: $options.isHorizontal(),
|
|
565
|
+
both: $options.isBoth()
|
|
515
566
|
}, () => [
|
|
516
567
|
vue.createVNode("div", {
|
|
517
568
|
ref: $options.contentRef,
|
|
518
|
-
class:
|
|
569
|
+
class: $options.contentClass,
|
|
570
|
+
style: $data.contentStyle
|
|
519
571
|
}, [
|
|
520
572
|
(vue.openBlock(true), vue.createBlock(vue.Fragment, null, vue.renderList($options.loadedItems, (item, index) => {
|
|
521
573
|
return vue.renderSlot(_ctx.$slots, "item", {
|
|
@@ -524,31 +576,38 @@ function render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
524
576
|
options: $options.getOptions(index)
|
|
525
577
|
})
|
|
526
578
|
}), 128))
|
|
527
|
-
],
|
|
579
|
+
], 6)
|
|
528
580
|
]),
|
|
529
|
-
|
|
530
|
-
ref: $options.spacerRef,
|
|
531
|
-
class: "p-virtualscroller-spacer"
|
|
532
|
-
}, null, 512),
|
|
533
|
-
($data.d_loading)
|
|
581
|
+
($props.showSpacer)
|
|
534
582
|
? (vue.openBlock(), vue.createBlock("div", {
|
|
535
583
|
key: 0,
|
|
584
|
+
class: "p-virtualscroller-spacer",
|
|
585
|
+
style: $data.spacerStyle
|
|
586
|
+
}, null, 4))
|
|
587
|
+
: vue.createCommentVNode("", true),
|
|
588
|
+
(!$props.loaderDisabled && $props.showLoader && $data.d_loading)
|
|
589
|
+
? (vue.openBlock(), vue.createBlock("div", {
|
|
590
|
+
key: 1,
|
|
536
591
|
class: $options.loaderClass
|
|
537
592
|
}, [
|
|
538
|
-
(
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
593
|
+
(_ctx.$slots && _ctx.$slots.loader)
|
|
594
|
+
? (vue.openBlock(true), vue.createBlock(vue.Fragment, { key: 0 }, vue.renderList($data.loaderArr, (_, index) => {
|
|
595
|
+
return vue.renderSlot(_ctx.$slots, "loader", {
|
|
596
|
+
key: index,
|
|
597
|
+
options: $options.getLoaderOptions(index, $options.isBoth() && { numCols: _ctx.d_numItemsInViewport.cols })
|
|
598
|
+
})
|
|
599
|
+
}), 128))
|
|
600
|
+
: (vue.openBlock(), vue.createBlock("i", _hoisted_1))
|
|
546
601
|
], 2))
|
|
547
602
|
: vue.createCommentVNode("", true)
|
|
548
603
|
], 38))
|
|
549
604
|
: (vue.openBlock(), vue.createBlock(vue.Fragment, { key: 1 }, [
|
|
550
605
|
vue.renderSlot(_ctx.$slots, "default"),
|
|
551
|
-
vue.renderSlot(_ctx.$slots, "content", {
|
|
606
|
+
vue.renderSlot(_ctx.$slots, "content", {
|
|
607
|
+
items: $props.items,
|
|
608
|
+
rows: $props.items,
|
|
609
|
+
columns: $options.loadedColumns
|
|
610
|
+
})
|
|
552
611
|
], 64))
|
|
553
612
|
}
|
|
554
613
|
|
|
@@ -579,7 +638,7 @@ function styleInject(css, ref) {
|
|
|
579
638
|
}
|
|
580
639
|
}
|
|
581
640
|
|
|
582
|
-
var css_248z = "\n.p-virtualscroller {\n position: relative;\n overflow: auto;\n contain: strict;\n -webkit-transform: translateZ(0);\n transform: translateZ(0);\n will-change: scroll-position;\n}\n.p-virtualscroller-content {\n position: absolute;\n top: 0;\n left: 0;\n contain: content;\n min-height: 100%;\n min-width: 100%;\n will-change: transform;\n}\n.p-virtualscroller-spacer {\n position: absolute;\n top: 0;\n left: 0;\n height: 1px;\n width: 1px;\n -webkit-transform-origin: 0 0;\n transform-origin: 0 0;\n pointer-events: none;\n}\n.p-virtualscroller .p-virtualscroller-loader {\n position: sticky;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n}\n.p-virtualscroller-loader.p-component-overlay {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n -webkit-box-pack: center;\n -ms-flex-pack: center;\n justify-content: center;\n}\n";
|
|
641
|
+
var css_248z = "\n.p-virtualscroller {\n position: relative;\n overflow: auto;\n contain: strict;\n -webkit-transform: translateZ(0);\n transform: translateZ(0);\n will-change: scroll-position;\n outline: 0 none;\n}\n.p-virtualscroller-content {\n position: absolute;\n top: 0;\n left: 0;\n contain: content;\n min-height: 100%;\n min-width: 100%;\n will-change: transform;\n}\n.p-virtualscroller-spacer {\n position: absolute;\n top: 0;\n left: 0;\n height: 1px;\n width: 1px;\n -webkit-transform-origin: 0 0;\n transform-origin: 0 0;\n pointer-events: none;\n}\n.p-virtualscroller .p-virtualscroller-loader {\n position: sticky;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n}\n.p-virtualscroller-loader.p-component-overlay {\n display: -webkit-box;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-align: center;\n -ms-flex-align: center;\n align-items: center;\n -webkit-box-pack: center;\n -ms-flex-pack: center;\n justify-content: center;\n}\n";
|
|
583
642
|
styleInject(css_248z);
|
|
584
643
|
|
|
585
644
|
script.render = render;
|