@coreui/vue-pro 5.10.0 → 5.12.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 +1 -1
- package/dist/cjs/components/accordion/CAccordion.js.map +1 -1
- package/dist/cjs/components/accordion/CAccordionBody.js.map +1 -1
- package/dist/cjs/components/accordion/CAccordionButton.js.map +1 -1
- package/dist/cjs/components/accordion/CAccordionHeader.js.map +1 -1
- package/dist/cjs/components/accordion/CAccordionItem.js.map +1 -1
- package/dist/cjs/components/alert/CAlert.js.map +1 -1
- package/dist/cjs/components/avatar/CAvatar.js.map +1 -1
- package/dist/cjs/components/backdrop/CBackdrop.js.map +1 -1
- package/dist/cjs/components/badge/CBadge.js.map +1 -1
- package/dist/cjs/components/breadcrumb/CBreadcrumb.js.map +1 -1
- package/dist/cjs/components/breadcrumb/CBreadcrumbItem.js.map +1 -1
- package/dist/cjs/components/button/CButton.js +1 -1
- package/dist/cjs/components/button/CButton.js.map +1 -1
- package/dist/cjs/components/button-group/CButtonGroup.js.map +1 -1
- package/dist/cjs/components/button-group/CButtonToolbar.js.map +1 -1
- package/dist/cjs/components/calendar/CCalendar.js +4 -3
- package/dist/cjs/components/calendar/CCalendar.js.map +1 -1
- package/dist/cjs/components/calendar/utils.d.ts +8 -0
- package/dist/cjs/components/calendar/utils.js +19 -0
- package/dist/cjs/components/calendar/utils.js.map +1 -1
- package/dist/cjs/components/callout/CCallout.js.map +1 -1
- package/dist/cjs/components/card/CCard.js.map +1 -1
- package/dist/cjs/components/card/CCardBody.js.map +1 -1
- package/dist/cjs/components/card/CCardFooter.js.map +1 -1
- package/dist/cjs/components/card/CCardGroup.js.map +1 -1
- package/dist/cjs/components/card/CCardHeader.js.map +1 -1
- package/dist/cjs/components/card/CCardImage.js.map +1 -1
- package/dist/cjs/components/card/CCardImageOverlay.js.map +1 -1
- package/dist/cjs/components/card/CCardLink.js.map +1 -1
- package/dist/cjs/components/card/CCardSubtitle.js.map +1 -1
- package/dist/cjs/components/card/CCardText.js.map +1 -1
- package/dist/cjs/components/card/CCardTitle.js.map +1 -1
- package/dist/cjs/components/carousel/CCarousel.js.map +1 -1
- package/dist/cjs/components/carousel/CCarouselCaption.js.map +1 -1
- package/dist/cjs/components/carousel/CCarouselItem.js.map +1 -1
- package/dist/cjs/components/collapse/CCollapse.js.map +1 -1
- package/dist/cjs/components/conditional-teleport/CConditionalTeleport.js.map +1 -1
- package/dist/cjs/components/date-picker/CDatePicker.js.map +1 -1
- package/dist/cjs/components/date-range-picker/CDateRangePicker.js.map +1 -1
- package/dist/cjs/components/date-range-picker/utils.d.ts +16 -0
- package/dist/cjs/components/date-range-picker/utils.js +18 -5
- package/dist/cjs/components/date-range-picker/utils.js.map +1 -1
- package/dist/cjs/components/dropdown/CDropdown.js.map +1 -1
- package/dist/cjs/components/dropdown/CDropdownDivider.js.map +1 -1
- package/dist/cjs/components/dropdown/CDropdownHeader.js.map +1 -1
- package/dist/cjs/components/dropdown/CDropdownItem.js.map +1 -1
- package/dist/cjs/components/dropdown/CDropdownMenu.js.map +1 -1
- package/dist/cjs/components/dropdown/CDropdownToggle.js.map +1 -1
- package/dist/cjs/components/dropdown/utils.js.map +1 -1
- package/dist/cjs/components/element-cover/CElementCover.js.map +1 -1
- package/dist/cjs/components/footer/CFooter.js.map +1 -1
- package/dist/cjs/components/form/CForm.js.map +1 -1
- package/dist/cjs/components/form/CFormCheck.js.map +1 -1
- package/dist/cjs/components/form/CFormControlValidation.js.map +1 -1
- package/dist/cjs/components/form/CFormControlWrapper.d.ts +2 -0
- package/dist/cjs/components/form/CFormControlWrapper.js +9 -1
- package/dist/cjs/components/form/CFormControlWrapper.js.map +1 -1
- package/dist/cjs/components/form/CFormFeedback.js.map +1 -1
- package/dist/cjs/components/form/CFormFloating.js.map +1 -1
- package/dist/cjs/components/form/CFormInput.js.map +1 -1
- package/dist/cjs/components/form/CFormLabel.js.map +1 -1
- package/dist/cjs/components/form/CFormRange.js.map +1 -1
- package/dist/cjs/components/form/CFormSelect.js.map +1 -1
- package/dist/cjs/components/form/CFormSwitch.js.map +1 -1
- package/dist/cjs/components/form/CFormText.js.map +1 -1
- package/dist/cjs/components/form/CFormTextarea.js.map +1 -1
- package/dist/cjs/components/form/CInputGroup.js.map +1 -1
- package/dist/cjs/components/form/CInputGroupText.js.map +1 -1
- package/dist/cjs/components/grid/CCol.js.map +1 -1
- package/dist/cjs/components/grid/CContainer.js.map +1 -1
- package/dist/cjs/components/grid/CRow.js.map +1 -1
- package/dist/cjs/components/header/CHeader.js.map +1 -1
- package/dist/cjs/components/header/CHeaderBrand.js.map +1 -1
- package/dist/cjs/components/header/CHeaderDivider.js.map +1 -1
- package/dist/cjs/components/header/CHeaderNav.js.map +1 -1
- package/dist/cjs/components/header/CHeaderText.js.map +1 -1
- package/dist/cjs/components/header/CHeaderToggler.js.map +1 -1
- package/dist/cjs/components/image/CImage.js.map +1 -1
- package/dist/cjs/components/index.d.ts +2 -0
- package/dist/cjs/components/index.js +44 -36
- package/dist/cjs/components/index.js.map +1 -1
- package/dist/cjs/components/link/CLink.js.map +1 -1
- package/dist/cjs/components/list-group/CListGroup.js.map +1 -1
- package/dist/cjs/components/list-group/CListGroupItem.js.map +1 -1
- package/dist/cjs/components/loading-button/CLoadingButton.d.ts +2 -2
- package/dist/cjs/components/loading-button/CLoadingButton.js.map +1 -1
- package/dist/cjs/components/modal/CModal.js.map +1 -1
- package/dist/cjs/components/modal/CModalBody.js.map +1 -1
- package/dist/cjs/components/modal/CModalFooter.js.map +1 -1
- package/dist/cjs/components/modal/CModalHeader.js.map +1 -1
- package/dist/cjs/components/modal/CModalTitle.js.map +1 -1
- package/dist/cjs/components/multi-select/CMultiSelect.d.ts +12 -0
- package/dist/cjs/components/multi-select/CMultiSelect.js +23 -1
- package/dist/cjs/components/multi-select/CMultiSelect.js.map +1 -1
- package/dist/cjs/components/multi-select/CMultiSelectNativeSelect.js.map +1 -1
- package/dist/cjs/components/multi-select/CMultiSelectOptions.js.map +1 -1
- package/dist/cjs/components/multi-select/CMultiSelectSelection.js.map +1 -1
- package/dist/cjs/components/multi-select/utils.js.map +1 -1
- package/dist/cjs/components/nav/CNav.d.ts +2 -2
- package/dist/cjs/components/nav/CNav.js +3 -2
- package/dist/cjs/components/nav/CNav.js.map +1 -1
- package/dist/cjs/components/nav/CNavGroup.js.map +1 -1
- package/dist/cjs/components/nav/CNavGroupItems.js.map +1 -1
- package/dist/cjs/components/nav/CNavItem.js.map +1 -1
- package/dist/cjs/components/nav/CNavLink.js.map +1 -1
- package/dist/cjs/components/nav/CNavTitle.js.map +1 -1
- package/dist/cjs/components/navbar/CNavbar.js.map +1 -1
- package/dist/cjs/components/navbar/CNavbarBrand.js.map +1 -1
- package/dist/cjs/components/navbar/CNavbarNav.js.map +1 -1
- package/dist/cjs/components/navbar/CNavbarText.js.map +1 -1
- package/dist/cjs/components/navbar/CNavbarToggler.js.map +1 -1
- package/dist/cjs/components/offcanvas/COffcanvas.js.map +1 -1
- package/dist/cjs/components/offcanvas/COffcanvasBody.js.map +1 -1
- package/dist/cjs/components/offcanvas/COffcanvasHeader.js.map +1 -1
- package/dist/cjs/components/offcanvas/COffcanvasTitle.js.map +1 -1
- package/dist/cjs/components/pagination/CPagination.js.map +1 -1
- package/dist/cjs/components/pagination/CPaginationItem.js.map +1 -1
- package/dist/cjs/components/password-input/CPasswordInput.d.ts +190 -0
- package/dist/cjs/components/password-input/CPasswordInput.js +178 -0
- package/dist/cjs/components/password-input/CPasswordInput.js.map +1 -0
- package/dist/cjs/components/password-input/index.d.ts +6 -0
- package/dist/cjs/components/password-input/index.js +13 -0
- package/dist/cjs/components/password-input/index.js.map +1 -0
- package/dist/cjs/components/picker/CPicker.js.map +1 -1
- package/dist/cjs/components/placeholder/CPlaceholder.js.map +1 -1
- package/dist/cjs/components/popover/CPopover.d.ts +1 -1
- package/dist/cjs/components/popover/CPopover.js.map +1 -1
- package/dist/cjs/components/progress/CProgress.js.map +1 -1
- package/dist/cjs/components/progress/CProgressBar.js.map +1 -1
- package/dist/cjs/components/progress/CProgressStacked.js.map +1 -1
- package/dist/cjs/components/props.js.map +1 -1
- package/dist/cjs/components/range-slider/CRangeSlider.js.map +1 -1
- package/dist/cjs/components/range-slider/utils.js.map +1 -1
- package/dist/cjs/components/rating/CRating.d.ts +1 -1
- package/dist/cjs/components/rating/CRating.js.map +1 -1
- package/dist/cjs/components/sidebar/CSidebar.js.map +1 -1
- package/dist/cjs/components/sidebar/CSidebarBrand.js.map +1 -1
- package/dist/cjs/components/sidebar/CSidebarFooter.js.map +1 -1
- package/dist/cjs/components/sidebar/CSidebarHeader.js.map +1 -1
- package/dist/cjs/components/sidebar/CSidebarNav.js.map +1 -1
- package/dist/cjs/components/sidebar/CSidebarToggler.js.map +1 -1
- package/dist/cjs/components/smart-pagination/CSmartPagination.js.map +1 -1
- package/dist/cjs/components/smart-table/CSmartTable.d.ts +2 -1
- package/dist/cjs/components/smart-table/CSmartTable.js +12 -2
- package/dist/cjs/components/smart-table/CSmartTable.js.map +1 -1
- package/dist/cjs/components/smart-table/CSmartTableBody.js.map +1 -1
- package/dist/cjs/components/smart-table/CSmartTableHead.d.ts +2 -0
- package/dist/cjs/components/smart-table/CSmartTableHead.js +8 -1
- package/dist/cjs/components/smart-table/CSmartTableHead.js.map +1 -1
- package/dist/cjs/components/smart-table/utils.js.map +1 -1
- package/dist/cjs/components/spinner/CSpinner.js.map +1 -1
- package/dist/cjs/components/stepper/CStepper.d.ts +168 -0
- package/dist/cjs/components/stepper/CStepper.js +304 -0
- package/dist/cjs/components/stepper/CStepper.js.map +1 -0
- package/dist/cjs/components/stepper/index.d.ts +6 -0
- package/dist/cjs/components/stepper/index.js +13 -0
- package/dist/cjs/components/stepper/index.js.map +1 -0
- package/dist/cjs/components/stepper/types.d.ts +15 -0
- package/dist/cjs/components/table/CTable.js.map +1 -1
- package/dist/cjs/components/table/CTableBody.js.map +1 -1
- package/dist/cjs/components/table/CTableCaption.js.map +1 -1
- package/dist/cjs/components/table/CTableDataCell.js.map +1 -1
- package/dist/cjs/components/table/CTableFoot.js.map +1 -1
- package/dist/cjs/components/table/CTableHead.js.map +1 -1
- package/dist/cjs/components/table/CTableHeaderCell.js.map +1 -1
- package/dist/cjs/components/table/CTableRow.js.map +1 -1
- package/dist/cjs/components/table/utils.js.map +1 -1
- package/dist/cjs/components/tabs/CTab.js.map +1 -1
- package/dist/cjs/components/tabs/CTabContent.js.map +1 -1
- package/dist/cjs/components/tabs/CTabList.d.ts +2 -2
- package/dist/cjs/components/tabs/CTabList.js +3 -2
- package/dist/cjs/components/tabs/CTabList.js.map +1 -1
- package/dist/cjs/components/tabs/CTabPane.js.map +1 -1
- package/dist/cjs/components/tabs/CTabPanel.js.map +1 -1
- package/dist/cjs/components/tabs/CTabs.js.map +1 -1
- package/dist/cjs/components/time-picker/CTimePicker.js.map +1 -1
- package/dist/cjs/components/time-picker/CTimePickerRollCol.js.map +1 -1
- package/dist/cjs/components/time-picker/utils.d.ts +10 -0
- package/dist/cjs/components/time-picker/utils.js +25 -9
- package/dist/cjs/components/time-picker/utils.js.map +1 -1
- package/dist/cjs/components/toast/CToast.js.map +1 -1
- package/dist/cjs/components/toast/CToastBody.js.map +1 -1
- package/dist/cjs/components/toast/CToastClose.js.map +1 -1
- package/dist/cjs/components/toast/CToastHeader.js.map +1 -1
- package/dist/cjs/components/toast/CToaster.js.map +1 -1
- package/dist/cjs/components/tooltip/CTooltip.d.ts +1 -1
- package/dist/cjs/components/tooltip/CTooltip.js.map +1 -1
- package/dist/cjs/components/virtual-scroller/CVirtualScroller.js.map +1 -1
- package/dist/cjs/components/widgets/CWidgetStatsA.js.map +1 -1
- package/dist/cjs/components/widgets/CWidgetStatsB.js +2 -2
- package/dist/cjs/components/widgets/CWidgetStatsB.js.map +1 -1
- package/dist/cjs/components/widgets/CWidgetStatsC.js +2 -2
- package/dist/cjs/components/widgets/CWidgetStatsC.js.map +1 -1
- package/dist/cjs/components/widgets/CWidgetStatsD.js.map +1 -1
- package/dist/cjs/components/widgets/CWidgetStatsE.js.map +1 -1
- package/dist/cjs/components/widgets/CWidgetStatsF.js.map +1 -1
- package/dist/cjs/composables/useDropdownWithPopper.js.map +1 -1
- package/dist/cjs/composables/useIsVisible.js.map +1 -1
- package/dist/cjs/composables/useUniqueId.js.map +1 -1
- package/dist/cjs/directives/v-c-placeholder.js.map +1 -1
- package/dist/cjs/directives/v-c-visible.js.map +1 -1
- package/dist/cjs/index.js +50 -42
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/node_modules/vue-types/dist/index.js +567 -0
- package/dist/cjs/node_modules/vue-types/dist/index.js.map +1 -0
- package/dist/cjs/node_modules/vue-types/dist/shared/vue-types.8139b772.js +29 -0
- package/dist/cjs/node_modules/vue-types/dist/shared/vue-types.8139b772.js.map +1 -0
- package/dist/cjs/props.js.map +1 -1
- package/dist/cjs/utils/getNextActiveElement.js.map +1 -1
- package/dist/cjs/utils/isObjectInArray.js.map +1 -1
- package/dist/cjs/utils/transition.js.map +1 -1
- package/dist/esm/components/accordion/CAccordion.js.map +1 -1
- package/dist/esm/components/accordion/CAccordionBody.js.map +1 -1
- package/dist/esm/components/accordion/CAccordionButton.js.map +1 -1
- package/dist/esm/components/accordion/CAccordionHeader.js.map +1 -1
- package/dist/esm/components/accordion/CAccordionItem.js.map +1 -1
- package/dist/esm/components/alert/CAlert.js.map +1 -1
- package/dist/esm/components/avatar/CAvatar.js +1 -1
- package/dist/esm/components/avatar/CAvatar.js.map +1 -1
- package/dist/esm/components/backdrop/CBackdrop.js.map +1 -1
- package/dist/esm/components/badge/CBadge.js +1 -1
- package/dist/esm/components/badge/CBadge.js.map +1 -1
- package/dist/esm/components/breadcrumb/CBreadcrumb.js.map +1 -1
- package/dist/esm/components/breadcrumb/CBreadcrumbItem.js.map +1 -1
- package/dist/esm/components/button/CButton.js +2 -2
- package/dist/esm/components/button/CButton.js.map +1 -1
- package/dist/esm/components/button-group/CButtonGroup.js.map +1 -1
- package/dist/esm/components/button-group/CButtonToolbar.js.map +1 -1
- package/dist/esm/components/calendar/CCalendar.js +5 -4
- package/dist/esm/components/calendar/CCalendar.js.map +1 -1
- package/dist/esm/components/calendar/utils.d.ts +8 -0
- package/dist/esm/components/calendar/utils.js +19 -1
- package/dist/esm/components/calendar/utils.js.map +1 -1
- package/dist/esm/components/callout/CCallout.js.map +1 -1
- package/dist/esm/components/card/CCard.js +1 -1
- package/dist/esm/components/card/CCard.js.map +1 -1
- package/dist/esm/components/card/CCardBody.js.map +1 -1
- package/dist/esm/components/card/CCardFooter.js.map +1 -1
- package/dist/esm/components/card/CCardGroup.js.map +1 -1
- package/dist/esm/components/card/CCardHeader.js.map +1 -1
- package/dist/esm/components/card/CCardImage.js.map +1 -1
- package/dist/esm/components/card/CCardImageOverlay.js.map +1 -1
- package/dist/esm/components/card/CCardLink.js.map +1 -1
- package/dist/esm/components/card/CCardSubtitle.js.map +1 -1
- package/dist/esm/components/card/CCardText.js.map +1 -1
- package/dist/esm/components/card/CCardTitle.js.map +1 -1
- package/dist/esm/components/carousel/CCarousel.js.map +1 -1
- package/dist/esm/components/carousel/CCarouselCaption.js.map +1 -1
- package/dist/esm/components/carousel/CCarouselItem.js.map +1 -1
- package/dist/esm/components/collapse/CCollapse.js.map +1 -1
- package/dist/esm/components/conditional-teleport/CConditionalTeleport.js.map +1 -1
- package/dist/esm/components/date-picker/CDatePicker.js.map +1 -1
- package/dist/esm/components/date-range-picker/CDateRangePicker.js.map +1 -1
- package/dist/esm/components/date-range-picker/utils.d.ts +16 -0
- package/dist/esm/components/date-range-picker/utils.js +18 -5
- package/dist/esm/components/date-range-picker/utils.js.map +1 -1
- package/dist/esm/components/dropdown/CDropdown.js.map +1 -1
- package/dist/esm/components/dropdown/CDropdownDivider.js.map +1 -1
- package/dist/esm/components/dropdown/CDropdownHeader.js.map +1 -1
- package/dist/esm/components/dropdown/CDropdownItem.js.map +1 -1
- package/dist/esm/components/dropdown/CDropdownMenu.js.map +1 -1
- package/dist/esm/components/dropdown/CDropdownToggle.js +2 -2
- package/dist/esm/components/dropdown/CDropdownToggle.js.map +1 -1
- package/dist/esm/components/dropdown/utils.js.map +1 -1
- package/dist/esm/components/element-cover/CElementCover.js.map +1 -1
- package/dist/esm/components/footer/CFooter.js.map +1 -1
- package/dist/esm/components/form/CForm.js.map +1 -1
- package/dist/esm/components/form/CFormCheck.js.map +1 -1
- package/dist/esm/components/form/CFormControlValidation.js.map +1 -1
- package/dist/esm/components/form/CFormControlWrapper.d.ts +2 -0
- package/dist/esm/components/form/CFormControlWrapper.js +9 -1
- package/dist/esm/components/form/CFormControlWrapper.js.map +1 -1
- package/dist/esm/components/form/CFormFeedback.js.map +1 -1
- package/dist/esm/components/form/CFormFloating.js.map +1 -1
- package/dist/esm/components/form/CFormInput.js.map +1 -1
- package/dist/esm/components/form/CFormLabel.js.map +1 -1
- package/dist/esm/components/form/CFormRange.js.map +1 -1
- package/dist/esm/components/form/CFormSelect.js.map +1 -1
- package/dist/esm/components/form/CFormSwitch.js.map +1 -1
- package/dist/esm/components/form/CFormText.js.map +1 -1
- package/dist/esm/components/form/CFormTextarea.js.map +1 -1
- package/dist/esm/components/form/CInputGroup.js.map +1 -1
- package/dist/esm/components/form/CInputGroupText.js.map +1 -1
- package/dist/esm/components/grid/CCol.js.map +1 -1
- package/dist/esm/components/grid/CContainer.js.map +1 -1
- package/dist/esm/components/grid/CRow.js.map +1 -1
- package/dist/esm/components/header/CHeader.js.map +1 -1
- package/dist/esm/components/header/CHeaderBrand.js.map +1 -1
- package/dist/esm/components/header/CHeaderDivider.js.map +1 -1
- package/dist/esm/components/header/CHeaderNav.js.map +1 -1
- package/dist/esm/components/header/CHeaderText.js.map +1 -1
- package/dist/esm/components/header/CHeaderToggler.js.map +1 -1
- package/dist/esm/components/image/CImage.js.map +1 -1
- package/dist/esm/components/index.d.ts +2 -0
- package/dist/esm/components/index.js +4 -0
- package/dist/esm/components/index.js.map +1 -1
- package/dist/esm/components/link/CLink.js.map +1 -1
- package/dist/esm/components/list-group/CListGroup.js.map +1 -1
- package/dist/esm/components/list-group/CListGroupItem.js.map +1 -1
- package/dist/esm/components/loading-button/CLoadingButton.d.ts +2 -2
- package/dist/esm/components/loading-button/CLoadingButton.js.map +1 -1
- package/dist/esm/components/modal/CModal.js.map +1 -1
- package/dist/esm/components/modal/CModalBody.js.map +1 -1
- package/dist/esm/components/modal/CModalFooter.js.map +1 -1
- package/dist/esm/components/modal/CModalHeader.js.map +1 -1
- package/dist/esm/components/modal/CModalTitle.js.map +1 -1
- package/dist/esm/components/multi-select/CMultiSelect.d.ts +12 -0
- package/dist/esm/components/multi-select/CMultiSelect.js +24 -2
- package/dist/esm/components/multi-select/CMultiSelect.js.map +1 -1
- package/dist/esm/components/multi-select/CMultiSelectNativeSelect.js.map +1 -1
- package/dist/esm/components/multi-select/CMultiSelectOptions.js.map +1 -1
- package/dist/esm/components/multi-select/CMultiSelectSelection.js.map +1 -1
- package/dist/esm/components/multi-select/utils.js.map +1 -1
- package/dist/esm/components/nav/CNav.d.ts +2 -2
- package/dist/esm/components/nav/CNav.js +3 -2
- package/dist/esm/components/nav/CNav.js.map +1 -1
- package/dist/esm/components/nav/CNavGroup.js.map +1 -1
- package/dist/esm/components/nav/CNavGroupItems.js.map +1 -1
- package/dist/esm/components/nav/CNavItem.js.map +1 -1
- package/dist/esm/components/nav/CNavLink.js.map +1 -1
- package/dist/esm/components/nav/CNavTitle.js.map +1 -1
- package/dist/esm/components/navbar/CNavbar.js.map +1 -1
- package/dist/esm/components/navbar/CNavbarBrand.js.map +1 -1
- package/dist/esm/components/navbar/CNavbarNav.js.map +1 -1
- package/dist/esm/components/navbar/CNavbarText.js.map +1 -1
- package/dist/esm/components/navbar/CNavbarToggler.js.map +1 -1
- package/dist/esm/components/offcanvas/COffcanvas.js.map +1 -1
- package/dist/esm/components/offcanvas/COffcanvasBody.js.map +1 -1
- package/dist/esm/components/offcanvas/COffcanvasHeader.js.map +1 -1
- package/dist/esm/components/offcanvas/COffcanvasTitle.js.map +1 -1
- package/dist/esm/components/pagination/CPagination.js.map +1 -1
- package/dist/esm/components/pagination/CPaginationItem.js.map +1 -1
- package/dist/esm/components/password-input/CPasswordInput.d.ts +190 -0
- package/dist/esm/components/password-input/CPasswordInput.js +176 -0
- package/dist/esm/components/password-input/CPasswordInput.js.map +1 -0
- package/dist/esm/components/password-input/index.d.ts +6 -0
- package/dist/esm/components/password-input/index.js +10 -0
- package/dist/esm/components/password-input/index.js.map +1 -0
- package/dist/esm/components/picker/CPicker.js.map +1 -1
- package/dist/esm/components/placeholder/CPlaceholder.js.map +1 -1
- package/dist/esm/components/popover/CPopover.d.ts +1 -1
- package/dist/esm/components/popover/CPopover.js.map +1 -1
- package/dist/esm/components/progress/CProgress.js.map +1 -1
- package/dist/esm/components/progress/CProgressBar.js.map +1 -1
- package/dist/esm/components/progress/CProgressStacked.js.map +1 -1
- package/dist/esm/components/props.js.map +1 -1
- package/dist/esm/components/range-slider/CRangeSlider.js.map +1 -1
- package/dist/esm/components/range-slider/utils.js.map +1 -1
- package/dist/esm/components/rating/CRating.d.ts +1 -1
- package/dist/esm/components/rating/CRating.js.map +1 -1
- package/dist/esm/components/sidebar/CSidebar.js.map +1 -1
- package/dist/esm/components/sidebar/CSidebarBrand.js.map +1 -1
- package/dist/esm/components/sidebar/CSidebarFooter.js.map +1 -1
- package/dist/esm/components/sidebar/CSidebarHeader.js.map +1 -1
- package/dist/esm/components/sidebar/CSidebarNav.js.map +1 -1
- package/dist/esm/components/sidebar/CSidebarToggler.js.map +1 -1
- package/dist/esm/components/smart-pagination/CSmartPagination.js.map +1 -1
- package/dist/esm/components/smart-table/CSmartTable.d.ts +2 -1
- package/dist/esm/components/smart-table/CSmartTable.js +12 -2
- package/dist/esm/components/smart-table/CSmartTable.js.map +1 -1
- package/dist/esm/components/smart-table/CSmartTableBody.js +1 -1
- package/dist/esm/components/smart-table/CSmartTableBody.js.map +1 -1
- package/dist/esm/components/smart-table/CSmartTableHead.d.ts +2 -0
- package/dist/esm/components/smart-table/CSmartTableHead.js +8 -1
- package/dist/esm/components/smart-table/CSmartTableHead.js.map +1 -1
- package/dist/esm/components/smart-table/utils.js.map +1 -1
- package/dist/esm/components/spinner/CSpinner.js.map +1 -1
- package/dist/esm/components/stepper/CStepper.d.ts +168 -0
- package/dist/esm/components/stepper/CStepper.js +302 -0
- package/dist/esm/components/stepper/CStepper.js.map +1 -0
- package/dist/esm/components/stepper/index.d.ts +6 -0
- package/dist/esm/components/stepper/index.js +10 -0
- package/dist/esm/components/stepper/index.js.map +1 -0
- package/dist/esm/components/stepper/types.d.ts +15 -0
- package/dist/esm/components/table/CTable.js.map +1 -1
- package/dist/esm/components/table/CTableBody.js.map +1 -1
- package/dist/esm/components/table/CTableCaption.js.map +1 -1
- package/dist/esm/components/table/CTableDataCell.js.map +1 -1
- package/dist/esm/components/table/CTableFoot.js.map +1 -1
- package/dist/esm/components/table/CTableHead.js.map +1 -1
- package/dist/esm/components/table/CTableHeaderCell.js.map +1 -1
- package/dist/esm/components/table/CTableRow.js.map +1 -1
- package/dist/esm/components/table/utils.js.map +1 -1
- package/dist/esm/components/tabs/CTab.js.map +1 -1
- package/dist/esm/components/tabs/CTabContent.js.map +1 -1
- package/dist/esm/components/tabs/CTabList.d.ts +2 -2
- package/dist/esm/components/tabs/CTabList.js +3 -2
- package/dist/esm/components/tabs/CTabList.js.map +1 -1
- package/dist/esm/components/tabs/CTabPane.js.map +1 -1
- package/dist/esm/components/tabs/CTabPanel.js.map +1 -1
- package/dist/esm/components/tabs/CTabs.js.map +1 -1
- package/dist/esm/components/time-picker/CTimePicker.js.map +1 -1
- package/dist/esm/components/time-picker/CTimePickerRollCol.js.map +1 -1
- package/dist/esm/components/time-picker/utils.d.ts +10 -0
- package/dist/esm/components/time-picker/utils.js +25 -10
- package/dist/esm/components/time-picker/utils.js.map +1 -1
- package/dist/esm/components/toast/CToast.js.map +1 -1
- package/dist/esm/components/toast/CToastBody.js.map +1 -1
- package/dist/esm/components/toast/CToastClose.js.map +1 -1
- package/dist/esm/components/toast/CToastHeader.js.map +1 -1
- package/dist/esm/components/toast/CToaster.js.map +1 -1
- package/dist/esm/components/tooltip/CTooltip.d.ts +1 -1
- package/dist/esm/components/tooltip/CTooltip.js.map +1 -1
- package/dist/esm/components/virtual-scroller/CVirtualScroller.js.map +1 -1
- package/dist/esm/components/widgets/CWidgetStatsA.js.map +1 -1
- package/dist/esm/components/widgets/CWidgetStatsB.js +2 -2
- package/dist/esm/components/widgets/CWidgetStatsB.js.map +1 -1
- package/dist/esm/components/widgets/CWidgetStatsC.js +2 -2
- package/dist/esm/components/widgets/CWidgetStatsC.js.map +1 -1
- package/dist/esm/components/widgets/CWidgetStatsD.js.map +1 -1
- package/dist/esm/components/widgets/CWidgetStatsE.js.map +1 -1
- package/dist/esm/components/widgets/CWidgetStatsF.js.map +1 -1
- package/dist/esm/composables/useDropdownWithPopper.js.map +1 -1
- package/dist/esm/composables/useIsVisible.js.map +1 -1
- package/dist/esm/composables/useUniqueId.js.map +1 -1
- package/dist/esm/directives/v-c-placeholder.js.map +1 -1
- package/dist/esm/directives/v-c-visible.js.map +1 -1
- package/dist/esm/index.js +4 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/node_modules/vue-types/dist/index.js +541 -0
- package/dist/esm/node_modules/vue-types/dist/index.js.map +1 -0
- package/dist/esm/node_modules/vue-types/dist/shared/vue-types.8139b772.js +25 -0
- package/dist/esm/node_modules/vue-types/dist/shared/vue-types.8139b772.js.map +1 -0
- package/dist/esm/props.js.map +1 -1
- package/dist/esm/utils/getNextActiveElement.js.map +1 -1
- package/dist/esm/utils/isObjectInArray.js.map +1 -1
- package/dist/esm/utils/transition.js.map +1 -1
- package/package.json +10 -10
- package/src/components/button/CButton.ts +1 -1
- package/src/components/calendar/CCalendar.ts +47 -44
- package/src/components/calendar/utils.ts +37 -10
- package/src/components/date-range-picker/utils.ts +26 -10
- package/src/components/form/CFormControlWrapper.ts +35 -21
- package/src/components/index.ts +2 -0
- package/src/components/multi-select/CMultiSelect.ts +48 -25
- package/src/components/nav/CNav.ts +3 -2
- package/src/components/password-input/CPasswordInput.ts +214 -0
- package/src/components/password-input/index.ts +10 -0
- package/src/components/smart-table/CSmartTable.ts +61 -50
- package/src/components/smart-table/CSmartTableHead.ts +24 -17
- package/src/components/stepper/CStepper.ts +382 -0
- package/src/components/stepper/__tests__/CStepper.spec.ts +175 -0
- package/src/components/stepper/index.ts +10 -0
- package/src/components/stepper/types.ts +18 -0
- package/src/components/tabs/CTabList.ts +3 -2
- package/src/components/time-picker/CTimePicker.ts +22 -22
- package/src/components/time-picker/CTimePickerRollCol.ts +3 -3
- package/src/components/time-picker/utils.ts +30 -13
- package/dist/cjs/components/Types.d.ts +0 -5
- package/dist/cjs/components/collapse/__test__/CCollapse.spec.d.ts +0 -1
- package/dist/cjs/components/smart-table/CSmartTableCleaner.d.ts +0 -20
- package/dist/cjs/components/smart-table/CSmartTableInterface.d.ts +0 -58
- package/dist/cjs/node_modules/is-plain-object/dist/is-plain-object.js +0 -37
- package/dist/cjs/node_modules/is-plain-object/dist/is-plain-object.js.map +0 -1
- package/dist/cjs/node_modules/vue-types/dist/vue-types.modern.js +0 -33
- package/dist/cjs/node_modules/vue-types/dist/vue-types.modern.js.map +0 -1
- package/dist/esm/components/Types.d.ts +0 -5
- package/dist/esm/components/collapse/__test__/CCollapse.spec.d.ts +0 -1
- package/dist/esm/components/smart-table/CSmartTableCleaner.d.ts +0 -20
- package/dist/esm/components/smart-table/CSmartTableInterface.d.ts +0 -58
- package/dist/esm/node_modules/is-plain-object/dist/is-plain-object.js +0 -35
- package/dist/esm/node_modules/is-plain-object/dist/is-plain-object.js.map +0 -1
- package/dist/esm/node_modules/vue-types/dist/vue-types.modern.js +0 -6
- package/dist/esm/node_modules/vue-types/dist/vue-types.modern.js.map +0 -1
|
@@ -0,0 +1,382 @@
|
|
|
1
|
+
import { defineComponent, h, ref, watch, computed, nextTick, shallowRef } from 'vue'
|
|
2
|
+
import { CCollapse } from '../collapse'
|
|
3
|
+
import type { StepperStepData } from './types'
|
|
4
|
+
|
|
5
|
+
export const CStepper = defineComponent({
|
|
6
|
+
name: 'CStepper',
|
|
7
|
+
inheritAttrs: false,
|
|
8
|
+
props: {
|
|
9
|
+
/**
|
|
10
|
+
* The default active step index when not using `v-model`.
|
|
11
|
+
*/
|
|
12
|
+
activeStepNumber: {
|
|
13
|
+
type: Number,
|
|
14
|
+
default: 1,
|
|
15
|
+
},
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Optional unique ID used for accessibility attributes like `aria-labelledby`.
|
|
19
|
+
*/
|
|
20
|
+
id: String,
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Sets the layout direction of the Vue Stepper component.
|
|
24
|
+
*
|
|
25
|
+
* - `'horizontal'` – Steps are placed side-by-side.
|
|
26
|
+
* - `'vertical'` – Steps are stacked vertically (ideal for mobile).
|
|
27
|
+
*
|
|
28
|
+
* This makes the Vue Form Wizard adaptable to various screen sizes.
|
|
29
|
+
*/
|
|
30
|
+
layout: {
|
|
31
|
+
type: String as () => 'horizontal' | 'vertical',
|
|
32
|
+
default: 'horizontal',
|
|
33
|
+
},
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Enables linear step progression in the Vue Form Wizard.
|
|
37
|
+
*
|
|
38
|
+
* - `true`: Steps must be completed in order.
|
|
39
|
+
* - `false`: Users can navigate freely between steps.
|
|
40
|
+
*
|
|
41
|
+
* Useful for enforcing validation and structured data entry in Vue multi-step forms.
|
|
42
|
+
*/
|
|
43
|
+
linear: {
|
|
44
|
+
type: Boolean,
|
|
45
|
+
default: true,
|
|
46
|
+
},
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* The current active step index of the Vue Stepper (used for controlled mode with `v-model`).
|
|
50
|
+
*
|
|
51
|
+
* If this prop is not provided, the Vue Form Wizard will use `activeStepNumber` as its initial value.
|
|
52
|
+
*/
|
|
53
|
+
modelValue: Number,
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Defines the list of steps in the Vue Stepper.
|
|
57
|
+
*
|
|
58
|
+
* Each step should include:
|
|
59
|
+
* - `label`: The title displayed in the step.
|
|
60
|
+
* - `indicator` (optional): Custom icon, number, or marker.
|
|
61
|
+
* - `formRef` (optional): A reference to the `<form>` used for validation in Vue Form Wizard scenarios.
|
|
62
|
+
*/
|
|
63
|
+
steps: {
|
|
64
|
+
type: Array as () => (StepperStepData | string)[],
|
|
65
|
+
required: true,
|
|
66
|
+
},
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* Controls the layout of the step indicator and label.
|
|
70
|
+
*
|
|
71
|
+
* - `'horizontal'`: Icon and label are side-by-side.
|
|
72
|
+
* - `'vertical'`: Label is shown below the icon.
|
|
73
|
+
*
|
|
74
|
+
* Applies only when `layout` is set to `'horizontal'`.
|
|
75
|
+
*/
|
|
76
|
+
stepButtonLayout: {
|
|
77
|
+
type: String as () => 'horizontal' | 'vertical',
|
|
78
|
+
default: 'horizontal',
|
|
79
|
+
},
|
|
80
|
+
|
|
81
|
+
/**
|
|
82
|
+
* Enables validation of forms within each step of the Vue Form Wizard.
|
|
83
|
+
*
|
|
84
|
+
* When set to `true`, the user cannot proceed unless the current step's form passes `checkValidity()`.
|
|
85
|
+
* Each step must expose a native form element via the `formRef` slot binding.
|
|
86
|
+
*/
|
|
87
|
+
validation: {
|
|
88
|
+
type: Boolean,
|
|
89
|
+
default: true,
|
|
90
|
+
},
|
|
91
|
+
},
|
|
92
|
+
emits: [
|
|
93
|
+
/**
|
|
94
|
+
* Emitted when the user successfully finishes all steps in the Vue Form Wizard.
|
|
95
|
+
*/
|
|
96
|
+
'finish',
|
|
97
|
+
|
|
98
|
+
/**
|
|
99
|
+
* Emitted when the stepper is reset to its initial state.
|
|
100
|
+
*/
|
|
101
|
+
'reset',
|
|
102
|
+
|
|
103
|
+
/**
|
|
104
|
+
* Emitted on any manual or programmatic step change.
|
|
105
|
+
*/
|
|
106
|
+
'stepChange',
|
|
107
|
+
|
|
108
|
+
/**
|
|
109
|
+
* Emitted after each step's form is validated (when `validation: true`).
|
|
110
|
+
*/
|
|
111
|
+
'stepValidationComplete',
|
|
112
|
+
|
|
113
|
+
/**
|
|
114
|
+
* Emitted when the current active step changes.
|
|
115
|
+
*
|
|
116
|
+
* Useful for syncing state with `v-model`.
|
|
117
|
+
*/
|
|
118
|
+
'update:modelValue',
|
|
119
|
+
],
|
|
120
|
+
setup(props, { emit, slots, attrs, expose }) {
|
|
121
|
+
const activeStepNumber = ref<number>(props.modelValue ?? props.activeStepNumber)
|
|
122
|
+
const isControlled = computed(() => props.modelValue !== undefined)
|
|
123
|
+
const isFinished = ref(false)
|
|
124
|
+
const stepsRef = ref<HTMLOListElement | null>(null)
|
|
125
|
+
const stepButtonRefs = shallowRef<(HTMLButtonElement | null)[]>([])
|
|
126
|
+
const formRefs = shallowRef<(HTMLFormElement | null)[]>([])
|
|
127
|
+
|
|
128
|
+
const registerFormRef = (stepNumber: number) => (el: HTMLFormElement | null) => {
|
|
129
|
+
formRefs.value[stepNumber - 1] = el
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
watch(
|
|
133
|
+
() => props.modelValue,
|
|
134
|
+
(val) => {
|
|
135
|
+
if (val !== undefined) activeStepNumber.value = val
|
|
136
|
+
}
|
|
137
|
+
)
|
|
138
|
+
|
|
139
|
+
watch(activeStepNumber, (val) => {
|
|
140
|
+
if (isControlled.value) emit('update:modelValue', val)
|
|
141
|
+
})
|
|
142
|
+
|
|
143
|
+
const isStepValid = (stepNumber: number): boolean => {
|
|
144
|
+
if (!props.validation) {
|
|
145
|
+
return true
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
const form = formRefs.value[stepNumber - 1]
|
|
149
|
+
|
|
150
|
+
if (form) {
|
|
151
|
+
const isValid = form.checkValidity()
|
|
152
|
+
emit('stepValidationComplete', { stepNumber: stepNumber, isValid: isValid })
|
|
153
|
+
|
|
154
|
+
if (form && !isValid) {
|
|
155
|
+
if (!form.noValidate) {
|
|
156
|
+
form.reportValidity()
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
return false
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
return true
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
const setActiveStep = (stepNumber: number, bypassValidation = false) => {
|
|
167
|
+
if (
|
|
168
|
+
stepNumber < 1 ||
|
|
169
|
+
stepNumber > props.steps.length ||
|
|
170
|
+
stepNumber === activeStepNumber.value
|
|
171
|
+
) {
|
|
172
|
+
return
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
if (
|
|
176
|
+
!bypassValidation &&
|
|
177
|
+
stepNumber > activeStepNumber.value &&
|
|
178
|
+
!isStepValid(activeStepNumber.value)
|
|
179
|
+
)
|
|
180
|
+
return
|
|
181
|
+
|
|
182
|
+
activeStepNumber.value = stepNumber
|
|
183
|
+
emit('stepChange', stepNumber)
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
const next = () => {
|
|
187
|
+
if (activeStepNumber.value <= props.steps.length) {
|
|
188
|
+
setActiveStep(activeStepNumber.value + 1)
|
|
189
|
+
} else {
|
|
190
|
+
finish()
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
const prev = () => {
|
|
195
|
+
if (activeStepNumber.value > 1) {
|
|
196
|
+
setActiveStep(activeStepNumber.value - 1, true)
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
const finish = () => {
|
|
201
|
+
if (activeStepNumber.value === props.steps.length && isStepValid(activeStepNumber.value)) {
|
|
202
|
+
isFinished.value = true
|
|
203
|
+
emit('finish')
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
const reset = () => {
|
|
208
|
+
formRefs.value.forEach((form) => form?.reset?.())
|
|
209
|
+
activeStepNumber.value = props.activeStepNumber
|
|
210
|
+
isFinished.value = false
|
|
211
|
+
emit('reset')
|
|
212
|
+
emit('stepChange', props.activeStepNumber)
|
|
213
|
+
nextTick(() => {
|
|
214
|
+
stepButtonRefs.value[props.activeStepNumber - 1]?.focus()
|
|
215
|
+
})
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
const handleKeyDown = (event: KeyboardEvent) => {
|
|
219
|
+
const buttons = stepButtonRefs.value
|
|
220
|
+
const current = event.target as HTMLButtonElement
|
|
221
|
+
const index = buttons.indexOf(current)
|
|
222
|
+
if (index === -1) return
|
|
223
|
+
|
|
224
|
+
let nextIndex = index
|
|
225
|
+
switch (event.key) {
|
|
226
|
+
case 'ArrowRight':
|
|
227
|
+
case 'ArrowDown': {
|
|
228
|
+
nextIndex = (index + 1) % buttons.length
|
|
229
|
+
break
|
|
230
|
+
}
|
|
231
|
+
case 'ArrowLeft':
|
|
232
|
+
case 'ArrowUp': {
|
|
233
|
+
nextIndex = (index - 1 + buttons.length) % buttons.length
|
|
234
|
+
break
|
|
235
|
+
}
|
|
236
|
+
case 'Home': {
|
|
237
|
+
nextIndex = 0
|
|
238
|
+
break
|
|
239
|
+
}
|
|
240
|
+
case 'End': {
|
|
241
|
+
nextIndex = buttons.length - 1
|
|
242
|
+
break
|
|
243
|
+
}
|
|
244
|
+
default: {
|
|
245
|
+
return
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
event.preventDefault()
|
|
250
|
+
buttons[nextIndex]?.focus()
|
|
251
|
+
}
|
|
252
|
+
|
|
253
|
+
expose({ next, prev, finish, reset })
|
|
254
|
+
|
|
255
|
+
return () => {
|
|
256
|
+
const isVertical = props.layout === 'vertical'
|
|
257
|
+
stepButtonRefs.value = []
|
|
258
|
+
|
|
259
|
+
return h(
|
|
260
|
+
'div',
|
|
261
|
+
{
|
|
262
|
+
...attrs,
|
|
263
|
+
class: ['stepper', { 'stepper-vertical': isVertical }, attrs.class],
|
|
264
|
+
},
|
|
265
|
+
[
|
|
266
|
+
h(
|
|
267
|
+
'ol',
|
|
268
|
+
{
|
|
269
|
+
class: 'stepper-steps',
|
|
270
|
+
role: 'tablist',
|
|
271
|
+
'aria-orientation': isVertical ? 'vertical' : 'horizontal',
|
|
272
|
+
onKeydown: handleKeyDown,
|
|
273
|
+
ref: stepsRef,
|
|
274
|
+
},
|
|
275
|
+
props.steps.map((step, index) => {
|
|
276
|
+
const stepNumber = index + 1
|
|
277
|
+
|
|
278
|
+
const isActive = !isFinished.value && stepNumber === activeStepNumber.value
|
|
279
|
+
const isComplete = isFinished.value || stepNumber < activeStepNumber.value
|
|
280
|
+
const isDisabled =
|
|
281
|
+
isFinished.value || (props.linear && stepNumber > activeStepNumber.value + 1)
|
|
282
|
+
const stepId = `step-${props.id || 'stepper'}-${stepNumber}`
|
|
283
|
+
const panelId = `panel-${props.id || 'stepper'}-${stepNumber}`
|
|
284
|
+
|
|
285
|
+
return h(
|
|
286
|
+
'li',
|
|
287
|
+
{
|
|
288
|
+
key: stepNumber,
|
|
289
|
+
class: ['stepper-step', props.stepButtonLayout],
|
|
290
|
+
role: 'presentation',
|
|
291
|
+
},
|
|
292
|
+
[
|
|
293
|
+
h(
|
|
294
|
+
'button',
|
|
295
|
+
{
|
|
296
|
+
type: 'button',
|
|
297
|
+
class: ['stepper-step-button', { active: isActive, complete: isComplete }],
|
|
298
|
+
disabled: isDisabled,
|
|
299
|
+
id: stepId,
|
|
300
|
+
role: 'tab',
|
|
301
|
+
'aria-selected': isActive,
|
|
302
|
+
tabindex: isActive ? 0 : -1,
|
|
303
|
+
'aria-controls': panelId,
|
|
304
|
+
onClick: () =>
|
|
305
|
+
setActiveStep(
|
|
306
|
+
stepNumber,
|
|
307
|
+
!props.linear || stepNumber <= activeStepNumber.value
|
|
308
|
+
),
|
|
309
|
+
ref: (el) => (stepButtonRefs.value[index] = el as HTMLButtonElement),
|
|
310
|
+
},
|
|
311
|
+
[
|
|
312
|
+
h('span', { class: 'stepper-step-indicator' }, [
|
|
313
|
+
isComplete
|
|
314
|
+
? h('span', { class: 'stepper-step-indicator-icon' })
|
|
315
|
+
: h(
|
|
316
|
+
'span',
|
|
317
|
+
{ class: 'stepper-step-indicator-text' },
|
|
318
|
+
typeof step === 'object' && 'indicator' in step
|
|
319
|
+
? step.indicator
|
|
320
|
+
: stepNumber
|
|
321
|
+
),
|
|
322
|
+
]),
|
|
323
|
+
h(
|
|
324
|
+
'span',
|
|
325
|
+
{ class: 'stepper-step-label' },
|
|
326
|
+
typeof step === 'object' && 'label' in step ? step.label : step
|
|
327
|
+
),
|
|
328
|
+
]
|
|
329
|
+
),
|
|
330
|
+
stepNumber < props.steps.length && h('div', { class: 'stepper-step-connector' }),
|
|
331
|
+
isVertical &&
|
|
332
|
+
h(
|
|
333
|
+
CCollapse,
|
|
334
|
+
{
|
|
335
|
+
class: 'stepper-step-content',
|
|
336
|
+
id: panelId,
|
|
337
|
+
role: 'tabpanel',
|
|
338
|
+
visible: isActive,
|
|
339
|
+
'aria-hidden': !isActive,
|
|
340
|
+
'aria-labelledby': stepId,
|
|
341
|
+
'aria-live': 'polite',
|
|
342
|
+
},
|
|
343
|
+
() => slots[`step-${stepNumber}`]?.({ formRef: registerFormRef(stepNumber) })
|
|
344
|
+
),
|
|
345
|
+
]
|
|
346
|
+
)
|
|
347
|
+
})
|
|
348
|
+
),
|
|
349
|
+
!isVertical &&
|
|
350
|
+
h(
|
|
351
|
+
'div',
|
|
352
|
+
{ class: 'stepper-content' },
|
|
353
|
+
props.steps.map((_, index) => {
|
|
354
|
+
const stepNumber = index + 1
|
|
355
|
+
|
|
356
|
+
const isActive = !isFinished.value && stepNumber === activeStepNumber.value
|
|
357
|
+
const stepId = `step-${props.id || 'stepper'}-${stepNumber}`
|
|
358
|
+
const panelId = `panel-${props.id || 'stepper'}-${stepNumber}`
|
|
359
|
+
|
|
360
|
+
return h(
|
|
361
|
+
'div',
|
|
362
|
+
{
|
|
363
|
+
key: stepNumber,
|
|
364
|
+
id: panelId,
|
|
365
|
+
role: 'tabpanel',
|
|
366
|
+
'aria-hidden': !isActive,
|
|
367
|
+
'aria-labelledby': stepId,
|
|
368
|
+
'aria-live': 'polite',
|
|
369
|
+
class: ['stepper-pane', { active: isActive, show: isActive }],
|
|
370
|
+
},
|
|
371
|
+
{
|
|
372
|
+
default: () =>
|
|
373
|
+
slots[`step-${stepNumber}`]?.({ formRef: registerFormRef(stepNumber) }),
|
|
374
|
+
}
|
|
375
|
+
)
|
|
376
|
+
})
|
|
377
|
+
),
|
|
378
|
+
]
|
|
379
|
+
)
|
|
380
|
+
}
|
|
381
|
+
},
|
|
382
|
+
})
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
import { mount } from '@vue/test-utils'
|
|
2
|
+
import { CStepper as Component } from '../../../index'
|
|
3
|
+
|
|
4
|
+
const ComponentName = 'CStepper'
|
|
5
|
+
|
|
6
|
+
const stepsMock = [
|
|
7
|
+
{ label: 'Step 1', content: 'Content 1' },
|
|
8
|
+
{ label: 'Step 2', content: 'Content 2' },
|
|
9
|
+
{ label: 'Step 3', content: 'Content 3' },
|
|
10
|
+
]
|
|
11
|
+
|
|
12
|
+
const defaultWrapper = mount(Component, {
|
|
13
|
+
propsData: {
|
|
14
|
+
steps: stepsMock,
|
|
15
|
+
},
|
|
16
|
+
})
|
|
17
|
+
|
|
18
|
+
const verticalWrapper = mount(Component, {
|
|
19
|
+
propsData: {
|
|
20
|
+
steps: stepsMock,
|
|
21
|
+
layout: 'vertical',
|
|
22
|
+
},
|
|
23
|
+
})
|
|
24
|
+
|
|
25
|
+
const linearWrapper = mount(Component, {
|
|
26
|
+
propsData: {
|
|
27
|
+
steps: stepsMock,
|
|
28
|
+
linear: true,
|
|
29
|
+
},
|
|
30
|
+
})
|
|
31
|
+
|
|
32
|
+
describe(`Loads and display ${ComponentName} component`, () => {
|
|
33
|
+
it('has a name', () => {
|
|
34
|
+
expect(Component.name).toMatch(ComponentName)
|
|
35
|
+
})
|
|
36
|
+
|
|
37
|
+
it('renders correctly', () => {
|
|
38
|
+
expect(defaultWrapper.html()).toMatchSnapshot()
|
|
39
|
+
})
|
|
40
|
+
|
|
41
|
+
it('contains step labels and content', () => {
|
|
42
|
+
expect(defaultWrapper.text()).toContain('Step 1')
|
|
43
|
+
expect(defaultWrapper.text()).toContain('Content 1')
|
|
44
|
+
})
|
|
45
|
+
})
|
|
46
|
+
|
|
47
|
+
describe(`Vertical layout ${ComponentName} component`, () => {
|
|
48
|
+
it('renders correctly', () => {
|
|
49
|
+
expect(verticalWrapper.html()).toMatchSnapshot()
|
|
50
|
+
})
|
|
51
|
+
|
|
52
|
+
it('uses vertical layout class (if applicable)', () => {
|
|
53
|
+
expect(verticalWrapper.classes()).toContain('stepper-vertical') // optional
|
|
54
|
+
})
|
|
55
|
+
})
|
|
56
|
+
|
|
57
|
+
describe(`Linear mode ${ComponentName} component`, () => {
|
|
58
|
+
it('disables future steps', () => {
|
|
59
|
+
const tabs = linearWrapper.findAll('[role="tab"]')
|
|
60
|
+
expect(tabs[0].attributes('disabled')).toBeUndefined()
|
|
61
|
+
expect(tabs[1].attributes('disabled')).toBeDefined()
|
|
62
|
+
expect(tabs[2].attributes('disabled')).toBeDefined()
|
|
63
|
+
})
|
|
64
|
+
})
|
|
65
|
+
|
|
66
|
+
describe(`Non-linear mode ${ComponentName} component`, () => {
|
|
67
|
+
const wrapper = mount(Component, {
|
|
68
|
+
propsData: {
|
|
69
|
+
steps: stepsMock,
|
|
70
|
+
linear: false,
|
|
71
|
+
},
|
|
72
|
+
})
|
|
73
|
+
|
|
74
|
+
it('allows clicking all steps', () => {
|
|
75
|
+
const tabs = wrapper.findAll('[role="tab"]')
|
|
76
|
+
expect(tabs[0].attributes('disabled')).toBeUndefined()
|
|
77
|
+
expect(tabs[1].attributes('disabled')).toBeUndefined()
|
|
78
|
+
expect(tabs[2].attributes('disabled')).toBeUndefined()
|
|
79
|
+
})
|
|
80
|
+
|
|
81
|
+
it('calls onStepChange when step is clicked', async () => {
|
|
82
|
+
const onStepChange = jest.fn()
|
|
83
|
+
const customWrapper = mount(Component, {
|
|
84
|
+
propsData: {
|
|
85
|
+
steps: stepsMock,
|
|
86
|
+
linear: false,
|
|
87
|
+
onStepChange,
|
|
88
|
+
},
|
|
89
|
+
})
|
|
90
|
+
await customWrapper.findAll('[role="tab"]')[2].trigger('click')
|
|
91
|
+
expect(onStepChange).toHaveBeenCalledWith(3)
|
|
92
|
+
})
|
|
93
|
+
})
|
|
94
|
+
|
|
95
|
+
describe(`Active step content ${ComponentName}`, () => {
|
|
96
|
+
const wrapper = mount(Component, {
|
|
97
|
+
propsData: {
|
|
98
|
+
steps: stepsMock,
|
|
99
|
+
layout: 'horizontal',
|
|
100
|
+
modelValue: 1,
|
|
101
|
+
},
|
|
102
|
+
})
|
|
103
|
+
|
|
104
|
+
it('renders only first step content', () => {
|
|
105
|
+
expect(wrapper.text()).toContain('Content 1')
|
|
106
|
+
expect(wrapper.text()).not.toContain('Content 2')
|
|
107
|
+
expect(wrapper.text()).not.toContain('Content 3')
|
|
108
|
+
})
|
|
109
|
+
})
|
|
110
|
+
|
|
111
|
+
describe(`Finish and reset events ${ComponentName}`, () => {
|
|
112
|
+
it('calls onFinish when last step is clicked', async () => {
|
|
113
|
+
const onFinish = jest.fn()
|
|
114
|
+
const wrapper = mount(Component, {
|
|
115
|
+
propsData: {
|
|
116
|
+
steps: stepsMock,
|
|
117
|
+
onFinish,
|
|
118
|
+
linear: false,
|
|
119
|
+
modelValue: 3,
|
|
120
|
+
},
|
|
121
|
+
})
|
|
122
|
+
|
|
123
|
+
await wrapper.findAll('[role="tab"]')[2].trigger('click')
|
|
124
|
+
expect(onFinish).toHaveBeenCalledTimes(1)
|
|
125
|
+
})
|
|
126
|
+
|
|
127
|
+
it('resets and focuses first step', async () => {
|
|
128
|
+
const onReset = jest.fn()
|
|
129
|
+
const wrapper = mount(Component, {
|
|
130
|
+
propsData: {
|
|
131
|
+
steps: stepsMock,
|
|
132
|
+
onReset,
|
|
133
|
+
},
|
|
134
|
+
})
|
|
135
|
+
|
|
136
|
+
const instance = wrapper.vm as any
|
|
137
|
+
instance.next()
|
|
138
|
+
await wrapper.vm.$nextTick()
|
|
139
|
+
instance.reset()
|
|
140
|
+
await wrapper.vm.$nextTick()
|
|
141
|
+
|
|
142
|
+
expect(onReset).toHaveBeenCalled()
|
|
143
|
+
expect(wrapper.findAll('[role="tab"]')[0].element).toBe(document.activeElement)
|
|
144
|
+
})
|
|
145
|
+
})
|
|
146
|
+
|
|
147
|
+
describe(`Uncontrolled vs Controlled ${ComponentName}`, () => {
|
|
148
|
+
it('starts at defaultActiveStepNumber', () => {
|
|
149
|
+
const wrapper = mount(Component, {
|
|
150
|
+
propsData: {
|
|
151
|
+
steps: stepsMock,
|
|
152
|
+
defaultActiveStepNumber: 2,
|
|
153
|
+
},
|
|
154
|
+
})
|
|
155
|
+
|
|
156
|
+
expect(wrapper.text()).toContain('Content 2')
|
|
157
|
+
expect(wrapper.text()).not.toContain('Content 1')
|
|
158
|
+
})
|
|
159
|
+
|
|
160
|
+
it('reacts to modelValue change', async () => {
|
|
161
|
+
const wrapper = mount(Component, {
|
|
162
|
+
propsData: {
|
|
163
|
+
steps: stepsMock,
|
|
164
|
+
modelValue: 1,
|
|
165
|
+
},
|
|
166
|
+
})
|
|
167
|
+
|
|
168
|
+
expect(wrapper.text()).toContain('Content 1')
|
|
169
|
+
|
|
170
|
+
await wrapper.setProps({ modelValue: 3 })
|
|
171
|
+
|
|
172
|
+
expect(wrapper.text()).toContain('Content 3')
|
|
173
|
+
expect(wrapper.text()).not.toContain('Content 1')
|
|
174
|
+
})
|
|
175
|
+
})
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { VNode } from 'vue'
|
|
2
|
+
|
|
3
|
+
export interface StepperRef {
|
|
4
|
+
next: () => void
|
|
5
|
+
prev: () => void
|
|
6
|
+
finish: () => void
|
|
7
|
+
reset: () => void
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export interface StepperStepData {
|
|
11
|
+
indicator?: VNode
|
|
12
|
+
label: VNode
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export type StepperStepValidationResult = {
|
|
16
|
+
stepNumber: number
|
|
17
|
+
isValid: boolean
|
|
18
|
+
}
|
|
@@ -18,12 +18,12 @@ const CTabList = defineComponent({
|
|
|
18
18
|
/**
|
|
19
19
|
* Set the nav variant to tabs or pills.
|
|
20
20
|
*
|
|
21
|
-
* @values 'pills', 'tabs', 'underline', 'underline-border'
|
|
21
|
+
* @values 'enclosed', 'enclosed-pills', 'pills', 'tabs', 'underline', 'underline-border'
|
|
22
22
|
*/
|
|
23
23
|
variant: {
|
|
24
24
|
type: String,
|
|
25
25
|
validator: (value: string) => {
|
|
26
|
-
return ['pills', 'tabs', 'underline', 'underline-border'].includes(value)
|
|
26
|
+
return ['enclosed', 'enclosed-pills', 'pills', 'tabs', 'underline', 'underline-border'].includes(value)
|
|
27
27
|
},
|
|
28
28
|
},
|
|
29
29
|
},
|
|
@@ -72,6 +72,7 @@ const CTabList = defineComponent({
|
|
|
72
72
|
{
|
|
73
73
|
class: [
|
|
74
74
|
'nav',
|
|
75
|
+
props.variant === 'enclosed-pills' && 'nav-enclosed',
|
|
75
76
|
{
|
|
76
77
|
[`nav-${props.layout}`]: props.layout,
|
|
77
78
|
[`nav-${props.variant}`]: props.variant,
|