@foxford/ui 2.89.0-beta-1917b0e-20251209 → 2.89.0-beta-ef311f9-20251210
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/components/AccordionItem/AccordionItem.js +1 -1
- package/components/AccordionItem/AccordionItem.js.map +1 -1
- package/components/AccordionItem/AccordionItem.mjs +1 -1
- package/components/AccordionItem/AccordionItem.mjs.map +1 -1
- package/components/Alert/Alert.js +1 -1
- package/components/Alert/Alert.js.map +1 -1
- package/components/Alert/Alert.mjs +1 -1
- package/components/Alert/Alert.mjs.map +1 -1
- package/components/Arrow/Arrow.js +1 -1
- package/components/Arrow/Arrow.js.map +1 -1
- package/components/Arrow/Arrow.mjs +1 -1
- package/components/Arrow/Arrow.mjs.map +1 -1
- package/components/Arrow/images/chevronUpDefault.svg.js +2 -0
- package/components/Arrow/images/chevronUpDefault.svg.js.map +1 -0
- package/components/Arrow/images/chevronUpDefault.svg.mjs +2 -0
- package/components/Arrow/images/chevronUpDefault.svg.mjs.map +1 -0
- package/components/Button/Button.js +1 -1
- package/components/Button/Button.js.map +1 -1
- package/components/Button/Button.mjs +1 -1
- package/components/Button/Button.mjs.map +1 -1
- package/components/Checkbox/images/checkDefault.svg.js +2 -0
- package/components/Checkbox/images/checkDefault.svg.js.map +1 -0
- package/components/Checkbox/images/checkDefault.svg.mjs +2 -0
- package/components/Checkbox/images/checkDefault.svg.mjs.map +1 -0
- package/components/Checkbox/style.js +1 -1
- package/components/Checkbox/style.js.map +1 -1
- package/components/Checkbox/style.mjs +1 -1
- package/components/Checkbox/style.mjs.map +1 -1
- package/components/Chip/Chip.js +1 -1
- package/components/Chip/Chip.js.map +1 -1
- package/components/Chip/Chip.mjs +1 -1
- package/components/Chip/Chip.mjs.map +1 -1
- package/components/DialogComponent/DialogComponent.js +1 -1
- package/components/DialogComponent/DialogComponent.js.map +1 -1
- package/components/DialogComponent/DialogComponent.mjs +1 -1
- package/components/DialogComponent/DialogComponent.mjs.map +1 -1
- package/components/Dropdown/Dropdown.js +1 -1
- package/components/Dropdown/Dropdown.js.map +1 -1
- package/components/Dropdown/Dropdown.mjs +1 -1
- package/components/Dropdown/Dropdown.mjs.map +1 -1
- package/components/Dropdown/DropdownMenuNoOptions.js +1 -1
- package/components/Dropdown/DropdownMenuNoOptions.js.map +1 -1
- package/components/Dropdown/DropdownMenuNoOptions.mjs +1 -1
- package/components/Dropdown/DropdownMenuNoOptions.mjs.map +1 -1
- package/components/Dropdown/style.js +1 -1
- package/components/Dropdown/style.js.map +1 -1
- package/components/Dropdown/style.mjs +1 -1
- package/components/Dropdown/style.mjs.map +1 -1
- package/components/FormLabel/FormLabel.js +1 -1
- package/components/FormLabel/FormLabel.js.map +1 -1
- package/components/FormLabel/FormLabel.mjs +1 -1
- package/components/FormLabel/FormLabel.mjs.map +1 -1
- package/components/Icon/Icon.js +1 -1
- package/components/Icon/Icon.js.map +1 -1
- package/components/Icon/Icon.mjs +1 -1
- package/components/Icon/Icon.mjs.map +1 -1
- package/components/Icon/iconPack.js +2 -0
- package/components/Icon/iconPack.js.map +1 -0
- package/components/Icon/iconPack.mjs +2 -0
- package/components/Icon/iconPack.mjs.map +1 -0
- package/components/Icon/iconsDefault.js +2 -0
- package/components/Icon/iconsDefault.js.map +1 -0
- package/components/Icon/iconsDefault.mjs +2 -0
- package/components/Icon/iconsDefault.mjs.map +1 -0
- package/components/Icon/images/blackBoard_default.svg.js +2 -0
- package/components/Icon/images/blackBoard_default.svg.js.map +1 -0
- package/components/Icon/images/blackBoard_default.svg.mjs +2 -0
- package/components/Icon/images/blackBoard_default.svg.mjs.map +1 -0
- package/components/Icon/images/book_default.svg.js +2 -0
- package/components/Icon/images/book_default.svg.js.map +1 -0
- package/components/Icon/images/book_default.svg.mjs +2 -0
- package/components/Icon/images/book_default.svg.mjs.map +1 -0
- package/components/Icon/images/burger_default.svg.js +2 -0
- package/components/Icon/images/burger_default.svg.js.map +1 -0
- package/components/Icon/images/burger_default.svg.mjs +2 -0
- package/components/Icon/images/burger_default.svg.mjs.map +1 -0
- package/components/Icon/images/calendar_default.svg.js +2 -0
- package/components/Icon/images/calendar_default.svg.js.map +1 -0
- package/components/Icon/images/calendar_default.svg.mjs +2 -0
- package/components/Icon/images/calendar_default.svg.mjs.map +1 -0
- package/components/Icon/images/calendar_simple_default.svg.js +2 -0
- package/components/Icon/images/calendar_simple_default.svg.js.map +1 -0
- package/components/Icon/images/calendar_simple_default.svg.mjs +2 -0
- package/components/Icon/images/calendar_simple_default.svg.mjs.map +1 -0
- package/components/Icon/images/camps_default.svg.js +2 -0
- package/components/Icon/images/camps_default.svg.js.map +1 -0
- package/components/Icon/images/camps_default.svg.mjs +2 -0
- package/components/Icon/images/camps_default.svg.mjs.map +1 -0
- package/components/Icon/images/cancel_default.svg.js +2 -0
- package/components/Icon/images/cancel_default.svg.js.map +1 -0
- package/components/Icon/images/cancel_default.svg.mjs +2 -0
- package/components/Icon/images/cancel_default.svg.mjs.map +1 -0
- package/components/Icon/images/cart_default.svg.js +2 -0
- package/components/Icon/images/cart_default.svg.js.map +1 -0
- package/components/Icon/images/cart_default.svg.mjs +2 -0
- package/components/Icon/images/cart_default.svg.mjs.map +1 -0
- package/components/Icon/images/checkCircle_default.svg.js +2 -0
- package/components/Icon/images/checkCircle_default.svg.js.map +1 -0
- package/components/Icon/images/checkCircle_default.svg.mjs +2 -0
- package/components/Icon/images/checkCircle_default.svg.mjs.map +1 -0
- package/components/Icon/images/check_default.svg.js +2 -0
- package/components/Icon/images/check_default.svg.js.map +1 -0
- package/components/Icon/images/check_default.svg.mjs +2 -0
- package/components/Icon/images/check_default.svg.mjs.map +1 -0
- package/components/Icon/images/chevronDown_default.svg.js +2 -0
- package/components/Icon/images/chevronDown_default.svg.js.map +1 -0
- package/components/Icon/images/chevronDown_default.svg.mjs +2 -0
- package/components/Icon/images/chevronDown_default.svg.mjs.map +1 -0
- package/components/Icon/images/chevronLeft_default.svg.js +2 -0
- package/components/Icon/images/chevronLeft_default.svg.js.map +1 -0
- package/components/Icon/images/chevronLeft_default.svg.mjs +2 -0
- package/components/Icon/images/chevronLeft_default.svg.mjs.map +1 -0
- package/components/Icon/images/chevronRight_default.svg.js +2 -0
- package/components/Icon/images/chevronRight_default.svg.js.map +1 -0
- package/components/Icon/images/chevronRight_default.svg.mjs +2 -0
- package/components/Icon/images/chevronRight_default.svg.mjs.map +1 -0
- package/components/Icon/images/chevronUp_default.svg.js +2 -0
- package/components/Icon/images/chevronUp_default.svg.js.map +1 -0
- package/components/Icon/images/chevronUp_default.svg.mjs +2 -0
- package/components/Icon/images/chevronUp_default.svg.mjs.map +1 -0
- package/components/Icon/images/clockFilled_default.svg.js +2 -0
- package/components/Icon/images/clockFilled_default.svg.js.map +1 -0
- package/components/Icon/images/clockFilled_default.svg.mjs +2 -0
- package/components/Icon/images/clockFilled_default.svg.mjs.map +1 -0
- package/components/Icon/images/clock_default.svg.js +2 -0
- package/components/Icon/images/clock_default.svg.js.map +1 -0
- package/components/Icon/images/clock_default.svg.mjs +2 -0
- package/components/Icon/images/clock_default.svg.mjs.map +1 -0
- package/components/Icon/images/coins_default.svg.js +2 -0
- package/components/Icon/images/coins_default.svg.js.map +1 -0
- package/components/Icon/images/coins_default.svg.mjs +2 -0
- package/components/Icon/images/coins_default.svg.mjs.map +1 -0
- package/components/Icon/images/copy_default.svg.js +2 -0
- package/components/Icon/images/copy_default.svg.js.map +1 -0
- package/components/Icon/images/copy_default.svg.mjs +2 -0
- package/components/Icon/images/copy_default.svg.mjs.map +1 -0
- package/components/Icon/images/courses_default.svg.js +2 -0
- package/components/Icon/images/courses_default.svg.js.map +1 -0
- package/components/Icon/images/courses_default.svg.mjs +2 -0
- package/components/Icon/images/courses_default.svg.mjs.map +1 -0
- package/components/Icon/images/cross_default.svg.js +2 -0
- package/components/Icon/images/cross_default.svg.js.map +1 -0
- package/components/Icon/images/cross_default.svg.mjs +2 -0
- package/components/Icon/images/cross_default.svg.mjs.map +1 -0
- package/components/Icon/images/dialog_default.svg.js +2 -0
- package/components/Icon/images/dialog_default.svg.js.map +1 -0
- package/components/Icon/images/dialog_default.svg.mjs +2 -0
- package/components/Icon/images/dialog_default.svg.mjs.map +1 -0
- package/components/Icon/images/diamondFilled_default.svg.js +2 -0
- package/components/Icon/images/diamondFilled_default.svg.js.map +1 -0
- package/components/Icon/images/diamondFilled_default.svg.mjs +2 -0
- package/components/Icon/images/diamondFilled_default.svg.mjs.map +1 -0
- package/components/Icon/images/diamond_default.svg.js +2 -0
- package/components/Icon/images/diamond_default.svg.js.map +1 -0
- package/components/Icon/images/diamond_default.svg.mjs +2 -0
- package/components/Icon/images/diamond_default.svg.mjs.map +1 -0
- package/components/Icon/images/discount_default.svg.js +2 -0
- package/components/Icon/images/discount_default.svg.js.map +1 -0
- package/components/Icon/images/discount_default.svg.mjs +2 -0
- package/components/Icon/images/discount_default.svg.mjs.map +1 -0
- package/components/Icon/images/document_default.svg.js +2 -0
- package/components/Icon/images/document_default.svg.js.map +1 -0
- package/components/Icon/images/document_default.svg.mjs +2 -0
- package/components/Icon/images/document_default.svg.mjs.map +1 -0
- package/components/Icon/images/dropDownArrow_default.svg.js +2 -0
- package/components/Icon/images/dropDownArrow_default.svg.js.map +1 -0
- package/components/Icon/images/dropDownArrow_default.svg.mjs +2 -0
- package/components/Icon/images/dropDownArrow_default.svg.mjs.map +1 -0
- package/components/Icon/images/edit_default.svg.js +2 -0
- package/components/Icon/images/edit_default.svg.js.map +1 -0
- package/components/Icon/images/edit_default.svg.mjs +2 -0
- package/components/Icon/images/edit_default.svg.mjs.map +1 -0
- package/components/Icon/images/email_default.svg.js +2 -0
- package/components/Icon/images/email_default.svg.js.map +1 -0
- package/components/Icon/images/email_default.svg.mjs +2 -0
- package/components/Icon/images/email_default.svg.mjs.map +1 -0
- package/components/Icon/images/externalLink_default.svg.js +2 -0
- package/components/Icon/images/externalLink_default.svg.js.map +1 -0
- package/components/Icon/images/externalLink_default.svg.mjs +2 -0
- package/components/Icon/images/externalLink_default.svg.mjs.map +1 -0
- package/components/Icon/images/externat_default.svg.js +2 -0
- package/components/Icon/images/externat_default.svg.js.map +1 -0
- package/components/Icon/images/externat_default.svg.mjs +2 -0
- package/components/Icon/images/externat_default.svg.mjs.map +1 -0
- package/components/Icon/images/eye_default.svg.js +2 -0
- package/components/Icon/images/eye_default.svg.js.map +1 -0
- package/components/Icon/images/eye_default.svg.mjs +2 -0
- package/components/Icon/images/eye_default.svg.mjs.map +1 -0
- package/components/Icon/images/fileBordered_default.svg.js +2 -0
- package/components/Icon/images/fileBordered_default.svg.js.map +1 -0
- package/components/Icon/images/fileBordered_default.svg.mjs +2 -0
- package/components/Icon/images/fileBordered_default.svg.mjs.map +1 -0
- package/components/Icon/images/file_default.svg.js +2 -0
- package/components/Icon/images/file_default.svg.js.map +1 -0
- package/components/Icon/images/file_default.svg.mjs +2 -0
- package/components/Icon/images/file_default.svg.mjs.map +1 -0
- package/components/Icon/images/fire_default.svg.js +2 -0
- package/components/Icon/images/fire_default.svg.js.map +1 -0
- package/components/Icon/images/fire_default.svg.mjs +2 -0
- package/components/Icon/images/fire_default.svg.mjs.map +1 -0
- package/components/Icon/images/headphones_default.svg.js +2 -0
- package/components/Icon/images/headphones_default.svg.js.map +1 -0
- package/components/Icon/images/headphones_default.svg.mjs +2 -0
- package/components/Icon/images/headphones_default.svg.mjs.map +1 -0
- package/components/Icon/images/home_default.svg.js +2 -0
- package/components/Icon/images/home_default.svg.js.map +1 -0
- package/components/Icon/images/home_default.svg.mjs +2 -0
- package/components/Icon/images/home_default.svg.mjs.map +1 -0
- package/components/Icon/images/infoInverse_default.svg.js +2 -0
- package/components/Icon/images/infoInverse_default.svg.js.map +1 -0
- package/components/Icon/images/infoInverse_default.svg.mjs +2 -0
- package/components/Icon/images/infoInverse_default.svg.mjs.map +1 -0
- package/components/Icon/images/info_default.svg.js +2 -0
- package/components/Icon/images/info_default.svg.js.map +1 -0
- package/components/Icon/images/info_default.svg.mjs +2 -0
- package/components/Icon/images/info_default.svg.mjs.map +1 -0
- package/components/Icon/images/lessons_default.svg.js +2 -0
- package/components/Icon/images/lessons_default.svg.js.map +1 -0
- package/components/Icon/images/lessons_default.svg.mjs +2 -0
- package/components/Icon/images/lessons_default.svg.mjs.map +1 -0
- package/components/Icon/images/list_default.svg.js +2 -0
- package/components/Icon/images/list_default.svg.js.map +1 -0
- package/components/Icon/images/list_default.svg.mjs +2 -0
- package/components/Icon/images/list_default.svg.mjs.map +1 -0
- package/components/Icon/images/login_default.svg.js +2 -0
- package/components/Icon/images/login_default.svg.js.map +1 -0
- package/components/Icon/images/login_default.svg.mjs +2 -0
- package/components/Icon/images/login_default.svg.mjs.map +1 -0
- package/components/Icon/images/logout_default.svg.js +2 -0
- package/components/Icon/images/logout_default.svg.js.map +1 -0
- package/components/Icon/images/logout_default.svg.mjs +2 -0
- package/components/Icon/images/logout_default.svg.mjs.map +1 -0
- package/components/Icon/images/message_default.svg.js +2 -0
- package/components/Icon/images/message_default.svg.js.map +1 -0
- package/components/Icon/images/message_default.svg.mjs +2 -0
- package/components/Icon/images/message_default.svg.mjs.map +1 -0
- package/components/Icon/images/objective_default.svg.js +2 -0
- package/components/Icon/images/objective_default.svg.js.map +1 -0
- package/components/Icon/images/objective_default.svg.mjs +2 -0
- package/components/Icon/images/objective_default.svg.mjs.map +1 -0
- package/components/Icon/images/page_default.svg.js +2 -0
- package/components/Icon/images/page_default.svg.js.map +1 -0
- package/components/Icon/images/page_default.svg.mjs +2 -0
- package/components/Icon/images/page_default.svg.mjs.map +1 -0
- package/components/Icon/images/pencil_default.svg.js +2 -0
- package/components/Icon/images/pencil_default.svg.js.map +1 -0
- package/components/Icon/images/pencil_default.svg.mjs +2 -0
- package/components/Icon/images/pencil_default.svg.mjs.map +1 -0
- package/components/Icon/images/person_default.svg.js +2 -0
- package/components/Icon/images/person_default.svg.js.map +1 -0
- package/components/Icon/images/person_default.svg.mjs +2 -0
- package/components/Icon/images/person_default.svg.mjs.map +1 -0
- package/components/Icon/images/phoneNoFill_default.svg.js +2 -0
- package/components/Icon/images/phoneNoFill_default.svg.js.map +1 -0
- package/components/Icon/images/phoneNoFill_default.svg.mjs +2 -0
- package/components/Icon/images/phoneNoFill_default.svg.mjs.map +1 -0
- package/components/Icon/images/phone_default.svg.js +2 -0
- package/components/Icon/images/phone_default.svg.js.map +1 -0
- package/components/Icon/images/phone_default.svg.mjs +2 -0
- package/components/Icon/images/phone_default.svg.mjs.map +1 -0
- package/components/Icon/images/playPause_default.svg.js +2 -0
- package/components/Icon/images/playPause_default.svg.js.map +1 -0
- package/components/Icon/images/playPause_default.svg.mjs +2 -0
- package/components/Icon/images/playPause_default.svg.mjs.map +1 -0
- package/components/Icon/images/play_default.svg.js +2 -0
- package/components/Icon/images/play_default.svg.js.map +1 -0
- package/components/Icon/images/play_default.svg.mjs +2 -0
- package/components/Icon/images/play_default.svg.mjs.map +1 -0
- package/components/Icon/images/plusThin_default.svg.js +2 -0
- package/components/Icon/images/plusThin_default.svg.js.map +1 -0
- package/components/Icon/images/plusThin_default.svg.mjs +2 -0
- package/components/Icon/images/plusThin_default.svg.mjs.map +1 -0
- package/components/Icon/images/plus_default.svg.js +2 -0
- package/components/Icon/images/plus_default.svg.js.map +1 -0
- package/components/Icon/images/plus_default.svg.mjs +2 -0
- package/components/Icon/images/plus_default.svg.mjs.map +1 -0
- package/components/Icon/images/present_default.svg.js +2 -0
- package/components/Icon/images/present_default.svg.js.map +1 -0
- package/components/Icon/images/present_default.svg.mjs +2 -0
- package/components/Icon/images/present_default.svg.mjs.map +1 -0
- package/components/Icon/images/priceTag_default.svg.js +2 -0
- package/components/Icon/images/priceTag_default.svg.js.map +1 -0
- package/components/Icon/images/priceTag_default.svg.mjs +2 -0
- package/components/Icon/images/priceTag_default.svg.mjs.map +1 -0
- package/components/Icon/images/print_default.svg.js +2 -0
- package/components/Icon/images/print_default.svg.js.map +1 -0
- package/components/Icon/images/print_default.svg.mjs +2 -0
- package/components/Icon/images/print_default.svg.mjs.map +1 -0
- package/components/Icon/images/prof_default.svg.js +2 -0
- package/components/Icon/images/prof_default.svg.js.map +1 -0
- package/components/Icon/images/prof_default.svg.mjs +2 -0
- package/components/Icon/images/prof_default.svg.mjs.map +1 -0
- package/components/Icon/images/questionFilled_default.svg.js +2 -0
- package/components/Icon/images/questionFilled_default.svg.js.map +1 -0
- package/components/Icon/images/questionFilled_default.svg.mjs +2 -0
- package/components/Icon/images/questionFilled_default.svg.mjs.map +1 -0
- package/components/Icon/images/radioChecked_default.svg.js +2 -0
- package/components/Icon/images/radioChecked_default.svg.js.map +1 -0
- package/components/Icon/images/radioChecked_default.svg.mjs +2 -0
- package/components/Icon/images/radioChecked_default.svg.mjs.map +1 -0
- package/components/Icon/images/radioNotChecked_default.svg.js +2 -0
- package/components/Icon/images/radioNotChecked_default.svg.js.map +1 -0
- package/components/Icon/images/radioNotChecked_default.svg.mjs +2 -0
- package/components/Icon/images/radioNotChecked_default.svg.mjs.map +1 -0
- package/components/Icon/images/reload_default.svg.js +2 -0
- package/components/Icon/images/reload_default.svg.js.map +1 -0
- package/components/Icon/images/reload_default.svg.mjs +2 -0
- package/components/Icon/images/reload_default.svg.mjs.map +1 -0
- package/components/Icon/images/search_default.svg.js +2 -0
- package/components/Icon/images/search_default.svg.js.map +1 -0
- package/components/Icon/images/search_default.svg.mjs +2 -0
- package/components/Icon/images/search_default.svg.mjs.map +1 -0
- package/components/Icon/images/settings_default.svg.js +2 -0
- package/components/Icon/images/settings_default.svg.js.map +1 -0
- package/components/Icon/images/settings_default.svg.mjs +2 -0
- package/components/Icon/images/settings_default.svg.mjs.map +1 -0
- package/components/Icon/images/sharpCross_default.svg.js +2 -0
- package/components/Icon/images/sharpCross_default.svg.js.map +1 -0
- package/components/Icon/images/sharpCross_default.svg.mjs +2 -0
- package/components/Icon/images/sharpCross_default.svg.mjs.map +1 -0
- package/components/Icon/images/sort_default.svg.js +2 -0
- package/components/Icon/images/sort_default.svg.js.map +1 -0
- package/components/Icon/images/sort_default.svg.mjs +2 -0
- package/components/Icon/images/sort_default.svg.mjs.map +1 -0
- package/components/Icon/images/star_default.svg.js +2 -0
- package/components/Icon/images/star_default.svg.js.map +1 -0
- package/components/Icon/images/star_default.svg.mjs +2 -0
- package/components/Icon/images/star_default.svg.mjs.map +1 -0
- package/components/Icon/images/student_default.svg.js +2 -0
- package/components/Icon/images/student_default.svg.js.map +1 -0
- package/components/Icon/images/student_default.svg.mjs +2 -0
- package/components/Icon/images/student_default.svg.mjs.map +1 -0
- package/components/Icon/images/target_default.svg.js +2 -0
- package/components/Icon/images/target_default.svg.js.map +1 -0
- package/components/Icon/images/target_default.svg.mjs +2 -0
- package/components/Icon/images/target_default.svg.mjs.map +1 -0
- package/components/Icon/images/tasks_default.svg.js +2 -0
- package/components/Icon/images/tasks_default.svg.js.map +1 -0
- package/components/Icon/images/tasks_default.svg.mjs +2 -0
- package/components/Icon/images/tasks_default.svg.mjs.map +1 -0
- package/components/Icon/images/textbook_default.svg.js +2 -0
- package/components/Icon/images/textbook_default.svg.js.map +1 -0
- package/components/Icon/images/textbook_default.svg.mjs +2 -0
- package/components/Icon/images/textbook_default.svg.mjs.map +1 -0
- package/components/Icon/images/tinyCross_default.svg.js +2 -0
- package/components/Icon/images/tinyCross_default.svg.js.map +1 -0
- package/components/Icon/images/tinyCross_default.svg.mjs +2 -0
- package/components/Icon/images/tinyCross_default.svg.mjs.map +1 -0
- package/components/Icon/images/trophy_default.svg.js +2 -0
- package/components/Icon/images/trophy_default.svg.js.map +1 -0
- package/components/Icon/images/trophy_default.svg.mjs +2 -0
- package/components/Icon/images/trophy_default.svg.mjs.map +1 -0
- package/components/Icon/images/unsort_default.svg.js +2 -0
- package/components/Icon/images/unsort_default.svg.js.map +1 -0
- package/components/Icon/images/unsort_default.svg.mjs +2 -0
- package/components/Icon/images/unsort_default.svg.mjs.map +1 -0
- package/components/Icon/images/video_default.svg.js +2 -0
- package/components/Icon/images/video_default.svg.js.map +1 -0
- package/components/Icon/images/video_default.svg.mjs +2 -0
- package/components/Icon/images/video_default.svg.mjs.map +1 -0
- package/components/Icon/images/wallet_default.svg.js +2 -0
- package/components/Icon/images/wallet_default.svg.js.map +1 -0
- package/components/Icon/images/wallet_default.svg.mjs +2 -0
- package/components/Icon/images/wallet_default.svg.mjs.map +1 -0
- package/components/Icon/sizes.js +2 -0
- package/components/Icon/sizes.js.map +1 -0
- package/components/Icon/sizes.mjs +2 -0
- package/components/Icon/sizes.mjs.map +1 -0
- package/components/Icon/style.js +1 -1
- package/components/Icon/style.js.map +1 -1
- package/components/Icon/style.mjs +1 -1
- package/components/Icon/style.mjs.map +1 -1
- package/components/Input/Input.js +1 -1
- package/components/Input/Input.js.map +1 -1
- package/components/Input/Input.mjs +1 -1
- package/components/Input/Input.mjs.map +1 -1
- package/components/InputCheckbox/style.js +1 -1
- package/components/InputCheckbox/style.js.map +1 -1
- package/components/InputCheckbox/style.mjs +1 -1
- package/components/InputCheckbox/style.mjs.map +1 -1
- package/components/MenuContainer/MenuContainer.js +1 -1
- package/components/MenuContainer/MenuContainer.js.map +1 -1
- package/components/MenuContainer/MenuContainer.mjs +1 -1
- package/components/MenuContainer/MenuContainer.mjs.map +1 -1
- package/components/Modal/Close.js +1 -1
- package/components/Modal/Close.js.map +1 -1
- package/components/Modal/Close.mjs +1 -1
- package/components/Modal/Close.mjs.map +1 -1
- package/components/Modal/images/tinyCrossDefault.svg.js +2 -0
- package/components/Modal/images/tinyCrossDefault.svg.js.map +1 -0
- package/components/Modal/images/tinyCrossDefault.svg.mjs +2 -0
- package/components/Modal/images/tinyCrossDefault.svg.mjs.map +1 -0
- package/components/Notification/Notification.js +1 -1
- package/components/Notification/Notification.js.map +1 -1
- package/components/Notification/Notification.mjs +1 -1
- package/components/Notification/Notification.mjs.map +1 -1
- package/components/Notification/constants.js +2 -0
- package/components/Notification/constants.js.map +1 -0
- package/components/Notification/constants.mjs +2 -0
- package/components/Notification/constants.mjs.map +1 -0
- package/components/Notification/style.js +1 -1
- package/components/Notification/style.js.map +1 -1
- package/components/Notification/style.mjs +1 -1
- package/components/Notification/style.mjs.map +1 -1
- package/components/PopoverComponent/PopoverComponent.js +1 -1
- package/components/PopoverComponent/PopoverComponent.js.map +1 -1
- package/components/PopoverComponent/PopoverComponent.mjs +1 -1
- package/components/PopoverComponent/PopoverComponent.mjs.map +1 -1
- package/components/ProgressLine/ProgressLine.js +1 -1
- package/components/ProgressLine/ProgressLine.js.map +1 -1
- package/components/ProgressLine/ProgressLine.mjs +1 -1
- package/components/ProgressLine/ProgressLine.mjs.map +1 -1
- package/components/ProgressLine/style.js +1 -1
- package/components/ProgressLine/style.js.map +1 -1
- package/components/ProgressLine/style.mjs +1 -1
- package/components/ProgressLine/style.mjs.map +1 -1
- package/components/TabList/TabList.js +1 -1
- package/components/TabList/TabList.js.map +1 -1
- package/components/TabList/TabList.mjs +1 -1
- package/components/TabList/TabList.mjs.map +1 -1
- package/components/TabList/TabListMenuTab.js +1 -1
- package/components/TabList/TabListMenuTab.js.map +1 -1
- package/components/TabList/TabListMenuTab.mjs +1 -1
- package/components/TabList/TabListMenuTab.mjs.map +1 -1
- package/components/Textarea/Textarea.js +1 -1
- package/components/Textarea/Textarea.js.map +1 -1
- package/components/Textarea/Textarea.mjs +1 -1
- package/components/Textarea/Textarea.mjs.map +1 -1
- package/components/TooltipComponent/TooltipComponent.js +1 -1
- package/components/TooltipComponent/TooltipComponent.js.map +1 -1
- package/components/TooltipComponent/TooltipComponent.mjs +1 -1
- package/components/TooltipComponent/TooltipComponent.mjs.map +1 -1
- package/dts/index.d.ts +1959 -350
- package/icon-pack/src/collection.json.js +2 -0
- package/icon-pack/src/collection.json.js.map +1 -0
- package/icon-pack/src/collection.json.mjs +2 -0
- package/icon-pack/src/collection.json.mjs.map +1 -0
- package/icon-pack/src/icons/ArrowUp/index.js +2 -0
- package/icon-pack/src/icons/ArrowUp/index.js.map +1 -0
- package/icon-pack/src/icons/ArrowUp/index.mjs +2 -0
- package/icon-pack/src/icons/ArrowUp/index.mjs.map +1 -0
- package/icon-pack/src/icons/CheckCircle/index.js +2 -0
- package/icon-pack/src/icons/CheckCircle/index.js.map +1 -0
- package/icon-pack/src/icons/CheckCircle/index.mjs +2 -0
- package/icon-pack/src/icons/CheckCircle/index.mjs.map +1 -0
- package/icon-pack/src/icons/CheckCircleFill/index.js +2 -0
- package/icon-pack/src/icons/CheckCircleFill/index.js.map +1 -0
- package/icon-pack/src/icons/CheckCircleFill/index.mjs +2 -0
- package/icon-pack/src/icons/CheckCircleFill/index.mjs.map +1 -0
- package/icon-pack/src/icons/CheckFill/index.js +2 -0
- package/icon-pack/src/icons/CheckFill/index.js.map +1 -0
- package/icon-pack/src/icons/CheckFill/index.mjs +2 -0
- package/icon-pack/src/icons/CheckFill/index.mjs.map +1 -0
- package/icon-pack/src/icons/ChevronDown/index.js +2 -0
- package/icon-pack/src/icons/ChevronDown/index.js.map +1 -0
- package/icon-pack/src/icons/ChevronDown/index.mjs +2 -0
- package/icon-pack/src/icons/ChevronDown/index.mjs.map +1 -0
- package/icon-pack/src/icons/ChevronLeft/index.js +2 -0
- package/icon-pack/src/icons/ChevronLeft/index.js.map +1 -0
- package/icon-pack/src/icons/ChevronLeft/index.mjs +2 -0
- package/icon-pack/src/icons/ChevronLeft/index.mjs.map +1 -0
- package/icon-pack/src/icons/ChevronRight/index.js +2 -0
- package/icon-pack/src/icons/ChevronRight/index.js.map +1 -0
- package/icon-pack/src/icons/ChevronRight/index.mjs +2 -0
- package/icon-pack/src/icons/ChevronRight/index.mjs.map +1 -0
- package/icon-pack/src/icons/Close/index.js +2 -0
- package/icon-pack/src/icons/Close/index.js.map +1 -0
- package/icon-pack/src/icons/Close/index.mjs +2 -0
- package/icon-pack/src/icons/Close/index.mjs.map +1 -0
- package/icon-pack/src/icons/CloseCirlce/index.js +2 -0
- package/icon-pack/src/icons/CloseCirlce/index.js.map +1 -0
- package/icon-pack/src/icons/CloseCirlce/index.mjs +2 -0
- package/icon-pack/src/icons/CloseCirlce/index.mjs.map +1 -0
- package/icon-pack/src/icons/CloseCirlceFill/index.js +2 -0
- package/icon-pack/src/icons/CloseCirlceFill/index.js.map +1 -0
- package/icon-pack/src/icons/CloseCirlceFill/index.mjs +2 -0
- package/icon-pack/src/icons/CloseCirlceFill/index.mjs.map +1 -0
- package/icon-pack/src/icons/HelpCircle/index.js +2 -0
- package/icon-pack/src/icons/HelpCircle/index.js.map +1 -0
- package/icon-pack/src/icons/HelpCircle/index.mjs +2 -0
- package/icon-pack/src/icons/HelpCircle/index.mjs.map +1 -0
- package/icon-pack/src/icons/InfoCircle/index.js +2 -0
- package/icon-pack/src/icons/InfoCircle/index.js.map +1 -0
- package/icon-pack/src/icons/InfoCircle/index.mjs +2 -0
- package/icon-pack/src/icons/InfoCircle/index.mjs.map +1 -0
- package/icon-pack/src/icons/LoaderFill/index.js +2 -0
- package/icon-pack/src/icons/LoaderFill/index.js.map +1 -0
- package/icon-pack/src/icons/LoaderFill/index.mjs +2 -0
- package/icon-pack/src/icons/LoaderFill/index.mjs.map +1 -0
- package/icon-pack/src/icons/Minus/index.js +2 -0
- package/icon-pack/src/icons/Minus/index.js.map +1 -0
- package/icon-pack/src/icons/Minus/index.mjs +2 -0
- package/icon-pack/src/icons/Minus/index.mjs.map +1 -0
- package/icon-pack/src/icons/MinusFill/index.js +2 -0
- package/icon-pack/src/icons/MinusFill/index.js.map +1 -0
- package/icon-pack/src/icons/MinusFill/index.mjs +2 -0
- package/icon-pack/src/icons/MinusFill/index.mjs.map +1 -0
- package/icon-pack/src/icons/NotifFill/index.js +2 -0
- package/icon-pack/src/icons/NotifFill/index.js.map +1 -0
- package/icon-pack/src/icons/NotifFill/index.mjs +2 -0
- package/icon-pack/src/icons/NotifFill/index.mjs.map +1 -0
- package/icon-pack/src/icons/Plus/index.js +2 -0
- package/icon-pack/src/icons/Plus/index.js.map +1 -0
- package/icon-pack/src/icons/Plus/index.mjs +2 -0
- package/icon-pack/src/icons/Plus/index.mjs.map +1 -0
- package/icon-pack/src/icons/Redo/index.js +2 -0
- package/icon-pack/src/icons/Redo/index.js.map +1 -0
- package/icon-pack/src/icons/Redo/index.mjs +2 -0
- package/icon-pack/src/icons/Redo/index.mjs.map +1 -0
- package/icon-pack/src/icons/ResizeHandle/index.js +2 -0
- package/icon-pack/src/icons/ResizeHandle/index.js.map +1 -0
- package/icon-pack/src/icons/ResizeHandle/index.mjs +2 -0
- package/icon-pack/src/icons/ResizeHandle/index.mjs.map +1 -0
- package/icon-pack/src/icons/StarFill/index.js +2 -0
- package/icon-pack/src/icons/StarFill/index.js.map +1 -0
- package/icon-pack/src/icons/StarFill/index.mjs +2 -0
- package/icon-pack/src/icons/StarFill/index.mjs.map +1 -0
- package/icon-pack/src/icons/WarningTriangle/index.js +2 -0
- package/icon-pack/src/icons/WarningTriangle/index.js.map +1 -0
- package/icon-pack/src/icons/WarningTriangle/index.mjs +2 -0
- package/icon-pack/src/icons/WarningTriangle/index.mjs.map +1 -0
- package/icon-pack/src/icons/WarningTriangleFill/index.js +2 -0
- package/icon-pack/src/icons/WarningTriangleFill/index.js.map +1 -0
- package/icon-pack/src/icons/WarningTriangleFill/index.mjs +2 -0
- package/icon-pack/src/icons/WarningTriangleFill/index.mjs.map +1 -0
- package/package.json +4 -9
- package/assets/add-reaction.svg +0 -1
- package/assets/afghanistan.svg +0 -1
- package/assets/airplay.svg +0 -1
- package/assets/aland-islands.svg +0 -1
- package/assets/alarm-add.svg +0 -1
- package/assets/alarm-clock.svg +0 -1
- package/assets/alarm-warning.svg +0 -1
- package/assets/albania.svg +0 -1
- package/assets/algebra.svg +0 -1
- package/assets/algeria.svg +0 -1
- package/assets/algorithms_color.svg +0 -1
- package/assets/align-center-justify.svg +0 -1
- package/assets/align-center.svg +0 -1
- package/assets/align-justify.svg +0 -1
- package/assets/align-left-justify.svg +0 -1
- package/assets/align-left.svg +0 -1
- package/assets/align-right-justify.svg +0 -1
- package/assets/align-right.svg +0 -1
- package/assets/american-samoa.svg +0 -1
- package/assets/analytics_2_color.svg +0 -1
- package/assets/analytics_3_color.svg +0 -1
- package/assets/analytics_color.svg +0 -1
- package/assets/andorra.svg +0 -1
- package/assets/angola.svg +0 -1
- package/assets/anguilla.svg +0 -1
- package/assets/annotation-user.svg +0 -1
- package/assets/annotation.svg +0 -1
- package/assets/antigua-and-barbuda.svg +0 -1
- package/assets/apple-auth-mono-color.svg +0 -1
- package/assets/apple-authorization.svg +0 -1
- package/assets/archive.svg +0 -1
- package/assets/archive_color.svg +0 -1
- package/assets/argentina.svg +0 -1
- package/assets/armenia.svg +0 -1
- package/assets/arrow-circle-down-fill-tin-fill.svg +0 -1
- package/assets/arrow-circle-down-fill.svg +0 -1
- package/assets/arrow-circle-down-left-fill-tin-fill.svg +0 -1
- package/assets/arrow-circle-down-left-fill.svg +0 -1
- package/assets/arrow-circle-down-left.svg +0 -1
- package/assets/arrow-circle-down-right-fill-tin-fill.svg +0 -1
- package/assets/arrow-circle-down-right-fill.svg +0 -1
- package/assets/arrow-circle-down-right.svg +0 -1
- package/assets/arrow-circle-down.svg +0 -1
- package/assets/arrow-circle-left-fill-tin-fill.svg +0 -1
- package/assets/arrow-circle-left-fill.svg +0 -1
- package/assets/arrow-circle-left.svg +0 -1
- package/assets/arrow-circle-right-fill-tin-fill.svg +0 -1
- package/assets/arrow-circle-right-fill.svg +0 -1
- package/assets/arrow-circle-right.svg +0 -1
- package/assets/arrow-circle-up-fill-tin-fill.svg +0 -1
- package/assets/arrow-circle-up-fill.svg +0 -1
- package/assets/arrow-circle-up-left-fill-tin-fill.svg +0 -1
- package/assets/arrow-circle-up-left-fill.svg +0 -1
- package/assets/arrow-circle-up-left.svg +0 -1
- package/assets/arrow-circle-up-right-fill-tin-fill.svg +0 -1
- package/assets/arrow-circle-up-right-fill.svg +0 -1
- package/assets/arrow-circle-up-right.svg +0 -1
- package/assets/arrow-circle-up.svg +0 -1
- package/assets/arrow-down-arrow-up.svg +0 -1
- package/assets/arrow-down-fill.svg +0 -1
- package/assets/arrow-down-left-fill.svg +0 -1
- package/assets/arrow-down-left.svg +0 -1
- package/assets/arrow-down-right-fill.svg +0 -1
- package/assets/arrow-down-right.svg +0 -1
- package/assets/arrow-down-short-wide.svg +0 -1
- package/assets/arrow-down-wide-short.svg +0 -1
- package/assets/arrow-down.svg +0 -1
- package/assets/arrow-left-fill.svg +0 -1
- package/assets/arrow-left.svg +0 -1
- package/assets/arrow-narrow-down-fill.svg +0 -1
- package/assets/arrow-narrow-down.svg +0 -1
- package/assets/arrow-narrow-left-fill.svg +0 -1
- package/assets/arrow-narrow-left.svg +0 -1
- package/assets/arrow-narrow-right-fill.svg +0 -1
- package/assets/arrow-narrow-right.svg +0 -1
- package/assets/arrow-narrow-up-fill.svg +0 -1
- package/assets/arrow-narrow-up.svg +0 -1
- package/assets/arrow-right-fill.svg +0 -1
- package/assets/arrow-right.svg +0 -1
- package/assets/arrow-sm-down-fill.svg +0 -1
- package/assets/arrow-sm-down.svg +0 -1
- package/assets/arrow-sm-left-fill.svg +0 -1
- package/assets/arrow-sm-left.svg +0 -1
- package/assets/arrow-sm-right-fill.svg +0 -1
- package/assets/arrow-sm-right.svg +0 -1
- package/assets/arrow-sm-up-fill.svg +0 -1
- package/assets/arrow-sm-up.svg +0 -1
- package/assets/arrow-spin-fill.svg +0 -1
- package/assets/arrow-spin.svg +0 -1
- package/assets/arrow-square-down-fill.svg +0 -1
- package/assets/arrow-square-down-left-fill.svg +0 -1
- package/assets/arrow-square-down-left.svg +0 -1
- package/assets/arrow-square-down-right-fill.svg +0 -1
- package/assets/arrow-square-down-right.svg +0 -1
- package/assets/arrow-square-down.svg +0 -1
- package/assets/arrow-square-left-fill.svg +0 -1
- package/assets/arrow-square-left.svg +0 -1
- package/assets/arrow-square-right-fill.svg +0 -1
- package/assets/arrow-square-right.svg +0 -1
- package/assets/arrow-square-up-fill.svg +0 -1
- package/assets/arrow-square-up-left-fill.svg +0 -1
- package/assets/arrow-square-up-left.svg +0 -1
- package/assets/arrow-square-up-right-fill.svg +0 -1
- package/assets/arrow-square-up-right.svg +0 -1
- package/assets/arrow-square-up.svg +0 -1
- package/assets/arrow-up-1-9.svg +0 -1
- package/assets/arrow-up-9-1.svg +0 -1
- package/assets/arrow-up-fill.svg +0 -1
- package/assets/arrow-up-left-fill.svg +0 -1
- package/assets/arrow-up-left.svg +0 -1
- package/assets/arrow-up-right-fill.svg +0 -1
- package/assets/arrow-up-right.svg +0 -1
- package/assets/arrow-up-short-wide.svg +0 -1
- package/assets/arrow-up-wide-short.svg +0 -1
- package/assets/arrow-up.svg +0 -1
- package/assets/arrows-left-right.svg +0 -1
- package/assets/arrows-up-down.svg +0 -1
- package/assets/art_color.svg +0 -1
- package/assets/aruba.svg +0 -1
- package/assets/astronomy_color.svg +0 -1
- package/assets/at-sign.svg +0 -1
- package/assets/australia.svg +0 -1
- package/assets/austria.svg +0 -1
- package/assets/azerbaijan.svg +0 -1
- package/assets/back-arrow.svg +0 -1
- package/assets/back-chevron.svg +0 -1
- package/assets/badge-check.svg +0 -1
- package/assets/badge.svg +0 -1
- package/assets/bag-shopping.svg +0 -1
- package/assets/bahamas.svg +0 -1
- package/assets/bahrain.svg +0 -1
- package/assets/ban.svg +0 -1
- package/assets/bangladesh.svg +0 -1
- package/assets/bank.svg +0 -1
- package/assets/barbados.svg +0 -1
- package/assets/bars-progress.svg +0 -1
- package/assets/basket-shopping.svg +0 -1
- package/assets/battery-bolt.svg +0 -1
- package/assets/battery-empty.svg +0 -1
- package/assets/battery-full.svg +0 -1
- package/assets/battery-off.svg +0 -1
- package/assets/battery-warning.svg +0 -1
- package/assets/belarus.svg +0 -1
- package/assets/belgium.svg +0 -1
- package/assets/belize.svg +0 -1
- package/assets/benin.svg +0 -1
- package/assets/bermuda.svg +0 -1
- package/assets/bhutan.svg +0 -1
- package/assets/biology.svg +0 -1
- package/assets/biology_color.svg +0 -1
- package/assets/blackBoard_default.svg +0 -1
- package/assets/blackboard.svg +0 -1
- package/assets/bloger_color.svg +0 -1
- package/assets/blogging.svg +0 -1
- package/assets/blogging_color.svg +0 -1
- package/assets/blueprint_color.svg +0 -1
- package/assets/bluetooth-off.svg +0 -1
- package/assets/bluetooth-on.svg +0 -1
- package/assets/body_human_color.svg +0 -1
- package/assets/bold.svg +0 -1
- package/assets/bolivia.svg +0 -1
- package/assets/bolt-fill.svg +0 -1
- package/assets/bolt.svg +0 -1
- package/assets/book-fill.svg +0 -1
- package/assets/book-open.svg +0 -1
- package/assets/book.svg +0 -1
- package/assets/book_default.svg +0 -1
- package/assets/bookmark-fill.svg +0 -1
- package/assets/bookmark-stack.svg +0 -1
- package/assets/bookmark.svg +0 -1
- package/assets/books.svg +0 -1
- package/assets/books_color.svg +0 -1
- package/assets/border-bottom.svg +0 -1
- package/assets/border-clear.svg +0 -1
- package/assets/border-horizontal.svg +0 -1
- package/assets/border-inner.svg +0 -1
- package/assets/border-left.svg +0 -1
- package/assets/border-outer.svg +0 -1
- package/assets/border-right.svg +0 -1
- package/assets/border-top-left.svg +0 -1
- package/assets/border-top.svg +0 -1
- package/assets/border-vertical.svg +0 -1
- package/assets/bosnia-and-herzegovina.svg +0 -1
- package/assets/botswana.svg +0 -1
- package/assets/bottom-alignment.svg +0 -1
- package/assets/bracket-curly-right.svg +0 -1
- package/assets/bracket-curly.svg +0 -1
- package/assets/bracket-round-right.svg +0 -1
- package/assets/bracket-round.svg +0 -1
- package/assets/bracket-square-right.svg +0 -1
- package/assets/bracket-square.svg +0 -1
- package/assets/brackets-curly.svg +0 -1
- package/assets/brackets-round.svg +0 -1
- package/assets/brackets-square.svg +0 -1
- package/assets/brazil.svg +0 -1
- package/assets/bright-full-fill.svg +0 -1
- package/assets/bright-low-fill.svg +0 -1
- package/assets/briight-full.svg +0 -1
- package/assets/briight-low.svg +0 -1
- package/assets/british-indian-ocean_territory.svg +0 -1
- package/assets/british-virgin-islands.svg +0 -1
- package/assets/browser.svg +0 -1
- package/assets/brunei.svg +0 -1
- package/assets/brush.svg +0 -1
- package/assets/building.svg +0 -1
- package/assets/bulgaria.svg +0 -1
- package/assets/burger_default.svg +0 -1
- package/assets/burkina-faso.svg +0 -1
- package/assets/burundi.svg +0 -1
- package/assets/bus.svg +0 -1
- package/assets/calendar-add.svg +0 -1
- package/assets/calendar-edit.svg +0 -1
- package/assets/calendar-export.svg +0 -1
- package/assets/calendar-fill.svg +0 -1
- package/assets/calendar-import.svg +0 -1
- package/assets/calendar-minus.svg +0 -1
- package/assets/calendar-remove.svg +0 -1
- package/assets/calendar-tick.svg +0 -1
- package/assets/calendar-user.svg +0 -1
- package/assets/calendar-warning.svg +0 -1
- package/assets/calendar.svg +0 -1
- package/assets/calendar_color.svg +0 -1
- package/assets/calendar_default.svg +0 -1
- package/assets/calendar_simple_default.svg +0 -1
- package/assets/calendars.svg +0 -1
- package/assets/cambodia.svg +0 -1
- package/assets/camera-off.svg +0 -1
- package/assets/camera.svg +0 -1
- package/assets/cameroon.svg +0 -1
- package/assets/camp.svg +0 -1
- package/assets/camps_default.svg +0 -1
- package/assets/canada.svg +0 -1
- package/assets/canary-islands.svg +0 -1
- package/assets/cancel_default.svg +0 -1
- package/assets/cape-verde.svg +0 -1
- package/assets/car.svg +0 -1
- package/assets/card-flip.svg +0 -1
- package/assets/caret-down-fill.svg +0 -1
- package/assets/caret-down.svg +0 -1
- package/assets/caret-left-fill.svg +0 -1
- package/assets/caret-left-to-line-fill.svg +0 -1
- package/assets/caret-left-to-line.svg +0 -1
- package/assets/caret-left.svg +0 -1
- package/assets/caret-right-fill.svg +0 -1
- package/assets/caret-right-to-line-fill.svg +0 -1
- package/assets/caret-right-to-line.svg +0 -1
- package/assets/caret-right.svg +0 -1
- package/assets/caret-up-fill.svg +0 -1
- package/assets/caret-up.svg +0 -1
- package/assets/cart-arrow-down.svg +0 -1
- package/assets/cart-arrow-up.svg +0 -1
- package/assets/cart-close.svg +0 -1
- package/assets/cart-fast.svg +0 -1
- package/assets/cart-minus.svg +0 -1
- package/assets/cart-notif.svg +0 -1
- package/assets/cart-plus.svg +0 -1
- package/assets/cart-tick.svg +0 -1
- package/assets/cart.svg +0 -1
- package/assets/cart_default.svg +0 -1
- package/assets/case_color.svg +0 -1
- package/assets/cayman-islands.svg +0 -1
- package/assets/central-african-republic.svg +0 -1
- package/assets/certificate-check.svg +0 -1
- package/assets/certificate.svg +0 -1
- package/assets/ceuta.svg +0 -1
- package/assets/chad.svg +0 -1
- package/assets/chart-area.svg +0 -1
- package/assets/chart-bar.svg +0 -1
- package/assets/chart-bullet.svg +0 -1
- package/assets/chart-column.svg +0 -1
- package/assets/chart-gantt.svg +0 -1
- package/assets/chart-line-down.svg +0 -1
- package/assets/chart-line-up.svg +0 -1
- package/assets/chart-line.svg +0 -1
- package/assets/chart-mixed.svg +0 -1
- package/assets/chart-network.svg +0 -1
- package/assets/chart-pie.svg +0 -1
- package/assets/chart-pyramid.svg +0 -1
- package/assets/chart-radar.svg +0 -1
- package/assets/chart-scatter-3d.svg +0 -1
- package/assets/chart-scatter-bubble.svg +0 -1
- package/assets/chart-scatter.svg +0 -1
- package/assets/chart-simple-horizontal.svg +0 -1
- package/assets/chart-simple.svg +0 -1
- package/assets/chart-tree-map.svg +0 -1
- package/assets/chart-user-square.svg +0 -1
- package/assets/chart-waterfall.svg +0 -1
- package/assets/check-circle-fill.svg +0 -1
- package/assets/check-circle.svg +0 -1
- package/assets/check-double-fill.svg +0 -1
- package/assets/check-double.svg +0 -1
- package/assets/check-fill.svg +0 -1
- package/assets/check.svg +0 -1
- package/assets/checkCircle_default.svg +0 -1
- package/assets/check_default.svg +0 -1
- package/assets/chemistry.svg +0 -1
- package/assets/chemistry_color.svg +0 -1
- package/assets/chess_alt_color.svg +0 -1
- package/assets/chess_color.svg +0 -1
- package/assets/chevron-down-fill.svg +0 -1
- package/assets/chevron-down-left-fill.svg +0 -1
- package/assets/chevron-down-left.svg +0 -1
- package/assets/chevron-down-right-fill.svg +0 -1
- package/assets/chevron-down-right.svg +0 -1
- package/assets/chevron-down-small-fill.svg +0 -1
- package/assets/chevron-down-small.svg +0 -1
- package/assets/chevron-down.svg +0 -1
- package/assets/chevron-left-fill.svg +0 -1
- package/assets/chevron-left-small-fill.svg +0 -1
- package/assets/chevron-left-small.svg +0 -1
- package/assets/chevron-left.svg +0 -1
- package/assets/chevron-right-fill.svg +0 -1
- package/assets/chevron-right-small-fill.svg +0 -1
- package/assets/chevron-right-small.svg +0 -1
- package/assets/chevron-right.svg +0 -1
- package/assets/chevron-selector-horizontal.svg +0 -1
- package/assets/chevron-selector-vertical.svg +0 -1
- package/assets/chevron-up-fill.svg +0 -1
- package/assets/chevron-up-left-fill.svg +0 -1
- package/assets/chevron-up-left.svg +0 -1
- package/assets/chevron-up-right-fill.svg +0 -1
- package/assets/chevron-up-right.svg +0 -1
- package/assets/chevron-up-small-fill.svg +0 -1
- package/assets/chevron-up-small.svg +0 -1
- package/assets/chevron-up.svg +0 -1
- package/assets/chevronDown_default.svg +0 -1
- package/assets/chevronLeft_default.svg +0 -1
- package/assets/chevronRight_default.svg +0 -1
- package/assets/chevronUp_default.svg +0 -1
- package/assets/children.svg +0 -1
- package/assets/chile.svg +0 -1
- package/assets/china.svg +0 -1
- package/assets/chinese_color.svg +0 -1
- package/assets/circle-dollar-to-slot.svg +0 -1
- package/assets/circle-dollar.svg +0 -1
- package/assets/circle-notch.svg +0 -1
- package/assets/circle-pause.svg +0 -1
- package/assets/circle-play.svg +0 -1
- package/assets/circle-quarter.svg +0 -1
- package/assets/circle-quarters.svg +0 -1
- package/assets/circle-three-quarters.svg +0 -1
- package/assets/circle-user-fill.svg +0 -1
- package/assets/city.svg +0 -1
- package/assets/clipboard-export.svg +0 -1
- package/assets/clipboard-import.svg +0 -1
- package/assets/clipboard-list-alt.svg +0 -1
- package/assets/clipboard-minus.svg +0 -1
- package/assets/clipboard-plus.svg +0 -1
- package/assets/clipboard-text.svg +0 -1
- package/assets/clipboard.svg +0 -1
- package/assets/clock-add.svg +0 -1
- package/assets/clock-done.svg +0 -1
- package/assets/clock-fill.svg +0 -1
- package/assets/clock-remove.svg +0 -1
- package/assets/clock-warning.svg +0 -1
- package/assets/clock.svg +0 -1
- package/assets/clockFilled_default.svg +0 -1
- package/assets/clock_default.svg +0 -1
- package/assets/close-cirlce-fill.svg +0 -1
- package/assets/close-cirlce.svg +0 -1
- package/assets/close-fill.svg +0 -1
- package/assets/close-large-fill.svg +0 -1
- package/assets/close-large.svg +0 -1
- package/assets/close.svg +0 -1
- package/assets/cloud-add.svg +0 -1
- package/assets/cloud-bolt.svg +0 -1
- package/assets/cloud-done.svg +0 -1
- package/assets/cloud-download.svg +0 -1
- package/assets/cloud-error.svg +0 -1
- package/assets/cloud-export.svg +0 -1
- package/assets/cloud-import.svg +0 -1
- package/assets/cloud-off.svg +0 -1
- package/assets/cloud-question.svg +0 -1
- package/assets/cloud-remove.svg +0 -1
- package/assets/cloud-upload.svg +0 -1
- package/assets/cloud-warning.svg +0 -1
- package/assets/cloud.svg +0 -1
- package/assets/club.svg +0 -1
- package/assets/cocos-island.svg +0 -1
- package/assets/code.svg +0 -1
- package/assets/coin-vertical.svg +0 -1
- package/assets/coin.svg +0 -1
- package/assets/coins.svg +0 -1
- package/assets/coins_default.svg +0 -1
- package/assets/college_color.svg +0 -1
- package/assets/colombia.svg +0 -1
- package/assets/columns-2.svg +0 -1
- package/assets/columns-3.svg +0 -1
- package/assets/comoros.svg +0 -1
- package/assets/compass.svg +0 -1
- package/assets/computer.svg +0 -1
- package/assets/constrict.svg +0 -1
- package/assets/cook-islands.svg +0 -1
- package/assets/copy-fill.svg +0 -1
- package/assets/copy.svg +0 -1
- package/assets/copy_default.svg +0 -4
- package/assets/corner-down-left-fill.svg +0 -1
- package/assets/corner-down-left.svg +0 -1
- package/assets/corner-down-right-fill.svg +0 -1
- package/assets/corner-down-right.svg +0 -1
- package/assets/corner-left-down-fill.svg +0 -1
- package/assets/corner-left-down.svg +0 -1
- package/assets/corner-left-up-fill.svg +0 -1
- package/assets/corner-left-up.svg +0 -1
- package/assets/corner-right-down-fill.svg +0 -1
- package/assets/corner-right-down.svg +0 -1
- package/assets/corner-right-up-fill.svg +0 -1
- package/assets/corner-right-up.svg +0 -1
- package/assets/corner-up-left-fill.svg +0 -1
- package/assets/corner-up-left.svg +0 -1
- package/assets/corner-up-right-fill.svg +0 -1
- package/assets/corner-up-right.svg +0 -1
- package/assets/costa-rica.svg +0 -1
- package/assets/cource_color.svg +0 -1
- package/assets/courses_default.svg +0 -1
- package/assets/creativity_color.svg +0 -1
- package/assets/credit-card-add.svg +0 -1
- package/assets/credit-card-remove.svg +0 -1
- package/assets/credit-card-scan.svg +0 -1
- package/assets/credit-card.svg +0 -1
- package/assets/croatia.svg +0 -1
- package/assets/crop.svg +0 -1
- package/assets/cross_default.svg +0 -1
- package/assets/crown.svg +0 -1
- package/assets/cuba.svg +0 -1
- package/assets/cube-sharp.svg +0 -1
- package/assets/cube-vr.svg +0 -1
- package/assets/cube.svg +0 -1
- package/assets/curacao.svg +0 -1
- package/assets/cursor-fill.svg +0 -1
- package/assets/cursor.svg +0 -1
- package/assets/cyprus.svg +0 -1
- package/assets/czech-republic.svg +0 -1
- package/assets/dash.svg +0 -1
- package/assets/delete-fill.svg +0 -1
- package/assets/delete.svg +0 -1
- package/assets/democratic-republic-of_congo.svg +0 -1
- package/assets/denmark.svg +0 -1
- package/assets/development_1_color.svg +0 -1
- package/assets/development_2_color.svg +0 -1
- package/assets/diagram-cells.svg +0 -1
- package/assets/diagram-lean-canvas.svg +0 -1
- package/assets/diagram-nested.svg +0 -1
- package/assets/diagram-next.svg +0 -1
- package/assets/diagram-predecessor.svg +0 -1
- package/assets/diagram-previous.svg +0 -1
- package/assets/diagram-project.svg +0 -1
- package/assets/diagram-sankey.svg +0 -1
- package/assets/diagram-subtask.svg +0 -1
- package/assets/diagram-successor.svg +0 -1
- package/assets/diagram-venn.svg +0 -1
- package/assets/dialog_default.svg +0 -1
- package/assets/dialpad-circle.svg +0 -1
- package/assets/dialpad-square.svg +0 -1
- package/assets/diamond-simple.svg +0 -1
- package/assets/diamond.svg +0 -1
- package/assets/diamondFilled_default.svg +0 -1
- package/assets/diamond_default.svg +0 -1
- package/assets/dice-five.svg +0 -1
- package/assets/dice-four.svg +0 -1
- package/assets/dice-one.svg +0 -1
- package/assets/dice-six.svg +0 -1
- package/assets/dice-three.svg +0 -1
- package/assets/dice-two.svg +0 -1
- package/assets/digital_professions_color.svg +0 -1
- package/assets/diploma_color.svg +0 -1
- package/assets/disc.svg +0 -1
- package/assets/discount-badge.svg +0 -1
- package/assets/discount-circle.svg +0 -1
- package/assets/discount_default.svg +0 -1
- package/assets/dislike.svg +0 -1
- package/assets/distribute-spacing-horizontal.svg +0 -1
- package/assets/distribute-spacing-vertical.svg +0 -1
- package/assets/djibouti.svg +0 -1
- package/assets/doc.svg +0 -1
- package/assets/document-layout-center.svg +0 -1
- package/assets/document-layout-left.svg +0 -1
- package/assets/document-layout-right.svg +0 -1
- package/assets/document_default.svg +0 -1
- package/assets/dominica.svg +0 -1
- package/assets/dominican-republic.svg +0 -1
- package/assets/door-closed.svg +0 -1
- package/assets/door-open.svg +0 -1
- package/assets/double-xp-fill.svg +0 -1
- package/assets/download-fill.svg +0 -1
- package/assets/download.svg +0 -1
- package/assets/draw-square-t.svg +0 -1
- package/assets/draw-square.svg +0 -1
- package/assets/drawing-tablet.svg +0 -1
- package/assets/drawing_color.svg +0 -1
- package/assets/dropDownArrow_default.svg +0 -1
- package/assets/early_education_color.svg +0 -1
- package/assets/east-timor.svg +0 -1
- package/assets/ecology.svg +0 -1
- package/assets/ecology_color.svg +0 -1
- package/assets/economy_color.svg +0 -1
- package/assets/ecuador.svg +0 -1
- package/assets/edit-fill.svg +0 -1
- package/assets/edit-pen-fill.svg +0 -1
- package/assets/edit-pen.svg +0 -1
- package/assets/edit.svg +0 -1
- package/assets/edit_default.svg +0 -1
- package/assets/education_color.svg +0 -1
- package/assets/education_program_color.svg +0 -1
- package/assets/educont-auth-mono-color.svg +0 -1
- package/assets/educont-authorization.svg +0 -1
- package/assets/egypt.svg +0 -1
- package/assets/el-salvador.svg +0 -1
- package/assets/elementary_color.svg +0 -1
- package/assets/email_default.svg +0 -1
- package/assets/emotional_intelligence_color.svg +0 -1
- package/assets/england.svg +0 -1
- package/assets/english-to-chinese.svg +0 -1
- package/assets/english.svg +0 -1
- package/assets/english_color.svg +0 -1
- package/assets/enter-fill.svg +0 -1
- package/assets/enter.svg +0 -1
- package/assets/equatorial-guinea.svg +0 -1
- package/assets/eritrea.svg +0 -1
- package/assets/estonia.svg +0 -1
- package/assets/ethiopia.svg +0 -1
- package/assets/european-union.svg +0 -1
- package/assets/exam-test_color.svg +0 -1
- package/assets/exam_color.svg +0 -1
- package/assets/expand.svg +0 -1
- package/assets/export-fill.svg +0 -1
- package/assets/export.svg +0 -1
- package/assets/external-link-fill.svg +0 -1
- package/assets/external-link.svg +0 -1
- package/assets/externalLink_default.svg +0 -1
- package/assets/externat_default.svg +0 -1
- package/assets/eye-close-fill.svg +0 -1
- package/assets/eye-close.svg +0 -1
- package/assets/eye-dropper-full.svg +0 -1
- package/assets/eye-dropper-half.svg +0 -1
- package/assets/eye-dropper.svg +0 -1
- package/assets/eye-fill.svg +0 -1
- package/assets/eye-slash-fill.svg +0 -1
- package/assets/eye-slash.svg +0 -1
- package/assets/eye.svg +0 -1
- package/assets/eye_default.svg +0 -1
- package/assets/face-frown-fill.svg +0 -1
- package/assets/face-frown.svg +0 -1
- package/assets/face-id.svg +0 -1
- package/assets/face-smile-fill.svg +0 -1
- package/assets/face-smile.svg +0 -1
- package/assets/facebook-social-color.svg +0 -1
- package/assets/facebook-social.svg +0 -1
- package/assets/falkland-islands.svg +0 -1
- package/assets/family-house.svg +0 -1
- package/assets/family.svg +0 -1
- package/assets/faroe-islands.svg +0 -1
- package/assets/fast-timer.svg +0 -1
- package/assets/figma.svg +0 -1
- package/assets/fiji.svg +0 -1
- package/assets/file-add-alt-1.svg +0 -1
- package/assets/file-add.svg +0 -1
- package/assets/file-bookmark.svg +0 -1
- package/assets/file-dashed-line.svg +0 -1
- package/assets/file-download.svg +0 -1
- package/assets/file-edit-corner.svg +0 -1
- package/assets/file-edit.svg +0 -1
- package/assets/file-exclamation-corner.svg +0 -1
- package/assets/file-horizontal.svg +0 -1
- package/assets/file-import.svg +0 -1
- package/assets/file-info-corner.svg +0 -1
- package/assets/file-info.svg +0 -1
- package/assets/file-link.svg +0 -1
- package/assets/file-minus-corner.svg +0 -1
- package/assets/file-minus.svg +0 -1
- package/assets/file-move.svg +0 -1
- package/assets/file-off.svg +0 -1
- package/assets/file-pdf.svg +0 -1
- package/assets/file-question-corner.svg +0 -1
- package/assets/file-question.svg +0 -1
- package/assets/file-remove.svg +0 -1
- package/assets/file-shredder.svg +0 -1
- package/assets/file-text.svg +0 -1
- package/assets/file-tick.svg +0 -1
- package/assets/file-upload.svg +0 -1
- package/assets/file-warning.svg +0 -1
- package/assets/file-zipper.svg +0 -1
- package/assets/file.svg +0 -1
- package/assets/fileBordered_default.svg +0 -1
- package/assets/file_default.svg +0 -1
- package/assets/files.svg +0 -1
- package/assets/filter-fill.svg +0 -1
- package/assets/filter.svg +0 -1
- package/assets/finance_color.svg +0 -1
- package/assets/financial_battle_color.svg +0 -1
- package/assets/financial_literature_color.svg +0 -1
- package/assets/fingerprint.svg +0 -1
- package/assets/finland.svg +0 -1
- package/assets/fire-alt.svg +0 -1
- package/assets/fire-fill.svg +0 -1
- package/assets/fire-small-fill.svg +0 -1
- package/assets/fire.svg +0 -1
- package/assets/fire_default.svg +0 -1
- package/assets/fizra_2_color.svg +0 -1
- package/assets/fizra_color.svg +0 -1
- package/assets/fizra_elementary_color.svg +0 -1
- package/assets/flag.svg +0 -1
- package/assets/flash-cards.svg +0 -1
- package/assets/flashlight.svg +0 -1
- package/assets/folder-add.svg +0 -1
- package/assets/folder-export.svg +0 -1
- package/assets/folder-import.svg +0 -1
- package/assets/folder-info.svg +0 -1
- package/assets/folder-minus.svg +0 -1
- package/assets/folder-move.svg +0 -1
- package/assets/folder-notif.svg +0 -1
- package/assets/folder-question.svg +0 -1
- package/assets/folder-remove.svg +0 -1
- package/assets/folder-tick.svg +0 -1
- package/assets/folder-warning.svg +0 -1
- package/assets/folder.svg +0 -1
- package/assets/folder_color.svg +0 -1
- package/assets/font-case.svg +0 -1
- package/assets/font.svg +0 -1
- package/assets/food_color.svg +0 -1
- package/assets/foreign_language_color.svg +0 -1
- package/assets/forward-fill.svg +0 -1
- package/assets/forward.svg +0 -1
- package/assets/fox-coin.svg +0 -1
- package/assets/fox-coins.svg +0 -1
- package/assets/france.svg +0 -1
- package/assets/french-polynesia.svg +0 -1
- package/assets/french_color.svg +0 -1
- package/assets/gabon.svg +0 -1
- package/assets/gallery-thumbnails.svg +0 -1
- package/assets/gambia.svg +0 -1
- package/assets/game.svg +0 -1
- package/assets/game_profession_dev_color.svg +0 -1
- package/assets/game_profession_producer_color.svg +0 -1
- package/assets/game_profession_screenwriter_color.svg +0 -1
- package/assets/games_color.svg +0 -1
- package/assets/gem.svg +0 -1
- package/assets/geography.svg +0 -1
- package/assets/geography_color.svg +0 -1
- package/assets/geography_elementary_color.svg +0 -1
- package/assets/geometry_color.svg +0 -1
- package/assets/georgia.svg +0 -1
- package/assets/german_color.svg +0 -1
- package/assets/germany.svg +0 -1
- package/assets/ghana.svg +0 -1
- package/assets/gibraltar.svg +0 -1
- package/assets/gift-alt-fill.svg +0 -1
- package/assets/gift-box.svg +0 -1
- package/assets/gift-card.svg +0 -1
- package/assets/gift-fill.svg +0 -1
- package/assets/gift.svg +0 -1
- package/assets/globe.svg +0 -1
- package/assets/goal.svg +0 -1
- package/assets/gold.svg +0 -1
- package/assets/google-auth-mono-color.svg +0 -1
- package/assets/google-authorization.svg +0 -1
- package/assets/gps-off.svg +0 -1
- package/assets/gps.svg +0 -1
- package/assets/greece.svg +0 -1
- package/assets/greenland.svg +0 -1
- package/assets/grenada.svg +0 -1
- package/assets/grid-circle-fill.svg +0 -1
- package/assets/grid-circle.svg +0 -1
- package/assets/grid-fill.svg +0 -1
- package/assets/grid-plus-fill.svg +0 -1
- package/assets/grid-plus.svg +0 -1
- package/assets/grid.svg +0 -1
- package/assets/grip-dots-fill.svg +0 -1
- package/assets/grip-dots-vertical-fill.svg +0 -1
- package/assets/grip-dots-vertical.svg +0 -1
- package/assets/grip-dots.svg +0 -1
- package/assets/group_color.svg +0 -1
- package/assets/guam.svg +0 -1
- package/assets/guatemala.svg +0 -1
- package/assets/guernsey.svg +0 -1
- package/assets/guinea-bissau.svg +0 -1
- package/assets/guinea.svg +0 -1
- package/assets/guyana.svg +0 -1
- package/assets/h1.svg +0 -1
- package/assets/h2.svg +0 -1
- package/assets/haiti.svg +0 -1
- package/assets/hand-left.svg +0 -1
- package/assets/hand-right.svg +0 -1
- package/assets/hand-slash.svg +0 -1
- package/assets/hard-drive.svg +0 -1
- package/assets/hashtag-lock.svg +0 -1
- package/assets/hashtag.svg +0 -1
- package/assets/hat.svg +0 -1
- package/assets/heading.svg +0 -1
- package/assets/headphones.svg +0 -1
- package/assets/headphones_default.svg +0 -1
- package/assets/heart-circle-fill.svg +0 -1
- package/assets/heart-circle.svg +0 -1
- package/assets/heart-crack.svg +0 -1
- package/assets/heart-fill.svg +0 -1
- package/assets/heart-half-stroke.svg +0 -1
- package/assets/heart-half.svg +0 -1
- package/assets/heart.svg +0 -1
- package/assets/help-circle-fill.svg +0 -1
- package/assets/help-circle.svg +0 -1
- package/assets/help-seal-fill.svg +0 -1
- package/assets/help-seal.svg +0 -1
- package/assets/help.svg +0 -1
- package/assets/hexagon.svg +0 -1
- package/assets/history.svg +0 -1
- package/assets/history_alt_color.svg +0 -1
- package/assets/history_color.svg +0 -1
- package/assets/home_default.svg +0 -1
- package/assets/home_school_color.svg +0 -1
- package/assets/honduras.svg +0 -1
- package/assets/hong-kong.svg +0 -1
- package/assets/horizontal-rule.svg +0 -1
- package/assets/hotel.svg +0 -1
- package/assets/hourglass-end.svg +0 -1
- package/assets/hourglass-half.svg +0 -1
- package/assets/hourglass-start.svg +0 -1
- package/assets/hourglass.svg +0 -1
- package/assets/house-alt-fill.svg +0 -1
- package/assets/house-empty.svg +0 -1
- package/assets/house-fill.svg +0 -1
- package/assets/house.svg +0 -1
- package/assets/hungary.svg +0 -1
- package/assets/i-cursor.svg +0 -1
- package/assets/iceland.svg +0 -1
- package/assets/image-add.svg +0 -1
- package/assets/image-edit.svg +0 -1
- package/assets/image-error.svg +0 -1
- package/assets/image-export.svg +0 -1
- package/assets/image-import.svg +0 -1
- package/assets/image-remove.svg +0 -1
- package/assets/image-tick.svg +0 -1
- package/assets/image-user.svg +0 -1
- package/assets/image.svg +0 -1
- package/assets/import-fill.svg +0 -1
- package/assets/import.svg +0 -1
- package/assets/inbox-add.svg +0 -1
- package/assets/inbox-check.svg +0 -1
- package/assets/inbox-export.svg +0 -1
- package/assets/inbox-import.svg +0 -1
- package/assets/inbox-information.svg +0 -1
- package/assets/inbox-minus.svg +0 -1
- package/assets/inbox-move.svg +0 -1
- package/assets/inbox-notif.svg +0 -1
- package/assets/inbox-remove.svg +0 -1
- package/assets/inbox-warning.svg +0 -1
- package/assets/inbox.svg +0 -1
- package/assets/income.svg +0 -1
- package/assets/indent.svg +0 -1
- package/assets/india.svg +0 -1
- package/assets/indonesia.svg +0 -1
- package/assets/industry.svg +0 -1
- package/assets/infinity.svg +0 -1
- package/assets/info-circle-fill.svg +0 -1
- package/assets/info-circle.svg +0 -1
- package/assets/infoInverse_default.svg +0 -1
- package/assets/info_default.svg +0 -1
- package/assets/informatics_color.svg +0 -1
- package/assets/information.svg +0 -1
- package/assets/instagram-social-color.svg +0 -1
- package/assets/instagram-social.svg +0 -1
- package/assets/iran.svg +0 -1
- package/assets/iraq.svg +0 -1
- package/assets/ireland.svg +0 -1
- package/assets/isle-of-man.svg +0 -1
- package/assets/israel.svg +0 -1
- package/assets/italic.svg +0 -1
- package/assets/italy.svg +0 -1
- package/assets/items.svg +0 -1
- package/assets/ivory-coast.svg +0 -1
- package/assets/jamaica.svg +0 -1
- package/assets/japan.svg +0 -1
- package/assets/jersey.svg +0 -1
- package/assets/jordan.svg +0 -1
- package/assets/journalistic_color.svg +0 -1
- package/assets/kazakhstan.svg +0 -1
- package/assets/kenya.svg +0 -1
- package/assets/kerning.svg +0 -1
- package/assets/key-tiny.svg +0 -1
- package/assets/key.svg +0 -1
- package/assets/keyboard-close.svg +0 -1
- package/assets/keyboard.svg +0 -1
- package/assets/kiribati.svg +0 -1
- package/assets/kuwait.svg +0 -1
- package/assets/kyrgyzstan.svg +0 -1
- package/assets/lamp-charge-fill.svg +0 -1
- package/assets/lamp-charge.svg +0 -1
- package/assets/lamp-off-fill.svg +0 -1
- package/assets/lamp-off.svg +0 -1
- package/assets/lamp-on-fill.svg +0 -1
- package/assets/lamp-on.svg +0 -1
- package/assets/lamp-warning-fill.svg +0 -1
- package/assets/lamp-warning.svg +0 -1
- package/assets/laos.svg +0 -1
- package/assets/laptop-arrow-down.svg +0 -1
- package/assets/laptop-arrow-up.svg +0 -1
- package/assets/laptop-error.svg +0 -1
- package/assets/laptop-exclamation.svg +0 -1
- package/assets/laptop-signal.svg +0 -1
- package/assets/laptop-tick.svg +0 -1
- package/assets/laptop.svg +0 -1
- package/assets/lasso.svg +0 -1
- package/assets/latvia.svg +0 -1
- package/assets/lebanon.svg +0 -1
- package/assets/left-alignment.svg +0 -1
- package/assets/left-indent.svg +0 -1
- package/assets/left-to-right-text-direction.svg +0 -1
- package/assets/lesotho.svg +0 -1
- package/assets/lessons_default.svg +0 -1
- package/assets/letter-chinese-a.svg +0 -1
- package/assets/liberia.svg +0 -1
- package/assets/libya.svg +0 -1
- package/assets/liechtenstein.svg +0 -1
- package/assets/light-warning-on.svg +0 -1
- package/assets/light-warning.svg +0 -1
- package/assets/lightning-fill.svg +0 -1
- package/assets/lightning.svg +0 -1
- package/assets/like.svg +0 -1
- package/assets/line-columns.svg +0 -1
- package/assets/line-height.svg +0 -1
- package/assets/lines-leaning.svg +0 -1
- package/assets/link-fill.svg +0 -1
- package/assets/link-slash.svg +0 -1
- package/assets/link.svg +0 -1
- package/assets/list-circle.svg +0 -1
- package/assets/list-ol.svg +0 -1
- package/assets/list-ul-level.svg +0 -1
- package/assets/list-ul.svg +0 -1
- package/assets/list.svg +0 -1
- package/assets/list_default.svg +0 -1
- package/assets/literature.svg +0 -1
- package/assets/literature_alt_color.svg +0 -1
- package/assets/literature_color.svg +0 -1
- package/assets/lithuania.svg +0 -1
- package/assets/loader-fill.svg +0 -1
- package/assets/loader.svg +0 -1
- package/assets/loading.svg +0 -1
- package/assets/location-check.svg +0 -1
- package/assets/lock-a.svg +0 -1
- package/assets/lock-fill.svg +0 -1
- package/assets/lock-hashtag.svg +0 -1
- package/assets/lock-slash.svg +0 -1
- package/assets/lock.svg +0 -1
- package/assets/log-in-fill.svg +0 -1
- package/assets/log-in.svg +0 -1
- package/assets/log-out-fill.svg +0 -1
- package/assets/log-out.svg +0 -1
- package/assets/logic_color.svg +0 -1
- package/assets/login_default.svg +0 -3
- package/assets/logoped_color.svg +0 -1
- package/assets/logout_default.svg +0 -1
- package/assets/loop.svg +0 -1
- package/assets/luxembourg.svg +0 -1
- package/assets/macao.svg +0 -1
- package/assets/madagascar.svg +0 -1
- package/assets/mail-add.svg +0 -1
- package/assets/mail-block.svg +0 -1
- package/assets/mail-edit.svg +0 -1
- package/assets/mail-fill.svg +0 -1
- package/assets/mail-info.svg +0 -1
- package/assets/mail-minus.svg +0 -1
- package/assets/mail-notif.svg +0 -1
- package/assets/mail-open.svg +0 -1
- package/assets/mail-refresh.svg +0 -1
- package/assets/mail-remove.svg +0 -1
- package/assets/mail-tick.svg +0 -1
- package/assets/mail-warning.svg +0 -1
- package/assets/mail.ru-authorization.svg +0 -1
- package/assets/mail.svg +0 -1
- package/assets/mailru-auth-mono-color.svg +0 -1
- package/assets/malawi.svg +0 -1
- package/assets/malaysia.svg +0 -1
- package/assets/maldives.svg +0 -1
- package/assets/mali.svg +0 -1
- package/assets/malta.svg +0 -1
- package/assets/map-location-pin.svg +0 -1
- package/assets/map-marker-add.svg +0 -1
- package/assets/map-marker-error.svg +0 -1
- package/assets/map-marker-off.svg +0 -1
- package/assets/map-marker-remove.svg +0 -1
- package/assets/map-marker-warning.svg +0 -1
- package/assets/map-marker.svg +0 -1
- package/assets/map.svg +0 -1
- package/assets/marshall-island.svg +0 -1
- package/assets/martinique.svg +0 -1
- package/assets/materials_color.svg +0 -1
- package/assets/math_color.svg +0 -1
- package/assets/math_elementary_color.svg +0 -1
- package/assets/mathematics.svg +0 -1
- package/assets/mauritania.svg +0 -1
- package/assets/mauritius.svg +0 -1
- package/assets/maximize.svg +0 -1
- package/assets/medal-fill.svg +0 -1
- package/assets/medal.svg +0 -1
- package/assets/medicine_color.svg +0 -1
- package/assets/megaphone_color.svg +0 -1
- package/assets/memo-check.svg +0 -1
- package/assets/memo-pencil.svg +0 -1
- package/assets/menu-fill.svg +0 -1
- package/assets/menu.svg +0 -1
- package/assets/message-circle-chat-fill.svg +0 -1
- package/assets/message-circle-chat.svg +0 -1
- package/assets/message-circle-export.svg +0 -1
- package/assets/message-circle-import.svg +0 -1
- package/assets/message-circle-info.svg +0 -1
- package/assets/message-circle-lines.svg +0 -1
- package/assets/message-circle-minus.svg +0 -1
- package/assets/message-circle-notif.svg +0 -1
- package/assets/message-circle-plus.svg +0 -1
- package/assets/message-circle-question.svg +0 -1
- package/assets/message-circle-tick.svg +0 -1
- package/assets/message-circle-warning.svg +0 -1
- package/assets/message-circle-xmark.svg +0 -1
- package/assets/message-circle.svg +0 -1
- package/assets/message-square-arrow-down.svg +0 -1
- package/assets/message-square-chat.svg +0 -1
- package/assets/message-square-export.svg +0 -1
- package/assets/message-square-info.svg +0 -1
- package/assets/message-square-lines-fill.svg +0 -1
- package/assets/message-square-lines.svg +0 -1
- package/assets/message-square-minus.svg +0 -1
- package/assets/message-square-notif.svg +0 -1
- package/assets/message-square-plus.svg +0 -1
- package/assets/message-square-question.svg +0 -1
- package/assets/message-square-remove.svg +0 -1
- package/assets/message-square-tick.svg +0 -1
- package/assets/message-square-warning.svg +0 -1
- package/assets/message-square.svg +0 -1
- package/assets/message_default.svg +0 -1
- package/assets/mexico.svg +0 -1
- package/assets/micronesia.svg +0 -1
- package/assets/microphone-off.svg +0 -1
- package/assets/microphone.svg +0 -1
- package/assets/mini_group_color.svg +0 -1
- package/assets/minimize.svg +0 -1
- package/assets/minus-circle-fill.svg +0 -1
- package/assets/minus-circle.svg +0 -1
- package/assets/minus-fill.svg +0 -1
- package/assets/minus.svg +0 -1
- package/assets/mix.svg +0 -1
- package/assets/mobile-bolt.svg +0 -1
- package/assets/mobile-remove.svg +0 -1
- package/assets/mobile-signal-out.svg +0 -1
- package/assets/mobile-signal.svg +0 -1
- package/assets/mobile-slash.svg +0 -1
- package/assets/mobile-tick.svg +0 -1
- package/assets/mobile.svg +0 -1
- package/assets/modem.svg +0 -1
- package/assets/moldova.svg +0 -1
- package/assets/monaco.svg +0 -1
- package/assets/mongolia.svg +0 -1
- package/assets/montenegro.svg +0 -1
- package/assets/montserrat.svg +0 -1
- package/assets/moon-fill.svg +0 -1
- package/assets/moon.svg +0 -1
- package/assets/more-horizontal-fill.svg +0 -1
- package/assets/more-horizontal.svg +0 -1
- package/assets/more-vertical-fill.svg +0 -1
- package/assets/more-vertical.svg +0 -1
- package/assets/morocco.svg +0 -1
- package/assets/motorcycle.svg +0 -1
- package/assets/mouse.svg +0 -1
- package/assets/move-down.svg +0 -1
- package/assets/move-left.svg +0 -1
- package/assets/move-right.svg +0 -1
- package/assets/move-up.svg +0 -1
- package/assets/move.svg +0 -1
- package/assets/mozambique.svg +0 -1
- package/assets/multi_discipline_color.svg +0 -1
- package/assets/music-note-off.svg +0 -1
- package/assets/music-note.svg +0 -1
- package/assets/music.svg +0 -1
- package/assets/music_color.svg +0 -1
- package/assets/myanmar.svg +0 -1
- package/assets/namibia.svg +0 -1
- package/assets/native_language_color.svg +0 -1
- package/assets/natural_sciences_color.svg +0 -1
- package/assets/nauru.svg +0 -1
- package/assets/navigation-forward.svg +0 -1
- package/assets/navigation.svg +0 -1
- package/assets/nepal.svg +0 -1
- package/assets/netherlands.svg +0 -1
- package/assets/new-zealand.svg +0 -1
- package/assets/next-fast.svg +0 -1
- package/assets/next.svg +0 -1
- package/assets/nicaragua.svg +0 -1
- package/assets/niger.svg +0 -1
- package/assets/nigeria.svg +0 -1
- package/assets/niue.svg +0 -1
- package/assets/norfolk-island.svg +0 -1
- package/assets/north-korea.svg +0 -1
- package/assets/northern-marianas-islands.svg +0 -1
- package/assets/norway.svg +0 -1
- package/assets/note-sticky.svg +0 -1
- package/assets/notebook.svg +0 -1
- package/assets/notif-fill.svg +0 -1
- package/assets/notif-off-fill.svg +0 -1
- package/assets/notif-off.svg +0 -1
- package/assets/notif.svg +0 -1
- package/assets/objective_default.svg +0 -1
- package/assets/objects-align-bottom.svg +0 -1
- package/assets/objects-align-center-horizontal.svg +0 -1
- package/assets/objects-align-center-vertical.svg +0 -1
- package/assets/objects-align-left.svg +0 -1
- package/assets/objects-align-right.svg +0 -1
- package/assets/objects-align-top.svg +0 -1
- package/assets/objects-column.svg +0 -1
- package/assets/obz_color.svg +0 -1
- package/assets/obz_elementary_color.svg +0 -1
- package/assets/octagon.svg +0 -1
- package/assets/ok-authorization.svg +0 -1
- package/assets/ok-social-color.svg +0 -1
- package/assets/ok-social.svg +0 -1
- package/assets/olympiad_color.svg +0 -1
- package/assets/oman.svg +0 -1
- package/assets/outcome.svg +0 -1
- package/assets/overline.svg +0 -1
- package/assets/ovz_color.svg +0 -1
- package/assets/page_default.svg +0 -1
- package/assets/paint-roller.svg +0 -1
- package/assets/paintbrush.svg +0 -1
- package/assets/pakistan.svg +0 -1
- package/assets/palau.svg +0 -1
- package/assets/palestine.svg +0 -1
- package/assets/palette-fill.svg +0 -1
- package/assets/palette.svg +0 -1
- package/assets/panama.svg +0 -1
- package/assets/paperclip-slash.svg +0 -1
- package/assets/paperclip.svg +0 -1
- package/assets/papua-new-guinea.svg +0 -1
- package/assets/paragraph.svg +0 -1
- package/assets/paraguay.svg +0 -1
- package/assets/parchment.svg +0 -1
- package/assets/parent.svg +0 -1
- package/assets/pause-circle.svg +0 -1
- package/assets/pause-fill.svg +0 -1
- package/assets/pause-square.svg +0 -1
- package/assets/pause-thin-fill.svg +0 -1
- package/assets/pause-thin.svg +0 -1
- package/assets/pause.svg +0 -1
- package/assets/pen-nib-off.svg +0 -1
- package/assets/pen-nib.svg +0 -1
- package/assets/pen-ruler.svg +0 -1
- package/assets/pen-slash.svg +0 -1
- package/assets/pen.svg +0 -1
- package/assets/pencil-off.svg +0 -1
- package/assets/pencil.svg +0 -1
- package/assets/pencil_default.svg +0 -1
- package/assets/pentagon.svg +0 -1
- package/assets/people.svg +0 -1
- package/assets/percentage.svg +0 -1
- package/assets/person_default.svg +0 -1
- package/assets/peru.svg +0 -1
- package/assets/philippines.svg +0 -1
- package/assets/phone-add.svg +0 -1
- package/assets/phone-call.svg +0 -1
- package/assets/phone-fill.svg +0 -1
- package/assets/phone-flip.svg +0 -1
- package/assets/phone-incoming.svg +0 -1
- package/assets/phone-missed.svg +0 -1
- package/assets/phone-office.svg +0 -1
- package/assets/phone-outgoing.svg +0 -1
- package/assets/phone-pause.svg +0 -1
- package/assets/phone-received.svg +0 -1
- package/assets/phone-remove.svg +0 -1
- package/assets/phone-slash.svg +0 -1
- package/assets/phone.svg +0 -1
- package/assets/phoneNoFill_default.svg +0 -1
- package/assets/phone_color.svg +0 -1
- package/assets/phone_default.svg +0 -1
- package/assets/photo-off.svg +0 -1
- package/assets/photo.svg +0 -1
- package/assets/physic_chemistry_color.svg +0 -1
- package/assets/physics.svg +0 -1
- package/assets/physics_color.svg +0 -1
- package/assets/picture_color.svg +0 -1
- package/assets/pin-fill.svg +0 -1
- package/assets/pin-location.svg +0 -1
- package/assets/pin.svg +0 -1
- package/assets/pitcairn-islands.svg +0 -1
- package/assets/play-circle.svg +0 -1
- package/assets/play-fill.svg +0 -1
- package/assets/play-pause.svg +0 -1
- package/assets/play-square.svg +0 -1
- package/assets/play.svg +0 -1
- package/assets/playPause_default.svg +0 -1
- package/assets/play_default.svg +0 -1
- package/assets/plug.svg +0 -1
- package/assets/plus-circle-fill.svg +0 -1
- package/assets/plus-circle.svg +0 -1
- package/assets/plus-fill.svg +0 -1
- package/assets/plus-large-fill.svg +0 -1
- package/assets/plus-large.svg +0 -1
- package/assets/plus.svg +0 -1
- package/assets/plusThin_default.svg +0 -1
- package/assets/plus_default.svg +0 -1
- package/assets/podcast.svg +0 -1
- package/assets/podium.svg +0 -1
- package/assets/pointer-down.svg +0 -1
- package/assets/pointer-left.svg +0 -1
- package/assets/pointer-right.svg +0 -1
- package/assets/pointer-up.svg +0 -1
- package/assets/poland.svg +0 -1
- package/assets/portugal.svg +0 -1
- package/assets/power-bank.svg +0 -1
- package/assets/power-off-fill.svg +0 -1
- package/assets/power-off.svg +0 -1
- package/assets/present_default.svg +0 -15
- package/assets/presentation-chart.svg +0 -1
- package/assets/presentation.svg +0 -1
- package/assets/previous-fast.svg +0 -1
- package/assets/previous.svg +0 -1
- package/assets/priceTag_default.svg +0 -1
- package/assets/print.svg +0 -1
- package/assets/print_color.svg +0 -1
- package/assets/print_default.svg +0 -1
- package/assets/product_pack_color.svg +0 -1
- package/assets/prof_default.svg +0 -1
- package/assets/program_color.svg +0 -1
- package/assets/programming.svg +0 -1
- package/assets/programming_color.svg +0 -1
- package/assets/projector.svg +0 -1
- package/assets/pronunciation_color.svg +0 -1
- package/assets/psychology_color.svg +0 -1
- package/assets/puerto-rico.svg +0 -1
- package/assets/qatar.svg +0 -1
- package/assets/questionFilled_default.svg +0 -1
- package/assets/radar.svg +0 -1
- package/assets/radioChecked_default.svg +0 -1
- package/assets/radioNotChecked_default.svg +0 -1
- package/assets/rap_and_culture_color.svg +0 -1
- package/assets/reciept.svg +0 -1
- package/assets/rectangle-code.svg +0 -1
- package/assets/rectangle-terminal.svg +0 -1
- package/assets/rectangle-vertical.svg +0 -1
- package/assets/rectangle-wide.svg +0 -1
- package/assets/rectangles-mixed-fill.svg +0 -1
- package/assets/rectangles-mixed.svg +0 -1
- package/assets/redo-fill.svg +0 -1
- package/assets/redo.svg +0 -1
- package/assets/refresh-clock.svg +0 -1
- package/assets/refresh-fill.svg +0 -1
- package/assets/refresh.svg +0 -1
- package/assets/reload_default.svg +0 -1
- package/assets/repeat-vertical.svg +0 -1
- package/assets/repeat.svg +0 -1
- package/assets/reply.svg +0 -1
- package/assets/republic-of-macedonia.svg +0 -1
- package/assets/republic-of-the_congo.svg +0 -1
- package/assets/resize-handle.svg +0 -1
- package/assets/rewinding-left.svg +0 -1
- package/assets/rewinding-right.svg +0 -1
- package/assets/rhombus.svg +0 -1
- package/assets/right-alignment.svg +0 -1
- package/assets/right-indent.svg +0 -1
- package/assets/right-to-left-text-direction.svg +0 -1
- package/assets/robot_color.svg +0 -1
- package/assets/robotechnics_color.svg +0 -1
- package/assets/rocket-fill.svg +0 -1
- package/assets/rocket.svg +0 -1
- package/assets/romania.svg +0 -1
- package/assets/rotate-fill.svg +0 -1
- package/assets/rotate-left-fill.svg +0 -1
- package/assets/rotate-left.svg +0 -1
- package/assets/rotate-right-fill.svg +0 -1
- package/assets/rotate-right.svg +0 -1
- package/assets/rotate.svg +0 -1
- package/assets/route.svg +0 -1
- package/assets/rss.svg +0 -1
- package/assets/rus_native_language_color.svg +0 -1
- package/assets/russia.svg +0 -1
- package/assets/russian_color.svg +0 -1
- package/assets/rwanda.svg +0 -1
- package/assets/sahrawi-arab-democratic_republic.svg +0 -1
- package/assets/samoa.svg +0 -1
- package/assets/san-marino.svg +0 -1
- package/assets/sao-tome-and_prince.svg +0 -1
- package/assets/saudi-arabia.svg +0 -1
- package/assets/sb-auth-mono-color.svg +0 -1
- package/assets/sb-authorization.svg +0 -1
- package/assets/scan.svg +0 -1
- package/assets/school-bag.svg +0 -1
- package/assets/school.svg +0 -1
- package/assets/school_preparation_color.svg +0 -1
- package/assets/school_preparing_color.svg +0 -1
- package/assets/school_program_color.svg +0 -1
- package/assets/scissors.svg +0 -1
- package/assets/scotland.svg +0 -1
- package/assets/screen-export.svg +0 -1
- package/assets/screen-import.svg +0 -1
- package/assets/screen-remove.svg +0 -1
- package/assets/screen-sharing.svg +0 -1
- package/assets/screen.svg +0 -1
- package/assets/screencast.svg +0 -1
- package/assets/scribble.svg +0 -1
- package/assets/seal.svg +0 -1
- package/assets/search-out.svg +0 -1
- package/assets/search-zoom.svg +0 -1
- package/assets/search.svg +0 -1
- package/assets/search_default.svg +0 -1
- package/assets/seconds-10-right.svg +0 -1
- package/assets/seconds-10.svg +0 -1
- package/assets/seconds-15-right.svg +0 -1
- package/assets/seconds-15.svg +0 -1
- package/assets/seconds-5-right.svg +0 -1
- package/assets/seconds-5.svg +0 -1
- package/assets/send-angle.svg +0 -1
- package/assets/send-forward.svg +0 -1
- package/assets/send.svg +0 -1
- package/assets/sending-left.svg +0 -1
- package/assets/sending-right.svg +0 -1
- package/assets/senegal.svg +0 -1
- package/assets/serbia.svg +0 -1
- package/assets/server.svg +0 -1
- package/assets/server_color.svg +0 -1
- package/assets/settings-fill.svg +0 -1
- package/assets/settings.svg +0 -1
- package/assets/settings_1_color.svg +0 -1
- package/assets/settings_2_color.svg +0 -1
- package/assets/settings_3_color.svg +0 -1
- package/assets/settings_default.svg +0 -1
- package/assets/seychelles.svg +0 -1
- package/assets/shapes.svg +0 -1
- package/assets/share-fill.svg +0 -1
- package/assets/share.svg +0 -1
- package/assets/sharpCross_default.svg +0 -1
- package/assets/shield-check.svg +0 -1
- package/assets/shield-error.svg +0 -1
- package/assets/shield-keyhole.svg +0 -1
- package/assets/shield-minus.svg +0 -1
- package/assets/shield-plus.svg +0 -1
- package/assets/shield-slash.svg +0 -1
- package/assets/shield-warning.svg +0 -1
- package/assets/shield.svg +0 -1
- package/assets/shop.svg +0 -1
- package/assets/shopping_color.svg +0 -1
- package/assets/sidebar.svg +0 -1
- package/assets/sierra-leone.svg +0 -1
- package/assets/sigma.svg +0 -1
- package/assets/signal-off.svg +0 -1
- package/assets/signal-steam-off.svg +0 -1
- package/assets/signal-steam-warning.svg +0 -1
- package/assets/signal-steam.svg +0 -1
- package/assets/signal-warning.svg +0 -1
- package/assets/signal.svg +0 -1
- package/assets/signature.svg +0 -1
- package/assets/singapore.svg +0 -1
- package/assets/sint-maarten.svg +0 -1
- package/assets/slash-flip.svg +0 -1
- package/assets/slash.svg +0 -1
- package/assets/slide.svg +0 -1
- package/assets/sliders.svg +0 -1
- package/assets/slovakia.svg +0 -1
- package/assets/slovenia.svg +0 -1
- package/assets/social_color.svg +0 -1
- package/assets/social_elementary_color.svg +0 -1
- package/assets/social_sciences_color.svg +0 -1
- package/assets/solomon-islands.svg +0 -1
- package/assets/somalia.svg +0 -1
- package/assets/sort-amount-down.svg +0 -1
- package/assets/sort-amount-up.svg +0 -1
- package/assets/sort-down-fill.svg +0 -1
- package/assets/sort-down.svg +0 -1
- package/assets/sort-fill.svg +0 -1
- package/assets/sort-up-fill.svg +0 -1
- package/assets/sort-up.svg +0 -1
- package/assets/sort.svg +0 -1
- package/assets/sort_default.svg +0 -1
- package/assets/south-africa.svg +0 -1
- package/assets/south-korea.svg +0 -1
- package/assets/south-sudan.svg +0 -1
- package/assets/spain.svg +0 -1
- package/assets/spanish_color.svg +0 -1
- package/assets/spell-check.svg +0 -1
- package/assets/spelling_color.svg +0 -1
- package/assets/sport.svg +0 -1
- package/assets/square-a-lock.svg +0 -1
- package/assets/square-check-fill.svg +0 -1
- package/assets/square-check.svg +0 -1
- package/assets/square-code.svg +0 -1
- package/assets/square-dashed.svg +0 -1
- package/assets/square-dazzle.svg +0 -1
- package/assets/square-kanban.svg +0 -1
- package/assets/square-list.svg +0 -1
- package/assets/square-minus-fill.svg +0 -1
- package/assets/square-minus.svg +0 -1
- package/assets/square-poll-horizontal.svg +0 -1
- package/assets/square-poll-vertical.svg +0 -1
- package/assets/square-quarters.svg +0 -1
- package/assets/square-ring.svg +0 -1
- package/assets/square-small.svg +0 -1
- package/assets/square-t.svg +0 -1
- package/assets/square-terminal.svg +0 -1
- package/assets/square.svg +0 -1
- package/assets/sri-lanka.svg +0 -1
- package/assets/st-barts.svg +0 -1
- package/assets/st-lucia.svg +0 -1
- package/assets/st-vincent-and-the-grenadines.svg +0 -1
- package/assets/star-blink.svg +0 -1
- package/assets/star-circle.svg +0 -1
- package/assets/star-fill.svg +0 -1
- package/assets/star-half-stroke.svg +0 -1
- package/assets/star-half.svg +0 -1
- package/assets/star-sparkle.svg +0 -1
- package/assets/star-warning.svg +0 -1
- package/assets/star.svg +0 -1
- package/assets/star_default.svg +0 -1
- package/assets/stars.svg +0 -1
- package/assets/stopwatch.svg +0 -1
- package/assets/strikethrough.svg +0 -1
- package/assets/structure.svg +0 -1
- package/assets/student-fill.svg +0 -1
- package/assets/student.svg +0 -1
- package/assets/student_default.svg +0 -1
- package/assets/subdirectory.svg +0 -1
- package/assets/subscript.svg +0 -1
- package/assets/sudan.svg +0 -1
- package/assets/superscript.svg +0 -1
- package/assets/support.svg +0 -1
- package/assets/suriname.svg +0 -1
- package/assets/swaziland.svg +0 -1
- package/assets/sweden.svg +0 -1
- package/assets/switch-horizontal.svg +0 -1
- package/assets/switch-vertical.svg +0 -1
- package/assets/switzerland.svg +0 -1
- package/assets/syria.svg +0 -1
- package/assets/t-bank-authorization.svg +0 -1
- package/assets/table-cells-large.svg +0 -1
- package/assets/table-cells.svg +0 -1
- package/assets/table-columns.svg +0 -1
- package/assets/table-layout.svg +0 -1
- package/assets/table-list.svg +0 -1
- package/assets/table-rows.svg +0 -1
- package/assets/table.svg +0 -1
- package/assets/tablet.svg +0 -1
- package/assets/tag-fill.svg +0 -1
- package/assets/tag.svg +0 -1
- package/assets/tags-fill.svg +0 -1
- package/assets/tags.svg +0 -1
- package/assets/taiwan.svg +0 -1
- package/assets/tajikistan.svg +0 -1
- package/assets/tanzania.svg +0 -1
- package/assets/target_default.svg +0 -1
- package/assets/task-fill.svg +0 -1
- package/assets/task.svg +0 -1
- package/assets/tasks_color.svg +0 -1
- package/assets/tasks_default.svg +0 -4
- package/assets/tbank-auth-mono-color.svg +0 -1
- package/assets/teacher.svg +0 -1
- package/assets/technology_color.svg +0 -1
- package/assets/telegram-social-color.svg +0 -1
- package/assets/telegram-social.svg +0 -1
- package/assets/terminal.svg +0 -1
- package/assets/terminal_color.svg +0 -1
- package/assets/test.svg +0 -1
- package/assets/test_color.svg +0 -1
- package/assets/text-big.svg +0 -1
- package/assets/text-erase.svg +0 -1
- package/assets/text-height.svg +0 -1
- package/assets/text-move-left.svg +0 -1
- package/assets/text-move-right.svg +0 -1
- package/assets/text-note.svg +0 -1
- package/assets/text-size.svg +0 -1
- package/assets/text-small.svg +0 -1
- package/assets/text-width.svg +0 -1
- package/assets/text.svg +0 -1
- package/assets/textbook_color.svg +0 -1
- package/assets/textbook_default.svg +0 -1
- package/assets/thailand.svg +0 -1
- package/assets/theory_color.svg +0 -1
- package/assets/ticket-simple.svg +0 -1
- package/assets/tiktok-social.svg +0 -1
- package/assets/time-off.svg +0 -1
- package/assets/timer.svg +0 -1
- package/assets/tinkoff-authorization.svg +0 -1
- package/assets/tinyCross_default.svg +0 -1
- package/assets/togo.svg +0 -1
- package/assets/tokelau.svg +0 -1
- package/assets/tonga.svg +0 -1
- package/assets/top-alignment.svg +0 -1
- package/assets/train.svg +0 -1
- package/assets/training_color.svg +0 -1
- package/assets/translate_color.svg +0 -1
- package/assets/trash-arrow-up-fill.svg +0 -1
- package/assets/trash-arrow-up.svg +0 -1
- package/assets/trash-blank-fill.svg +0 -1
- package/assets/trash-blank.svg +0 -1
- package/assets/trash-check-fill.svg +0 -1
- package/assets/trash-check.svg +0 -1
- package/assets/trash-clock.svg +0 -1
- package/assets/trash-fill.svg +0 -1
- package/assets/trash-list-fill.svg +0 -1
- package/assets/trash-list.svg +0 -1
- package/assets/trash-plus-fill.svg +0 -1
- package/assets/trash-plus.svg +0 -1
- package/assets/trash-slash-fill.svg +0 -1
- package/assets/trash-slash.svg +0 -1
- package/assets/trash-undo-fill.svg +0 -1
- package/assets/trash-undo.svg +0 -1
- package/assets/trash-xmark-fill.svg +0 -1
- package/assets/trash-xmark.svg +0 -1
- package/assets/trash.svg +0 -1
- package/assets/triangle.svg +0 -1
- package/assets/trinidad-and-tobago.svg +0 -1
- package/assets/trophy.svg +0 -1
- package/assets/trophy_color.svg +0 -1
- package/assets/trophy_default.svg +0 -1
- package/assets/tunisia.svg +0 -1
- package/assets/turkey.svg +0 -1
- package/assets/turkmenistan.svg +0 -1
- package/assets/turks-and-caicos.svg +0 -1
- package/assets/tutor_color.svg +0 -1
- package/assets/tuvalu.svg +0 -1
- package/assets/tv.svg +0 -1
- package/assets/twenty-thirty-five-authorization.svg +0 -1
- package/assets/uganda.svg +0 -1
- package/assets/ukraine.svg +0 -1
- package/assets/un2035-auth-mono-color.svg +0 -1
- package/assets/underline.svg +0 -1
- package/assets/undo-fill.svg +0 -1
- package/assets/undo.svg +0 -1
- package/assets/united-arab-emirates.svg +0 -1
- package/assets/united-kingdom.svg +0 -1
- package/assets/united-states.svg +0 -1
- package/assets/university.svg +0 -1
- package/assets/unlock.svg +0 -1
- package/assets/unsort_default.svg +0 -1
- package/assets/upload-fill.svg +0 -1
- package/assets/upload.svg +0 -1
- package/assets/uruguay.svg +0 -1
- package/assets/usb-flash-drive.svg +0 -1
- package/assets/user-add.svg +0 -1
- package/assets/user-block.svg +0 -1
- package/assets/user-circle.svg +0 -1
- package/assets/user-edit.svg +0 -1
- package/assets/user-heart.svg +0 -1
- package/assets/user-lock.svg +0 -1
- package/assets/user-minus.svg +0 -1
- package/assets/user-question.svg +0 -1
- package/assets/user-remove.svg +0 -1
- package/assets/user-square.svg +0 -1
- package/assets/user-tick.svg +0 -1
- package/assets/user.svg +0 -1
- package/assets/users-fill.svg +0 -1
- package/assets/users.svg +0 -1
- package/assets/uzbekistan.svg +0 -1
- package/assets/vanuatu.svg +0 -1
- package/assets/vatican-city.svg +0 -1
- package/assets/vault.svg +0 -1
- package/assets/venezuela.svg +0 -1
- package/assets/video-add.svg +0 -1
- package/assets/video-export.svg +0 -1
- package/assets/video-fill.svg +0 -1
- package/assets/video-import.svg +0 -1
- package/assets/video-slash-fill.svg +0 -1
- package/assets/video_default.svg +0 -1
- package/assets/vietnam.svg +0 -1
- package/assets/virgin-islands.svg +0 -1
- package/assets/vk-auth-mono-color.svg +0 -1
- package/assets/vk-authorization.svg +0 -1
- package/assets/vk-social-color.svg +0 -1
- package/assets/vk-social.svg +0 -1
- package/assets/voicemail.svg +0 -1
- package/assets/volume-add.svg +0 -1
- package/assets/volume-min.svg +0 -1
- package/assets/volume-minus.svg +0 -1
- package/assets/volume-off.svg +0 -1
- package/assets/volume-remove.svg +0 -1
- package/assets/volume.svg +0 -1
- package/assets/wales.svg +0 -1
- package/assets/wallet-add.svg +0 -1
- package/assets/wallet-remove.svg +0 -1
- package/assets/wallet-transfer.svg +0 -1
- package/assets/wallet.svg +0 -1
- package/assets/wallet_default.svg +0 -1
- package/assets/wand-magic-sparkles.svg +0 -1
- package/assets/wand-magic.svg +0 -1
- package/assets/warning-circle-check.svg +0 -1
- package/assets/warning-circle-fill.svg +0 -1
- package/assets/warning-circle.svg +0 -1
- package/assets/warning-seal-fill.svg +0 -1
- package/assets/warning-seal.svg +0 -1
- package/assets/warning-triangle-fill.svg +0 -1
- package/assets/warning-triangle.svg +0 -1
- package/assets/warning.svg +0 -1
- package/assets/watch.svg +0 -1
- package/assets/webcam-slash-off.svg +0 -1
- package/assets/webcam.svg +0 -1
- package/assets/weight.svg +0 -1
- package/assets/whatsapp-social-color.svg +0 -1
- package/assets/whatsapp-social-fill.svg +0 -1
- package/assets/whatsapp-social.svg +0 -1
- package/assets/wifi-off.svg +0 -1
- package/assets/wifi-warning.svg +0 -1
- package/assets/wifi.svg +0 -1
- package/assets/window.svg +0 -1
- package/assets/work.svg +0 -1
- package/assets/world_color.svg +0 -1
- package/assets/world_elementary_color.svg +0 -1
- package/assets/yandex-auth-mono-color.svg +0 -1
- package/assets/yandex-authorization.svg +0 -1
- package/assets/yemen.svg +0 -1
- package/assets/youtube-alt-social-color.svg +0 -1
- package/assets/youtube-alt-social.svg +0 -1
- package/assets/youtube-social.svg +0 -1
- package/assets/zambia.svg +0 -1
- package/assets/zimbabwe.svg +0 -1
- package/components/Checkbox/images/check-default.svg.js +0 -2
- package/components/Checkbox/images/check-default.svg.js.map +0 -1
- package/components/Checkbox/images/check-default.svg.mjs +0 -2
- package/components/Checkbox/images/check-default.svg.mjs.map +0 -1
- package/components/Checkbox/images/check.svg.js +0 -2
- package/components/Checkbox/images/check.svg.js.map +0 -1
- package/components/Checkbox/images/check.svg.mjs +0 -2
- package/components/Checkbox/images/check.svg.mjs.map +0 -1
- package/components/Icon/bg-worker.js +0 -2
- package/components/Icon/bg-worker.js.map +0 -1
- package/components/Icon/bg-worker.mjs +0 -2
- package/components/Icon/bg-worker.mjs.map +0 -1
- package/components/Icon/constants.js +0 -2
- package/components/Icon/constants.js.map +0 -1
- package/components/Icon/constants.mjs +0 -2
- package/components/Icon/constants.mjs.map +0 -1
- package/components/Icon/list/default.js +0 -2
- package/components/Icon/list/default.js.map +0 -1
- package/components/Icon/list/default.mjs +0 -2
- package/components/Icon/list/default.mjs.map +0 -1
- package/components/Icon/list/icon-pack.js +0 -2
- package/components/Icon/list/icon-pack.js.map +0 -1
- package/components/Icon/list/icon-pack.mjs +0 -2
- package/components/Icon/list/icon-pack.mjs.map +0 -1
- package/components/Icon/list/index.js +0 -2
- package/components/Icon/list/index.js.map +0 -1
- package/components/Icon/list/index.mjs +0 -2
- package/components/Icon/list/index.mjs.map +0 -1
- package/components/InputCheckbox/images/checked.svg.js +0 -2
- package/components/InputCheckbox/images/checked.svg.js.map +0 -1
- package/components/InputCheckbox/images/checked.svg.mjs +0 -2
- package/components/InputCheckbox/images/checked.svg.mjs.map +0 -1
- package/components/InputCheckbox/images/indeterminate.svg.js +0 -2
- package/components/InputCheckbox/images/indeterminate.svg.js.map +0 -1
- package/components/InputCheckbox/images/indeterminate.svg.mjs +0 -2
- package/components/InputCheckbox/images/indeterminate.svg.mjs.map +0 -1
- package/components/Notification/layouts.js +0 -2
- package/components/Notification/layouts.js.map +0 -1
- package/components/Notification/layouts.mjs +0 -2
- package/components/Notification/layouts.mjs.map +0 -1
- package/components/Notification/sizes.js +0 -2
- package/components/Notification/sizes.js.map +0 -1
- package/components/Notification/sizes.mjs +0 -2
- package/components/Notification/sizes.mjs.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TabList.mjs","sources":["../../../../src/components/TabList/TabList.tsx"],"sourcesContent":["import { forwardRef, useRef, useImperativeHandle, cloneElement, useMemo } from 'react'\nimport { withMergedProps } from 'hocs/withMergedProps'\nimport type { MergedProps } from 'hocs/withMergedProps'\nimport { useScrollThresholds } from 'hooks/useScrollThresholds'\nimport { TabListTab } from 'components/TabListTab'\nimport { IconButton } from 'components/IconButton'\nimport type { IconButtonProps } from 'components/IconButton'\nimport { TabListTabsContext, TabListPropsContext } from 'shared/context/tabList'\nimport { keyboardKeys } from 'shared/constants'\nimport { navigateHorizontalList, SELECTORS_FOCUSABLE } from 'shared/utils/dom'\nimport { focus } from 'mixins/focus'\nimport { TabListPanel } from './TabListPanel'\nimport { useTabList, useTabListItems, useTabListAutoGroup } from './hooks'\nimport { TabListMenuTab } from './TabListMenuTab'\nimport { SIZES, SIZES_SCROLL_CONTROL } from './sizes'\nimport { LAYOUTS, LAYOUTS_DIVIDER, LAYOUTS_ADDON } from './layouts'\nimport type { TabListProps } from './types'\nimport * as Styled from './style'\n\nconst COMPONENT_NAME = 'TabList'\n\n/**\n *\n * Компонент для создания группы табов и ассоциированных с ними панелей с контентом.\n *\n * Поддерживается \"ref\" и все нативные атрибуты \\<div\\> элемента.\n *\n * Дизайн соответствует [рекомендациям WAI-ARIA](https://www.w3.org/WAI/ARIA/apg/patterns/tabs/).\n */\nconst TabList: React.ForwardRefExoticComponent<TabListProps> & {\n Tab: typeof TabListTab\n Panel: typeof TabListPanel\n} = Object.assign(\n withMergedProps<TabListProps, HTMLDivElement>(\n forwardRef<HTMLDivElement, MergedProps<TabListProps>>((props, forwardedRef) => {\n const {\n size = 'm',\n layout = 'horizontal',\n gap = 8,\n activationOnFocus = false,\n tabsAutoGroup = false,\n scrollControls = false,\n scrollFading = false,\n defaultActiveTab,\n activeTab,\n onActiveTabChange,\n variant,\n disabled,\n children,\n menuItems: menuItemsProp,\n addon,\n menuTabText,\n menuTabControl,\n scrollControlLeft,\n scrollControlRight,\n palette,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n layoutXXS,\n layoutXS,\n layoutS,\n layoutM,\n layoutL,\n layoutXL,\n ...restProps\n } = props\n\n const sizeProps = useMemo(\n () => ({ size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL }),\n [size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL]\n )\n\n const layoutProps = {\n layout,\n layoutXXS,\n layoutXS,\n layoutS,\n layoutM,\n layoutL,\n layoutXL,\n }\n\n const rootRef = useRef<HTMLDivElement | null>(null)\n const tabsTrackRef = useRef<HTMLDivElement | null>(null)\n const scrollControlRef = useRef<HTMLDivElement | null>(null)\n\n useImperativeHandle(forwardedRef, () => rootRef.current as HTMLDivElement, [])\n\n const tabListItems = useTabListItems(children, menuItemsProp)\n\n const autoGroupMode = useTabListAutoGroup({\n enabled: tabsAutoGroup,\n tabList: tabListItems.tabs,\n })\n\n const tabList = useTabList({\n defaultActiveTab,\n activeTab,\n onActiveTabChange,\n tabList: tabsAutoGroup ? tabListItems.tabs : tabListItems.combined,\n })\n\n const { scrollThresholds, setScrollThresholds } = useScrollThresholds({\n enabled: !tabsAutoGroup,\n target: tabsTrackRef,\n })\n\n const scrollControlLeftProps: IconButtonProps = {\n ...sizeProps,\n sizes: SIZES_SCROLL_CONTROL,\n icon: 'chevronLeft',\n tabIndex: -1,\n onFocus: (evt) => {\n evt.currentTarget.blur()\n },\n onClick: () => {\n if (!tabsTrackRef.current || !scrollControlRef.current) {\n return\n }\n\n const trackLeft = Math.round(\n tabsTrackRef.current.getBoundingClientRect().left + scrollControlRef.current.getBoundingClientRect().width\n )\n const tabsLeft = Array.from(tabsTrackRef.current.querySelectorAll<HTMLLIElement>('[role=\"tab\"]')).map((tab) =>\n Math.round(tab.getBoundingClientRect().left + focus.padding)\n )\n\n const idx = tabsLeft.findIndex((tabLeft) => tabLeft >= trackLeft)\n\n if ([-1, 0, 1].includes(idx)) {\n tabsTrackRef.current.scrollTo({ top: 0, left: 0, behavior: 'smooth' })\n } else {\n tabsTrackRef.current.scrollBy({\n top: 0,\n left: tabsLeft[idx - 1] - trackLeft,\n behavior: 'smooth',\n })\n }\n },\n }\n\n const scrollControlRightProps: IconButtonProps = {\n ...sizeProps,\n sizes: SIZES_SCROLL_CONTROL,\n icon: 'chevronRight',\n tabIndex: -1,\n onFocus: (evt) => {\n evt.currentTarget.blur()\n },\n onClick: () => {\n if (!tabsTrackRef.current) {\n return\n }\n\n const trackRight = Math.round(tabsTrackRef.current.getBoundingClientRect().right)\n const tabsRight = Array.from(tabsTrackRef.current.querySelectorAll<HTMLLIElement>('[role=\"tab\"]'))\n .map((tab) => Math.round(tab.getBoundingClientRect().right + focus.padding))\n .reverse()\n\n const idx = tabsRight.findIndex((tabRight) => tabRight <= trackRight)\n\n if ([-1, 0, 1].includes(idx)) {\n tabsTrackRef.current.scrollTo({ top: 0, left: tabsTrackRef.current.scrollWidth, behavior: 'smooth' })\n } else {\n tabsTrackRef.current.scrollBy({\n top: 0,\n left: tabsRight[idx - 1] - trackRight,\n behavior: 'smooth',\n })\n }\n },\n }\n\n const controlsContextProps = useMemo(() => ({ ...tabList, activationOnFocus }), [tabList, activationOnFocus])\n\n const tabsContextProps = useMemo(\n () => ({\n ...sizeProps,\n role: 'tab',\n marginRight: gap,\n variant,\n disabled,\n palette: {\n color: palette.tabColor,\n colorHover: palette.tabColorHover,\n colorActive: palette.tabColorActive,\n colorDisabled: palette.tabColorDisabled,\n colorActiveDisabled: palette.tabColorActiveDisabled,\n backgroundColor: palette.tabBackgroundColor,\n backgroundColorHover: palette.tabBackgroundColorHover,\n backgroundColorActive: palette.tabBackgroundColorActive,\n backgroundColorDisabled: palette.tabBackgroundColorDisabled,\n backgroundColorActiveDisabled: palette.tabBackgroundColorActiveDisabled,\n },\n }),\n [sizeProps, gap, variant, disabled, palette]\n )\n\n const hiddenTabsContextProps = useMemo(\n () => ({ ...sizeProps, marginRight: gap, variant }),\n [sizeProps, gap, variant]\n )\n\n const tabs = tabsAutoGroup ? autoGroupMode.groups.tabs : tabListItems.tabs\n const menuItems = tabsAutoGroup ? autoGroupMode.groups.menuItems : tabListItems.menuItems\n\n return (\n <Styled.Root\n {...restProps}\n {...sizeProps}\n {...layoutProps}\n layouts={LAYOUTS}\n palette={{\n backgroundColor: palette.backgroundColor,\n }}\n ref={(node) => {\n rootRef.current = node\n autoGroupMode.refs.root(node)\n }}\n >\n <Styled.List\n role='tablist'\n aria-orientation='horizontal'\n onKeyDown={(evt) => {\n if (\n !(document.activeElement instanceof HTMLElement) ||\n !document.activeElement.matches('[role=\"tab\"]') ||\n (!keyboardKeys.Home.validate(evt.key) &&\n !keyboardKeys.End.validate(evt.key) &&\n !keyboardKeys.ArrowRight.validate(evt.key) &&\n !keyboardKeys.ArrowLeft.validate(evt.key))\n ) {\n return\n }\n\n const tabListTabs = Array.from(evt.currentTarget.querySelectorAll<HTMLElement>('[role=\"tab\"]')).filter(\n (tab) => !tab.closest('[aria-hidden=\"true\"]')\n )\n\n if (tabListTabs.length === 0) return\n\n if (keyboardKeys.Home.validate(evt.key)) {\n evt.preventDefault()\n tabListTabs[0].focus()\n } else if (keyboardKeys.End.validate(evt.key)) {\n evt.preventDefault()\n tabListTabs[tabListTabs.length - 1].focus()\n } else if (keyboardKeys.ArrowRight.validate(evt.key) || keyboardKeys.ArrowLeft.validate(evt.key)) {\n evt.preventDefault()\n navigateHorizontalList(evt.key, document.activeElement, tabListTabs, SELECTORS_FOCUSABLE)\n }\n }}\n >\n <Styled.Container ref={autoGroupMode.refs.container}>\n <Styled.TabsTrack>\n {!tabsAutoGroup && (scrollControls || scrollFading) ? (\n <Styled.Floats hidden={scrollThresholds.left === true || scrollThresholds.left === null}>\n {scrollControls ? (\n <Styled.Control ref={scrollControlRef}>\n {typeof scrollControlLeft === 'function' ? (\n scrollControlLeft(scrollControlLeftProps)\n ) : (\n <IconButton {...scrollControlLeftProps} />\n )}\n </Styled.Control>\n ) : null}\n {scrollFading ? <Styled.ScrollFading /> : null}\n </Styled.Floats>\n ) : null}\n <Styled.TrackScrollable\n ref={(node) => {\n tabsTrackRef.current = node\n autoGroupMode.refs.track(node)\n }}\n tabIndex={-1}\n data-ui-track-scrollable\n onFocus={(evt) => {\n if (!evt.target.matches('[role=\"tab\"]')) {\n return\n }\n\n const trackRect = evt.currentTarget.getBoundingClientRect()\n const tabRect = evt.target.getBoundingClientRect()\n\n const trackRight = Math.round(trackRect.right)\n const trackLeft = Math.round(\n scrollControlRef.current && scrollThresholds.left === false\n ? trackRect.left + scrollControlRef.current.getBoundingClientRect().width\n : trackRect.left\n )\n\n const tabRight = Math.round(tabRect.right + focus.padding)\n const tabLeft = Math.round(tabRect.left - focus.padding)\n\n if (tabRight > trackRight) {\n evt.currentTarget.scrollBy(tabRight - trackRight, 0)\n } else if (tabLeft < trackLeft) {\n evt.currentTarget.scrollBy(tabLeft - trackLeft, 0)\n }\n }}\n onScroll={(evt) => {\n if (!tabsAutoGroup) {\n setScrollThresholds(evt.currentTarget)\n }\n }}\n >\n <TabListTabsContext.Provider value={controlsContextProps}>\n <TabListPropsContext.Provider value={tabsContextProps}>\n {tabsAutoGroup\n ? tabs.map((tab, idx) => <Styled.TabWrapper key={idx}>{tab}</Styled.TabWrapper>)\n : tabs}\n </TabListPropsContext.Provider>\n </TabListTabsContext.Provider>\n </Styled.TrackScrollable>\n {!tabsAutoGroup && scrollFading ? (\n <Styled.Floats hidden={scrollThresholds.right === true || scrollThresholds.right === null} after>\n <Styled.ScrollFading after />\n </Styled.Floats>\n ) : null}\n </Styled.TabsTrack>\n {!tabsAutoGroup && scrollControls ? (\n <Styled.Control hidden={scrollThresholds.right === true || scrollThresholds.right === null}>\n {typeof scrollControlRight === 'function' ? (\n scrollControlRight(scrollControlRightProps)\n ) : (\n <IconButton {...scrollControlRightProps} />\n )}\n </Styled.Control>\n ) : null}\n {menuItems.length > 0 && (\n <Styled.Control\n ref={(node) => {\n autoGroupMode.refs.control(node)\n }}\n >\n <TabListMenuTab\n {...sizeProps}\n {...tabList}\n role='tab'\n variant={variant}\n disabled={disabled}\n palette={palette}\n menuItems={menuItems}\n activationOnFocus={activationOnFocus}\n text={menuTabText}\n control={menuTabControl}\n />\n </Styled.Control>\n )}\n </Styled.Container>\n {tabsAutoGroup ? (\n <Styled.Hidden aria-hidden>\n <Styled.TabsHidden>\n <TabListPropsContext.Provider value={hiddenTabsContextProps}>\n {tabListItems.tabs.map((tab, idx) => (\n <Styled.TabWrapper\n key={idx}\n ref={(node) => {\n autoGroupMode.refs.tabHidden(idx, node)\n }}\n >\n {cloneElement(tab, { ref: null, id: undefined, role: 'none' })}\n </Styled.TabWrapper>\n ))}\n </TabListPropsContext.Provider>\n </Styled.TabsHidden>\n </Styled.Hidden>\n ) : null}\n </Styled.List>\n {addon ? (\n <Styled.Addon\n {...layoutProps}\n layouts={LAYOUTS_ADDON}\n ref={(node) => {\n autoGroupMode.refs.addon(node)\n }}\n >\n {addon}\n </Styled.Addon>\n ) : null}\n {variant === 'underlined' && (\n <Styled.DividerPositioned {...layoutProps} layouts={LAYOUTS_DIVIDER} color={palette.dividerColor} />\n )}\n </Styled.Root>\n )\n }),\n {\n displayName: COMPONENT_NAME,\n sizes: SIZES,\n }\n ),\n {\n Tab: TabListTab,\n Panel: TabListPanel,\n }\n)\n\nexport { TabList }\n"],"names":["TabList","Object","assign","withMergedProps","forwardRef","props","forwardedRef","size","layout","gap","activationOnFocus","tabsAutoGroup","scrollControls","scrollFading","defaultActiveTab","activeTab","onActiveTabChange","variant","disabled","children","menuItems","menuItemsProp","addon","menuTabText","menuTabControl","scrollControlLeft","scrollControlRight","palette","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","layoutXXS","layoutXS","layoutS","layoutM","layoutL","layoutXL","restProps","sizeProps","useMemo","layoutProps","rootRef","useRef","tabsTrackRef","scrollControlRef","useImperativeHandle","current","tabListItems","useTabListItems","autoGroupMode","useTabListAutoGroup","enabled","tabList","tabs","useTabList","combined","scrollThresholds","setScrollThresholds","useScrollThresholds","target","scrollControlLeftProps","sizes","SIZES_SCROLL_CONTROL","icon","tabIndex","onFocus","evt","currentTarget","blur","onClick","trackLeft","Math","round","getBoundingClientRect","left","width","tabsLeft","Array","from","querySelectorAll","map","tab","focus","padding","idx","findIndex","tabLeft","includes","scrollTo","top","behavior","scrollBy","scrollControlRightProps","trackRight","right","tabsRight","reverse","tabRight","scrollWidth","controlsContextProps","tabsContextProps","role","marginRight","color","tabColor","colorHover","tabColorHover","colorActive","tabColorActive","colorDisabled","tabColorDisabled","colorActiveDisabled","tabColorActiveDisabled","backgroundColor","tabBackgroundColor","backgroundColorHover","tabBackgroundColorHover","backgroundColorActive","tabBackgroundColorActive","backgroundColorDisabled","tabBackgroundColorDisabled","backgroundColorActiveDisabled","tabBackgroundColorActiveDisabled","hiddenTabsContextProps","groups","_jsxs","Styled","layouts","LAYOUTS","ref","node","refs","root","onKeyDown","document","activeElement","HTMLElement","matches","keyboardKeys","Home","validate","key","End","ArrowRight","ArrowLeft","tabListTabs","filter","closest","length","preventDefault","navigateHorizontalList","SELECTORS_FOCUSABLE","container","hidden","_jsx","IconButton","track","trackRect","tabRect","onScroll","TabListTabsContext","Provider","value","TabListPropsContext","after","control","TabListMenuTab","text","tabHidden","cloneElement","id","undefined","LAYOUTS_ADDON","LAYOUTS_DIVIDER","dividerColor","displayName","SIZES","Tab","TabListTab","Panel","TabListPanel"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"TabList.mjs","sources":["../../../../src/components/TabList/TabList.tsx"],"sourcesContent":["import { forwardRef, useRef, useImperativeHandle, cloneElement, useMemo } from 'react'\nimport { ChevronLeft, ChevronRight } from '@foxford/icon-pack'\nimport { withMergedProps } from 'hocs/withMergedProps'\nimport type { MergedProps } from 'hocs/withMergedProps'\nimport { useScrollThresholds } from 'hooks/useScrollThresholds'\nimport { TabListTab } from 'components/TabListTab'\nimport { IconButton } from 'components/IconButton'\nimport type { IconButtonProps } from 'components/IconButton'\nimport { TabListTabsContext, TabListPropsContext } from 'shared/context/tabList'\nimport { keyboardKeys } from 'shared/constants'\nimport { navigateHorizontalList, SELECTORS_FOCUSABLE } from 'shared/utils/dom'\nimport { focus } from 'mixins/focus'\nimport { TabListPanel } from './TabListPanel'\nimport { useTabList, useTabListItems, useTabListAutoGroup } from './hooks'\nimport { TabListMenuTab } from './TabListMenuTab'\nimport { SIZES, SIZES_SCROLL_CONTROL } from './sizes'\nimport { LAYOUTS, LAYOUTS_DIVIDER, LAYOUTS_ADDON } from './layouts'\nimport type { TabListProps } from './types'\nimport * as Styled from './style'\n\nconst COMPONENT_NAME = 'TabList'\n\n/**\n *\n * Компонент для создания группы табов и ассоциированных с ними панелей с контентом.\n *\n * Поддерживается \"ref\" и все нативные атрибуты \\<div\\> элемента.\n *\n * Дизайн соответствует [рекомендациям WAI-ARIA](https://www.w3.org/WAI/ARIA/apg/patterns/tabs/).\n */\nconst TabList: React.ForwardRefExoticComponent<TabListProps> & {\n Tab: typeof TabListTab\n Panel: typeof TabListPanel\n} = Object.assign(\n withMergedProps<TabListProps, HTMLDivElement>(\n forwardRef<HTMLDivElement, MergedProps<TabListProps>>((props, forwardedRef) => {\n const {\n size = 'm',\n layout = 'horizontal',\n gap = 8,\n activationOnFocus = false,\n tabsAutoGroup = false,\n scrollControls = false,\n scrollFading = false,\n defaultActiveTab,\n activeTab,\n onActiveTabChange,\n variant,\n disabled,\n children,\n menuItems: menuItemsProp,\n addon,\n menuTabText,\n menuTabControl,\n scrollControlLeft,\n scrollControlRight,\n palette,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n layoutXXS,\n layoutXS,\n layoutS,\n layoutM,\n layoutL,\n layoutXL,\n ...restProps\n } = props\n\n const sizeProps = useMemo(\n () => ({ size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL }),\n [size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL]\n )\n\n const layoutProps = {\n layout,\n layoutXXS,\n layoutXS,\n layoutS,\n layoutM,\n layoutL,\n layoutXL,\n }\n\n const rootRef = useRef<HTMLDivElement | null>(null)\n const tabsTrackRef = useRef<HTMLDivElement | null>(null)\n const scrollControlRef = useRef<HTMLDivElement | null>(null)\n\n useImperativeHandle(forwardedRef, () => rootRef.current as HTMLDivElement, [])\n\n const tabListItems = useTabListItems(children, menuItemsProp)\n\n const autoGroupMode = useTabListAutoGroup({\n enabled: tabsAutoGroup,\n tabList: tabListItems.tabs,\n })\n\n const tabList = useTabList({\n defaultActiveTab,\n activeTab,\n onActiveTabChange,\n tabList: tabsAutoGroup ? tabListItems.tabs : tabListItems.combined,\n })\n\n const { scrollThresholds, setScrollThresholds } = useScrollThresholds({\n enabled: !tabsAutoGroup,\n target: tabsTrackRef,\n })\n\n const scrollControlLeftProps: IconButtonProps = {\n ...sizeProps,\n sizes: SIZES_SCROLL_CONTROL,\n icon: <ChevronLeft />,\n tabIndex: -1,\n onFocus: (evt) => {\n evt.currentTarget.blur()\n },\n onClick: () => {\n if (!tabsTrackRef.current || !scrollControlRef.current) {\n return\n }\n\n const trackLeft = Math.round(\n tabsTrackRef.current.getBoundingClientRect().left + scrollControlRef.current.getBoundingClientRect().width\n )\n const tabsLeft = Array.from(tabsTrackRef.current.querySelectorAll<HTMLLIElement>('[role=\"tab\"]')).map((tab) =>\n Math.round(tab.getBoundingClientRect().left + focus.padding)\n )\n\n const idx = tabsLeft.findIndex((tabLeft) => tabLeft >= trackLeft)\n\n if ([-1, 0, 1].includes(idx)) {\n tabsTrackRef.current.scrollTo({ top: 0, left: 0, behavior: 'smooth' })\n } else {\n tabsTrackRef.current.scrollBy({\n top: 0,\n left: tabsLeft[idx - 1] - trackLeft,\n behavior: 'smooth',\n })\n }\n },\n }\n\n const scrollControlRightProps: IconButtonProps = {\n ...sizeProps,\n sizes: SIZES_SCROLL_CONTROL,\n icon: <ChevronRight />,\n tabIndex: -1,\n onFocus: (evt) => {\n evt.currentTarget.blur()\n },\n onClick: () => {\n if (!tabsTrackRef.current) {\n return\n }\n\n const trackRight = Math.round(tabsTrackRef.current.getBoundingClientRect().right)\n const tabsRight = Array.from(tabsTrackRef.current.querySelectorAll<HTMLLIElement>('[role=\"tab\"]'))\n .map((tab) => Math.round(tab.getBoundingClientRect().right + focus.padding))\n .reverse()\n\n const idx = tabsRight.findIndex((tabRight) => tabRight <= trackRight)\n\n if ([-1, 0, 1].includes(idx)) {\n tabsTrackRef.current.scrollTo({ top: 0, left: tabsTrackRef.current.scrollWidth, behavior: 'smooth' })\n } else {\n tabsTrackRef.current.scrollBy({\n top: 0,\n left: tabsRight[idx - 1] - trackRight,\n behavior: 'smooth',\n })\n }\n },\n }\n\n const controlsContextProps = useMemo(() => ({ ...tabList, activationOnFocus }), [tabList, activationOnFocus])\n\n const tabsContextProps = useMemo(\n () => ({\n ...sizeProps,\n role: 'tab',\n marginRight: gap,\n variant,\n disabled,\n palette: {\n color: palette.tabColor,\n colorHover: palette.tabColorHover,\n colorActive: palette.tabColorActive,\n colorDisabled: palette.tabColorDisabled,\n colorActiveDisabled: palette.tabColorActiveDisabled,\n backgroundColor: palette.tabBackgroundColor,\n backgroundColorHover: palette.tabBackgroundColorHover,\n backgroundColorActive: palette.tabBackgroundColorActive,\n backgroundColorDisabled: palette.tabBackgroundColorDisabled,\n backgroundColorActiveDisabled: palette.tabBackgroundColorActiveDisabled,\n },\n }),\n [sizeProps, gap, variant, disabled, palette]\n )\n\n const hiddenTabsContextProps = useMemo(\n () => ({ ...sizeProps, marginRight: gap, variant }),\n [sizeProps, gap, variant]\n )\n\n const tabs = tabsAutoGroup ? autoGroupMode.groups.tabs : tabListItems.tabs\n const menuItems = tabsAutoGroup ? autoGroupMode.groups.menuItems : tabListItems.menuItems\n\n return (\n <Styled.Root\n {...restProps}\n {...sizeProps}\n {...layoutProps}\n layouts={LAYOUTS}\n palette={{\n backgroundColor: palette.backgroundColor,\n }}\n ref={(node) => {\n rootRef.current = node\n autoGroupMode.refs.root(node)\n }}\n >\n <Styled.List\n role='tablist'\n aria-orientation='horizontal'\n onKeyDown={(evt) => {\n if (\n !(document.activeElement instanceof HTMLElement) ||\n !document.activeElement.matches('[role=\"tab\"]') ||\n (!keyboardKeys.Home.validate(evt.key) &&\n !keyboardKeys.End.validate(evt.key) &&\n !keyboardKeys.ArrowRight.validate(evt.key) &&\n !keyboardKeys.ArrowLeft.validate(evt.key))\n ) {\n return\n }\n\n const tabListTabs = Array.from(evt.currentTarget.querySelectorAll<HTMLElement>('[role=\"tab\"]')).filter(\n (tab) => !tab.closest('[aria-hidden=\"true\"]')\n )\n\n if (tabListTabs.length === 0) return\n\n if (keyboardKeys.Home.validate(evt.key)) {\n evt.preventDefault()\n tabListTabs[0].focus()\n } else if (keyboardKeys.End.validate(evt.key)) {\n evt.preventDefault()\n tabListTabs[tabListTabs.length - 1].focus()\n } else if (keyboardKeys.ArrowRight.validate(evt.key) || keyboardKeys.ArrowLeft.validate(evt.key)) {\n evt.preventDefault()\n navigateHorizontalList(evt.key, document.activeElement, tabListTabs, SELECTORS_FOCUSABLE)\n }\n }}\n >\n <Styled.Container ref={autoGroupMode.refs.container}>\n <Styled.TabsTrack>\n {!tabsAutoGroup && (scrollControls || scrollFading) ? (\n <Styled.Floats hidden={scrollThresholds.left === true || scrollThresholds.left === null}>\n {scrollControls ? (\n <Styled.Control ref={scrollControlRef}>\n {typeof scrollControlLeft === 'function' ? (\n scrollControlLeft(scrollControlLeftProps)\n ) : (\n <IconButton {...scrollControlLeftProps} />\n )}\n </Styled.Control>\n ) : null}\n {scrollFading ? <Styled.ScrollFading /> : null}\n </Styled.Floats>\n ) : null}\n <Styled.TrackScrollable\n ref={(node) => {\n tabsTrackRef.current = node\n autoGroupMode.refs.track(node)\n }}\n tabIndex={-1}\n data-ui-track-scrollable\n onFocus={(evt) => {\n if (!evt.target.matches('[role=\"tab\"]')) {\n return\n }\n\n const trackRect = evt.currentTarget.getBoundingClientRect()\n const tabRect = evt.target.getBoundingClientRect()\n\n const trackRight = Math.round(trackRect.right)\n const trackLeft = Math.round(\n scrollControlRef.current && scrollThresholds.left === false\n ? trackRect.left + scrollControlRef.current.getBoundingClientRect().width\n : trackRect.left\n )\n\n const tabRight = Math.round(tabRect.right + focus.padding)\n const tabLeft = Math.round(tabRect.left - focus.padding)\n\n if (tabRight > trackRight) {\n evt.currentTarget.scrollBy(tabRight - trackRight, 0)\n } else if (tabLeft < trackLeft) {\n evt.currentTarget.scrollBy(tabLeft - trackLeft, 0)\n }\n }}\n onScroll={(evt) => {\n if (!tabsAutoGroup) {\n setScrollThresholds(evt.currentTarget)\n }\n }}\n >\n <TabListTabsContext.Provider value={controlsContextProps}>\n <TabListPropsContext.Provider value={tabsContextProps}>\n {tabsAutoGroup\n ? tabs.map((tab, idx) => <Styled.TabWrapper key={idx}>{tab}</Styled.TabWrapper>)\n : tabs}\n </TabListPropsContext.Provider>\n </TabListTabsContext.Provider>\n </Styled.TrackScrollable>\n {!tabsAutoGroup && scrollFading ? (\n <Styled.Floats hidden={scrollThresholds.right === true || scrollThresholds.right === null} after>\n <Styled.ScrollFading after />\n </Styled.Floats>\n ) : null}\n </Styled.TabsTrack>\n {!tabsAutoGroup && scrollControls ? (\n <Styled.Control hidden={scrollThresholds.right === true || scrollThresholds.right === null}>\n {typeof scrollControlRight === 'function' ? (\n scrollControlRight(scrollControlRightProps)\n ) : (\n <IconButton {...scrollControlRightProps} />\n )}\n </Styled.Control>\n ) : null}\n {menuItems.length > 0 && (\n <Styled.Control\n ref={(node) => {\n autoGroupMode.refs.control(node)\n }}\n >\n <TabListMenuTab\n {...sizeProps}\n {...tabList}\n role='tab'\n variant={variant}\n disabled={disabled}\n palette={palette}\n menuItems={menuItems}\n activationOnFocus={activationOnFocus}\n text={menuTabText}\n control={menuTabControl}\n />\n </Styled.Control>\n )}\n </Styled.Container>\n {tabsAutoGroup ? (\n <Styled.Hidden aria-hidden>\n <Styled.TabsHidden>\n <TabListPropsContext.Provider value={hiddenTabsContextProps}>\n {tabListItems.tabs.map((tab, idx) => (\n <Styled.TabWrapper\n key={idx}\n ref={(node) => {\n autoGroupMode.refs.tabHidden(idx, node)\n }}\n >\n {cloneElement(tab, { ref: null, id: undefined, role: 'none' })}\n </Styled.TabWrapper>\n ))}\n </TabListPropsContext.Provider>\n </Styled.TabsHidden>\n </Styled.Hidden>\n ) : null}\n </Styled.List>\n {addon ? (\n <Styled.Addon\n {...layoutProps}\n layouts={LAYOUTS_ADDON}\n ref={(node) => {\n autoGroupMode.refs.addon(node)\n }}\n >\n {addon}\n </Styled.Addon>\n ) : null}\n {variant === 'underlined' && (\n <Styled.DividerPositioned {...layoutProps} layouts={LAYOUTS_DIVIDER} color={palette.dividerColor} />\n )}\n </Styled.Root>\n )\n }),\n {\n displayName: COMPONENT_NAME,\n sizes: SIZES,\n }\n ),\n {\n Tab: TabListTab,\n Panel: TabListPanel,\n }\n)\n\nexport { TabList }\n"],"names":["TabList","Object","assign","withMergedProps","forwardRef","props","forwardedRef","size","layout","gap","activationOnFocus","tabsAutoGroup","scrollControls","scrollFading","defaultActiveTab","activeTab","onActiveTabChange","variant","disabled","children","menuItems","menuItemsProp","addon","menuTabText","menuTabControl","scrollControlLeft","scrollControlRight","palette","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","layoutXXS","layoutXS","layoutS","layoutM","layoutL","layoutXL","restProps","sizeProps","useMemo","layoutProps","rootRef","useRef","tabsTrackRef","scrollControlRef","useImperativeHandle","current","tabListItems","useTabListItems","autoGroupMode","useTabListAutoGroup","enabled","tabList","tabs","useTabList","combined","scrollThresholds","setScrollThresholds","useScrollThresholds","target","scrollControlLeftProps","sizes","SIZES_SCROLL_CONTROL","icon","_jsx","ChevronLeft","tabIndex","onFocus","evt","currentTarget","blur","onClick","trackLeft","Math","round","getBoundingClientRect","left","width","tabsLeft","Array","from","querySelectorAll","map","tab","focus","padding","idx","findIndex","tabLeft","includes","scrollTo","top","behavior","scrollBy","scrollControlRightProps","ChevronRight","trackRight","right","tabsRight","reverse","tabRight","scrollWidth","controlsContextProps","tabsContextProps","role","marginRight","color","tabColor","colorHover","tabColorHover","colorActive","tabColorActive","colorDisabled","tabColorDisabled","colorActiveDisabled","tabColorActiveDisabled","backgroundColor","tabBackgroundColor","backgroundColorHover","tabBackgroundColorHover","backgroundColorActive","tabBackgroundColorActive","backgroundColorDisabled","tabBackgroundColorDisabled","backgroundColorActiveDisabled","tabBackgroundColorActiveDisabled","hiddenTabsContextProps","groups","_jsxs","Styled","layouts","LAYOUTS","ref","node","refs","root","onKeyDown","document","activeElement","HTMLElement","matches","keyboardKeys","Home","validate","key","End","ArrowRight","ArrowLeft","tabListTabs","filter","closest","length","preventDefault","navigateHorizontalList","SELECTORS_FOCUSABLE","container","hidden","IconButton","track","trackRect","tabRect","onScroll","TabListTabsContext","Provider","value","TabListPropsContext","after","control","TabListMenuTab","text","tabHidden","cloneElement","id","undefined","LAYOUTS_ADDON","LAYOUTS_DIVIDER","dividerColor","displayName","SIZES","Tab","TabListTab","Panel","TabListPanel"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var React=require('react');var Floater=require('react-floater');var nanoid=require('nanoid');var tabList=require('../../shared/context/tabList.js');var useMergedPalette=require('../../hooks/useMergedPalette.js');var useClickOutside=require('../../hooks/useClickOutside.js');var constants=require('../../shared/constants.js');var useFloaterPortal=require('../../hooks/useFloaterPortal.js');var dom=require('../../shared/utils/dom.js');var style=require('./style.js');var jsxRuntime=require('react/jsx-runtime');var TabListTab=require('../TabListTab/TabListTab.js');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var Floater__default=_interopDefault(Floater);exports.TabListMenuTab=e=>{const{role:t="tab",type:o="button",variant:a="clear",size:r="m",sizeXXS:s,sizeXS:n,sizeS:i,sizeM:l,sizeL:c,sizeXL:u,disabled:d,text:m,control:b,menuItems:y,activeTab:p,firstTab:v,activationOnFocus:f,getTabIndex:k,onActiveTabChange:T}=e;const
|
|
1
|
+
'use strict';var React=require('react');var Floater=require('react-floater');var nanoid=require('nanoid');var tabList=require('../../shared/context/tabList.js');var useMergedPalette=require('../../hooks/useMergedPalette.js');var useClickOutside=require('../../hooks/useClickOutside.js');var constants=require('../../shared/constants.js');var useFloaterPortal=require('../../hooks/useFloaterPortal.js');var dom=require('../../shared/utils/dom.js');var style=require('./style.js');var jsxRuntime=require('react/jsx-runtime');var index=require('../../icon-pack/src/icons/ChevronDown/index.js');var TabListTab=require('../TabListTab/TabListTab.js');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var Floater__default=_interopDefault(Floater);exports.TabListMenuTab=e=>{const{role:t="tab",type:o="button",variant:a="clear",size:r="m",sizeXXS:s,sizeXS:n,sizeS:i,sizeM:l,sizeL:c,sizeXL:u,disabled:d,text:m,control:b,menuItems:y,activeTab:p,firstTab:v,activationOnFocus:f,getTabIndex:k,onActiveTabChange:T}=e;const x=React.useMemo((()=>({size:r,sizeXXS:s,sizeXS:n,sizeS:i,sizeM:l,sizeL:c,sizeXL:u})),[r,s,n,i,l,c,u]);const C=useMergedPalette.useMergedPalette(e);const h=React.useRef(null);const[g,R]=React.useState(null);const j=React.useRef(null);const L=useFloaterPortal.useFloaterPortal();const[D,A]=React.useState(!1);const E=React.useMemo((()=>nanoid.nanoid()),[]);const M=React.useMemo((()=>[h,g]),[g]);const K=React.useCallback((()=>{A(!1)}),[]);const S=Boolean(y.find((e=>React.isValidElement(e)&&typeof e.props=='object'&&e.props!==null&&e.props.id===p)));const q={...x,role:t,type:o,variant:a,'aria-haspopup':'menu',id:E,'aria-selected':S,active:S,tabIndex:S||!v?0:-1,disabled:d,text:m,addonRight:e=>jsxRuntime.jsx(style.IconAnimated,{...e.iconProps,rotate:D,icon:jsxRuntime.jsx(index.ChevronDown,{}),preset:"brand"}),palette:{color:C.tabColor,colorHover:C.tabColorHover,colorActive:C.tabColorActive,colorDisabled:C.tabColorDisabled,colorActiveDisabled:C.tabColorActiveDisabled,backgroundColor:C.tabBackgroundColor,backgroundColorHover:C.tabBackgroundColorHover,backgroundColorActive:C.tabBackgroundColorActive,backgroundColorDisabled:C.tabBackgroundColorDisabled,backgroundColorActiveDisabled:C.tabBackgroundColorActiveDisabled},onClick:()=>{A((e=>!e))},onKeyDown:e=>{D&&(constants.keyboardKeys.Esc.validate(e.key)||constants.keyboardKeys.Tab.validate(e.key))?(e.preventDefault(),A(!1)):!D&&(constants.keyboardKeys.F10.validate(e.key)&&e.shiftKey||constants.keyboardKeys.ArrowDown.validate(e.key))&&(e.preventDefault(),A(!0))}};const w=React.useMemo((()=>({activationOnFocus:f,activeTab:p,onActiveTabChange:T,getTabIndex:k})),[f,p,T,k]);const z=React.useMemo((()=>({...x,disabled:d,role:'menuitem',variant:'filled'})),[x,d]);return useClickOutside.useClickOutside(M,K,{enabled:D,event:'mousedown'}),React.useEffect((()=>(j.current=setTimeout((()=>{if(!g)return;const e=Array.from(g.querySelectorAll('[role="menuitem"]')).filter((e=>e.matches(dom.SELECTORS_FOCUSABLE)));const t=e.find((e=>e.matches('[aria-selected="true"]')));t?t.focus():e[0]&&e[0].focus(),j.current=null}),100),()=>{j.current&&clearTimeout(j.current)})),[g]),L?jsxRuntime.jsx(Floater__default.default,{open:D,portalElement:L,placement:"bottom-end",offset:8,hideArrow:!0,styles:{options:{zIndex:void 0},wrapper:{cursor:d?'not-allowed':'pointer'},floater:{filter:'none',opacity:1,transitionDuration:'10ms'}},getPopper:e=>{e.state.elements.reference instanceof HTMLElement&&(h.current=e.state.elements.reference)},modifiers:{removeRoles:{name:'removeRoles',enabled:!0,phase:'beforeWrite',effect:({state:e})=>{if(e.elements.popper instanceof HTMLElement){const t=e.elements.popper.querySelector('[role="tooltip"]');t&&t.removeAttribute('role')}}},minWidth:{name:'minWidth',enabled:!0,phase:'beforeWrite',requires:['computeStyles'],fn:({state:e})=>{e.styles.popper.minWidth=`${e.rects.reference.width}px`},effect:({state:e})=>{e.elements.popper instanceof HTMLElement&&e.elements.reference instanceof HTMLElement&&(e.elements.popper.style.display='flex',e.elements.popper.style.flexDirection='column',e.elements.popper.style.alignItems='stretch',e.elements.popper.style.minWidth=`${e.elements.reference.offsetWidth}px`)}}},component:()=>jsxRuntime.jsx(style.Menu,{role:"menu","aria-labelledby":E,ref:R,palette:{backgroundColor:C.menuBackgroundColor},onClick:e=>{e.target instanceof HTMLElement&&e.target.closest('[role="menuitem"]')&&(A(!1),setTimeout((()=>{h.current?.focus()}),100))},onKeyDown:e=>{if(e.stopPropagation(),!(document.activeElement instanceof HTMLElement&&document.activeElement.matches('[role="menuitem"]')&&(constants.keyboardKeys.Esc.validate(e.key)||constants.keyboardKeys.Tab.validate(e.key)||constants.keyboardKeys.Home.validate(e.key)||constants.keyboardKeys.End.validate(e.key)||constants.keyboardKeys.ArrowDown.validate(e.key)||constants.keyboardKeys.ArrowUp.validate(e.key))))return;if(constants.keyboardKeys.Esc.validate(e.key)||constants.keyboardKeys.Tab.validate(e.key))return e.preventDefault(),A(!1),void setTimeout((()=>{h.current?.focus()}),100);const t=Array.from(e.currentTarget.querySelectorAll('[role="menuitem"]'));t.length!==0&&(constants.keyboardKeys.Home.validate(e.key)?(e.preventDefault(),t[0].focus()):constants.keyboardKeys.End.validate(e.key)?(e.preventDefault(),t[t.length-1].focus()):(constants.keyboardKeys.ArrowDown.validate(e.key)||constants.keyboardKeys.ArrowUp.validate(e.key))&&(e.preventDefault(),dom.navigateVerticalList(e.key,document.activeElement,t,dom.SELECTORS_FOCUSABLE)))},children:jsxRuntime.jsx(tabList.TabListTabsContext.Provider,{value:w,children:jsxRuntime.jsx(tabList.TabListPropsContext.Provider,{value:z,children:React.Children.map(y,(e=>jsxRuntime.jsx(style.MenuItem,{role:"none",children:e})))})})}),children:typeof b=='function'?b(q):jsxRuntime.jsx(TabListTab.TabListTab,{...q})}):null};
|
|
2
2
|
//# sourceMappingURL=TabListMenuTab.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TabListMenuTab.js","sources":["../../../../src/components/TabList/TabListMenuTab.tsx"],"sourcesContent":["import { useState, useRef, useEffect, useMemo, useCallback, Children, isValidElement } from 'react'\nimport Floater from 'react-floater'\nimport { nanoid } from 'nanoid'\nimport type { Nullable } from 'shared/types'\nimport { TabListTabsContext, TabListPropsContext } from 'shared/context/tabList'\nimport { TabListTab } from 'components/TabListTab'\nimport { useMergedPalette } from 'hooks/useMergedPalette'\nimport { useClickOutside } from 'hooks/useClickOutside'\nimport { keyboardKeys } from 'shared/constants'\nimport { useFloaterPortal } from 'hooks/useFloaterPortal'\nimport { navigateVerticalList, SELECTORS_FOCUSABLE } from 'shared/utils/dom'\nimport type { TabListTabProps } from 'components/TabListTab'\nimport * as Styled from './style'\nimport type { TabListMenuTabProps } from './types'\n\nconst TabListMenuTab = (props: TabListMenuTabProps) => {\n const {\n role = 'tab',\n type = 'button',\n variant = 'clear',\n size = 'm',\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n disabled,\n text,\n control,\n menuItems,\n activeTab,\n firstTab,\n activationOnFocus,\n getTabIndex,\n onActiveTabChange,\n } = props\n\n const sizeProps = useMemo(\n () => ({ size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL }),\n [size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL]\n )\n\n const palette = useMergedPalette(props)\n\n const controlRef = useRef<Nullable<HTMLElement>>(null)\n const [menuRef, setMenuRef] = useState<Nullable<HTMLUListElement>>(null)\n\n const timerId = useRef<Nullable<ReturnType<typeof setTimeout>>>(null)\n\n const portalElement = useFloaterPortal()\n\n const [menuOpen, setMenuOpen] = useState(false)\n\n const controlId = useMemo(() => nanoid(), [])\n\n const clickOutsideTargets = useMemo(() => [controlRef, menuRef], [menuRef])\n\n const handleCloseMenu = useCallback(() => {\n setMenuOpen(false)\n }, [])\n\n const menuHasActiveTab = Boolean(\n menuItems.find(\n (item) =>\n isValidElement(item) && typeof item.props === 'object' && item.props !== null && item.props.id === activeTab\n )\n )\n\n const controlProps: TabListTabProps = {\n ...sizeProps,\n role,\n type,\n variant,\n 'aria-haspopup': 'menu',\n id: controlId,\n 'aria-selected': menuHasActiveTab,\n active: menuHasActiveTab,\n tabIndex: menuHasActiveTab || !firstTab ? 0 : -1,\n disabled,\n text,\n // eslint-disable-next-line react/no-unstable-nested-components\n addonRight: (addonProps) => (\n <Styled.IconAnimated {...addonProps.iconProps} rotate={menuOpen} name='chevronDown' preset='brand' />\n ),\n palette: {\n color: palette.tabColor,\n colorHover: palette.tabColorHover,\n colorActive: palette.tabColorActive,\n colorDisabled: palette.tabColorDisabled,\n colorActiveDisabled: palette.tabColorActiveDisabled,\n backgroundColor: palette.tabBackgroundColor,\n backgroundColorHover: palette.tabBackgroundColorHover,\n backgroundColorActive: palette.tabBackgroundColorActive,\n backgroundColorDisabled: palette.tabBackgroundColorDisabled,\n backgroundColorActiveDisabled: palette.tabBackgroundColorActiveDisabled,\n },\n onClick: () => {\n setMenuOpen((prev) => !prev)\n },\n onKeyDown: (evt) => {\n if (menuOpen && (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key))) {\n evt.preventDefault()\n setMenuOpen(false)\n } else if (\n !menuOpen &&\n ((keyboardKeys.F10.validate(evt.key) && evt.shiftKey) || keyboardKeys.ArrowDown.validate(evt.key))\n ) {\n evt.preventDefault()\n setMenuOpen(true)\n }\n },\n }\n\n const controlsContextProps = useMemo(\n () => ({\n activationOnFocus,\n activeTab,\n onActiveTabChange,\n getTabIndex,\n }),\n [activationOnFocus, activeTab, onActiveTabChange, getTabIndex]\n )\n\n const menuItemsContextProps = useMemo(\n () => ({\n ...sizeProps,\n disabled,\n role: 'menuitem',\n variant: 'filled' as TabListTabProps['variant'],\n }),\n [sizeProps, disabled]\n )\n\n useClickOutside(clickOutsideTargets, handleCloseMenu, {\n enabled: menuOpen,\n event: 'mousedown',\n })\n\n useEffect(() => {\n timerId.current = setTimeout(() => {\n if (!menuRef) return\n\n const items = Array.from(menuRef.querySelectorAll<HTMLElement>('[role=\"menuitem\"]')).filter((item) =>\n item.matches(SELECTORS_FOCUSABLE)\n )\n\n const activeItem = items.find((item) => item.matches('[aria-selected=\"true\"]'))\n\n if (activeItem) {\n activeItem.focus()\n } else if (items[0]) {\n items[0].focus()\n }\n\n timerId.current = null\n }, 100)\n\n return () => {\n if (timerId.current) {\n clearTimeout(timerId.current)\n }\n }\n }, [menuRef])\n\n if (!portalElement) {\n return null\n }\n\n return (\n <Floater\n open={menuOpen}\n portalElement={portalElement}\n placement='bottom-end'\n offset={8}\n hideArrow\n styles={{\n options: {\n zIndex: undefined,\n },\n wrapper: {\n cursor: disabled ? 'not-allowed' : 'pointer',\n },\n floater: {\n filter: 'none',\n opacity: 1,\n transitionDuration: '10ms',\n },\n }}\n getPopper={(popper) => {\n if (popper.state.elements.reference instanceof HTMLElement) {\n controlRef.current = popper.state.elements.reference\n }\n }}\n modifiers={{\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n removeRoles: {\n name: 'removeRoles',\n enabled: true,\n phase: 'beforeWrite',\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement) {\n const floaterElement = state.elements.popper.querySelector('[role=\"tooltip\"]')\n if (floaterElement) {\n floaterElement.removeAttribute('role')\n }\n }\n },\n },\n minWidth: {\n name: 'minWidth',\n enabled: true,\n phase: 'beforeWrite',\n requires: ['computeStyles'],\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n fn: ({ state }) => {\n state.styles.popper.minWidth = `${state.rects.reference.width}px`\n },\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement && state.elements.reference instanceof HTMLElement) {\n state.elements.popper.style.display = 'flex'\n state.elements.popper.style.flexDirection = 'column'\n state.elements.popper.style.alignItems = 'stretch'\n state.elements.popper.style.minWidth = `${state.elements.reference.offsetWidth}px`\n }\n },\n },\n }}\n // eslint-disable-next-line react/no-unstable-nested-components\n component={() => (\n <Styled.Menu\n role='menu'\n aria-labelledby={controlId}\n ref={setMenuRef}\n palette={{\n backgroundColor: palette.menuBackgroundColor,\n }}\n onClick={(evt) => {\n if (evt.target instanceof HTMLElement && evt.target.closest('[role=\"menuitem\"]')) {\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n }\n }}\n onKeyDown={(evt) => {\n evt.stopPropagation()\n\n if (\n !(document.activeElement instanceof HTMLElement) ||\n !document.activeElement.matches('[role=\"menuitem\"]') ||\n (!keyboardKeys.Esc.validate(evt.key) &&\n !keyboardKeys.Tab.validate(evt.key) &&\n !keyboardKeys.Home.validate(evt.key) &&\n !keyboardKeys.End.validate(evt.key) &&\n !keyboardKeys.ArrowDown.validate(evt.key) &&\n !keyboardKeys.ArrowUp.validate(evt.key))\n ) {\n return\n }\n\n if (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key)) {\n evt.preventDefault()\n\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n\n return\n }\n\n const items = Array.from(evt.currentTarget.querySelectorAll<HTMLElement>('[role=\"menuitem\"]'))\n\n if (items.length === 0) return\n\n if (keyboardKeys.Home.validate(evt.key)) {\n evt.preventDefault()\n items[0].focus()\n } else if (keyboardKeys.End.validate(evt.key)) {\n evt.preventDefault()\n items[items.length - 1].focus()\n } else if (keyboardKeys.ArrowDown.validate(evt.key) || keyboardKeys.ArrowUp.validate(evt.key)) {\n evt.preventDefault()\n navigateVerticalList(evt.key, document.activeElement, items, SELECTORS_FOCUSABLE)\n }\n }}\n >\n <TabListTabsContext.Provider value={controlsContextProps}>\n <TabListPropsContext.Provider value={menuItemsContextProps}>\n {Children.map(menuItems, (item) => (\n <Styled.MenuItem role='none'>{item}</Styled.MenuItem>\n ))}\n </TabListPropsContext.Provider>\n </TabListTabsContext.Provider>\n </Styled.Menu>\n )}\n >\n {typeof control === 'function' ? control(controlProps) : <TabListTab {...controlProps} />}\n </Floater>\n )\n}\n\nexport { TabListMenuTab }\n"],"names":["props","role","type","variant","size","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","disabled","text","control","menuItems","activeTab","firstTab","activationOnFocus","getTabIndex","onActiveTabChange","sizeProps","useMemo","palette","useMergedPalette","controlRef","useRef","menuRef","setMenuRef","useState","timerId","portalElement","useFloaterPortal","menuOpen","setMenuOpen","controlId","nanoid","clickOutsideTargets","handleCloseMenu","useCallback","menuHasActiveTab","Boolean","find","item","isValidElement","id","controlProps","active","tabIndex","addonRight","addonProps","_jsx","jsx","Styled","iconProps","rotate","name","preset","color","tabColor","colorHover","tabColorHover","colorActive","tabColorActive","colorDisabled","tabColorDisabled","colorActiveDisabled","tabColorActiveDisabled","backgroundColor","tabBackgroundColor","backgroundColorHover","tabBackgroundColorHover","backgroundColorActive","tabBackgroundColorActive","backgroundColorDisabled","tabBackgroundColorDisabled","backgroundColorActiveDisabled","tabBackgroundColorActiveDisabled","onClick","prev","onKeyDown","evt","keyboardKeys","Esc","validate","key","Tab","preventDefault","F10","shiftKey","ArrowDown","controlsContextProps","menuItemsContextProps","useClickOutside","enabled","event","useEffect","current","setTimeout","items","Array","from","querySelectorAll","filter","matches","SELECTORS_FOCUSABLE","activeItem","focus","clearTimeout","Floater","open","placement","offset","hideArrow","styles","options","zIndex","undefined","wrapper","cursor","floater","opacity","transitionDuration","getPopper","popper","state","elements","reference","HTMLElement","modifiers","removeRoles","phase","effect","floaterElement","querySelector","removeAttribute","minWidth","requires","fn","rects","width","style","display","flexDirection","alignItems","offsetWidth","component","ref","menuBackgroundColor","target","closest","stopPropagation","document","activeElement","Home","End","ArrowUp","currentTarget","length","navigateVerticalList","children","TabListTabsContext","Provider","value","TabListPropsContext","Children","map","TabListTab"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"TabListMenuTab.js","sources":["../../../../src/components/TabList/TabListMenuTab.tsx"],"sourcesContent":["import { useState, useRef, useEffect, useMemo, useCallback, Children, isValidElement } from 'react'\nimport Floater from 'react-floater'\nimport { nanoid } from 'nanoid'\nimport { ChevronDown } from '@foxford/icon-pack'\nimport type { Nullable } from 'shared/types'\nimport { TabListTabsContext, TabListPropsContext } from 'shared/context/tabList'\nimport { TabListTab } from 'components/TabListTab'\nimport { useMergedPalette } from 'hooks/useMergedPalette'\nimport { useClickOutside } from 'hooks/useClickOutside'\nimport { keyboardKeys } from 'shared/constants'\nimport { useFloaterPortal } from 'hooks/useFloaterPortal'\nimport { navigateVerticalList, SELECTORS_FOCUSABLE } from 'shared/utils/dom'\nimport type { TabListTabProps } from 'components/TabListTab'\nimport * as Styled from './style'\nimport type { TabListMenuTabProps } from './types'\n\nconst TabListMenuTab = (props: TabListMenuTabProps) => {\n const {\n role = 'tab',\n type = 'button',\n variant = 'clear',\n size = 'm',\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n disabled,\n text,\n control,\n menuItems,\n activeTab,\n firstTab,\n activationOnFocus,\n getTabIndex,\n onActiveTabChange,\n } = props\n\n const sizeProps = useMemo(\n () => ({ size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL }),\n [size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL]\n )\n\n const palette = useMergedPalette(props)\n\n const controlRef = useRef<Nullable<HTMLElement>>(null)\n const [menuRef, setMenuRef] = useState<Nullable<HTMLUListElement>>(null)\n\n const timerId = useRef<Nullable<ReturnType<typeof setTimeout>>>(null)\n\n const portalElement = useFloaterPortal()\n\n const [menuOpen, setMenuOpen] = useState(false)\n\n const controlId = useMemo(() => nanoid(), [])\n\n const clickOutsideTargets = useMemo(() => [controlRef, menuRef], [menuRef])\n\n const handleCloseMenu = useCallback(() => {\n setMenuOpen(false)\n }, [])\n\n const menuHasActiveTab = Boolean(\n menuItems.find(\n (item) =>\n isValidElement(item) && typeof item.props === 'object' && item.props !== null && item.props.id === activeTab\n )\n )\n\n const controlProps: TabListTabProps = {\n ...sizeProps,\n role,\n type,\n variant,\n 'aria-haspopup': 'menu',\n id: controlId,\n 'aria-selected': menuHasActiveTab,\n active: menuHasActiveTab,\n tabIndex: menuHasActiveTab || !firstTab ? 0 : -1,\n disabled,\n text,\n // eslint-disable-next-line react/no-unstable-nested-components\n addonRight: (addonProps) => (\n <Styled.IconAnimated {...addonProps.iconProps} rotate={menuOpen} icon={<ChevronDown />} preset='brand' />\n ),\n palette: {\n color: palette.tabColor,\n colorHover: palette.tabColorHover,\n colorActive: palette.tabColorActive,\n colorDisabled: palette.tabColorDisabled,\n colorActiveDisabled: palette.tabColorActiveDisabled,\n backgroundColor: palette.tabBackgroundColor,\n backgroundColorHover: palette.tabBackgroundColorHover,\n backgroundColorActive: palette.tabBackgroundColorActive,\n backgroundColorDisabled: palette.tabBackgroundColorDisabled,\n backgroundColorActiveDisabled: palette.tabBackgroundColorActiveDisabled,\n },\n onClick: () => {\n setMenuOpen((prev) => !prev)\n },\n onKeyDown: (evt) => {\n if (menuOpen && (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key))) {\n evt.preventDefault()\n setMenuOpen(false)\n } else if (\n !menuOpen &&\n ((keyboardKeys.F10.validate(evt.key) && evt.shiftKey) || keyboardKeys.ArrowDown.validate(evt.key))\n ) {\n evt.preventDefault()\n setMenuOpen(true)\n }\n },\n }\n\n const controlsContextProps = useMemo(\n () => ({\n activationOnFocus,\n activeTab,\n onActiveTabChange,\n getTabIndex,\n }),\n [activationOnFocus, activeTab, onActiveTabChange, getTabIndex]\n )\n\n const menuItemsContextProps = useMemo(\n () => ({\n ...sizeProps,\n disabled,\n role: 'menuitem',\n variant: 'filled' as TabListTabProps['variant'],\n }),\n [sizeProps, disabled]\n )\n\n useClickOutside(clickOutsideTargets, handleCloseMenu, {\n enabled: menuOpen,\n event: 'mousedown',\n })\n\n useEffect(() => {\n timerId.current = setTimeout(() => {\n if (!menuRef) return\n\n const items = Array.from(menuRef.querySelectorAll<HTMLElement>('[role=\"menuitem\"]')).filter((item) =>\n item.matches(SELECTORS_FOCUSABLE)\n )\n\n const activeItem = items.find((item) => item.matches('[aria-selected=\"true\"]'))\n\n if (activeItem) {\n activeItem.focus()\n } else if (items[0]) {\n items[0].focus()\n }\n\n timerId.current = null\n }, 100)\n\n return () => {\n if (timerId.current) {\n clearTimeout(timerId.current)\n }\n }\n }, [menuRef])\n\n if (!portalElement) {\n return null\n }\n\n return (\n <Floater\n open={menuOpen}\n portalElement={portalElement}\n placement='bottom-end'\n offset={8}\n hideArrow\n styles={{\n options: {\n zIndex: undefined,\n },\n wrapper: {\n cursor: disabled ? 'not-allowed' : 'pointer',\n },\n floater: {\n filter: 'none',\n opacity: 1,\n transitionDuration: '10ms',\n },\n }}\n getPopper={(popper) => {\n if (popper.state.elements.reference instanceof HTMLElement) {\n controlRef.current = popper.state.elements.reference\n }\n }}\n modifiers={{\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n removeRoles: {\n name: 'removeRoles',\n enabled: true,\n phase: 'beforeWrite',\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement) {\n const floaterElement = state.elements.popper.querySelector('[role=\"tooltip\"]')\n if (floaterElement) {\n floaterElement.removeAttribute('role')\n }\n }\n },\n },\n minWidth: {\n name: 'minWidth',\n enabled: true,\n phase: 'beforeWrite',\n requires: ['computeStyles'],\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n fn: ({ state }) => {\n state.styles.popper.minWidth = `${state.rects.reference.width}px`\n },\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement && state.elements.reference instanceof HTMLElement) {\n state.elements.popper.style.display = 'flex'\n state.elements.popper.style.flexDirection = 'column'\n state.elements.popper.style.alignItems = 'stretch'\n state.elements.popper.style.minWidth = `${state.elements.reference.offsetWidth}px`\n }\n },\n },\n }}\n // eslint-disable-next-line react/no-unstable-nested-components\n component={() => (\n <Styled.Menu\n role='menu'\n aria-labelledby={controlId}\n ref={setMenuRef}\n palette={{\n backgroundColor: palette.menuBackgroundColor,\n }}\n onClick={(evt) => {\n if (evt.target instanceof HTMLElement && evt.target.closest('[role=\"menuitem\"]')) {\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n }\n }}\n onKeyDown={(evt) => {\n evt.stopPropagation()\n\n if (\n !(document.activeElement instanceof HTMLElement) ||\n !document.activeElement.matches('[role=\"menuitem\"]') ||\n (!keyboardKeys.Esc.validate(evt.key) &&\n !keyboardKeys.Tab.validate(evt.key) &&\n !keyboardKeys.Home.validate(evt.key) &&\n !keyboardKeys.End.validate(evt.key) &&\n !keyboardKeys.ArrowDown.validate(evt.key) &&\n !keyboardKeys.ArrowUp.validate(evt.key))\n ) {\n return\n }\n\n if (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key)) {\n evt.preventDefault()\n\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n\n return\n }\n\n const items = Array.from(evt.currentTarget.querySelectorAll<HTMLElement>('[role=\"menuitem\"]'))\n\n if (items.length === 0) return\n\n if (keyboardKeys.Home.validate(evt.key)) {\n evt.preventDefault()\n items[0].focus()\n } else if (keyboardKeys.End.validate(evt.key)) {\n evt.preventDefault()\n items[items.length - 1].focus()\n } else if (keyboardKeys.ArrowDown.validate(evt.key) || keyboardKeys.ArrowUp.validate(evt.key)) {\n evt.preventDefault()\n navigateVerticalList(evt.key, document.activeElement, items, SELECTORS_FOCUSABLE)\n }\n }}\n >\n <TabListTabsContext.Provider value={controlsContextProps}>\n <TabListPropsContext.Provider value={menuItemsContextProps}>\n {Children.map(menuItems, (item) => (\n <Styled.MenuItem role='none'>{item}</Styled.MenuItem>\n ))}\n </TabListPropsContext.Provider>\n </TabListTabsContext.Provider>\n </Styled.Menu>\n )}\n >\n {typeof control === 'function' ? control(controlProps) : <TabListTab {...controlProps} />}\n </Floater>\n )\n}\n\nexport { TabListMenuTab }\n"],"names":["props","role","type","variant","size","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","disabled","text","control","menuItems","activeTab","firstTab","activationOnFocus","getTabIndex","onActiveTabChange","sizeProps","useMemo","palette","useMergedPalette","controlRef","useRef","menuRef","setMenuRef","useState","timerId","portalElement","useFloaterPortal","menuOpen","setMenuOpen","controlId","nanoid","clickOutsideTargets","handleCloseMenu","useCallback","menuHasActiveTab","Boolean","find","item","isValidElement","id","controlProps","active","tabIndex","addonRight","addonProps","_jsx","jsx","Styled","iconProps","rotate","icon","ChevronDown","preset","color","tabColor","colorHover","tabColorHover","colorActive","tabColorActive","colorDisabled","tabColorDisabled","colorActiveDisabled","tabColorActiveDisabled","backgroundColor","tabBackgroundColor","backgroundColorHover","tabBackgroundColorHover","backgroundColorActive","tabBackgroundColorActive","backgroundColorDisabled","tabBackgroundColorDisabled","backgroundColorActiveDisabled","tabBackgroundColorActiveDisabled","onClick","prev","onKeyDown","evt","keyboardKeys","Esc","validate","key","Tab","preventDefault","F10","shiftKey","ArrowDown","controlsContextProps","menuItemsContextProps","useClickOutside","enabled","event","useEffect","current","setTimeout","items","Array","from","querySelectorAll","filter","matches","SELECTORS_FOCUSABLE","activeItem","focus","clearTimeout","Floater","open","placement","offset","hideArrow","styles","options","zIndex","undefined","wrapper","cursor","floater","opacity","transitionDuration","getPopper","popper","state","elements","reference","HTMLElement","modifiers","removeRoles","name","phase","effect","floaterElement","querySelector","removeAttribute","minWidth","requires","fn","rects","width","style","display","flexDirection","alignItems","offsetWidth","component","ref","menuBackgroundColor","target","closest","stopPropagation","document","activeElement","Home","End","ArrowUp","currentTarget","length","navigateVerticalList","children","TabListTabsContext","Provider","value","TabListPropsContext","Children","map","TabListTab"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{useMemo,useRef,useState,useCallback,isValidElement,useEffect,Children}from'react';import Floater from'react-floater';import{nanoid}from'nanoid';import{TabListTabsContext,TabListPropsContext}from'../../shared/context/tabList.mjs';import{useMergedPalette}from'../../hooks/useMergedPalette.mjs';import{useClickOutside}from'../../hooks/useClickOutside.mjs';import{keyboardKeys}from'../../shared/constants.mjs';import{useFloaterPortal}from'../../hooks/useFloaterPortal.mjs';import{SELECTORS_FOCUSABLE,navigateVerticalList}from'../../shared/utils/dom.mjs';import{IconAnimated,Menu,MenuItem}from'./style.mjs';import{jsx}from'react/jsx-runtime';import{TabListTab}from'../TabListTab/TabListTab.mjs';const TabListMenuTab=e=>{const{role:t="tab",type:o="button",variant:r="clear",size:a="m",sizeXXS:
|
|
1
|
+
import{useMemo,useRef,useState,useCallback,isValidElement,useEffect,Children}from'react';import Floater from'react-floater';import{nanoid}from'nanoid';import{TabListTabsContext,TabListPropsContext}from'../../shared/context/tabList.mjs';import{useMergedPalette}from'../../hooks/useMergedPalette.mjs';import{useClickOutside}from'../../hooks/useClickOutside.mjs';import{keyboardKeys}from'../../shared/constants.mjs';import{useFloaterPortal}from'../../hooks/useFloaterPortal.mjs';import{SELECTORS_FOCUSABLE,navigateVerticalList}from'../../shared/utils/dom.mjs';import{IconAnimated,Menu,MenuItem}from'./style.mjs';import{jsx}from'react/jsx-runtime';import{ChevronDown}from'../../icon-pack/src/icons/ChevronDown/index.mjs';import{TabListTab}from'../TabListTab/TabListTab.mjs';const TabListMenuTab=e=>{const{role:t="tab",type:o="button",variant:r="clear",size:a="m",sizeXXS:n,sizeXS:s,sizeS:i,sizeM:l,sizeL:c,sizeXL:d,disabled:m,text:u,control:b,menuItems:p,activeTab:f,firstTab:y,activationOnFocus:v,getTabIndex:k,onActiveTabChange:T}=e;const C=useMemo((()=>({size:a,sizeXXS:n,sizeXS:s,sizeS:i,sizeM:l,sizeL:c,sizeXL:d})),[a,n,s,i,l,c,d]);const h=useMergedPalette(e);const g=useRef(null);const[L,E]=useState(null);const x=useRef(null);const A=useFloaterPortal();const[D,M]=useState(!1);const S=useMemo((()=>nanoid()),[]);const j=useMemo((()=>[g,L]),[L]);const K=useCallback((()=>{M(!1)}),[]);const w=Boolean(p.find((e=>isValidElement(e)&&typeof e.props=='object'&&e.props!==null&&e.props.id===f)));const z={...C,role:t,type:o,variant:r,'aria-haspopup':'menu',id:S,'aria-selected':w,active:w,tabIndex:w||!y?0:-1,disabled:m,text:u,addonRight:e=>jsx(IconAnimated,{...e.iconProps,rotate:D,icon:jsx(ChevronDown,{}),preset:"brand"}),palette:{color:h.tabColor,colorHover:h.tabColorHover,colorActive:h.tabColorActive,colorDisabled:h.tabColorDisabled,colorActiveDisabled:h.tabColorActiveDisabled,backgroundColor:h.tabBackgroundColor,backgroundColorHover:h.tabBackgroundColorHover,backgroundColorActive:h.tabBackgroundColorActive,backgroundColorDisabled:h.tabBackgroundColorDisabled,backgroundColorActiveDisabled:h.tabBackgroundColorActiveDisabled},onClick:()=>{M((e=>!e))},onKeyDown:e=>{D&&(keyboardKeys.Esc.validate(e.key)||keyboardKeys.Tab.validate(e.key))?(e.preventDefault(),M(!1)):!D&&(keyboardKeys.F10.validate(e.key)&&e.shiftKey||keyboardKeys.ArrowDown.validate(e.key))&&(e.preventDefault(),M(!0))}};const P=useMemo((()=>({activationOnFocus:v,activeTab:f,onActiveTabChange:T,getTabIndex:k})),[v,f,T,k]);const H=useMemo((()=>({...C,disabled:m,role:'menuitem',variant:'filled'})),[C,m]);return useClickOutside(j,K,{enabled:D,event:'mousedown'}),useEffect((()=>(x.current=setTimeout((()=>{if(!L)return;const e=Array.from(L.querySelectorAll('[role="menuitem"]')).filter((e=>e.matches(SELECTORS_FOCUSABLE)));const t=e.find((e=>e.matches('[aria-selected="true"]')));t?t.focus():e[0]&&e[0].focus(),x.current=null}),100),()=>{x.current&&clearTimeout(x.current)})),[L]),A?jsx(Floater,{open:D,portalElement:A,placement:"bottom-end",offset:8,hideArrow:!0,styles:{options:{zIndex:void 0},wrapper:{cursor:m?'not-allowed':'pointer'},floater:{filter:'none',opacity:1,transitionDuration:'10ms'}},getPopper:e=>{e.state.elements.reference instanceof HTMLElement&&(g.current=e.state.elements.reference)},modifiers:{removeRoles:{name:'removeRoles',enabled:!0,phase:'beforeWrite',effect:({state:e})=>{if(e.elements.popper instanceof HTMLElement){const t=e.elements.popper.querySelector('[role="tooltip"]');t&&t.removeAttribute('role')}}},minWidth:{name:'minWidth',enabled:!0,phase:'beforeWrite',requires:['computeStyles'],fn:({state:e})=>{e.styles.popper.minWidth=`${e.rects.reference.width}px`},effect:({state:e})=>{e.elements.popper instanceof HTMLElement&&e.elements.reference instanceof HTMLElement&&(e.elements.popper.style.display='flex',e.elements.popper.style.flexDirection='column',e.elements.popper.style.alignItems='stretch',e.elements.popper.style.minWidth=`${e.elements.reference.offsetWidth}px`)}}},component:()=>jsx(Menu,{role:"menu","aria-labelledby":S,ref:E,palette:{backgroundColor:h.menuBackgroundColor},onClick:e=>{e.target instanceof HTMLElement&&e.target.closest('[role="menuitem"]')&&(M(!1),setTimeout((()=>{g.current?.focus()}),100))},onKeyDown:e=>{if(e.stopPropagation(),!(document.activeElement instanceof HTMLElement&&document.activeElement.matches('[role="menuitem"]')&&(keyboardKeys.Esc.validate(e.key)||keyboardKeys.Tab.validate(e.key)||keyboardKeys.Home.validate(e.key)||keyboardKeys.End.validate(e.key)||keyboardKeys.ArrowDown.validate(e.key)||keyboardKeys.ArrowUp.validate(e.key))))return;if(keyboardKeys.Esc.validate(e.key)||keyboardKeys.Tab.validate(e.key))return e.preventDefault(),M(!1),void setTimeout((()=>{g.current?.focus()}),100);const t=Array.from(e.currentTarget.querySelectorAll('[role="menuitem"]'));t.length!==0&&(keyboardKeys.Home.validate(e.key)?(e.preventDefault(),t[0].focus()):keyboardKeys.End.validate(e.key)?(e.preventDefault(),t[t.length-1].focus()):(keyboardKeys.ArrowDown.validate(e.key)||keyboardKeys.ArrowUp.validate(e.key))&&(e.preventDefault(),navigateVerticalList(e.key,document.activeElement,t,SELECTORS_FOCUSABLE)))},children:jsx(TabListTabsContext.Provider,{value:P,children:jsx(TabListPropsContext.Provider,{value:H,children:Children.map(p,(e=>jsx(MenuItem,{role:"none",children:e})))})})}),children:typeof b=='function'?b(z):jsx(TabListTab,{...z})}):null};export{TabListMenuTab};
|
|
2
2
|
//# sourceMappingURL=TabListMenuTab.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TabListMenuTab.mjs","sources":["../../../../src/components/TabList/TabListMenuTab.tsx"],"sourcesContent":["import { useState, useRef, useEffect, useMemo, useCallback, Children, isValidElement } from 'react'\nimport Floater from 'react-floater'\nimport { nanoid } from 'nanoid'\nimport type { Nullable } from 'shared/types'\nimport { TabListTabsContext, TabListPropsContext } from 'shared/context/tabList'\nimport { TabListTab } from 'components/TabListTab'\nimport { useMergedPalette } from 'hooks/useMergedPalette'\nimport { useClickOutside } from 'hooks/useClickOutside'\nimport { keyboardKeys } from 'shared/constants'\nimport { useFloaterPortal } from 'hooks/useFloaterPortal'\nimport { navigateVerticalList, SELECTORS_FOCUSABLE } from 'shared/utils/dom'\nimport type { TabListTabProps } from 'components/TabListTab'\nimport * as Styled from './style'\nimport type { TabListMenuTabProps } from './types'\n\nconst TabListMenuTab = (props: TabListMenuTabProps) => {\n const {\n role = 'tab',\n type = 'button',\n variant = 'clear',\n size = 'm',\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n disabled,\n text,\n control,\n menuItems,\n activeTab,\n firstTab,\n activationOnFocus,\n getTabIndex,\n onActiveTabChange,\n } = props\n\n const sizeProps = useMemo(\n () => ({ size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL }),\n [size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL]\n )\n\n const palette = useMergedPalette(props)\n\n const controlRef = useRef<Nullable<HTMLElement>>(null)\n const [menuRef, setMenuRef] = useState<Nullable<HTMLUListElement>>(null)\n\n const timerId = useRef<Nullable<ReturnType<typeof setTimeout>>>(null)\n\n const portalElement = useFloaterPortal()\n\n const [menuOpen, setMenuOpen] = useState(false)\n\n const controlId = useMemo(() => nanoid(), [])\n\n const clickOutsideTargets = useMemo(() => [controlRef, menuRef], [menuRef])\n\n const handleCloseMenu = useCallback(() => {\n setMenuOpen(false)\n }, [])\n\n const menuHasActiveTab = Boolean(\n menuItems.find(\n (item) =>\n isValidElement(item) && typeof item.props === 'object' && item.props !== null && item.props.id === activeTab\n )\n )\n\n const controlProps: TabListTabProps = {\n ...sizeProps,\n role,\n type,\n variant,\n 'aria-haspopup': 'menu',\n id: controlId,\n 'aria-selected': menuHasActiveTab,\n active: menuHasActiveTab,\n tabIndex: menuHasActiveTab || !firstTab ? 0 : -1,\n disabled,\n text,\n // eslint-disable-next-line react/no-unstable-nested-components\n addonRight: (addonProps) => (\n <Styled.IconAnimated {...addonProps.iconProps} rotate={menuOpen} name='chevronDown' preset='brand' />\n ),\n palette: {\n color: palette.tabColor,\n colorHover: palette.tabColorHover,\n colorActive: palette.tabColorActive,\n colorDisabled: palette.tabColorDisabled,\n colorActiveDisabled: palette.tabColorActiveDisabled,\n backgroundColor: palette.tabBackgroundColor,\n backgroundColorHover: palette.tabBackgroundColorHover,\n backgroundColorActive: palette.tabBackgroundColorActive,\n backgroundColorDisabled: palette.tabBackgroundColorDisabled,\n backgroundColorActiveDisabled: palette.tabBackgroundColorActiveDisabled,\n },\n onClick: () => {\n setMenuOpen((prev) => !prev)\n },\n onKeyDown: (evt) => {\n if (menuOpen && (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key))) {\n evt.preventDefault()\n setMenuOpen(false)\n } else if (\n !menuOpen &&\n ((keyboardKeys.F10.validate(evt.key) && evt.shiftKey) || keyboardKeys.ArrowDown.validate(evt.key))\n ) {\n evt.preventDefault()\n setMenuOpen(true)\n }\n },\n }\n\n const controlsContextProps = useMemo(\n () => ({\n activationOnFocus,\n activeTab,\n onActiveTabChange,\n getTabIndex,\n }),\n [activationOnFocus, activeTab, onActiveTabChange, getTabIndex]\n )\n\n const menuItemsContextProps = useMemo(\n () => ({\n ...sizeProps,\n disabled,\n role: 'menuitem',\n variant: 'filled' as TabListTabProps['variant'],\n }),\n [sizeProps, disabled]\n )\n\n useClickOutside(clickOutsideTargets, handleCloseMenu, {\n enabled: menuOpen,\n event: 'mousedown',\n })\n\n useEffect(() => {\n timerId.current = setTimeout(() => {\n if (!menuRef) return\n\n const items = Array.from(menuRef.querySelectorAll<HTMLElement>('[role=\"menuitem\"]')).filter((item) =>\n item.matches(SELECTORS_FOCUSABLE)\n )\n\n const activeItem = items.find((item) => item.matches('[aria-selected=\"true\"]'))\n\n if (activeItem) {\n activeItem.focus()\n } else if (items[0]) {\n items[0].focus()\n }\n\n timerId.current = null\n }, 100)\n\n return () => {\n if (timerId.current) {\n clearTimeout(timerId.current)\n }\n }\n }, [menuRef])\n\n if (!portalElement) {\n return null\n }\n\n return (\n <Floater\n open={menuOpen}\n portalElement={portalElement}\n placement='bottom-end'\n offset={8}\n hideArrow\n styles={{\n options: {\n zIndex: undefined,\n },\n wrapper: {\n cursor: disabled ? 'not-allowed' : 'pointer',\n },\n floater: {\n filter: 'none',\n opacity: 1,\n transitionDuration: '10ms',\n },\n }}\n getPopper={(popper) => {\n if (popper.state.elements.reference instanceof HTMLElement) {\n controlRef.current = popper.state.elements.reference\n }\n }}\n modifiers={{\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n removeRoles: {\n name: 'removeRoles',\n enabled: true,\n phase: 'beforeWrite',\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement) {\n const floaterElement = state.elements.popper.querySelector('[role=\"tooltip\"]')\n if (floaterElement) {\n floaterElement.removeAttribute('role')\n }\n }\n },\n },\n minWidth: {\n name: 'minWidth',\n enabled: true,\n phase: 'beforeWrite',\n requires: ['computeStyles'],\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n fn: ({ state }) => {\n state.styles.popper.minWidth = `${state.rects.reference.width}px`\n },\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement && state.elements.reference instanceof HTMLElement) {\n state.elements.popper.style.display = 'flex'\n state.elements.popper.style.flexDirection = 'column'\n state.elements.popper.style.alignItems = 'stretch'\n state.elements.popper.style.minWidth = `${state.elements.reference.offsetWidth}px`\n }\n },\n },\n }}\n // eslint-disable-next-line react/no-unstable-nested-components\n component={() => (\n <Styled.Menu\n role='menu'\n aria-labelledby={controlId}\n ref={setMenuRef}\n palette={{\n backgroundColor: palette.menuBackgroundColor,\n }}\n onClick={(evt) => {\n if (evt.target instanceof HTMLElement && evt.target.closest('[role=\"menuitem\"]')) {\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n }\n }}\n onKeyDown={(evt) => {\n evt.stopPropagation()\n\n if (\n !(document.activeElement instanceof HTMLElement) ||\n !document.activeElement.matches('[role=\"menuitem\"]') ||\n (!keyboardKeys.Esc.validate(evt.key) &&\n !keyboardKeys.Tab.validate(evt.key) &&\n !keyboardKeys.Home.validate(evt.key) &&\n !keyboardKeys.End.validate(evt.key) &&\n !keyboardKeys.ArrowDown.validate(evt.key) &&\n !keyboardKeys.ArrowUp.validate(evt.key))\n ) {\n return\n }\n\n if (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key)) {\n evt.preventDefault()\n\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n\n return\n }\n\n const items = Array.from(evt.currentTarget.querySelectorAll<HTMLElement>('[role=\"menuitem\"]'))\n\n if (items.length === 0) return\n\n if (keyboardKeys.Home.validate(evt.key)) {\n evt.preventDefault()\n items[0].focus()\n } else if (keyboardKeys.End.validate(evt.key)) {\n evt.preventDefault()\n items[items.length - 1].focus()\n } else if (keyboardKeys.ArrowDown.validate(evt.key) || keyboardKeys.ArrowUp.validate(evt.key)) {\n evt.preventDefault()\n navigateVerticalList(evt.key, document.activeElement, items, SELECTORS_FOCUSABLE)\n }\n }}\n >\n <TabListTabsContext.Provider value={controlsContextProps}>\n <TabListPropsContext.Provider value={menuItemsContextProps}>\n {Children.map(menuItems, (item) => (\n <Styled.MenuItem role='none'>{item}</Styled.MenuItem>\n ))}\n </TabListPropsContext.Provider>\n </TabListTabsContext.Provider>\n </Styled.Menu>\n )}\n >\n {typeof control === 'function' ? control(controlProps) : <TabListTab {...controlProps} />}\n </Floater>\n )\n}\n\nexport { TabListMenuTab }\n"],"names":["TabListMenuTab","props","role","type","variant","size","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","disabled","text","control","menuItems","activeTab","firstTab","activationOnFocus","getTabIndex","onActiveTabChange","sizeProps","useMemo","palette","useMergedPalette","controlRef","useRef","menuRef","setMenuRef","useState","timerId","portalElement","useFloaterPortal","menuOpen","setMenuOpen","controlId","nanoid","clickOutsideTargets","handleCloseMenu","useCallback","menuHasActiveTab","Boolean","find","item","isValidElement","id","controlProps","active","tabIndex","addonRight","addonProps","_jsx","Styled","iconProps","rotate","name","preset","color","tabColor","colorHover","tabColorHover","colorActive","tabColorActive","colorDisabled","tabColorDisabled","colorActiveDisabled","tabColorActiveDisabled","backgroundColor","tabBackgroundColor","backgroundColorHover","tabBackgroundColorHover","backgroundColorActive","tabBackgroundColorActive","backgroundColorDisabled","tabBackgroundColorDisabled","backgroundColorActiveDisabled","tabBackgroundColorActiveDisabled","onClick","prev","onKeyDown","evt","keyboardKeys","Esc","validate","key","Tab","preventDefault","F10","shiftKey","ArrowDown","controlsContextProps","menuItemsContextProps","useClickOutside","enabled","event","useEffect","current","setTimeout","items","Array","from","querySelectorAll","filter","matches","SELECTORS_FOCUSABLE","activeItem","focus","clearTimeout","Floater","open","placement","offset","hideArrow","styles","options","zIndex","undefined","wrapper","cursor","floater","opacity","transitionDuration","getPopper","popper","state","elements","reference","HTMLElement","modifiers","removeRoles","phase","effect","floaterElement","querySelector","removeAttribute","minWidth","requires","fn","rects","width","style","display","flexDirection","alignItems","offsetWidth","component","ref","menuBackgroundColor","target","closest","stopPropagation","document","activeElement","Home","End","ArrowUp","currentTarget","length","navigateVerticalList","children","TabListTabsContext","Provider","value","TabListPropsContext","Children","map","TabListTab"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"TabListMenuTab.mjs","sources":["../../../../src/components/TabList/TabListMenuTab.tsx"],"sourcesContent":["import { useState, useRef, useEffect, useMemo, useCallback, Children, isValidElement } from 'react'\nimport Floater from 'react-floater'\nimport { nanoid } from 'nanoid'\nimport { ChevronDown } from '@foxford/icon-pack'\nimport type { Nullable } from 'shared/types'\nimport { TabListTabsContext, TabListPropsContext } from 'shared/context/tabList'\nimport { TabListTab } from 'components/TabListTab'\nimport { useMergedPalette } from 'hooks/useMergedPalette'\nimport { useClickOutside } from 'hooks/useClickOutside'\nimport { keyboardKeys } from 'shared/constants'\nimport { useFloaterPortal } from 'hooks/useFloaterPortal'\nimport { navigateVerticalList, SELECTORS_FOCUSABLE } from 'shared/utils/dom'\nimport type { TabListTabProps } from 'components/TabListTab'\nimport * as Styled from './style'\nimport type { TabListMenuTabProps } from './types'\n\nconst TabListMenuTab = (props: TabListMenuTabProps) => {\n const {\n role = 'tab',\n type = 'button',\n variant = 'clear',\n size = 'm',\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n disabled,\n text,\n control,\n menuItems,\n activeTab,\n firstTab,\n activationOnFocus,\n getTabIndex,\n onActiveTabChange,\n } = props\n\n const sizeProps = useMemo(\n () => ({ size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL }),\n [size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL]\n )\n\n const palette = useMergedPalette(props)\n\n const controlRef = useRef<Nullable<HTMLElement>>(null)\n const [menuRef, setMenuRef] = useState<Nullable<HTMLUListElement>>(null)\n\n const timerId = useRef<Nullable<ReturnType<typeof setTimeout>>>(null)\n\n const portalElement = useFloaterPortal()\n\n const [menuOpen, setMenuOpen] = useState(false)\n\n const controlId = useMemo(() => nanoid(), [])\n\n const clickOutsideTargets = useMemo(() => [controlRef, menuRef], [menuRef])\n\n const handleCloseMenu = useCallback(() => {\n setMenuOpen(false)\n }, [])\n\n const menuHasActiveTab = Boolean(\n menuItems.find(\n (item) =>\n isValidElement(item) && typeof item.props === 'object' && item.props !== null && item.props.id === activeTab\n )\n )\n\n const controlProps: TabListTabProps = {\n ...sizeProps,\n role,\n type,\n variant,\n 'aria-haspopup': 'menu',\n id: controlId,\n 'aria-selected': menuHasActiveTab,\n active: menuHasActiveTab,\n tabIndex: menuHasActiveTab || !firstTab ? 0 : -1,\n disabled,\n text,\n // eslint-disable-next-line react/no-unstable-nested-components\n addonRight: (addonProps) => (\n <Styled.IconAnimated {...addonProps.iconProps} rotate={menuOpen} icon={<ChevronDown />} preset='brand' />\n ),\n palette: {\n color: palette.tabColor,\n colorHover: palette.tabColorHover,\n colorActive: palette.tabColorActive,\n colorDisabled: palette.tabColorDisabled,\n colorActiveDisabled: palette.tabColorActiveDisabled,\n backgroundColor: palette.tabBackgroundColor,\n backgroundColorHover: palette.tabBackgroundColorHover,\n backgroundColorActive: palette.tabBackgroundColorActive,\n backgroundColorDisabled: palette.tabBackgroundColorDisabled,\n backgroundColorActiveDisabled: palette.tabBackgroundColorActiveDisabled,\n },\n onClick: () => {\n setMenuOpen((prev) => !prev)\n },\n onKeyDown: (evt) => {\n if (menuOpen && (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key))) {\n evt.preventDefault()\n setMenuOpen(false)\n } else if (\n !menuOpen &&\n ((keyboardKeys.F10.validate(evt.key) && evt.shiftKey) || keyboardKeys.ArrowDown.validate(evt.key))\n ) {\n evt.preventDefault()\n setMenuOpen(true)\n }\n },\n }\n\n const controlsContextProps = useMemo(\n () => ({\n activationOnFocus,\n activeTab,\n onActiveTabChange,\n getTabIndex,\n }),\n [activationOnFocus, activeTab, onActiveTabChange, getTabIndex]\n )\n\n const menuItemsContextProps = useMemo(\n () => ({\n ...sizeProps,\n disabled,\n role: 'menuitem',\n variant: 'filled' as TabListTabProps['variant'],\n }),\n [sizeProps, disabled]\n )\n\n useClickOutside(clickOutsideTargets, handleCloseMenu, {\n enabled: menuOpen,\n event: 'mousedown',\n })\n\n useEffect(() => {\n timerId.current = setTimeout(() => {\n if (!menuRef) return\n\n const items = Array.from(menuRef.querySelectorAll<HTMLElement>('[role=\"menuitem\"]')).filter((item) =>\n item.matches(SELECTORS_FOCUSABLE)\n )\n\n const activeItem = items.find((item) => item.matches('[aria-selected=\"true\"]'))\n\n if (activeItem) {\n activeItem.focus()\n } else if (items[0]) {\n items[0].focus()\n }\n\n timerId.current = null\n }, 100)\n\n return () => {\n if (timerId.current) {\n clearTimeout(timerId.current)\n }\n }\n }, [menuRef])\n\n if (!portalElement) {\n return null\n }\n\n return (\n <Floater\n open={menuOpen}\n portalElement={portalElement}\n placement='bottom-end'\n offset={8}\n hideArrow\n styles={{\n options: {\n zIndex: undefined,\n },\n wrapper: {\n cursor: disabled ? 'not-allowed' : 'pointer',\n },\n floater: {\n filter: 'none',\n opacity: 1,\n transitionDuration: '10ms',\n },\n }}\n getPopper={(popper) => {\n if (popper.state.elements.reference instanceof HTMLElement) {\n controlRef.current = popper.state.elements.reference\n }\n }}\n modifiers={{\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n removeRoles: {\n name: 'removeRoles',\n enabled: true,\n phase: 'beforeWrite',\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement) {\n const floaterElement = state.elements.popper.querySelector('[role=\"tooltip\"]')\n if (floaterElement) {\n floaterElement.removeAttribute('role')\n }\n }\n },\n },\n minWidth: {\n name: 'minWidth',\n enabled: true,\n phase: 'beforeWrite',\n requires: ['computeStyles'],\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n fn: ({ state }) => {\n state.styles.popper.minWidth = `${state.rects.reference.width}px`\n },\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement && state.elements.reference instanceof HTMLElement) {\n state.elements.popper.style.display = 'flex'\n state.elements.popper.style.flexDirection = 'column'\n state.elements.popper.style.alignItems = 'stretch'\n state.elements.popper.style.minWidth = `${state.elements.reference.offsetWidth}px`\n }\n },\n },\n }}\n // eslint-disable-next-line react/no-unstable-nested-components\n component={() => (\n <Styled.Menu\n role='menu'\n aria-labelledby={controlId}\n ref={setMenuRef}\n palette={{\n backgroundColor: palette.menuBackgroundColor,\n }}\n onClick={(evt) => {\n if (evt.target instanceof HTMLElement && evt.target.closest('[role=\"menuitem\"]')) {\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n }\n }}\n onKeyDown={(evt) => {\n evt.stopPropagation()\n\n if (\n !(document.activeElement instanceof HTMLElement) ||\n !document.activeElement.matches('[role=\"menuitem\"]') ||\n (!keyboardKeys.Esc.validate(evt.key) &&\n !keyboardKeys.Tab.validate(evt.key) &&\n !keyboardKeys.Home.validate(evt.key) &&\n !keyboardKeys.End.validate(evt.key) &&\n !keyboardKeys.ArrowDown.validate(evt.key) &&\n !keyboardKeys.ArrowUp.validate(evt.key))\n ) {\n return\n }\n\n if (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key)) {\n evt.preventDefault()\n\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n\n return\n }\n\n const items = Array.from(evt.currentTarget.querySelectorAll<HTMLElement>('[role=\"menuitem\"]'))\n\n if (items.length === 0) return\n\n if (keyboardKeys.Home.validate(evt.key)) {\n evt.preventDefault()\n items[0].focus()\n } else if (keyboardKeys.End.validate(evt.key)) {\n evt.preventDefault()\n items[items.length - 1].focus()\n } else if (keyboardKeys.ArrowDown.validate(evt.key) || keyboardKeys.ArrowUp.validate(evt.key)) {\n evt.preventDefault()\n navigateVerticalList(evt.key, document.activeElement, items, SELECTORS_FOCUSABLE)\n }\n }}\n >\n <TabListTabsContext.Provider value={controlsContextProps}>\n <TabListPropsContext.Provider value={menuItemsContextProps}>\n {Children.map(menuItems, (item) => (\n <Styled.MenuItem role='none'>{item}</Styled.MenuItem>\n ))}\n </TabListPropsContext.Provider>\n </TabListTabsContext.Provider>\n </Styled.Menu>\n )}\n >\n {typeof control === 'function' ? control(controlProps) : <TabListTab {...controlProps} />}\n </Floater>\n )\n}\n\nexport { TabListMenuTab }\n"],"names":["TabListMenuTab","props","role","type","variant","size","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","disabled","text","control","menuItems","activeTab","firstTab","activationOnFocus","getTabIndex","onActiveTabChange","sizeProps","useMemo","palette","useMergedPalette","controlRef","useRef","menuRef","setMenuRef","useState","timerId","portalElement","useFloaterPortal","menuOpen","setMenuOpen","controlId","nanoid","clickOutsideTargets","handleCloseMenu","useCallback","menuHasActiveTab","Boolean","find","item","isValidElement","id","controlProps","active","tabIndex","addonRight","addonProps","_jsx","Styled","iconProps","rotate","icon","ChevronDown","preset","color","tabColor","colorHover","tabColorHover","colorActive","tabColorActive","colorDisabled","tabColorDisabled","colorActiveDisabled","tabColorActiveDisabled","backgroundColor","tabBackgroundColor","backgroundColorHover","tabBackgroundColorHover","backgroundColorActive","tabBackgroundColorActive","backgroundColorDisabled","tabBackgroundColorDisabled","backgroundColorActiveDisabled","tabBackgroundColorActiveDisabled","onClick","prev","onKeyDown","evt","keyboardKeys","Esc","validate","key","Tab","preventDefault","F10","shiftKey","ArrowDown","controlsContextProps","menuItemsContextProps","useClickOutside","enabled","event","useEffect","current","setTimeout","items","Array","from","querySelectorAll","filter","matches","SELECTORS_FOCUSABLE","activeItem","focus","clearTimeout","Floater","open","placement","offset","hideArrow","styles","options","zIndex","undefined","wrapper","cursor","floater","opacity","transitionDuration","getPopper","popper","state","elements","reference","HTMLElement","modifiers","removeRoles","name","phase","effect","floaterElement","querySelector","removeAttribute","minWidth","requires","fn","rects","width","style","display","flexDirection","alignItems","offsetWidth","component","ref","menuBackgroundColor","target","closest","stopPropagation","document","activeElement","Home","End","ArrowUp","currentTarget","length","navigateVerticalList","children","TabListTabsContext","Provider","value","TabListPropsContext","Children","map","TabListTab"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var React=require('react');var styled=require('styled-components');var nanoid=require('nanoid');var
|
|
1
|
+
'use strict';var React=require('react');var styled=require('styled-components');var nanoid=require('nanoid');var withMergedProps=require('../../hocs/withMergedProps.js');var useResizable=require('../../hooks/useResizable.js');var misc=require('../../shared/utils/misc.js');var sizes=require('./sizes.js');var style=require('./style.js');var jsxRuntime=require('react/jsx-runtime');var FormInputLabel=require('../FormInputLabel/FormInputLabel.js');var InputLabel=require('../InputLabel/InputLabel.js');var sizes$1=require('../FormInput/sizes.js');var index=require('../../icon-pack/src/icons/ResizeHandle/index.js');const Textarea=withMergedProps.withMergedProps(React.forwardRef(((e,r)=>{const t=styled.useTheme();const{size:a="m",rows:i=2,maxRows:n=30,labelPosition:o="dynamic",primary:s=!0,width:l=t.defaultInputControlsWidth,autosize:m=!0,rounded:u=!0,color:c="mineShaft",placeholderColor:g="silver",autoRows:d,resize:h,contrast:p,inline:X,secondary:b,success:L,error:R,sizeXXS:S,sizeXS:z,sizeS:f,sizeM:x,sizeL:v,sizeXL:w,sizes:j,sizeUnits:M,margin:C,marginXXS:T,marginXS:y,marginS:I,marginM:B,marginL:q,marginXL:D,marginTop:F,marginTopXXS:k,marginTopXS:N,marginTopS:E,marginTopM:H,marginTopL:P,marginTopXL:O,marginRight:U,marginRightXXS:Z,marginRightXS:$,marginRightS:A,marginRightM:G,marginRightL:K,marginRightXL:V,marginBottom:W,marginBottomXXS:_,marginBottomXS:J,marginBottomS:Q,marginBottomM:Y,marginBottomL:ee,marginBottomXL:re,marginLeft:te,marginLeftXXS:ae,marginLeftXS:ie,marginLeftS:ne,marginLeftM:oe,marginLeftL:se,marginLeftXL:le,widthXXS:me,widthXS:ue,widthS:ce,widthM:ge,widthL:de,widthXL:he,preset:pe,palette:Xe,label:be,fluid:Le,className:Re,style:Se,disabled:ze,...fe}=e;const xe={size:a,sizeXXS:S,sizeXS:z,sizeS:f,sizeM:x,sizeL:v,sizeXL:w};const ve=React.useRef(null);const we=React.useRef(null);const je=React.useRef(null);React.useImperativeHandle(r,(()=>ve.current),[]);const[Me,Ce,Te]=useResizable.useResizable({target:je,direction:h});const ye=React.useMemo((()=>nanoid.nanoid()),[]);const[Ie,Be]=React.useState((()=>{const e=fe.value??fe.defaultValue;return typeof e=='string'&&e.length>0}));const[qe,De]=React.useState((()=>Math.min(i,n)));const Fe=pe==='brand'&&d||pe!=='brand'&&m?qe:Math.min(i,n);const ke=h==='horizontal'?'ew-resize':h==='vertical'?'ns-resize':'nwse-resize';const Ne=React.useCallback((()=>{if(!ve.current)return;if(pe==='brand'){if(!we.current)return;we.current.value=ve.current.value;const e=Math.max(Math.round(we.current.scrollHeight/we.current.clientHeight),i);return void De(Math.min(e,n))}const e=getComputedStyle(ve.current);const r=parseFloat(e.lineHeight);const t=Math.max(Math.round((ve.current.scrollHeight-parseFloat(e.paddingTop)-parseFloat(e.paddingBottom))/(Number.isNaN(r)?parseFloat(e.fontSize)*1.2:r)),i);De((e=>t>e?Math.min(t,n):ve.current&&!ve.current.value?i:e))}),[pe,i,n]);return React.useLayoutEffect((()=>{pe==='brand'&&typeof fe.value=='string'&&ve.current&&ve.current!==document.activeElement&&Be(fe.value.length>0)}),[pe,fe.value]),React.useEffect((()=>{const e=misc.createThrottledCallback(Ne,200);return(pe==='brand'&&d||pe!=='brand'&&m)&&(Ne(),window.addEventListener('resize',e)),()=>{window.removeEventListener('resize',e)}}),[pe,d,m,Ne]),pe!=='brand'?jsxRuntime.jsx(style.Root,{...fe,ref:ve,className:Re,style:Se,onChange:e=>{m&&Ne(),fe.onChange&&fe.onChange(e)},rows:Fe,color:c,rounded:u,placeholderColor:g,disabled:ze,error:R,fluid:Le,width:l,widthXXS:me,widthXS:ue,widthS:ce,widthM:ge,widthL:de,widthXL:he}):jsxRuntime.jsx(FormInputLabel.FormInputLabel,{...xe,ref:je,sizes:j,sizeUnits:M,margin:C,marginXXS:T,marginXS:y,marginS:I,marginM:B,marginL:q,marginXL:D,marginTop:F,marginTopXXS:k,marginTopXS:N,marginTopS:E,marginTopM:H,marginTopL:P,marginTopXL:O,marginRight:U,marginRightXXS:Z,marginRightXS:$,marginRightS:A,marginRightM:G,marginRightL:K,marginRightXL:V,marginBottom:W,marginBottomXXS:_,marginBottomXS:J,marginBottomS:Q,marginBottomM:Y,marginBottomL:ee,marginBottomXL:re,marginLeft:te,marginLeftXXS:ae,marginLeftXS:ie,marginLeftS:ne,marginLeftM:oe,marginLeftL:se,marginLeftXL:le,className:Re,style:Se,contrast:p,error:R,inline:X,disabled:ze,primary:s,secondary:b,success:L,palette:{color:ze?Xe.colorDisabled:Xe.color,backgroundColor:ze?Xe.backgroundColorDisabled:Xe.backgroundColor,backgroundColorHover:ze?Xe.backgroundColorDisabled:Xe.backgroundColorHover,borderColor:ze?Xe.borderColorDisabled:Xe.borderColor},onClick:()=>{ve.current&&ve.current.focus()},onFocus:()=>{Be(!0)},onPointerDown:e=>{e.target!==ve.current&&e.target instanceof Node&&e.preventDefault()},onBlur:e=>{ve.current&&!e.currentTarget.contains(e.relatedTarget)&&Be(Boolean(ve.current.value))},overflow:"hidden",input:jsxRuntime.jsxs(InputLabel.InputLabel,{...xe,sizes:sizes$1.SIZES,active:Ie,label:be,labelId:ye,labelPosition:o,children:[d?jsxRuntime.jsx(style.TextareaMimic,{ref:we,rows:1}):null,jsxRuntime.jsx(style.Textarea,{...fe,ref:ve,"aria-labelledby":be?ye:void 0,disabled:ze,onChange:e=>{d&&Ne(),fe.onChange&&fe.onChange(e)},rows:Fe,palette:{color:Xe.color,colorDisabled:Xe.colorDisabled,placeholderColor:Xe.placeholderColor,placeholderColorDisabled:Xe.placeholderColorDisabled}})]}),addon:h?jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[Me?jsxRuntime.jsx(style.ResizeGlobals,{cursor:ke}):null,jsxRuntime.jsx(style.ResizeIcon,{size:"l",icon:jsxRuntime.jsx(index.ResizeHandle,{}),color:"border-onmain-default-small",tabIndex:0,onPointerDown:Ce,onKeyDown:Te,cursor:ke})]}):void 0})})),{displayName:"Textarea",sizes:sizes.SIZES});exports.COMPONENT_NAME="Textarea",exports.Textarea=Textarea;
|
|
2
2
|
//# sourceMappingURL=Textarea.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Textarea.js","sources":["../../../../src/components/Textarea/Textarea.tsx"],"sourcesContent":["import {\n forwardRef,\n useImperativeHandle,\n useLayoutEffect,\n useEffect,\n useRef,\n useState,\n useMemo,\n useCallback,\n} from 'react'\nimport { useTheme } from 'styled-components'\nimport { nanoid } from 'nanoid'\nimport { ResizeHandle } from '@foxford/icon-pack'\nimport { withMergedProps } from 'hocs/withMergedProps'\nimport { InputLabel } from 'components/InputLabel'\nimport type { MergedProps } from 'hocs/withMergedProps'\nimport { useResizable } from 'hooks/useResizable'\nimport { createThrottledCallback } from 'shared/utils/misc'\nimport { FormInputLabel } from 'components/FormInputLabel'\nimport { SIZES as SIZES_FORM_INPUT } from 'components/FormInput'\nimport { SIZES } from './sizes'\nimport * as Styled from './style'\nimport type { TextareaProps } from './types'\n\nconst COMPONENT_NAME = 'Textarea'\n\n/**\n *\n * Компонент для приема многострочного ввода.\n *\n * Поддерживается \"ref\" и все нативные атрибуты \\<textarea\\> элемента.\n */\nconst Textarea: React.ForwardRefExoticComponent<TextareaProps> = withMergedProps<TextareaProps, HTMLTextAreaElement>(\n forwardRef<HTMLTextAreaElement, MergedProps<TextareaProps>>((props, forwardedRef) => {\n const theme = useTheme()\n\n const {\n size = 'm',\n rows = 2,\n maxRows = 30,\n labelPosition = 'dynamic',\n primary = true,\n width = theme.defaultInputControlsWidth,\n autosize = true,\n rounded = true,\n color = 'mineShaft',\n placeholderColor = 'silver',\n autoRows,\n resize,\n contrast,\n inline,\n secondary,\n success,\n error,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n sizes,\n sizeUnits,\n margin,\n marginXXS,\n marginXS,\n marginS,\n marginM,\n marginL,\n marginXL,\n marginTop,\n marginTopXXS,\n marginTopXS,\n marginTopS,\n marginTopM,\n marginTopL,\n marginTopXL,\n marginRight,\n marginRightXXS,\n marginRightXS,\n marginRightS,\n marginRightM,\n marginRightL,\n marginRightXL,\n marginBottom,\n marginBottomXXS,\n marginBottomXS,\n marginBottomS,\n marginBottomM,\n marginBottomL,\n marginBottomXL,\n marginLeft,\n marginLeftXXS,\n marginLeftXS,\n marginLeftS,\n marginLeftM,\n marginLeftL,\n marginLeftXL,\n widthXXS,\n widthXS,\n widthS,\n widthM,\n widthL,\n widthXL,\n preset,\n palette,\n label,\n fluid,\n className,\n style,\n disabled,\n ...textareaProps\n } = props\n\n const sizeProps = {\n size,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n }\n\n const textareaRef = useRef<HTMLTextAreaElement>(null)\n\n const textareaMimicRef = useRef<HTMLTextAreaElement>(null)\n\n const formInputLabelRef = useRef<HTMLDivElement>(null)\n\n useImperativeHandle(forwardedRef, () => textareaRef.current as HTMLTextAreaElement, [])\n\n const [resizing, handleResizeStart, handleResizeOnNudge] = useResizable<HTMLDivElement, HTMLSpanElement>({\n target: formInputLabelRef,\n direction: resize,\n })\n\n const labelId = useMemo(() => nanoid(), [])\n\n const [active, setActive] = useState(() => {\n const valueInit = textareaProps.value ?? textareaProps.defaultValue\n\n return typeof valueInit === 'string' && valueInit.length > 0\n })\n\n const [autoRowsCount, setAutoRowsCount] = useState(() => Math.min(rows, maxRows))\n\n const rowsVisible =\n (preset === 'brand' && autoRows) || (preset !== 'brand' && autosize) ? autoRowsCount : Math.min(rows, maxRows)\n\n const cursorResize = resize === 'horizontal' ? 'ew-resize' : resize === 'vertical' ? 'ns-resize' : 'nwse-resize'\n\n const updateAutoRowsCount = useCallback(() => {\n if (!textareaRef.current) return\n\n if (preset === 'brand') {\n if (!textareaMimicRef.current) return\n\n textareaMimicRef.current.value = textareaRef.current.value\n\n const nextRows = Math.max(\n Math.round(textareaMimicRef.current.scrollHeight / textareaMimicRef.current.clientHeight),\n rows\n )\n\n setAutoRowsCount(Math.min(nextRows, maxRows))\n\n return\n }\n\n const styles = getComputedStyle(textareaRef.current)\n\n const lineHeight = parseFloat(styles.lineHeight)\n\n const nextRows = Math.max(\n Math.round(\n (textareaRef.current.scrollHeight - parseFloat(styles.paddingTop) - parseFloat(styles.paddingBottom)) /\n (Number.isNaN(lineHeight) ? parseFloat(styles.fontSize) * 1.2 : lineHeight)\n ),\n rows\n )\n\n setAutoRowsCount((prevRows) => {\n if (nextRows > prevRows) return Math.min(nextRows, maxRows)\n if (textareaRef.current && !textareaRef.current.value) return rows\n\n return prevRows\n })\n }, [preset, rows, maxRows])\n\n useLayoutEffect(() => {\n if (\n preset === 'brand' &&\n typeof textareaProps.value === 'string' &&\n textareaRef.current &&\n textareaRef.current !== document.activeElement\n ) {\n setActive(textareaProps.value.length > 0)\n }\n }, [preset, textareaProps.value])\n\n useEffect(() => {\n const handleResize = createThrottledCallback<UIEvent>(updateAutoRowsCount, 200)\n\n if ((preset === 'brand' && autoRows) || (preset !== 'brand' && autosize)) {\n updateAutoRowsCount()\n window.addEventListener('resize', handleResize)\n }\n\n return () => {\n window.removeEventListener('resize', handleResize)\n }\n }, [preset, autoRows, autosize, updateAutoRowsCount])\n\n if (preset !== 'brand') {\n return (\n <Styled.Root\n {...textareaProps}\n ref={textareaRef}\n className={className}\n style={style}\n onChange={(evt) => {\n if (autosize) updateAutoRowsCount()\n if (textareaProps.onChange) textareaProps.onChange(evt)\n }}\n rows={rowsVisible}\n color={color}\n rounded={rounded}\n placeholderColor={placeholderColor}\n disabled={disabled}\n error={error}\n fluid={fluid}\n width={width}\n widthXXS={widthXXS}\n widthXS={widthXS}\n widthS={widthS}\n widthM={widthM}\n widthL={widthL}\n widthXL={widthXL}\n />\n )\n }\n\n return (\n <FormInputLabel\n {...sizeProps}\n ref={formInputLabelRef}\n sizes={sizes}\n sizeUnits={sizeUnits}\n margin={margin}\n marginXXS={marginXXS}\n marginXS={marginXS}\n marginS={marginS}\n marginM={marginM}\n marginL={marginL}\n marginXL={marginXL}\n marginTop={marginTop}\n marginTopXXS={marginTopXXS}\n marginTopXS={marginTopXS}\n marginTopS={marginTopS}\n marginTopM={marginTopM}\n marginTopL={marginTopL}\n marginTopXL={marginTopXL}\n marginRight={marginRight}\n marginRightXXS={marginRightXXS}\n marginRightXS={marginRightXS}\n marginRightS={marginRightS}\n marginRightM={marginRightM}\n marginRightL={marginRightL}\n marginRightXL={marginRightXL}\n marginBottom={marginBottom}\n marginBottomXXS={marginBottomXXS}\n marginBottomXS={marginBottomXS}\n marginBottomS={marginBottomS}\n marginBottomM={marginBottomM}\n marginBottomL={marginBottomL}\n marginBottomXL={marginBottomXL}\n marginLeft={marginLeft}\n marginLeftXXS={marginLeftXXS}\n marginLeftXS={marginLeftXS}\n marginLeftS={marginLeftS}\n marginLeftM={marginLeftM}\n marginLeftL={marginLeftL}\n marginLeftXL={marginLeftXL}\n className={className}\n style={style}\n contrast={contrast}\n error={error}\n inline={inline}\n disabled={disabled}\n primary={primary}\n secondary={secondary}\n success={success}\n palette={{\n color: disabled ? palette.colorDisabled : palette.color,\n backgroundColor: disabled ? palette.backgroundColorDisabled : palette.backgroundColor,\n backgroundColorHover: disabled ? palette.backgroundColorDisabled : palette.backgroundColorHover,\n borderColor: disabled ? palette.borderColorDisabled : palette.borderColor,\n }}\n onClick={() => {\n if (textareaRef.current) {\n textareaRef.current.focus()\n }\n }}\n onFocus={() => {\n setActive(true)\n }}\n onPointerDown={(evt) => {\n if (evt.target === textareaRef.current || !(evt.target instanceof Node)) {\n return\n }\n evt.preventDefault()\n }}\n onBlur={(evt) => {\n if (textareaRef.current && !evt.currentTarget.contains(evt.relatedTarget)) {\n setActive(Boolean(textareaRef.current.value))\n }\n }}\n overflow='hidden'\n input={\n <InputLabel\n {...sizeProps}\n sizes={SIZES_FORM_INPUT}\n active={active}\n label={label}\n labelId={labelId}\n labelPosition={labelPosition}\n >\n {autoRows ? <Styled.TextareaMimic ref={textareaMimicRef} rows={1} /> : null}\n <Styled.Textarea\n {...textareaProps}\n ref={textareaRef}\n aria-labelledby={label ? labelId : undefined}\n disabled={disabled}\n onChange={(evt) => {\n if (autoRows) updateAutoRowsCount()\n if (textareaProps.onChange) textareaProps.onChange(evt)\n }}\n rows={rowsVisible}\n palette={{\n color: palette.color,\n colorDisabled: palette.colorDisabled,\n placeholderColor: palette.placeholderColor,\n placeholderColorDisabled: palette.placeholderColorDisabled,\n }}\n />\n </InputLabel>\n }\n addon={\n resize ? (\n <>\n {resizing ? <Styled.ResizeGlobals cursor={cursorResize} /> : null}\n <Styled.ResizeIcon\n size='l'\n icon={<ResizeHandle />}\n color='border-onmain-default-small'\n tabIndex={0}\n onPointerDown={handleResizeStart}\n onKeyDown={handleResizeOnNudge}\n cursor={cursorResize}\n />\n </>\n ) : undefined\n }\n />\n )\n }),\n {\n displayName: COMPONENT_NAME,\n sizes: SIZES,\n }\n)\n\nexport { Textarea, COMPONENT_NAME }\n"],"names":["Textarea","withMergedProps","forwardRef","props","forwardedRef","theme","useTheme","size","rows","maxRows","labelPosition","primary","width","defaultInputControlsWidth","autosize","rounded","color","placeholderColor","autoRows","resize","contrast","inline","secondary","success","error","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","sizes","sizeUnits","margin","marginXXS","marginXS","marginS","marginM","marginL","marginXL","marginTop","marginTopXXS","marginTopXS","marginTopS","marginTopM","marginTopL","marginTopXL","marginRight","marginRightXXS","marginRightXS","marginRightS","marginRightM","marginRightL","marginRightXL","marginBottom","marginBottomXXS","marginBottomXS","marginBottomS","marginBottomM","marginBottomL","marginBottomXL","marginLeft","marginLeftXXS","marginLeftXS","marginLeftS","marginLeftM","marginLeftL","marginLeftXL","widthXXS","widthXS","widthS","widthM","widthL","widthXL","preset","palette","label","fluid","className","style","disabled","textareaProps","sizeProps","textareaRef","useRef","textareaMimicRef","formInputLabelRef","useImperativeHandle","current","resizing","handleResizeStart","handleResizeOnNudge","useResizable","target","direction","labelId","useMemo","nanoid","active","setActive","useState","valueInit","value","defaultValue","length","autoRowsCount","setAutoRowsCount","Math","min","rowsVisible","cursorResize","updateAutoRowsCount","useCallback","nextRows","max","round","scrollHeight","clientHeight","styles","getComputedStyle","lineHeight","parseFloat","paddingTop","paddingBottom","Number","isNaN","fontSize","prevRows","useLayoutEffect","document","activeElement","useEffect","handleResize","createThrottledCallback","window","addEventListener","removeEventListener","_jsx","Styled","ref","onChange","evt","FormInputLabel","colorDisabled","backgroundColor","backgroundColorDisabled","backgroundColorHover","borderColor","borderColorDisabled","onClick","focus","onFocus","onPointerDown","Node","preventDefault","onBlur","currentTarget","contains","relatedTarget","Boolean","overflow","input","_jsxs","jsxs","InputLabel","SIZES_FORM_INPUT","SIZES","children","jsx","undefined","placeholderColorDisabled","addon","_Fragment","cursor","icon","ResizeHandle","tabIndex","onKeyDown","displayName"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Textarea.js","sources":["../../../../src/components/Textarea/Textarea.tsx"],"sourcesContent":["import {\n forwardRef,\n useImperativeHandle,\n useLayoutEffect,\n useEffect,\n useRef,\n useState,\n useMemo,\n useCallback,\n} from 'react'\nimport { useTheme } from 'styled-components'\nimport { nanoid } from 'nanoid'\nimport { ResizeHandle } from '@foxford/icon-pack'\nimport { withMergedProps } from 'hocs/withMergedProps'\nimport { InputLabel } from 'components/InputLabel'\nimport type { MergedProps } from 'hocs/withMergedProps'\nimport { useResizable } from 'hooks/useResizable'\nimport { createThrottledCallback } from 'shared/utils/misc'\nimport { FormInputLabel } from 'components/FormInputLabel'\nimport { SIZES as SIZES_FORM_INPUT } from 'components/FormInput'\nimport { SIZES } from './sizes'\nimport * as Styled from './style'\nimport type { TextareaProps } from './types'\n\nconst COMPONENT_NAME = 'Textarea'\n\n/**\n *\n * Компонент для приема многострочного ввода.\n *\n * Поддерживается \"ref\" и все нативные атрибуты \\<textarea\\> элемента.\n */\nconst Textarea: React.ForwardRefExoticComponent<TextareaProps> = withMergedProps<TextareaProps, HTMLTextAreaElement>(\n forwardRef<HTMLTextAreaElement, MergedProps<TextareaProps>>((props, forwardedRef) => {\n const theme = useTheme()\n\n const {\n size = 'm',\n rows = 2,\n maxRows = 30,\n labelPosition = 'dynamic',\n primary = true,\n width = theme.defaultInputControlsWidth,\n autosize = true,\n rounded = true,\n color = 'mineShaft',\n placeholderColor = 'silver',\n autoRows,\n resize,\n contrast,\n inline,\n secondary,\n success,\n error,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n sizes,\n sizeUnits,\n margin,\n marginXXS,\n marginXS,\n marginS,\n marginM,\n marginL,\n marginXL,\n marginTop,\n marginTopXXS,\n marginTopXS,\n marginTopS,\n marginTopM,\n marginTopL,\n marginTopXL,\n marginRight,\n marginRightXXS,\n marginRightXS,\n marginRightS,\n marginRightM,\n marginRightL,\n marginRightXL,\n marginBottom,\n marginBottomXXS,\n marginBottomXS,\n marginBottomS,\n marginBottomM,\n marginBottomL,\n marginBottomXL,\n marginLeft,\n marginLeftXXS,\n marginLeftXS,\n marginLeftS,\n marginLeftM,\n marginLeftL,\n marginLeftXL,\n widthXXS,\n widthXS,\n widthS,\n widthM,\n widthL,\n widthXL,\n preset,\n palette,\n label,\n fluid,\n className,\n style,\n disabled,\n ...textareaProps\n } = props\n\n const sizeProps = {\n size,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n }\n\n const textareaRef = useRef<HTMLTextAreaElement>(null)\n\n const textareaMimicRef = useRef<HTMLTextAreaElement>(null)\n\n const formInputLabelRef = useRef<HTMLDivElement>(null)\n\n useImperativeHandle(forwardedRef, () => textareaRef.current as HTMLTextAreaElement, [])\n\n const [resizing, handleResizeStart, handleResizeOnNudge] = useResizable<HTMLDivElement, HTMLSpanElement>({\n target: formInputLabelRef,\n direction: resize,\n })\n\n const labelId = useMemo(() => nanoid(), [])\n\n const [active, setActive] = useState(() => {\n const valueInit = textareaProps.value ?? textareaProps.defaultValue\n\n return typeof valueInit === 'string' && valueInit.length > 0\n })\n\n const [autoRowsCount, setAutoRowsCount] = useState(() => Math.min(rows, maxRows))\n\n const rowsVisible =\n (preset === 'brand' && autoRows) || (preset !== 'brand' && autosize) ? autoRowsCount : Math.min(rows, maxRows)\n\n const cursorResize = resize === 'horizontal' ? 'ew-resize' : resize === 'vertical' ? 'ns-resize' : 'nwse-resize'\n\n const updateAutoRowsCount = useCallback(() => {\n if (!textareaRef.current) return\n\n if (preset === 'brand') {\n if (!textareaMimicRef.current) return\n\n textareaMimicRef.current.value = textareaRef.current.value\n\n const nextRows = Math.max(\n Math.round(textareaMimicRef.current.scrollHeight / textareaMimicRef.current.clientHeight),\n rows\n )\n\n setAutoRowsCount(Math.min(nextRows, maxRows))\n\n return\n }\n\n const styles = getComputedStyle(textareaRef.current)\n\n const lineHeight = parseFloat(styles.lineHeight)\n\n const nextRows = Math.max(\n Math.round(\n (textareaRef.current.scrollHeight - parseFloat(styles.paddingTop) - parseFloat(styles.paddingBottom)) /\n (Number.isNaN(lineHeight) ? parseFloat(styles.fontSize) * 1.2 : lineHeight)\n ),\n rows\n )\n\n setAutoRowsCount((prevRows) => {\n if (nextRows > prevRows) return Math.min(nextRows, maxRows)\n if (textareaRef.current && !textareaRef.current.value) return rows\n\n return prevRows\n })\n }, [preset, rows, maxRows])\n\n useLayoutEffect(() => {\n if (\n preset === 'brand' &&\n typeof textareaProps.value === 'string' &&\n textareaRef.current &&\n textareaRef.current !== document.activeElement\n ) {\n setActive(textareaProps.value.length > 0)\n }\n }, [preset, textareaProps.value])\n\n useEffect(() => {\n const handleResize = createThrottledCallback<UIEvent>(updateAutoRowsCount, 200)\n\n if ((preset === 'brand' && autoRows) || (preset !== 'brand' && autosize)) {\n updateAutoRowsCount()\n window.addEventListener('resize', handleResize)\n }\n\n return () => {\n window.removeEventListener('resize', handleResize)\n }\n }, [preset, autoRows, autosize, updateAutoRowsCount])\n\n if (preset !== 'brand') {\n return (\n <Styled.Root\n {...textareaProps}\n ref={textareaRef}\n className={className}\n style={style}\n onChange={(evt) => {\n if (autosize) updateAutoRowsCount()\n if (textareaProps.onChange) textareaProps.onChange(evt)\n }}\n rows={rowsVisible}\n color={color}\n rounded={rounded}\n placeholderColor={placeholderColor}\n disabled={disabled}\n error={error}\n fluid={fluid}\n width={width}\n widthXXS={widthXXS}\n widthXS={widthXS}\n widthS={widthS}\n widthM={widthM}\n widthL={widthL}\n widthXL={widthXL}\n />\n )\n }\n\n return (\n <FormInputLabel\n {...sizeProps}\n ref={formInputLabelRef}\n sizes={sizes}\n sizeUnits={sizeUnits}\n margin={margin}\n marginXXS={marginXXS}\n marginXS={marginXS}\n marginS={marginS}\n marginM={marginM}\n marginL={marginL}\n marginXL={marginXL}\n marginTop={marginTop}\n marginTopXXS={marginTopXXS}\n marginTopXS={marginTopXS}\n marginTopS={marginTopS}\n marginTopM={marginTopM}\n marginTopL={marginTopL}\n marginTopXL={marginTopXL}\n marginRight={marginRight}\n marginRightXXS={marginRightXXS}\n marginRightXS={marginRightXS}\n marginRightS={marginRightS}\n marginRightM={marginRightM}\n marginRightL={marginRightL}\n marginRightXL={marginRightXL}\n marginBottom={marginBottom}\n marginBottomXXS={marginBottomXXS}\n marginBottomXS={marginBottomXS}\n marginBottomS={marginBottomS}\n marginBottomM={marginBottomM}\n marginBottomL={marginBottomL}\n marginBottomXL={marginBottomXL}\n marginLeft={marginLeft}\n marginLeftXXS={marginLeftXXS}\n marginLeftXS={marginLeftXS}\n marginLeftS={marginLeftS}\n marginLeftM={marginLeftM}\n marginLeftL={marginLeftL}\n marginLeftXL={marginLeftXL}\n className={className}\n style={style}\n contrast={contrast}\n error={error}\n inline={inline}\n disabled={disabled}\n primary={primary}\n secondary={secondary}\n success={success}\n palette={{\n color: disabled ? palette.colorDisabled : palette.color,\n backgroundColor: disabled ? palette.backgroundColorDisabled : palette.backgroundColor,\n backgroundColorHover: disabled ? palette.backgroundColorDisabled : palette.backgroundColorHover,\n borderColor: disabled ? palette.borderColorDisabled : palette.borderColor,\n }}\n onClick={() => {\n if (textareaRef.current) {\n textareaRef.current.focus()\n }\n }}\n onFocus={() => {\n setActive(true)\n }}\n onPointerDown={(evt) => {\n if (evt.target === textareaRef.current || !(evt.target instanceof Node)) {\n return\n }\n evt.preventDefault()\n }}\n onBlur={(evt) => {\n if (textareaRef.current && !evt.currentTarget.contains(evt.relatedTarget)) {\n setActive(Boolean(textareaRef.current.value))\n }\n }}\n overflow='hidden'\n input={\n <InputLabel\n {...sizeProps}\n sizes={SIZES_FORM_INPUT}\n active={active}\n label={label}\n labelId={labelId}\n labelPosition={labelPosition}\n >\n {autoRows ? <Styled.TextareaMimic ref={textareaMimicRef} rows={1} /> : null}\n <Styled.Textarea\n {...textareaProps}\n ref={textareaRef}\n aria-labelledby={label ? labelId : undefined}\n disabled={disabled}\n onChange={(evt) => {\n if (autoRows) updateAutoRowsCount()\n if (textareaProps.onChange) textareaProps.onChange(evt)\n }}\n rows={rowsVisible}\n palette={{\n color: palette.color,\n colorDisabled: palette.colorDisabled,\n placeholderColor: palette.placeholderColor,\n placeholderColorDisabled: palette.placeholderColorDisabled,\n }}\n />\n </InputLabel>\n }\n addon={\n resize ? (\n <>\n {resizing ? <Styled.ResizeGlobals cursor={cursorResize} /> : null}\n <Styled.ResizeIcon\n size='l'\n icon={<ResizeHandle />}\n color='border-onmain-default-small'\n tabIndex={0}\n onPointerDown={handleResizeStart}\n onKeyDown={handleResizeOnNudge}\n cursor={cursorResize}\n />\n </>\n ) : undefined\n }\n />\n )\n }),\n {\n displayName: COMPONENT_NAME,\n sizes: SIZES,\n }\n)\n\nexport { Textarea, COMPONENT_NAME }\n"],"names":["Textarea","withMergedProps","forwardRef","props","forwardedRef","theme","useTheme","size","rows","maxRows","labelPosition","primary","width","defaultInputControlsWidth","autosize","rounded","color","placeholderColor","autoRows","resize","contrast","inline","secondary","success","error","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","sizes","sizeUnits","margin","marginXXS","marginXS","marginS","marginM","marginL","marginXL","marginTop","marginTopXXS","marginTopXS","marginTopS","marginTopM","marginTopL","marginTopXL","marginRight","marginRightXXS","marginRightXS","marginRightS","marginRightM","marginRightL","marginRightXL","marginBottom","marginBottomXXS","marginBottomXS","marginBottomS","marginBottomM","marginBottomL","marginBottomXL","marginLeft","marginLeftXXS","marginLeftXS","marginLeftS","marginLeftM","marginLeftL","marginLeftXL","widthXXS","widthXS","widthS","widthM","widthL","widthXL","preset","palette","label","fluid","className","style","disabled","textareaProps","sizeProps","textareaRef","useRef","textareaMimicRef","formInputLabelRef","useImperativeHandle","current","resizing","handleResizeStart","handleResizeOnNudge","useResizable","target","direction","labelId","useMemo","nanoid","active","setActive","useState","valueInit","value","defaultValue","length","autoRowsCount","setAutoRowsCount","Math","min","rowsVisible","cursorResize","updateAutoRowsCount","useCallback","nextRows","max","round","scrollHeight","clientHeight","styles","getComputedStyle","lineHeight","parseFloat","paddingTop","paddingBottom","Number","isNaN","fontSize","prevRows","useLayoutEffect","document","activeElement","useEffect","handleResize","createThrottledCallback","window","addEventListener","removeEventListener","_jsx","Styled","ref","onChange","evt","FormInputLabel","colorDisabled","backgroundColor","backgroundColorDisabled","backgroundColorHover","borderColor","borderColorDisabled","onClick","focus","onFocus","onPointerDown","Node","preventDefault","onBlur","currentTarget","contains","relatedTarget","Boolean","overflow","input","_jsxs","jsxs","InputLabel","SIZES_FORM_INPUT","SIZES","children","jsx","undefined","placeholderColorDisabled","addon","_Fragment","cursor","icon","ResizeHandle","tabIndex","onKeyDown","displayName"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{forwardRef,useRef,useImperativeHandle,useMemo,useState,useCallback,useLayoutEffect,useEffect}from'react';import{useTheme}from'styled-components';import{nanoid}from'nanoid';import{
|
|
1
|
+
import{forwardRef,useRef,useImperativeHandle,useMemo,useState,useCallback,useLayoutEffect,useEffect}from'react';import{useTheme}from'styled-components';import{nanoid}from'nanoid';import{withMergedProps}from'../../hocs/withMergedProps.mjs';import{useResizable}from'../../hooks/useResizable.mjs';import{createThrottledCallback}from'../../shared/utils/misc.mjs';import{SIZES}from'./sizes.mjs';import{Root,TextareaMimic,Textarea as Textarea$1,ResizeGlobals,ResizeIcon}from'./style.mjs';import{jsx,jsxs,Fragment}from'react/jsx-runtime';import{FormInputLabel}from'../FormInputLabel/FormInputLabel.mjs';import{InputLabel}from'../InputLabel/InputLabel.mjs';import{SIZES as SIZES$1}from'../FormInput/sizes.mjs';import{ResizeHandle}from'../../icon-pack/src/icons/ResizeHandle/index.mjs';const COMPONENT_NAME='Textarea';const Textarea=withMergedProps(forwardRef(((e,r)=>{const o=useTheme();const{size:t="m",rows:a=2,maxRows:n=30,labelPosition:i="dynamic",primary:s=!0,width:m=o.defaultInputControlsWidth,autosize:l=!0,rounded:g=!0,color:c="mineShaft",placeholderColor:d="silver",autoRows:u,resize:h,contrast:p,inline:f,secondary:S,success:X,error:b,sizeXXS:L,sizeXS:z,sizeS:w,sizeM:R,sizeL:M,sizeXL:T,sizes:C,sizeUnits:x,margin:v,marginXXS:j,marginXS:I,marginS:y,marginM:B,marginL:E,marginXL:N,marginTop:k,marginTopXXS:D,marginTopXS:F,marginTopS:H,marginTopM:P,marginTopL:Z,marginTopXL:O,marginRight:$,marginRightXXS:A,marginRightXS:G,marginRightS:U,marginRightM:_,marginRightL:K,marginRightXL:V,marginBottom:W,marginBottomXXS:q,marginBottomXS:J,marginBottomS:Q,marginBottomM:Y,marginBottomL:ee,marginBottomXL:re,marginLeft:oe,marginLeftXXS:te,marginLeftXS:ae,marginLeftS:ne,marginLeftM:ie,marginLeftL:se,marginLeftXL:me,widthXXS:le,widthXS:ge,widthS:ce,widthM:de,widthL:ue,widthXL:he,preset:pe,palette:fe,label:Se,fluid:Xe,className:be,style:Le,disabled:ze,...we}=e;const Re={size:t,sizeXXS:L,sizeXS:z,sizeS:w,sizeM:R,sizeL:M,sizeXL:T};const Me=useRef(null);const Te=useRef(null);const Ce=useRef(null);useImperativeHandle(r,(()=>Me.current),[]);const[xe,ve,je]=useResizable({target:Ce,direction:h});const Ie=useMemo((()=>nanoid()),[]);const[ye,Be]=useState((()=>{const e=we.value??we.defaultValue;return typeof e=='string'&&e.length>0}));const[Ee,Ne]=useState((()=>Math.min(a,n)));const ke=pe==='brand'&&u||pe!=='brand'&&l?Ee:Math.min(a,n);const De=h==='horizontal'?'ew-resize':h==='vertical'?'ns-resize':'nwse-resize';const Fe=useCallback((()=>{if(!Me.current)return;if(pe==='brand'){if(!Te.current)return;Te.current.value=Me.current.value;const e=Math.max(Math.round(Te.current.scrollHeight/Te.current.clientHeight),a);return void Ne(Math.min(e,n))}const e=getComputedStyle(Me.current);const r=parseFloat(e.lineHeight);const o=Math.max(Math.round((Me.current.scrollHeight-parseFloat(e.paddingTop)-parseFloat(e.paddingBottom))/(Number.isNaN(r)?parseFloat(e.fontSize)*1.2:r)),a);Ne((e=>o>e?Math.min(o,n):Me.current&&!Me.current.value?a:e))}),[pe,a,n]);return useLayoutEffect((()=>{pe==='brand'&&typeof we.value=='string'&&Me.current&&Me.current!==document.activeElement&&Be(we.value.length>0)}),[pe,we.value]),useEffect((()=>{const e=createThrottledCallback(Fe,200);return(pe==='brand'&&u||pe!=='brand'&&l)&&(Fe(),window.addEventListener('resize',e)),()=>{window.removeEventListener('resize',e)}}),[pe,u,l,Fe]),pe!=='brand'?jsx(Root,{...we,ref:Me,className:be,style:Le,onChange:e=>{l&&Fe(),we.onChange&&we.onChange(e)},rows:ke,color:c,rounded:g,placeholderColor:d,disabled:ze,error:b,fluid:Xe,width:m,widthXXS:le,widthXS:ge,widthS:ce,widthM:de,widthL:ue,widthXL:he}):jsx(FormInputLabel,{...Re,ref:Ce,sizes:C,sizeUnits:x,margin:v,marginXXS:j,marginXS:I,marginS:y,marginM:B,marginL:E,marginXL:N,marginTop:k,marginTopXXS:D,marginTopXS:F,marginTopS:H,marginTopM:P,marginTopL:Z,marginTopXL:O,marginRight:$,marginRightXXS:A,marginRightXS:G,marginRightS:U,marginRightM:_,marginRightL:K,marginRightXL:V,marginBottom:W,marginBottomXXS:q,marginBottomXS:J,marginBottomS:Q,marginBottomM:Y,marginBottomL:ee,marginBottomXL:re,marginLeft:oe,marginLeftXXS:te,marginLeftXS:ae,marginLeftS:ne,marginLeftM:ie,marginLeftL:se,marginLeftXL:me,className:be,style:Le,contrast:p,error:b,inline:f,disabled:ze,primary:s,secondary:S,success:X,palette:{color:ze?fe.colorDisabled:fe.color,backgroundColor:ze?fe.backgroundColorDisabled:fe.backgroundColor,backgroundColorHover:ze?fe.backgroundColorDisabled:fe.backgroundColorHover,borderColor:ze?fe.borderColorDisabled:fe.borderColor},onClick:()=>{Me.current&&Me.current.focus()},onFocus:()=>{Be(!0)},onPointerDown:e=>{e.target!==Me.current&&e.target instanceof Node&&e.preventDefault()},onBlur:e=>{Me.current&&!e.currentTarget.contains(e.relatedTarget)&&Be(Boolean(Me.current.value))},overflow:"hidden",input:jsxs(InputLabel,{...Re,sizes:SIZES$1,active:ye,label:Se,labelId:Ie,labelPosition:i,children:[u?jsx(TextareaMimic,{ref:Te,rows:1}):null,jsx(Textarea$1,{...we,ref:Me,"aria-labelledby":Se?Ie:void 0,disabled:ze,onChange:e=>{u&&Fe(),we.onChange&&we.onChange(e)},rows:ke,palette:{color:fe.color,colorDisabled:fe.colorDisabled,placeholderColor:fe.placeholderColor,placeholderColorDisabled:fe.placeholderColorDisabled}})]}),addon:h?jsxs(Fragment,{children:[xe?jsx(ResizeGlobals,{cursor:De}):null,jsx(ResizeIcon,{size:"l",icon:jsx(ResizeHandle,{}),color:"border-onmain-default-small",tabIndex:0,onPointerDown:ve,onKeyDown:je,cursor:De})]}):void 0})})),{displayName:"Textarea",sizes:SIZES});export{COMPONENT_NAME,Textarea};
|
|
2
2
|
//# sourceMappingURL=Textarea.mjs.map
|