@pisell/private-materials 6.3.2 → 6.3.4
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/build/lowcode/assets-daily.json +11 -11
- package/build/lowcode/assets-dev.json +2 -2
- package/build/lowcode/assets-prod.json +11 -11
- package/build/lowcode/index.js +1 -1
- package/build/lowcode/meta.js +1 -1
- package/build/lowcode/preview.js +13 -13
- package/build/lowcode/render/default/view.css +1 -1
- package/build/lowcode/render/default/view.js +8 -8
- package/build/lowcode/view.css +1 -1
- package/build/lowcode/view.js +8 -8
- package/es/components/Sales/Summary/utils.d.ts +1 -1
- package/es/components/appointmentBooking/components/Cart/Item/Total.d.ts +0 -1
- package/es/components/appointmentBooking/components/Cart/index.d.ts +0 -1
- package/es/components/appointmentBooking/components/Content/index.js +1 -1
- package/es/components/appointmentBooking/components/Content/index.less +3 -3
- package/es/components/appointmentBooking/components/Deposit/index.d.ts +0 -1
- package/es/components/appointmentBooking/components/Header/index.d.ts +0 -1
- package/es/components/appointmentBooking/components/Services/index.js +2 -2
- package/es/components/appointmentBooking/components/Voucher/index.d.ts +0 -1
- package/es/components/appointmentBooking/deposit/index.d.ts +0 -1
- package/es/components/appointmentBooking/index.js +8 -2
- package/es/components/booking/addons/model.d.ts +10 -1
- package/es/components/booking/components/TabProduct/productItem/index.d.ts +0 -1
- package/es/components/booking/components/TabProduct/selectProductItem/index.d.ts +0 -1
- package/es/components/booking/components/TabProduct/tabs/index.js +1 -5
- package/es/components/booking/components/browserSelect/index.js +1 -1
- package/es/components/booking/components/collapsibleList/utils.d.ts +0 -1
- package/es/components/booking/components/emptyBooking/index.d.ts +0 -1
- package/es/components/booking/components/footer/FooterMenus/index.d.ts +0 -1
- package/es/components/booking/components/reloadResourceModal/index.d.ts +0 -1
- package/es/components/booking/deposit/index.d.ts +0 -1
- package/es/components/booking/forms/model.d.ts +10 -1
- package/es/components/booking/forms/model.js +5 -5
- package/es/components/booking/forms/sendModal/useSendModal.d.ts +0 -1
- package/es/components/booking/forms/single/RenderValueById.d.ts +1 -0
- package/es/components/booking/forms/single/RenderValueById.js +68 -17
- package/es/components/booking/forms/single/index.d.ts +0 -1
- package/es/components/booking/forms/single/index.less +67 -1
- package/es/components/booking/hooks/useClearCart.d.ts +0 -1
- package/es/components/booking/info/clientVariant/hooks/useClientFn.d.ts +0 -1
- package/es/components/booking/info/date/index.d.ts +0 -1
- package/es/components/booking/info/header/index.d.ts +0 -1
- package/es/components/booking/info/hooks/useInfoHolder.d.ts +1 -0
- package/es/components/booking/info/model.d.ts +10 -1
- package/es/components/booking/info/notes/index.d.ts +0 -1
- package/es/components/booking/info/service/Lists.d.ts +1 -0
- package/es/components/booking/info/service/actions/index.d.ts +0 -1
- package/es/components/booking/info/service/addService/utils.d.ts +1 -1
- package/es/components/booking/info/service/like/index.js +1 -1
- package/es/components/booking/info/service/serviceList/index.d.ts +0 -1
- package/es/components/booking/info/service2/utils.d.ts +1 -1
- package/es/components/booking/info2/service/actions/index.d.ts +0 -1
- package/es/components/booking/info2/service/addService/index.d.ts +0 -1
- package/es/components/booking/info2/service/addService/utils.d.ts +1 -1
- package/es/components/booking/info2/service/addTimeModal/index.js +0 -1
- package/es/components/booking/info2/service/serviceList/index.d.ts +0 -1
- package/es/components/booking/locales.d.ts +3 -0
- package/es/components/booking/locales.js +6 -3
- package/es/components/booking/materiels/contacts/index.d.ts +0 -1
- package/es/components/booking/materiels/startTime/index.d.ts +1 -0
- package/es/components/booking/model.d.ts +9 -1
- package/es/components/booking/notes/NoteBlock/NoteItem/index.d.ts +0 -1
- package/es/components/booking/notes/NoteBlock/NoteItem/index.js +1 -1
- package/es/components/booking/notes/NoteBlock/index.d.ts +0 -1
- package/es/components/booking/notes/NoteBlock/index.js +11 -11
- package/es/components/booking/notes/model.d.ts +10 -1
- package/es/components/booking/notes/model.js +5 -5
- package/es/components/booking/payments/model.d.ts +10 -1
- package/es/components/booking/payments/model.js +5 -5
- package/es/components/booking/utils.d.ts +2 -2
- package/es/components/eftpos/index.d.ts +0 -1
- package/es/components/eftpos/pos.d.ts +0 -1
- package/es/components/eftposPay/amount.d.ts +1 -2
- package/es/components/eftposPay/app.d.ts +0 -1
- package/es/components/eftposPay/component/fail/network.d.ts +0 -1
- package/es/components/eftposPay/component/manual/index.d.ts +0 -1
- package/es/components/eftposPay/component/signature/index.d.ts +0 -1
- package/es/components/eftposPay/device.d.ts +1 -2
- package/es/components/eftposPay/hooks.d.ts +2 -2
- package/es/components/eftposPay/payo/config.d.ts +0 -1
- package/es/components/eftposPay/store/index.d.ts +5 -5
- package/es/components/eftposPay/tip.d.ts +0 -1
- package/es/components/eftposPay/windcave/receiptAction.d.ts +0 -1
- package/es/components/eftposPay/windcave/windcave.d.ts +0 -1
- package/es/components/eventBooking/components/Provider/Cart/Item/Total.d.ts +0 -1
- package/es/components/eventBooking/components/Provider/Cart/Item/index.d.ts +0 -1
- package/es/components/eventBooking/components/Provider/Cart/index.d.ts +0 -1
- package/es/components/eventBooking/components/Provider/Content/index.d.ts +0 -1
- package/es/components/eventBooking/components/Provider/EmptyHolderModal/index.d.ts +0 -1
- package/es/components/eventBooking/components/Provider/Event/index.d.ts +0 -1
- package/es/components/eventBooking/components/Provider/Footer/index.d.ts +0 -1
- package/es/components/eventBooking/components/Provider/Header/index.d.ts +0 -1
- package/es/components/eventBooking/components/Provider/OrderProductModal/index.d.ts +0 -1
- package/es/components/eventBooking/components/Provider/RemoveOptionConfirmModal.d.ts +0 -1
- package/es/components/eventBooking/components/Provider/Resource/index.d.ts +0 -1
- package/es/components/eventBooking/components/Provider/SelectHolderModal.d.ts +0 -1
- package/es/components/eventBooking/components/bookingDetailModal/components/BookingOptions.d.ts +0 -1
- package/es/components/eventBooking/components/bookingDetailModal/components/Resource.d.ts +0 -1
- package/es/components/eventBooking/components/bookingDetailModal/components/Schedule.d.ts +0 -1
- package/es/components/eventBooking/components/scheduleCalendar/ProductItem/index.d.ts +0 -1
- package/es/components/eventBooking/components/scheduleCalendar/components/ScheduleTimeItem/index.d.ts +0 -1
- package/es/components/eventBooking/index.js +8 -1
- package/es/components/listComponent/index.js +5 -5
- package/es/components/login/index.d.ts +0 -1
- package/es/components/pay/toC/PaymentMethods/MWCreditCard/TDSPay/ThreedsLoading/index.d.ts +0 -1
- package/es/components/pay/toC/model.d.ts +9 -1
- package/es/components/pisellSelectCustomerModal/RightPanel/Add/BirthdayField/index.d.ts +0 -1
- package/es/components/pisellSelectCustomerModal/RightPanel/Add/GenderField/index.d.ts +0 -1
- package/es/components/pisellSelectCustomerModal/RightPanel/Add/index.d.ts +0 -1
- package/es/components/pisellSelectCustomerModal/RightPanel/List/index.d.ts +0 -1
- package/es/components/pisellSelectCustomerModal/RightPanel/index.d.ts +0 -1
- package/es/components/pisellSelectCustomerModal/index.d.ts +0 -1
- package/es/components/productExtension/card/index.js +3 -3
- package/es/components/productExtension/fields/Actor/CutOffTime/index.js +1 -1
- package/es/components/productExtension/fields/Forms/index.js +12 -12
- package/es/components/productExtension/fields/SelectProducts/ProductItem/index.d.ts +0 -1
- package/es/components/productExtension/fields/SelectProducts/ProductItemPreview/index.d.ts +0 -1
- package/es/components/productExtension/fields/SelectProducts/ProductItemPreview/index.js +1 -1
- package/es/components/productExtension/fields/SelectProducts/index.d.ts +0 -1
- package/es/components/productExtension/fields/SelectProducts/server.js +2 -2
- package/es/components/productExtension/fields/SelectResourcesTable/index.d.ts +0 -1
- package/es/components/productExtension/fields/SelectResourcesTable/server.js +2 -2
- package/es/components/productExtension/index.d.ts +0 -1
- package/es/components/productExtension/server.js +2 -2
- package/es/components/productSelect/components/TabProduct/index.d.ts +0 -1
- package/es/components/ruleSetting/ruleBorder/index.d.ts +0 -1
- package/es/components/ruleSetting/ruleBorder/index.js +1 -1
- package/es/components/schedules/calendar/index.d.ts +0 -1
- package/es/components/schedules/calendar/index.js +4 -4
- package/es/components/schedules/calendar/serve.js +2 -2
- package/es/components/schedules/components/CurrentDay/index.js +5 -5
- package/es/components/schedules/components/CurrentDay/serve.js +2 -2
- package/es/components/schedules/components/DropdownSort/index.js +1 -1
- package/es/components/schedules/components/ResourceList/index.js +1 -1
- package/es/components/schedules/components/ScheduleDetailList/index.d.ts +0 -1
- package/es/components/schedules/components/ScheduleList/index.d.ts +0 -1
- package/es/components/schedules/components/Search/index.js +5 -5
- package/es/components/schedules/model.d.ts +9 -1
- package/es/components/schedules/model.js +5 -5
- package/es/components/schedules/openHours/index.js +1 -1
- package/es/components/schedules/openHours/serve.js +2 -2
- package/es/components/schedules/products/ProductDetailDrawer/ProductDetail/MaxParticipantsModule/index.d.ts +0 -1
- package/es/components/schedules/products/ProductDetailDrawer/ProductDetail/MaxParticipantsModule/index.js +1 -1
- package/es/components/schedules/products/ProductDetailDrawer/ProductDetail/ResourcesModule/index.d.ts +0 -1
- package/es/components/schedules/products/ProductDetailDrawer/ProductDetail/ResourcesModule/index.js +5 -5
- package/es/components/schedules/products/ProductDetailDrawer/ProductDetail/SchedulesModule/AddSchedules/index.d.ts +0 -1
- package/es/components/schedules/products/ProductDetailDrawer/ProductDetail/SchedulesModule/index.d.ts +0 -1
- package/es/components/schedules/products/ProductDetailDrawer/ProductDetail/SchedulesModule/index.js +4 -4
- package/es/components/schedules/products/ProductDetailDrawer/index.d.ts +0 -1
- package/es/components/schedules/products/ProductDetailDrawer/index.js +3 -3
- package/es/components/schedules/products/list/ProductItem/index.d.ts +0 -1
- package/es/components/schedules/products/list/index.d.ts +0 -1
- package/es/components/schedules/products/serve.js +2 -2
- package/es/components/schedules/products/utils.js +5 -5
- package/es/components/schedules/resources/detail/detailContent.js +2 -2
- package/es/components/schedules/resources/detail/index.js +10 -10
- package/es/components/schedules/resources/index.d.ts +0 -1
- package/es/components/schedules/resources/list/index.d.ts +0 -1
- package/es/components/schedules/resources/list/index.js +2 -2
- package/es/components/schedules/resources/relationProduct/index.js +1 -1
- package/es/components/schedules/resources/serve.js +2 -2
- package/es/components/schedules/schedules/AllSchedules/index.d.ts +0 -1
- package/es/components/schedules/schedules/ScheduleDetailDrawer/index.d.ts +0 -1
- package/es/components/schedules/schedules/ScheduleDetailDrawer/index.js +9 -9
- package/es/components/schedules/schedules/index.d.ts +0 -1
- package/es/components/schedules/utils.d.ts +1 -1
- package/es/components/schedules/utils.js +4 -4
- package/es/components/selectModal/index.js +2 -2
- package/es/components/shoppingCart/components/Cart/Product.d.ts +1 -0
- package/es/components/shoppingCart/components/Cart/index.d.ts +0 -1
- package/es/components/shoppingCart/hooks/useAddService.d.ts +0 -1
- package/es/components/shoppingCart/hooks/useClearCart.d.ts +0 -1
- package/es/components/shoppingCart/index.d.ts +0 -1
- package/es/components/taxSelect/index.d.ts +0 -1
- package/es/components/ticketBooking/components/addServiceVariant/addService.js +3 -3
- package/es/components/ticketBooking/components/menuBar/index.d.ts +0 -1
- package/es/components/wallet/Detail/model.d.ts +13 -1
- package/es/components/wallet/DiscountCard/model.d.ts +14 -1
- package/es/components/wallet/PointCard/model.d.ts +13 -1
- package/es/components/wallet/RechargeableCard/model.d.ts +29 -1
- package/es/components/wallet/Voucher/model.d.ts +13 -1
- package/es/components/wallet/hooks/useWalletCard.d.ts +0 -1
- package/es/components/wallet/model.d.ts +9 -1
- package/es/components/workSpaceList/components/SearchWorkspaceAndBase/index.d.ts +1 -0
- package/es/hooks/useComponents.js +1 -1
- package/es/hooks/useWindowSize.js +8 -1
- package/es/plus/productSelect/CategoryTabs/CategorySkeleton.d.ts +10 -0
- package/es/plus/productSelect/CategoryTabs/CategorySkeleton.js +29 -0
- package/es/plus/productSelect/CategoryTabs/CategorySkeleton.less +30 -0
- package/es/plus/productSelect/CategoryTabs/index.d.ts +18 -0
- package/es/plus/productSelect/CategoryTabs/index.js +171 -0
- package/es/plus/productSelect/ProductCard/ProductCardSkeleton.d.ts +10 -0
- package/es/plus/productSelect/ProductCard/ProductCardSkeleton.js +37 -0
- package/es/plus/productSelect/ProductCard/ProductCardSkeleton.less +81 -0
- package/es/plus/productSelect/ProductCard/index.d.ts +45 -0
- package/es/plus/productSelect/ProductCard/index.js +170 -0
- package/es/plus/productSelect/ProductCard/index.less +270 -0
- package/es/plus/productSelect/ProductList/gridComponents.d.ts +44 -0
- package/es/plus/productSelect/ProductList/gridComponents.js +149 -0
- package/es/plus/productSelect/ProductList/index.d.ts +22 -0
- package/es/plus/productSelect/ProductList/index.js +72 -0
- package/es/plus/productSelect/ProductList/index.less +0 -0
- package/es/plus/productSelect/components/IntersectionObserver.d.ts +42 -0
- package/es/plus/productSelect/components/IntersectionObserver.js +276 -0
- package/es/plus/productSelect/components/TabsStructure/TabsStructure.d.ts +30 -0
- package/es/plus/productSelect/components/TabsStructure/TabsStructure.js +357 -0
- package/es/plus/productSelect/components/TabsStructure/TabsStructure.less +224 -0
- package/es/plus/productSelect/components/TabsStructure/hooks.d.ts +22 -0
- package/es/plus/productSelect/components/TabsStructure/hooks.js +243 -0
- package/es/plus/productSelect/components/TabsStructure/index.d.ts +5 -0
- package/es/plus/productSelect/components/TabsStructure/index.js +13 -0
- package/es/plus/productSelect/components/TabsStructure/styles.d.ts +47 -0
- package/es/plus/productSelect/components/TabsStructure/styles.js +87 -0
- package/es/plus/productSelect/components/TabsStructure/types.d.ts +105 -0
- package/es/plus/productSelect/components/TabsStructure/types.js +1 -0
- package/es/plus/productSelect/components/TabsStructure/utils.d.ts +12 -0
- package/es/plus/productSelect/components/TabsStructure/utils.js +56 -0
- package/es/plus/productSelect/components/pisellPriceText/index.d.ts +11 -0
- package/es/plus/productSelect/components/pisellPriceText/index.js +43 -0
- package/es/plus/productSelect/hooks/useToken.d.ts +18 -0
- package/es/plus/productSelect/hooks/useToken.js +34 -0
- package/es/plus/productSelect/index.d.ts +31 -0
- package/es/plus/productSelect/index.js +270 -0
- package/es/plus/productSelect/index.less +56 -0
- package/es/plus/productSelect/locales.d.ts +18 -0
- package/es/plus/productSelect/locales.js +17 -0
- package/es/plus/productSelect/theme/token.d.ts +17 -0
- package/es/plus/productSelect/theme/token.js +19 -0
- package/es/plus/productSelect/utils.d.ts +39 -0
- package/es/plus/productSelect/utils.js +162 -0
- package/es/utils/index.d.ts +1 -1
- package/lib/components/Sales/Summary/utils.d.ts +1 -1
- package/lib/components/appointmentBooking/components/Cart/Item/Total.d.ts +0 -1
- package/lib/components/appointmentBooking/components/Cart/index.d.ts +0 -1
- package/lib/components/appointmentBooking/components/Content/index.js +1 -1
- package/lib/components/appointmentBooking/components/Content/index.less +3 -3
- package/lib/components/appointmentBooking/components/Deposit/index.d.ts +0 -1
- package/lib/components/appointmentBooking/components/Header/index.d.ts +0 -1
- package/lib/components/appointmentBooking/components/Services/index.js +2 -2
- package/lib/components/appointmentBooking/components/Voucher/index.d.ts +0 -1
- package/lib/components/appointmentBooking/deposit/index.d.ts +0 -1
- package/lib/components/appointmentBooking/index.js +6 -1
- package/lib/components/booking/addons/model.d.ts +10 -1
- package/lib/components/booking/components/TabProduct/productItem/index.d.ts +0 -1
- package/lib/components/booking/components/TabProduct/selectProductItem/index.d.ts +0 -1
- package/lib/components/booking/components/collapsibleList/utils.d.ts +0 -1
- package/lib/components/booking/components/emptyBooking/index.d.ts +0 -1
- package/lib/components/booking/components/footer/FooterMenus/index.d.ts +0 -1
- package/lib/components/booking/components/reloadResourceModal/index.d.ts +0 -1
- package/lib/components/booking/deposit/index.d.ts +0 -1
- package/lib/components/booking/forms/model.d.ts +10 -1
- package/lib/components/booking/forms/sendModal/useSendModal.d.ts +0 -1
- package/lib/components/booking/forms/single/RenderValueById.d.ts +1 -0
- package/lib/components/booking/forms/single/RenderValueById.js +37 -9
- package/lib/components/booking/forms/single/index.d.ts +0 -1
- package/lib/components/booking/forms/single/index.less +67 -1
- package/lib/components/booking/hooks/useClearCart.d.ts +0 -1
- package/lib/components/booking/info/clientVariant/hooks/useClientFn.d.ts +0 -1
- package/lib/components/booking/info/date/index.d.ts +0 -1
- package/lib/components/booking/info/header/index.d.ts +0 -1
- package/lib/components/booking/info/hooks/useInfoHolder.d.ts +1 -0
- package/lib/components/booking/info/model.d.ts +10 -1
- package/lib/components/booking/info/notes/index.d.ts +0 -1
- package/lib/components/booking/info/service/Lists.d.ts +1 -0
- package/lib/components/booking/info/service/actions/index.d.ts +0 -1
- package/lib/components/booking/info/service/addService/utils.d.ts +1 -1
- package/lib/components/booking/info/service/serviceList/index.d.ts +0 -1
- package/lib/components/booking/info/service2/utils.d.ts +1 -1
- package/lib/components/booking/info2/service/actions/index.d.ts +0 -1
- package/lib/components/booking/info2/service/addService/index.d.ts +0 -1
- package/lib/components/booking/info2/service/addService/utils.d.ts +1 -1
- package/lib/components/booking/info2/service/addTimeModal/index.js +0 -1
- package/lib/components/booking/info2/service/serviceList/index.d.ts +0 -1
- package/lib/components/booking/locales.d.ts +3 -0
- package/lib/components/booking/locales.js +6 -3
- package/lib/components/booking/materiels/contacts/index.d.ts +0 -1
- package/lib/components/booking/materiels/startTime/index.d.ts +1 -0
- package/lib/components/booking/model.d.ts +9 -1
- package/lib/components/booking/notes/NoteBlock/NoteItem/index.d.ts +0 -1
- package/lib/components/booking/notes/NoteBlock/index.d.ts +0 -1
- package/lib/components/booking/notes/model.d.ts +10 -1
- package/lib/components/booking/payments/model.d.ts +10 -1
- package/lib/components/booking/utils.d.ts +2 -2
- package/lib/components/eftpos/index.d.ts +0 -1
- package/lib/components/eftpos/pos.d.ts +0 -1
- package/lib/components/eftposPay/amount.d.ts +1 -2
- package/lib/components/eftposPay/app.d.ts +0 -1
- package/lib/components/eftposPay/component/fail/network.d.ts +0 -1
- package/lib/components/eftposPay/component/manual/index.d.ts +0 -1
- package/lib/components/eftposPay/component/signature/index.d.ts +0 -1
- package/lib/components/eftposPay/device.d.ts +1 -2
- package/lib/components/eftposPay/hooks.d.ts +2 -2
- package/lib/components/eftposPay/payo/config.d.ts +0 -1
- package/lib/components/eftposPay/store/index.d.ts +5 -5
- package/lib/components/eftposPay/tip.d.ts +0 -1
- package/lib/components/eftposPay/windcave/receiptAction.d.ts +0 -1
- package/lib/components/eftposPay/windcave/windcave.d.ts +0 -1
- package/lib/components/eventBooking/components/Provider/Cart/Item/Total.d.ts +0 -1
- package/lib/components/eventBooking/components/Provider/Cart/Item/index.d.ts +0 -1
- package/lib/components/eventBooking/components/Provider/Cart/index.d.ts +0 -1
- package/lib/components/eventBooking/components/Provider/Content/index.d.ts +0 -1
- package/lib/components/eventBooking/components/Provider/EmptyHolderModal/index.d.ts +0 -1
- package/lib/components/eventBooking/components/Provider/Event/index.d.ts +0 -1
- package/lib/components/eventBooking/components/Provider/Footer/index.d.ts +0 -1
- package/lib/components/eventBooking/components/Provider/Header/index.d.ts +0 -1
- package/lib/components/eventBooking/components/Provider/OrderProductModal/index.d.ts +0 -1
- package/lib/components/eventBooking/components/Provider/RemoveOptionConfirmModal.d.ts +0 -1
- package/lib/components/eventBooking/components/Provider/Resource/index.d.ts +0 -1
- package/lib/components/eventBooking/components/Provider/SelectHolderModal.d.ts +0 -1
- package/lib/components/eventBooking/components/bookingDetailModal/components/BookingOptions.d.ts +0 -1
- package/lib/components/eventBooking/components/bookingDetailModal/components/Resource.d.ts +0 -1
- package/lib/components/eventBooking/components/bookingDetailModal/components/Schedule.d.ts +0 -1
- package/lib/components/eventBooking/components/scheduleCalendar/ProductItem/index.d.ts +0 -1
- package/lib/components/eventBooking/components/scheduleCalendar/components/ScheduleTimeItem/index.d.ts +0 -1
- package/lib/components/eventBooking/index.js +6 -1
- package/lib/components/login/index.d.ts +0 -1
- package/lib/components/pay/toC/PaymentMethods/MWCreditCard/TDSPay/ThreedsLoading/index.d.ts +0 -1
- package/lib/components/pay/toC/model.d.ts +9 -1
- package/lib/components/pisellSelectCustomerModal/RightPanel/Add/BirthdayField/index.d.ts +0 -1
- package/lib/components/pisellSelectCustomerModal/RightPanel/Add/GenderField/index.d.ts +0 -1
- package/lib/components/pisellSelectCustomerModal/RightPanel/Add/index.d.ts +0 -1
- package/lib/components/pisellSelectCustomerModal/RightPanel/List/index.d.ts +0 -1
- package/lib/components/pisellSelectCustomerModal/RightPanel/index.d.ts +0 -1
- package/lib/components/pisellSelectCustomerModal/index.d.ts +0 -1
- package/lib/components/productExtension/fields/SelectProducts/ProductItem/index.d.ts +0 -1
- package/lib/components/productExtension/fields/SelectProducts/ProductItemPreview/index.d.ts +0 -1
- package/lib/components/productExtension/fields/SelectProducts/index.d.ts +0 -1
- package/lib/components/productExtension/fields/SelectResourcesTable/index.d.ts +0 -1
- package/lib/components/productExtension/index.d.ts +0 -1
- package/lib/components/productSelect/components/TabProduct/index.d.ts +0 -1
- package/lib/components/ruleSetting/ruleBorder/index.d.ts +0 -1
- package/lib/components/schedules/calendar/index.d.ts +0 -1
- package/lib/components/schedules/components/ScheduleDetailList/index.d.ts +0 -1
- package/lib/components/schedules/components/ScheduleList/index.d.ts +0 -1
- package/lib/components/schedules/model.d.ts +9 -1
- package/lib/components/schedules/products/ProductDetailDrawer/ProductDetail/MaxParticipantsModule/index.d.ts +0 -1
- package/lib/components/schedules/products/ProductDetailDrawer/ProductDetail/ResourcesModule/index.d.ts +0 -1
- package/lib/components/schedules/products/ProductDetailDrawer/ProductDetail/SchedulesModule/AddSchedules/index.d.ts +0 -1
- package/lib/components/schedules/products/ProductDetailDrawer/ProductDetail/SchedulesModule/index.d.ts +0 -1
- package/lib/components/schedules/products/ProductDetailDrawer/index.d.ts +0 -1
- package/lib/components/schedules/products/list/ProductItem/index.d.ts +0 -1
- package/lib/components/schedules/products/list/index.d.ts +0 -1
- package/lib/components/schedules/resources/index.d.ts +0 -1
- package/lib/components/schedules/resources/list/index.d.ts +0 -1
- package/lib/components/schedules/schedules/AllSchedules/index.d.ts +0 -1
- package/lib/components/schedules/schedules/ScheduleDetailDrawer/index.d.ts +0 -1
- package/lib/components/schedules/schedules/index.d.ts +0 -1
- package/lib/components/schedules/utils.d.ts +1 -1
- package/lib/components/schedules/utils.js +1 -1
- package/lib/components/shoppingCart/components/Cart/Product.d.ts +1 -0
- package/lib/components/shoppingCart/components/Cart/index.d.ts +0 -1
- package/lib/components/shoppingCart/hooks/useAddService.d.ts +0 -1
- package/lib/components/shoppingCart/hooks/useClearCart.d.ts +0 -1
- package/lib/components/shoppingCart/index.d.ts +0 -1
- package/lib/components/taxSelect/index.d.ts +0 -1
- package/lib/components/ticketBooking/components/addServiceVariant/addService.js +3 -3
- package/lib/components/ticketBooking/components/menuBar/index.d.ts +0 -1
- package/lib/components/wallet/Detail/model.d.ts +13 -1
- package/lib/components/wallet/DiscountCard/model.d.ts +14 -1
- package/lib/components/wallet/PointCard/model.d.ts +13 -1
- package/lib/components/wallet/RechargeableCard/model.d.ts +29 -1
- package/lib/components/wallet/Voucher/model.d.ts +13 -1
- package/lib/components/wallet/hooks/useWalletCard.d.ts +0 -1
- package/lib/components/wallet/model.d.ts +9 -1
- package/lib/components/workSpaceList/components/SearchWorkspaceAndBase/index.d.ts +1 -0
- package/lib/hooks/useWindowSize.js +6 -1
- package/lib/plus/productSelect/CategoryTabs/CategorySkeleton.d.ts +10 -0
- package/lib/plus/productSelect/CategoryTabs/CategorySkeleton.js +62 -0
- package/lib/plus/productSelect/CategoryTabs/CategorySkeleton.less +30 -0
- package/lib/plus/productSelect/CategoryTabs/index.d.ts +18 -0
- package/lib/plus/productSelect/CategoryTabs/index.js +183 -0
- package/lib/plus/productSelect/ProductCard/ProductCardSkeleton.d.ts +10 -0
- package/lib/plus/productSelect/ProductCard/ProductCardSkeleton.js +58 -0
- package/lib/plus/productSelect/ProductCard/ProductCardSkeleton.less +81 -0
- package/lib/plus/productSelect/ProductCard/index.d.ts +45 -0
- package/lib/plus/productSelect/ProductCard/index.js +184 -0
- package/lib/plus/productSelect/ProductCard/index.less +270 -0
- package/lib/plus/productSelect/ProductList/gridComponents.d.ts +44 -0
- package/lib/plus/productSelect/ProductList/gridComponents.js +148 -0
- package/lib/plus/productSelect/ProductList/index.d.ts +22 -0
- package/lib/plus/productSelect/ProductList/index.js +86 -0
- package/lib/plus/productSelect/ProductList/index.less +0 -0
- package/lib/plus/productSelect/components/IntersectionObserver.d.ts +42 -0
- package/lib/plus/productSelect/components/IntersectionObserver.js +269 -0
- package/lib/plus/productSelect/components/TabsStructure/TabsStructure.d.ts +30 -0
- package/lib/plus/productSelect/components/TabsStructure/TabsStructure.js +393 -0
- package/lib/plus/productSelect/components/TabsStructure/TabsStructure.less +224 -0
- package/lib/plus/productSelect/components/TabsStructure/hooks.d.ts +22 -0
- package/lib/plus/productSelect/components/TabsStructure/hooks.js +209 -0
- package/lib/plus/productSelect/components/TabsStructure/index.d.ts +5 -0
- package/lib/plus/productSelect/components/TabsStructure/index.js +92 -0
- package/lib/plus/productSelect/components/TabsStructure/styles.d.ts +47 -0
- package/lib/plus/productSelect/components/TabsStructure/styles.js +122 -0
- package/lib/plus/productSelect/components/TabsStructure/types.d.ts +105 -0
- package/lib/plus/productSelect/components/TabsStructure/types.js +17 -0
- package/lib/plus/productSelect/components/TabsStructure/utils.d.ts +12 -0
- package/lib/plus/productSelect/components/TabsStructure/utils.js +72 -0
- package/lib/plus/productSelect/components/pisellPriceText/index.d.ts +11 -0
- package/lib/plus/productSelect/components/pisellPriceText/index.js +72 -0
- package/lib/plus/productSelect/hooks/useToken.d.ts +18 -0
- package/lib/plus/productSelect/hooks/useToken.js +50 -0
- package/lib/plus/productSelect/index.d.ts +31 -0
- package/lib/plus/productSelect/index.js +299 -0
- package/lib/plus/productSelect/index.less +56 -0
- package/lib/plus/productSelect/locales.d.ts +18 -0
- package/lib/plus/productSelect/locales.js +41 -0
- package/lib/plus/productSelect/theme/token.d.ts +17 -0
- package/lib/plus/productSelect/theme/token.js +47 -0
- package/lib/plus/productSelect/utils.d.ts +39 -0
- package/lib/plus/productSelect/utils.js +138 -0
- package/lib/utils/index.d.ts +1 -1
- package/package.json +4 -4
@@ -0,0 +1,357 @@
|
|
1
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
2
|
+
var _excluded = ["children", "className"],
|
3
|
+
_excluded2 = ["children", "isSelected", "isDisabled", "className", "onClick", "tabId", "autoRegister"],
|
4
|
+
_excluded3 = ["children", "className"],
|
5
|
+
_excluded4 = ["focusRingClasses", "isFocusVisible", "style", "className"],
|
6
|
+
_excluded5 = ["visible", "location", "className"],
|
7
|
+
_excluded6 = ["direction", "disabled", "onClick", "className", "aria-label"],
|
8
|
+
_excluded7 = ["isPrevDisabled", "isNextDisabled", "onPrevClick", "onNextClick", "prevAction", "nextAction", "className"],
|
9
|
+
_excluded8 = ["selectedTab", "onTabChange", "autoScrollToSelected", "children", "className", "railRef"];
|
10
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
11
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
|
12
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
13
|
+
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
14
|
+
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
15
|
+
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
16
|
+
import React, { forwardRef, useMemo, useContext, createContext, useCallback, useRef, useEffect } from 'react';
|
17
|
+
import classNames from 'classnames';
|
18
|
+
import { tabWrapperClasses, tabListClasses, tabItemClasses, railClasses, selectionClasses, shadowClasses, chevronClasses, chevronButtonClasses } from "./styles";
|
19
|
+
import { safeScrollTo } from "./utils";
|
20
|
+
import ChevronLeft from '@pisell/icon/es/ChevronLeft';
|
21
|
+
import ChevronRight from '@pisell/icon/es/ChevronRight';
|
22
|
+
|
23
|
+
// WeakRef 类型声明(用于兼容性检测)
|
24
|
+
|
25
|
+
// Tab上下文
|
26
|
+
var TabContext = /*#__PURE__*/createContext({});
|
27
|
+
|
28
|
+
// Hook to use tab context
|
29
|
+
var useTabContext = function useTabContext() {
|
30
|
+
var context = useContext(TabContext);
|
31
|
+
if (!context) {
|
32
|
+
throw new Error('useTabContext must be used within a TabContext.Provider');
|
33
|
+
}
|
34
|
+
return context;
|
35
|
+
};
|
36
|
+
var TabListContainer = /*#__PURE__*/forwardRef(function (_ref, ref) {
|
37
|
+
var children = _ref.children,
|
38
|
+
className = _ref.className,
|
39
|
+
props = _objectWithoutProperties(_ref, _excluded);
|
40
|
+
return /*#__PURE__*/React.createElement("ul", _extends({
|
41
|
+
ref: ref,
|
42
|
+
className: classNames(tabListClasses.list, className),
|
43
|
+
role: "tablist"
|
44
|
+
}, props), children);
|
45
|
+
});
|
46
|
+
var TabItem = /*#__PURE__*/forwardRef(function (_ref2, ref) {
|
47
|
+
var children = _ref2.children,
|
48
|
+
_ref2$isSelected = _ref2.isSelected,
|
49
|
+
isSelected = _ref2$isSelected === void 0 ? false : _ref2$isSelected,
|
50
|
+
_ref2$isDisabled = _ref2.isDisabled,
|
51
|
+
isDisabled = _ref2$isDisabled === void 0 ? false : _ref2$isDisabled,
|
52
|
+
className = _ref2.className,
|
53
|
+
onClick = _ref2.onClick,
|
54
|
+
tabId = _ref2.tabId,
|
55
|
+
_ref2$autoRegister = _ref2.autoRegister,
|
56
|
+
autoRegister = _ref2$autoRegister === void 0 ? true : _ref2$autoRegister,
|
57
|
+
props = _objectWithoutProperties(_ref2, _excluded2);
|
58
|
+
var _useTabContext = useTabContext(),
|
59
|
+
selectedTab = _useTabContext.selectedTab,
|
60
|
+
onTabChange = _useTabContext.onTabChange,
|
61
|
+
registerTab = _useTabContext.registerTab,
|
62
|
+
unregisterTab = _useTabContext.unregisterTab;
|
63
|
+
var elementRef = useRef(null);
|
64
|
+
|
65
|
+
// ref 合并逻辑已在 combinedRef 中处理
|
66
|
+
|
67
|
+
// 组合内部ref和外部ref
|
68
|
+
var combinedRef = useCallback(function (element) {
|
69
|
+
elementRef.current = element;
|
70
|
+
if (typeof ref === 'function') {
|
71
|
+
ref(element);
|
72
|
+
} else if (ref && 'current' in ref) {
|
73
|
+
ref.current = element;
|
74
|
+
}
|
75
|
+
}, [ref]);
|
76
|
+
|
77
|
+
// 自动注册tab
|
78
|
+
useEffect(function () {
|
79
|
+
if (autoRegister && tabId && elementRef.current && registerTab) {
|
80
|
+
registerTab(tabId, elementRef.current);
|
81
|
+
return function () {
|
82
|
+
if (unregisterTab) {
|
83
|
+
unregisterTab(tabId);
|
84
|
+
}
|
85
|
+
};
|
86
|
+
}
|
87
|
+
}, [tabId, autoRegister, registerTab, unregisterTab]);
|
88
|
+
|
89
|
+
// 处理点击事件
|
90
|
+
var handleClick = useCallback(function () {
|
91
|
+
if (!isDisabled) {
|
92
|
+
if (tabId && onTabChange) {
|
93
|
+
onTabChange(tabId);
|
94
|
+
}
|
95
|
+
onClick === null || onClick === void 0 || onClick(tabId);
|
96
|
+
}
|
97
|
+
}, [isDisabled, tabId, onTabChange, onClick]);
|
98
|
+
|
99
|
+
// 确定是否选中
|
100
|
+
var isTabSelected = tabId ? selectedTab === tabId : isSelected;
|
101
|
+
return /*#__PURE__*/React.createElement("li", {
|
102
|
+
role: "presentation",
|
103
|
+
style: {
|
104
|
+
lineHeight: 0
|
105
|
+
}
|
106
|
+
}, /*#__PURE__*/React.createElement("button", _extends({
|
107
|
+
id: tabId,
|
108
|
+
ref: combinedRef,
|
109
|
+
className: classNames(tabItemClasses.item, isTabSelected && tabItemClasses.selected, isDisabled && tabItemClasses.disabled, className),
|
110
|
+
role: "tab",
|
111
|
+
"aria-selected": isTabSelected,
|
112
|
+
"aria-disabled": isDisabled,
|
113
|
+
disabled: isDisabled,
|
114
|
+
onClick: handleClick,
|
115
|
+
tabIndex: isTabSelected ? 0 : -1
|
116
|
+
}, props), children));
|
117
|
+
});
|
118
|
+
var Rail = /*#__PURE__*/forwardRef(function (_ref3, ref) {
|
119
|
+
var children = _ref3.children,
|
120
|
+
className = _ref3.className,
|
121
|
+
props = _objectWithoutProperties(_ref3, _excluded3);
|
122
|
+
var _useTabContext2 = useTabContext(),
|
123
|
+
contextRailRef = _useTabContext2.railRef;
|
124
|
+
|
125
|
+
// 合并context ref和外部ref
|
126
|
+
var mergedRef = useCallback(function (element) {
|
127
|
+
// 安全地设置context中的railRef
|
128
|
+
if (contextRailRef && 'current' in contextRailRef) {
|
129
|
+
contextRailRef.current = element;
|
130
|
+
}
|
131
|
+
|
132
|
+
// 设置外部传入的ref
|
133
|
+
if (typeof ref === 'function') {
|
134
|
+
ref(element);
|
135
|
+
} else if (ref && 'current' in ref) {
|
136
|
+
ref.current = element;
|
137
|
+
}
|
138
|
+
}, [ref, contextRailRef]);
|
139
|
+
return /*#__PURE__*/React.createElement("div", _extends({
|
140
|
+
ref: mergedRef,
|
141
|
+
className: classNames(railClasses.rail, className)
|
142
|
+
}, props), children);
|
143
|
+
});
|
144
|
+
var SelectionIndicator = /*#__PURE__*/forwardRef(function (_ref4, ref) {
|
145
|
+
var focusRingClasses = _ref4.focusRingClasses,
|
146
|
+
_ref4$isFocusVisible = _ref4.isFocusVisible,
|
147
|
+
isFocusVisible = _ref4$isFocusVisible === void 0 ? false : _ref4$isFocusVisible,
|
148
|
+
style = _ref4.style,
|
149
|
+
className = _ref4.className,
|
150
|
+
props = _objectWithoutProperties(_ref4, _excluded4);
|
151
|
+
return /*#__PURE__*/React.createElement("div", _extends({
|
152
|
+
ref: ref,
|
153
|
+
className: classNames(selectionClasses.selection, selectionClasses.position, _defineProperty({}, selectionClasses.focused, isFocusVisible && focusRingClasses), className),
|
154
|
+
style: style,
|
155
|
+
"aria-hidden": "true"
|
156
|
+
}, props));
|
157
|
+
});
|
158
|
+
var ScrollShadow = /*#__PURE__*/forwardRef(function (_ref5, ref) {
|
159
|
+
var visible = _ref5.visible,
|
160
|
+
location = _ref5.location,
|
161
|
+
className = _ref5.className,
|
162
|
+
props = _objectWithoutProperties(_ref5, _excluded5);
|
163
|
+
return /*#__PURE__*/React.createElement("div", _extends({
|
164
|
+
ref: ref,
|
165
|
+
className: classNames(shadowClasses.shadow, _defineProperty(_defineProperty(_defineProperty({}, shadowClasses.isVisible, visible), shadowClasses.locationStart, location === 'start'), shadowClasses.locationEnd, location === 'end'), className)
|
166
|
+
}, props));
|
167
|
+
});
|
168
|
+
var ChevronButton = /*#__PURE__*/forwardRef(function (_ref6, ref) {
|
169
|
+
var direction = _ref6.direction,
|
170
|
+
_ref6$disabled = _ref6.disabled,
|
171
|
+
disabled = _ref6$disabled === void 0 ? false : _ref6$disabled,
|
172
|
+
onClick = _ref6.onClick,
|
173
|
+
className = _ref6.className,
|
174
|
+
ariaLabel = _ref6['aria-label'],
|
175
|
+
props = _objectWithoutProperties(_ref6, _excluded6);
|
176
|
+
var defaultAriaLabel = direction === 'prev' ? 'prev' : 'next';
|
177
|
+
return /*#__PURE__*/React.createElement("button", _extends({
|
178
|
+
ref: ref,
|
179
|
+
className: classNames(chevronButtonClasses.button, _defineProperty(_defineProperty(_defineProperty({}, chevronButtonClasses.disabled, disabled), chevronButtonClasses.prev, direction === 'prev'), chevronButtonClasses.next, direction === 'next'), className),
|
180
|
+
disabled: disabled,
|
181
|
+
onClick: onClick,
|
182
|
+
"aria-label": ariaLabel || defaultAriaLabel,
|
183
|
+
type: "button"
|
184
|
+
}, props), direction === 'prev' ? /*#__PURE__*/React.createElement(ChevronLeft, null) : /*#__PURE__*/React.createElement(ChevronRight, null));
|
185
|
+
});
|
186
|
+
var ChevronControls = function ChevronControls(_ref7) {
|
187
|
+
var _ref7$isPrevDisabled = _ref7.isPrevDisabled,
|
188
|
+
isPrevDisabled = _ref7$isPrevDisabled === void 0 ? false : _ref7$isPrevDisabled,
|
189
|
+
_ref7$isNextDisabled = _ref7.isNextDisabled,
|
190
|
+
isNextDisabled = _ref7$isNextDisabled === void 0 ? false : _ref7$isNextDisabled,
|
191
|
+
onPrevClick = _ref7.onPrevClick,
|
192
|
+
onNextClick = _ref7.onNextClick,
|
193
|
+
prevAction = _ref7.prevAction,
|
194
|
+
nextAction = _ref7.nextAction,
|
195
|
+
className = _ref7.className,
|
196
|
+
props = _objectWithoutProperties(_ref7, _excluded7);
|
197
|
+
// 支持两种命名方式
|
198
|
+
var handlePrevClick = onPrevClick || prevAction;
|
199
|
+
var handleNextClick = onNextClick || nextAction;
|
200
|
+
return /*#__PURE__*/React.createElement("div", _extends({
|
201
|
+
className: classNames(chevronClasses.controls, className)
|
202
|
+
}, props), /*#__PURE__*/React.createElement(ChevronButton, {
|
203
|
+
direction: "prev",
|
204
|
+
disabled: isPrevDisabled,
|
205
|
+
onClick: handlePrevClick
|
206
|
+
}), /*#__PURE__*/React.createElement(ChevronButton, {
|
207
|
+
direction: "next",
|
208
|
+
disabled: isNextDisabled,
|
209
|
+
onClick: handleNextClick
|
210
|
+
}));
|
211
|
+
};
|
212
|
+
var TabsStructure = function TabsStructure(_ref8) {
|
213
|
+
var selectedTab = _ref8.selectedTab,
|
214
|
+
onTabChange = _ref8.onTabChange,
|
215
|
+
_ref8$autoScrollToSel = _ref8.autoScrollToSelected,
|
216
|
+
autoScrollToSelected = _ref8$autoScrollToSel === void 0 ? true : _ref8$autoScrollToSel,
|
217
|
+
children = _ref8.children,
|
218
|
+
className = _ref8.className,
|
219
|
+
externalRailRef = _ref8.railRef,
|
220
|
+
props = _objectWithoutProperties(_ref8, _excluded8);
|
221
|
+
// 使用WeakRef优化内存管理,避免内存泄漏(支持降级到直接引用)
|
222
|
+
var tabElementsRef = useRef(new Map());
|
223
|
+
var internalRailRef = useRef(null);
|
224
|
+
|
225
|
+
// 使用外部传入的railRef,如果没有则使用内部的
|
226
|
+
var railRef = externalRailRef || internalRailRef;
|
227
|
+
if (!selectedTab && children) {
|
228
|
+
console.warn('TabsStructure: No selectedTab provided, consider setting a default value');
|
229
|
+
}
|
230
|
+
var registerTab = useCallback(function (tabId, element) {
|
231
|
+
if (!tabId || !element) {
|
232
|
+
console.warn('TabsStructure: Invalid tabId or element provided to registerTab');
|
233
|
+
return;
|
234
|
+
}
|
235
|
+
|
236
|
+
// 特性检测:检查浏览器是否支持 WeakRef
|
237
|
+
if (typeof WeakRef !== 'undefined') {
|
238
|
+
// 支持 WeakRef 的现代浏览器
|
239
|
+
tabElementsRef.current.set(tabId, new WeakRef(element));
|
240
|
+
} else {
|
241
|
+
// 降级到直接引用(需要手动清理)
|
242
|
+
tabElementsRef.current.set(tabId, element);
|
243
|
+
}
|
244
|
+
}, []);
|
245
|
+
|
246
|
+
// 注销tab元素
|
247
|
+
var unregisterTab = useCallback(function (tabId) {
|
248
|
+
if (tabId) {
|
249
|
+
tabElementsRef.current.delete(tabId);
|
250
|
+
}
|
251
|
+
}, []);
|
252
|
+
|
253
|
+
// 清理所有tab引用(主要用于降级模式的内存管理)
|
254
|
+
var clearAllTabs = useCallback(function () {
|
255
|
+
tabElementsRef.current.clear();
|
256
|
+
}, []);
|
257
|
+
|
258
|
+
// 组件卸载时清理所有引用
|
259
|
+
useEffect(function () {
|
260
|
+
return function () {
|
261
|
+
// 在降级模式下,确保清理所有直接引用
|
262
|
+
if (typeof WeakRef === 'undefined') {
|
263
|
+
clearAllTabs();
|
264
|
+
}
|
265
|
+
};
|
266
|
+
}, [clearAllTabs]);
|
267
|
+
var getTabElement = useCallback(function (tabId) {
|
268
|
+
var ref = tabElementsRef.current.get(tabId);
|
269
|
+
if (!ref) return null;
|
270
|
+
|
271
|
+
// 特性检测:检查是否为 WeakRef 实例
|
272
|
+
if (typeof WeakRef !== 'undefined' && ref instanceof WeakRef) {
|
273
|
+
var element = ref.deref();
|
274
|
+
if (!element) {
|
275
|
+
// 元素已被垃圾回收,清理引用
|
276
|
+
tabElementsRef.current.delete(tabId);
|
277
|
+
return null;
|
278
|
+
}
|
279
|
+
return element;
|
280
|
+
} else {
|
281
|
+
// 降级模式:直接返回元素
|
282
|
+
return ref;
|
283
|
+
}
|
284
|
+
}, []);
|
285
|
+
|
286
|
+
// 优化的滚动函数,包含错误处理和边界检查
|
287
|
+
var scrollToTab = useCallback(function (tabId) {
|
288
|
+
if (!tabId || !railRef.current) {
|
289
|
+
return;
|
290
|
+
}
|
291
|
+
var targetElement = getTabElement(tabId);
|
292
|
+
if (!targetElement) {
|
293
|
+
console.warn("TabsStructure: Tab element with id \"".concat(tabId, "\" not found"));
|
294
|
+
return;
|
295
|
+
}
|
296
|
+
|
297
|
+
// 检查元素是否有有效的offsetParent(即是否在DOM中且可见)
|
298
|
+
if (!targetElement.offsetParent) {
|
299
|
+
console.warn("TabsStructure: Tab element \"".concat(tabId, "\" is not visible or not in DOM"));
|
300
|
+
return;
|
301
|
+
}
|
302
|
+
var rail = railRef.current;
|
303
|
+
var targetLeft = targetElement.offsetLeft;
|
304
|
+
var currentScrollLeft = rail.scrollLeft;
|
305
|
+
|
306
|
+
// 只有当需要滚动时才执行
|
307
|
+
if (Math.abs(targetLeft - currentScrollLeft) > 1) {
|
308
|
+
safeScrollTo(rail, {
|
309
|
+
left: targetLeft,
|
310
|
+
behavior: 'smooth'
|
311
|
+
});
|
312
|
+
}
|
313
|
+
}, [getTabElement]);
|
314
|
+
|
315
|
+
// 自动滚动到选中的tab
|
316
|
+
useEffect(function () {
|
317
|
+
if (autoScrollToSelected && selectedTab) {
|
318
|
+
scrollToTab(selectedTab);
|
319
|
+
}
|
320
|
+
}, [selectedTab, autoScrollToSelected, scrollToTab]);
|
321
|
+
|
322
|
+
// 上下文值
|
323
|
+
var contextValue = useMemo(function () {
|
324
|
+
return {
|
325
|
+
selectedTab: selectedTab,
|
326
|
+
onTabChange: onTabChange,
|
327
|
+
registerTab: registerTab,
|
328
|
+
unregisterTab: unregisterTab,
|
329
|
+
railRef: railRef
|
330
|
+
};
|
331
|
+
}, [selectedTab, onTabChange, registerTab, unregisterTab, railRef]);
|
332
|
+
return /*#__PURE__*/React.createElement(TabContext.Provider, {
|
333
|
+
value: contextValue
|
334
|
+
}, /*#__PURE__*/React.createElement("div", _extends({}, props, {
|
335
|
+
className: classNames(tabWrapperClasses.wrapper, className)
|
336
|
+
}), children));
|
337
|
+
};
|
338
|
+
var TabsStructureWithSubComponents = TabsStructure;
|
339
|
+
TabsStructureWithSubComponents.Rail = Rail;
|
340
|
+
TabsStructureWithSubComponents.ListContainer = TabListContainer;
|
341
|
+
TabsStructureWithSubComponents.Item = TabItem;
|
342
|
+
TabsStructureWithSubComponents.SelectionIndicator = SelectionIndicator;
|
343
|
+
TabsStructureWithSubComponents.ScrollShadow = ScrollShadow;
|
344
|
+
TabsStructureWithSubComponents.ChevronControls = ChevronControls;
|
345
|
+
TabsStructureWithSubComponents.ChevronButton = ChevronButton;
|
346
|
+
TabsStructure.displayName = 'TabsStructure';
|
347
|
+
Rail.displayName = 'TabsStructure.Rail';
|
348
|
+
TabListContainer.displayName = 'TabsStructure.ListContainer';
|
349
|
+
TabItem.displayName = 'TabsStructure.Item';
|
350
|
+
SelectionIndicator.displayName = 'TabsStructure.SelectionIndicator';
|
351
|
+
ScrollShadow.displayName = 'TabsStructure.ScrollShadow';
|
352
|
+
ChevronControls.displayName = 'TabsStructure.ChevronControls';
|
353
|
+
ChevronButton.displayName = 'TabsStructure.ChevronButton';
|
354
|
+
export default TabsStructureWithSubComponents;
|
355
|
+
|
356
|
+
// 导出所有子组件
|
357
|
+
export { TabListContainer, TabItem, Rail, SelectionIndicator, ScrollShadow, ChevronControls, ChevronButton };
|
@@ -0,0 +1,224 @@
|
|
1
|
+
// ===== Mixins =====
|
2
|
+
.pisell-tabstruct-focus-ring() {
|
3
|
+
outline: 2px solid var(--ps-color-primary, #7f56d9);
|
4
|
+
outline-offset: 2px;
|
5
|
+
}
|
6
|
+
|
7
|
+
.pisell-tabstruct-disabled() {
|
8
|
+
opacity: 0.6;
|
9
|
+
cursor: not-allowed;
|
10
|
+
pointer-events: none;
|
11
|
+
}
|
12
|
+
|
13
|
+
.pisell-tabstruct-smooth-scroll() {
|
14
|
+
scroll-behavior: smooth;
|
15
|
+
-webkit-overflow-scrolling: touch;
|
16
|
+
}
|
17
|
+
|
18
|
+
.pisell-tabstruct-hide-scrollbar() {
|
19
|
+
scrollbar-width: none;
|
20
|
+
/* Firefox */
|
21
|
+
-ms-overflow-style: none;
|
22
|
+
/* IE and Edge */
|
23
|
+
|
24
|
+
&::-webkit-scrollbar {
|
25
|
+
display: none;
|
26
|
+
/* Chrome, Safari, Opera */
|
27
|
+
}
|
28
|
+
}
|
29
|
+
|
30
|
+
// ===== Tab Wrapper =====
|
31
|
+
.pisell-tabstruct-wrapper {
|
32
|
+
position: relative;
|
33
|
+
display: flex;
|
34
|
+
align-items: center;
|
35
|
+
inline-size: 100%;
|
36
|
+
box-sizing: border-box;
|
37
|
+
}
|
38
|
+
|
39
|
+
// ===== Tab List =====
|
40
|
+
.pisell-tabstruct-list {
|
41
|
+
padding: 0;
|
42
|
+
margin: 0;
|
43
|
+
display: inline-flex;
|
44
|
+
align-items: center;
|
45
|
+
list-style: none;
|
46
|
+
gap: 8px;
|
47
|
+
border-radius: 20px;
|
48
|
+
}
|
49
|
+
|
50
|
+
// ===== Tab Item =====
|
51
|
+
.pisell-tabstruct-item {
|
52
|
+
position: relative;
|
53
|
+
display: inline-flex;
|
54
|
+
align-items: center;
|
55
|
+
justify-content: center;
|
56
|
+
padding: 0 16px;
|
57
|
+
height: 40px;
|
58
|
+
border: none;
|
59
|
+
background: var(--ps-tab-item-bg, #fff);
|
60
|
+
color: #1b1b1b;
|
61
|
+
font-size: 14px;
|
62
|
+
font-weight: 600;
|
63
|
+
line-height: 1.4;
|
64
|
+
text-decoration: none;
|
65
|
+
cursor: pointer;
|
66
|
+
transition: all 0.2s ease-in-out;
|
67
|
+
white-space: nowrap;
|
68
|
+
user-select: none;
|
69
|
+
// 基础样式采用原pill样式
|
70
|
+
border-radius: 20px;
|
71
|
+
|
72
|
+
// Focus state
|
73
|
+
&:focus-visible {
|
74
|
+
.pisell-tabstruct-focus-ring();
|
75
|
+
}
|
76
|
+
|
77
|
+
&--selected {
|
78
|
+
color: #ffffff;
|
79
|
+
border-radius: 20px;
|
80
|
+
background-color: var(--ps-color-primary, #7f56d9);;
|
81
|
+
}
|
82
|
+
|
83
|
+
&[aria-selected='true'] {
|
84
|
+
color: #ffffff;
|
85
|
+
border-radius: 20px;
|
86
|
+
background-color: var(--ps-color-primary, #7f56d9);;
|
87
|
+
}
|
88
|
+
|
89
|
+
// Disabled state
|
90
|
+
&--disabled {
|
91
|
+
.pisell-tabstruct-disabled();
|
92
|
+
color: #adb5bd;
|
93
|
+
}
|
94
|
+
}
|
95
|
+
|
96
|
+
// ===== Tab Rail =====
|
97
|
+
.pisell-tabstruct-rail {
|
98
|
+
position: relative;
|
99
|
+
display: inline-flex;
|
100
|
+
inline-size: 100%;
|
101
|
+
overflow: auto;
|
102
|
+
scroll-snap-type: x mandatory;
|
103
|
+
.pisell-tabstruct-smooth-scroll();
|
104
|
+
.pisell-tabstruct-hide-scrollbar();
|
105
|
+
}
|
106
|
+
|
107
|
+
// ===== Selection Indicator =====
|
108
|
+
.pisell-tabstruct-selection {
|
109
|
+
position: absolute;
|
110
|
+
z-index: 10;
|
111
|
+
transition: all 0.2s ease-in-out;
|
112
|
+
pointer-events: none;
|
113
|
+
z-index: 0;
|
114
|
+
block-size: 100%;
|
115
|
+
background-color: var(--ps-color-primary, #7f56d9);
|
116
|
+
border-radius: 20px;
|
117
|
+
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
|
118
|
+
|
119
|
+
&--positioned {
|
120
|
+
inset-block-start: auto;
|
121
|
+
inset-block-end: 0;
|
122
|
+
inset-inline-start: 0;
|
123
|
+
}
|
124
|
+
|
125
|
+
&::before {
|
126
|
+
content: '';
|
127
|
+
position: absolute;
|
128
|
+
inset: 2px;
|
129
|
+
border-radius: calc(20px - 2px);
|
130
|
+
}
|
131
|
+
|
132
|
+
&::after {
|
133
|
+
content: '';
|
134
|
+
position: absolute;
|
135
|
+
inset-block-start: 1px;
|
136
|
+
inset-inline-start: 1px;
|
137
|
+
inset-inline-end: 1px;
|
138
|
+
block-size: 50%;
|
139
|
+
background-color: var(--ps-color-primary, #7f56d9);
|
140
|
+
border-radius: 20px 20px 0 0;
|
141
|
+
}
|
142
|
+
|
143
|
+
&--focused {
|
144
|
+
.pisell-tabstruct-focus-ring();
|
145
|
+
}
|
146
|
+
}
|
147
|
+
|
148
|
+
// ===== Scroll Shadow =====
|
149
|
+
.pisell-tabstruct-shadow {
|
150
|
+
position: absolute;
|
151
|
+
z-index: 5;
|
152
|
+
pointer-events: none;
|
153
|
+
opacity: 0;
|
154
|
+
transition: opacity all 0.2s ease-in-out;
|
155
|
+
|
156
|
+
&--visible {
|
157
|
+
opacity: 1;
|
158
|
+
}
|
159
|
+
|
160
|
+
&--start {
|
161
|
+
inset-block-start: 0;
|
162
|
+
inset-block-end: 0;
|
163
|
+
inset-inline-start: 0;
|
164
|
+
inline-size: 20px;
|
165
|
+
background: linear-gradient(90deg, rgba(0, 0, 0, 0.1) 0%, transparent 100%);
|
166
|
+
}
|
167
|
+
|
168
|
+
&--end {
|
169
|
+
inset-block-start: 0;
|
170
|
+
inset-block-end: 0;
|
171
|
+
inset-inline-end: 0;
|
172
|
+
inline-size: 20px;
|
173
|
+
background: linear-gradient(
|
174
|
+
270deg,
|
175
|
+
rgba(0, 0, 0, 0.1) 0%,
|
176
|
+
transparent 100%
|
177
|
+
);
|
178
|
+
}
|
179
|
+
}
|
180
|
+
|
181
|
+
// ===== Chevron Controls =====
|
182
|
+
.pisell-tabstruct-chevron-controls {
|
183
|
+
display: flex;
|
184
|
+
align-items: center;
|
185
|
+
gap: 8px;
|
186
|
+
z-index: 15;
|
187
|
+
}
|
188
|
+
|
189
|
+
.pisell-tabstruct-chevron-button {
|
190
|
+
display: inline-flex;
|
191
|
+
align-items: center;
|
192
|
+
justify-content: center;
|
193
|
+
width: 24px;
|
194
|
+
height: 24px;
|
195
|
+
padding: 0;
|
196
|
+
border: 1px solid transparent;
|
197
|
+
border-radius: 12px;
|
198
|
+
background-color: #f8f9fa;
|
199
|
+
color: #262626;
|
200
|
+
cursor: pointer;
|
201
|
+
transition: all 0.2s ease-in-out;
|
202
|
+
flex-shrink: 0;
|
203
|
+
|
204
|
+
&:hover:not(.pisell-tabstruct-chevron-button--disabled) {
|
205
|
+
background-color: #e9ecef;
|
206
|
+
color: #495057;
|
207
|
+
}
|
208
|
+
|
209
|
+
&:focus-visible {
|
210
|
+
.pisell-tabstruct-focus-ring();
|
211
|
+
}
|
212
|
+
|
213
|
+
&--disabled {
|
214
|
+
.pisell-tabstruct-disabled();
|
215
|
+
color: #adb5bd;
|
216
|
+
background-color: #f2f4f7;
|
217
|
+
}
|
218
|
+
|
219
|
+
svg {
|
220
|
+
font-size: 20px;
|
221
|
+
font-weight: bold;
|
222
|
+
flex-shrink: 0;
|
223
|
+
}
|
224
|
+
}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
/// <reference types="react" />
|
2
|
+
interface UseSelectionIndicatorReturn {
|
3
|
+
selectionIndicatorProps: {
|
4
|
+
focusRingClasses: string;
|
5
|
+
isFocusVisible: boolean;
|
6
|
+
style: React.CSSProperties;
|
7
|
+
};
|
8
|
+
listContainerProps: {
|
9
|
+
onFocus: (event: React.FocusEvent) => void;
|
10
|
+
onBlur: () => void;
|
11
|
+
onMouseDown: () => void;
|
12
|
+
};
|
13
|
+
}
|
14
|
+
/**
|
15
|
+
* Hook for managing selection indicator position with enhanced features
|
16
|
+
* @param containerRef - Ref to the tab container
|
17
|
+
* @param selectedTabId - ID of the currently selected tab (optional)
|
18
|
+
* @param transition - Custom transition string (optional)
|
19
|
+
* @returns Selection indicator props and list container props
|
20
|
+
*/
|
21
|
+
export declare function useSelectionIndicator(containerRef: React.RefObject<HTMLElement>, selectedTabId?: string, transition?: string): UseSelectionIndicatorReturn;
|
22
|
+
export {};
|