@laerdal/life-react-components 5.0.0-dev.1 → 5.0.0-dev.2
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/dist/Accordion/AccordionItem.cjs +1 -1
- package/dist/Accordion/AccordionItem.cjs.map +1 -1
- package/dist/Accordion/AccordionItem.js +1 -1
- package/dist/Accordion/AccordionItem.js.map +1 -1
- package/dist/Accordion/styles.cjs +3 -3
- package/dist/Accordion/styles.cjs.map +1 -1
- package/dist/Accordion/styles.d.ts +1 -1
- package/dist/Accordion/styles.js +3 -3
- package/dist/Accordion/styles.js.map +1 -1
- package/dist/AuthPage/AuthPage.cjs +1 -1
- package/dist/AuthPage/AuthPage.cjs.map +1 -1
- package/dist/AuthPage/AuthPage.js +1 -1
- package/dist/AuthPage/AuthPage.js.map +1 -1
- package/dist/AuthPage/ScreenSetsContainer.cjs +1 -1
- package/dist/AuthPage/ScreenSetsContainer.cjs.map +1 -1
- package/dist/AuthPage/ScreenSetsContainer.d.ts +1 -1
- package/dist/AuthPage/ScreenSetsContainer.js +1 -1
- package/dist/AuthPage/ScreenSetsContainer.js.map +1 -1
- package/dist/Banners/Banner.cjs +8 -8
- package/dist/Banners/Banner.cjs.map +1 -1
- package/dist/Banners/Banner.d.ts +8 -2
- package/dist/Banners/Banner.js +8 -8
- package/dist/Banners/Banner.js.map +1 -1
- package/dist/Banners/OverviewBanner.d.ts +4 -4
- package/dist/Breadcrumb/Breadcrumb.cjs +2 -2
- package/dist/Breadcrumb/Breadcrumb.cjs.map +1 -1
- package/dist/Breadcrumb/Breadcrumb.js +2 -2
- package/dist/Breadcrumb/Breadcrumb.js.map +1 -1
- package/dist/Breadcrumb/styles.cjs +5 -5
- package/dist/Breadcrumb/styles.cjs.map +1 -1
- package/dist/Breadcrumb/styles.d.ts +2 -2
- package/dist/Breadcrumb/styles.js +5 -5
- package/dist/Breadcrumb/styles.js.map +1 -1
- package/dist/Button/BackButton.cjs +2 -2
- package/dist/Button/BackButton.cjs.map +1 -1
- package/dist/Button/BackButton.js +2 -2
- package/dist/Button/BackButton.js.map +1 -1
- package/dist/Button/Button.cjs +1 -1
- package/dist/Button/Button.cjs.map +1 -1
- package/dist/Button/Button.js +1 -1
- package/dist/Button/Button.js.map +1 -1
- package/dist/Button/DualFunctionButton.cjs +5 -5
- package/dist/Button/DualFunctionButton.cjs.map +1 -1
- package/dist/Button/DualFunctionButton.js +5 -5
- package/dist/Button/DualFunctionButton.js.map +1 -1
- package/dist/Button/Iconbutton.cjs +25 -23
- package/dist/Button/Iconbutton.cjs.map +1 -1
- package/dist/Button/Iconbutton.d.ts +24 -3
- package/dist/Button/Iconbutton.js +25 -23
- package/dist/Button/Iconbutton.js.map +1 -1
- package/dist/Card/VerticalCard/CardBottomSection.cjs +2 -2
- package/dist/Card/VerticalCard/CardBottomSection.cjs.map +1 -1
- package/dist/Card/VerticalCard/CardBottomSection.d.ts +1 -1
- package/dist/Card/VerticalCard/CardBottomSection.js +2 -2
- package/dist/Card/VerticalCard/CardBottomSection.js.map +1 -1
- package/dist/Card/VerticalCard/CardMiddleSection.cjs +2 -2
- package/dist/Card/VerticalCard/CardMiddleSection.cjs.map +1 -1
- package/dist/Card/VerticalCard/CardMiddleSection.d.ts +2 -2
- package/dist/Card/VerticalCard/CardMiddleSection.js +2 -2
- package/dist/Card/VerticalCard/CardMiddleSection.js.map +1 -1
- package/dist/Dropdown/BasicDropdown.cjs +9 -9
- package/dist/Dropdown/BasicDropdown.cjs.map +1 -1
- package/dist/Dropdown/BasicDropdown.js +9 -9
- package/dist/Dropdown/BasicDropdown.js.map +1 -1
- package/dist/Dropdown/CommonStyling.cjs +10 -10
- package/dist/Dropdown/CommonStyling.cjs.map +1 -1
- package/dist/Dropdown/CommonStyling.d.ts +9 -9
- package/dist/Dropdown/CommonStyling.js +10 -10
- package/dist/Dropdown/CommonStyling.js.map +1 -1
- package/dist/Dropdown/DropdownContent.cjs +41 -41
- package/dist/Dropdown/DropdownContent.cjs.map +1 -1
- package/dist/Dropdown/DropdownContent.d.ts +12 -12
- package/dist/Dropdown/DropdownContent.js +41 -41
- package/dist/Dropdown/DropdownContent.js.map +1 -1
- package/dist/Dropdown/DropdownFilter.cjs +8 -8
- package/dist/Dropdown/DropdownFilter.cjs.map +1 -1
- package/dist/Dropdown/DropdownFilter.js +8 -8
- package/dist/Dropdown/DropdownFilter.js.map +1 -1
- package/dist/Footer/Components/FooterDropdownLinks.cjs +3 -3
- package/dist/Footer/Components/FooterDropdownLinks.cjs.map +1 -1
- package/dist/Footer/Components/FooterDropdownLinks.js +3 -3
- package/dist/Footer/Components/FooterDropdownLinks.js.map +1 -1
- package/dist/Footer/Components/FooterNavSection.cjs +2 -2
- package/dist/Footer/Components/FooterNavSection.cjs.map +1 -1
- package/dist/Footer/Components/FooterNavSection.js +2 -2
- package/dist/Footer/Components/FooterNavSection.js.map +1 -1
- package/dist/Footer/SiteFooter.cjs +3 -3
- package/dist/Footer/SiteFooter.cjs.map +1 -1
- package/dist/Footer/SiteFooter.js +3 -3
- package/dist/Footer/SiteFooter.js.map +1 -1
- package/dist/GlobalNavigationBar/GlobalNavigationBar.cjs +5 -5
- package/dist/GlobalNavigationBar/GlobalNavigationBar.cjs.map +1 -1
- package/dist/GlobalNavigationBar/GlobalNavigationBar.js +5 -5
- package/dist/GlobalNavigationBar/GlobalNavigationBar.js.map +1 -1
- package/dist/GlobalNavigationBar/Logo.cjs +4 -4
- package/dist/GlobalNavigationBar/Logo.cjs.map +1 -1
- package/dist/GlobalNavigationBar/Logo.js +4 -4
- package/dist/GlobalNavigationBar/Logo.js.map +1 -1
- package/dist/GlobalNavigationBar/desktop/MainMenu.cjs +2 -13
- package/dist/GlobalNavigationBar/desktop/MainMenu.cjs.map +1 -1
- package/dist/GlobalNavigationBar/desktop/MainMenu.js +2 -13
- package/dist/GlobalNavigationBar/desktop/MainMenu.js.map +1 -1
- package/dist/GlobalNavigationBar/desktop/SubMenu.cjs +5 -5
- package/dist/GlobalNavigationBar/desktop/SubMenu.cjs.map +1 -1
- package/dist/GlobalNavigationBar/desktop/SubMenu.d.ts +2 -2
- package/dist/GlobalNavigationBar/desktop/SubMenu.js +5 -5
- package/dist/GlobalNavigationBar/desktop/SubMenu.js.map +1 -1
- package/dist/HyperLink/HyperLink.cjs +3 -3
- package/dist/HyperLink/HyperLink.cjs.map +1 -1
- package/dist/HyperLink/HyperLink.d.ts +2 -2
- package/dist/HyperLink/HyperLink.js +3 -3
- package/dist/HyperLink/HyperLink.js.map +1 -1
- package/dist/InputFields/Checkbox.cjs +4 -4
- package/dist/InputFields/Checkbox.cjs.map +1 -1
- package/dist/InputFields/Checkbox.d.ts +3 -3
- package/dist/InputFields/Checkbox.js +4 -4
- package/dist/InputFields/Checkbox.js.map +1 -1
- package/dist/InputFields/DatepickerField.cjs +9 -9
- package/dist/InputFields/DatepickerField.cjs.map +1 -1
- package/dist/InputFields/DatepickerField.js +9 -9
- package/dist/InputFields/DatepickerField.js.map +1 -1
- package/dist/InputFields/Label.cjs +2 -2
- package/dist/InputFields/Label.cjs.map +1 -1
- package/dist/InputFields/Label.js +2 -2
- package/dist/InputFields/Label.js.map +1 -1
- package/dist/InputFields/NumberField.cjs +24 -24
- package/dist/InputFields/NumberField.cjs.map +1 -1
- package/dist/InputFields/NumberField.js +24 -24
- package/dist/InputFields/NumberField.js.map +1 -1
- package/dist/InputFields/PasswordField.cjs +4 -4
- package/dist/InputFields/PasswordField.cjs.map +1 -1
- package/dist/InputFields/PasswordField.js +4 -4
- package/dist/InputFields/PasswordField.js.map +1 -1
- package/dist/InputFields/SearchBar.cjs +2 -2
- package/dist/InputFields/SearchBar.cjs.map +1 -1
- package/dist/InputFields/SearchBar.js +2 -2
- package/dist/InputFields/SearchBar.js.map +1 -1
- package/dist/InputFields/TextField.cjs +5 -5
- package/dist/InputFields/TextField.cjs.map +1 -1
- package/dist/InputFields/TextField.js +5 -5
- package/dist/InputFields/TextField.js.map +1 -1
- package/dist/InputFields/Textarea.cjs +3 -3
- package/dist/InputFields/Textarea.cjs.map +1 -1
- package/dist/InputFields/Textarea.js +3 -3
- package/dist/InputFields/Textarea.js.map +1 -1
- package/dist/InputFields/components/SearchField.cjs.map +1 -1
- package/dist/InputFields/components/SearchField.d.ts +1 -1
- package/dist/InputFields/components/SearchField.js.map +1 -1
- package/dist/InputFields/styling.cjs +7 -7
- package/dist/InputFields/styling.cjs.map +1 -1
- package/dist/InputFields/styling.d.ts +9 -9
- package/dist/InputFields/styling.js +7 -7
- package/dist/InputFields/styling.js.map +1 -1
- package/dist/Layouts/index.cjs +11 -11
- package/dist/Layouts/index.cjs.map +1 -1
- package/dist/Layouts/index.d.ts +6 -6
- package/dist/Layouts/index.js +11 -11
- package/dist/Layouts/index.js.map +1 -1
- package/dist/LoadingPage/GlobalLoadingPage.cjs.map +1 -1
- package/dist/LoadingPage/GlobalLoadingPage.js.map +1 -1
- package/dist/MenuItem/MenuItem.cjs +8 -8
- package/dist/MenuItem/MenuItem.cjs.map +1 -1
- package/dist/MenuItem/MenuItem.d.ts +2 -2
- package/dist/MenuItem/MenuItem.js +8 -8
- package/dist/MenuItem/MenuItem.js.map +1 -1
- package/dist/Modals/ModalDialog.cjs +11 -11
- package/dist/Modals/ModalDialog.cjs.map +1 -1
- package/dist/Modals/ModalDialog.js +11 -11
- package/dist/Modals/ModalDialog.js.map +1 -1
- package/dist/Modals/ModalNote.cjs +8 -8
- package/dist/Modals/ModalNote.cjs.map +1 -1
- package/dist/Modals/ModalNote.js +8 -8
- package/dist/Modals/ModalNote.js.map +1 -1
- package/dist/Modals/ModalStyles.cjs +19 -19
- package/dist/Modals/ModalStyles.cjs.map +1 -1
- package/dist/Modals/ModalStyles.d.ts +17 -17
- package/dist/Modals/ModalStyles.js +19 -19
- package/dist/Modals/ModalStyles.js.map +1 -1
- package/dist/NotificationDot/NotificationDot.cjs +11 -12
- package/dist/NotificationDot/NotificationDot.cjs.map +1 -1
- package/dist/NotificationDot/NotificationDot.js +11 -12
- package/dist/NotificationDot/NotificationDot.js.map +1 -1
- package/dist/Popover/Popover.cjs +40 -40
- package/dist/Popover/Popover.cjs.map +1 -1
- package/dist/Popover/Popover.d.ts +9 -9
- package/dist/Popover/Popover.js +40 -40
- package/dist/Popover/Popover.js.map +1 -1
- package/dist/QuizButton/QuizButton.cjs +14 -14
- package/dist/QuizButton/QuizButton.cjs.map +1 -1
- package/dist/QuizButton/QuizButton.js +14 -14
- package/dist/QuizButton/QuizButton.js.map +1 -1
- package/dist/Table/Table.cjs +1 -1
- package/dist/Table/Table.cjs.map +1 -1
- package/dist/Table/Table.js +1 -1
- package/dist/Table/Table.js.map +1 -1
- package/dist/Table/TableBody.cjs +2 -2
- package/dist/Table/TableBody.cjs.map +1 -1
- package/dist/Table/TableBody.js +2 -2
- package/dist/Table/TableBody.js.map +1 -1
- package/dist/Table/TableStyles.cjs +4 -4
- package/dist/Table/TableStyles.cjs.map +1 -1
- package/dist/Table/TableStyles.d.ts +3 -3
- package/dist/Table/TableStyles.js +4 -4
- package/dist/Table/TableStyles.js.map +1 -1
- package/dist/Tabs/TabLink.cjs +3 -3
- package/dist/Tabs/TabLink.cjs.map +1 -1
- package/dist/Tabs/TabLink.js +3 -3
- package/dist/Tabs/TabLink.js.map +1 -1
- package/dist/Tabs/Tabs.cjs.map +1 -1
- package/dist/Tabs/Tabs.js.map +1 -1
- package/dist/Tag/Tag.cjs +6 -6
- package/dist/Tag/Tag.cjs.map +1 -1
- package/dist/Tag/Tag.js +6 -6
- package/dist/Tag/Tag.js.map +1 -1
- package/dist/Toasters/Toast.cjs +16 -16
- package/dist/Toasters/Toast.cjs.map +1 -1
- package/dist/Toasters/Toast.d.ts +6 -7
- package/dist/Toasters/Toast.js +16 -16
- package/dist/Toasters/Toast.js.map +1 -1
- package/dist/Toggles/ToggleSwitch.cjs +1 -1
- package/dist/Toggles/ToggleSwitch.cjs.map +1 -1
- package/dist/Toggles/ToggleSwitch.js +1 -1
- package/dist/Toggles/ToggleSwitch.js.map +1 -1
- package/dist/Toggles/TogglerStyles.cjs.map +1 -1
- package/dist/Toggles/TogglerStyles.d.ts +1 -1
- package/dist/Toggles/TogglerStyles.js.map +1 -1
- package/dist/Tooltips/TooltipOverflow.cjs +7 -7
- package/dist/Tooltips/TooltipOverflow.cjs.map +1 -1
- package/dist/Tooltips/TooltipOverflow.js +7 -7
- package/dist/Tooltips/TooltipOverflow.js.map +1 -1
- package/dist/Tooltips/TooltipStyles.cjs +29 -29
- package/dist/Tooltips/TooltipStyles.cjs.map +1 -1
- package/dist/Tooltips/TooltipStyles.d.ts +9 -9
- package/dist/Tooltips/TooltipStyles.js +29 -29
- package/dist/Tooltips/TooltipStyles.js.map +1 -1
- package/dist/Tooltips/TooltipWrapper.cjs +7 -7
- package/dist/Tooltips/TooltipWrapper.cjs.map +1 -1
- package/dist/Tooltips/TooltipWrapper.js +7 -7
- package/dist/Tooltips/TooltipWrapper.js.map +1 -1
- package/package.json +1 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Popover.js","names":["React","styled","useTheme","COLORS","ComponentTextStyle","ComponentXSStyling","Button","IconButton","SystemIcons","BOXSHADOWS","ComponentLStyling","ComponentMStyling","ComponentSStyling","ComponentXXSStyling","scrollBarStyling","Z_INDEXES","Position","Size","jsx","_jsx","jsxs","_jsxs","PopoverContainer","div","_templateObject","_taggedTemplateLiteral","props","size","Small","Large","getColor","theme","BOXSHADOW_CENTERED","popover","position","Bottom","Top","Left","Right","showArrowPointer","renderArrowStyles","PopoverTopSectionContainer","_templateObject2","PopoverMiddleSectionContainer","_templateObject3","PopoverBottomSectionContainer","_templateObject4","TextContainer","_templateObject5","renderMargins","note","NoteContainer","_templateObject6","Regular","LabelContainer","_templateObject7","Bold","CloseButtonContainer","_templateObject8","TextButtonContainer","_templateObject9","IconButtonContainer","_templateObject10","PopoverWrapper","_templateObject11","showOnClick","concat","showPopover","isNotePresent","Popover","_ref","_bottomSectionProps$t","_bottomSectionProps$i","_ref$size","Medium","topSectionProps","bottomSectionProps","mainContent","children","_ref$showOnClick","_ref$showArrowPointer","_React$useState","useState","_React$useState2","_slicedToArray","setShowPopover","popoverRef","useRef","useEffect","checkIfClickedOutside","e","current","contains","target","document","addEventListener","removeEventListener","ref","text","action","useTransparentBackground","iconColor","variant","shape","Close","textButton","icon","onClick","label","className","iconButtons","map","iconButton","propTypes","_pt","string","isRequired","arrayOf","node","func","bool"],"sources":["../../src/Popover/Popover.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport styled, { useTheme } from 'styled-components';\r\nimport { COLORS, ComponentTextStyle, ComponentXSStyling } from '..';\r\nimport { Button, IconButton } from '../Button';\r\nimport { SystemIcons } from '../icons';\r\nimport { BOXSHADOWS, ComponentLStyling, ComponentMStyling, ComponentSStyling, ComponentXXSStyling, scrollBarStyling, Z_INDEXES } from '../styles';\r\nimport { Position, Size } from '../types';\r\n\r\nexport const PopoverContainer = styled.div<{ size: Size; position: Position; showArrowPointer: boolean }>`\r\n //height: ${(props) => (props.size === Size.Small ? '240px' : props.size === Size.Large ? '480px' : '360px')};\r\n min-width: ${(props) => (props.size === Size.Small ? '320px' : props.size === Size.Large ? '640px' : '480px')};\r\n border-radius: 4px;\r\n background: ${props => COLORS.getColor('white', props.theme)};\r\n cursor: default;\r\n box-shadow: ${BOXSHADOWS.BOXSHADOW_CENTERED};\r\n\r\n position: absolute; \r\n visibility: hidden;\r\n opacity: 0;\r\n z-index: ${Z_INDEXES.popover};\r\n\r\n ${(props) => (props.position == Position.Bottom ? 'right: 50%; top: calc(100% + 16px); transform: translateX(50%);' : '')}\r\n ${(props) => (props.position == Position.Top ? 'right: 50%; bottom: calc(100% + 16px); transform: translateX(50%);' : '')}\r\n\r\n ${(props) => (props.position == Position.Left ? 'bottom: 50%; right: calc(100% + 16px); transform: translateY(50%);' : '')}\r\n ${(props) => (props.position == Position.Right ? 'bottom: 50%; left: calc(100% + 16px); transform: translateY(50%);' : '')}\r\n\r\n &::after {\r\n ${(props) => (props.showArrowPointer ? renderArrowStyles(props.position) : '')}\r\n`;\r\n\r\nexport const PopoverTopSectionContainer = styled.div<{ size: Size }>`\r\n height: ${(props) => (props.size === Size.Small ? '56px' : props.size === Size.Large ? '72px' : '64px')};\r\n display: flex;\r\n`;\r\n\r\nexport const PopoverMiddleSectionContainer = styled.div<{ size: Size }>`\r\n margin: 8px;\r\n height: ${(props) => (props.size === Size.Small ? '104px' : props.size === Size.Large ? '304px' : '208px')};\r\n padding: ${(props) => (props.size === Size.Small ? '0 8px' : props.size === Size.Large ? '0 16px' : '0 12px')};\r\n overflow-y: auto;\r\n ${scrollBarStyling(Size.Small)}\r\n`;\r\n\r\nexport const PopoverBottomSectionContainer = styled.div<{ size: Size }>`\r\n height: ${(props) => (props.size === Size.Small ? '64px' : props.size === Size.Large ? '88px' : '72px')}; \r\n display: flex;\r\n\r\n .bottom-flex {\r\n flex: 1;\r\n }\r\n`;\r\n\r\nconst TextContainer = styled.div<{ note: boolean; size: Size }>`\r\n display: flex;\r\n flex-direction: column;\r\n margin: ${(props) => renderMargins(props.note, props.size)};\r\n flex-grow: 1;\r\n`;\r\n\r\nconst NoteContainer = styled.div<{ size: Size }>`\r\n ${(props) =>\r\n props.size === Size.Small\r\n ? ComponentXXSStyling(ComponentTextStyle.Regular, COLORS.getColor('neutral_600', props.theme))\r\n : props.size === Size.Large\r\n ? ComponentSStyling(ComponentTextStyle.Regular, COLORS.getColor('neutral_600', props.theme))\r\n : ComponentXSStyling(ComponentTextStyle.Regular, COLORS.getColor('neutral_600', props.theme))}\r\n`;\r\n\r\nconst LabelContainer = styled.div<{ size: Size }>`\r\n ${(props) =>\r\n props.size === Size.Small\r\n ? ComponentSStyling(ComponentTextStyle.Bold, null)\r\n : props.size === Size.Large\r\n ? ComponentLStyling(ComponentTextStyle.Bold, null)\r\n : ComponentMStyling(ComponentTextStyle.Bold, null)}\r\n`;\r\n\r\nconst CloseButtonContainer = styled.div<{ size: Size }>`\r\n margin: ${(props) => (props.size === Size.Small ? '4px 16px 4px 0' : props.size === Size.Large ? '12px 24px 12px 0' : '8px 20px 8px 0')};\r\n`;\r\n\r\nconst TextButtonContainer = styled.div<{ size: Size }>`\r\n margin: ${(props) => (props.size === Size.Small ? '8px 0 8px 16px' : props.size === Size.Large ? '16px 0 16px 24px' : '12px 0 12px 20px')};\r\n`;\r\n\r\nconst IconButtonContainer = styled.div<{ size: Size }>`\r\n margin: ${(props) => (props.size === Size.Small ? '8px 16px 8px 0' : props.size === Size.Large ? '16px 24px 16px 0' : '12px 20px 12px 0')};\r\n display: flex;\r\n`;\r\n\r\nexport const PopoverWrapper = styled.div<{ position: Position; showOnClick: boolean; showPopover: boolean }>`\r\n position: relative;\r\n\r\n .pointer-space {\r\n height: ${(props) => (props.position === Position.Top || props.position === Position.Bottom ? '16px' : '100%')};\r\n width: ${(props) => (props.position === Position.Left || props.position === Position.Right ? '16px' : '100%')};\r\n position: absolute;\r\n\r\n ${(props) => (props.position === Position.Left ? 'right:100%; bottom: 0%' : '')};\r\n ${(props) => (props.position === Position.Right ? 'left:100%; bottom: 0%' : '')};\r\n\r\n ${(props) => (props.position === Position.Top ? 'bottom: 100%' : '')};\r\n ${(props) => (props.position === Position.Bottom ? 'top: 100%' : '')};\r\n }\r\n\r\n ${(props) =>\r\n props.showOnClick\r\n ? `${PopoverContainer} {\r\n visibility: ${props.showPopover ? 'visible' : 'hidden'};\r\n opacity: ${props.showPopover ? '1' : '0'};\r\n }\r\n cursor: pointer;`\r\n : `&:hover {\r\n ${PopoverContainer} {\r\n visibility: visible;\r\n opacity: 1;\r\n }\r\n }`}\r\n`;\r\n\r\nconst renderMargins = (isNotePresent: boolean, size: Size): string => {\r\n if (isNotePresent) {\r\n return size === Size.Small ? '10px 16px' : size === Size.Large ? '14px 24px' : '12px 20px';\r\n } else {\r\n return size === Size.Small ? '18px 16px' : size === Size.Large ? '24px' : '20px';\r\n }\r\n};\r\n\r\nconst renderArrowStyles = (position: Position) => {\r\n if (position === Position.Bottom) {\r\n return `height: 0px;\r\n width: 0px;\r\n border-top: 16px solid transparent;\r\n border-right: 12px solid transparent;\r\n border-bottom: 16px solid rgb(255,255,255);\r\n border-left: 12px solid transparent;\r\n content: \"\";\r\n position: absolute;\r\n right: calc(50% - 12px);\r\n bottom: calc(100% - 1px);`;\r\n }\r\n\r\n if (position === Position.Top) {\r\n return `height: 0px;\r\n width: 0px;\r\n border-top: 16px solid rgb(255,255,255);\r\n border-right: 12px solid transparent;\r\n border-bottom: 16px solid transparent;\r\n border-left: 12px solid transparent;\r\n content: \"\";\r\n position: absolute;\r\n right: calc(50% - 12px);\r\n top: calc(100% - 1px);`;\r\n }\r\n\r\n if (position === Position.Left) {\r\n return `height: 0px;\r\n width: 0px;\r\n border-top: 12px solid transparent;\r\n border-right: 16px solid transparent;\r\n border-bottom: 12px solid transparent;\r\n border-left: 16px solid rgb(255,255,255);\r\n content: \"\";\r\n position: absolute;\r\n left: calc(100% - 1px);\r\n bottom: calc(50% - 12px);`;\r\n }\r\n\r\n if (position === Position.Right) {\r\n return `height: 0px;\r\n width: 0px;\r\n border-top: 12px solid transparent;\r\n border-right: 16px solid rgb(255,255,255);\r\n border-bottom: 12px solid transparent;\r\n border-left: 16px solid transparent;\r\n content: \"\";\r\n position: absolute;\r\n right: calc(100% - 1px);\r\n bottom: calc(50% - 12px);`;\r\n }\r\n};\r\n\r\nexport interface PopoverTopSectionProps {\r\n /**\r\n * Required. The main text to be displayed in the top section of the popover.\r\n */\r\n text: string;\r\n\r\n /**\r\n * Optional. A note to be displayed below the main text in the top section of the popover.\r\n */\r\n note?: string;\r\n};\r\n\r\nexport interface PopoverActionButtonProps {\r\n /**\r\n * Required. The icon to be displayed on the button.\r\n */\r\n icon: React.ReactNode;\r\n\r\n /**\r\n * Required. The handler function to be called when the button is clicked.\r\n */\r\n action: () => void;\r\n\r\n /**\r\n * Optional. The label for the button. If provided, the button will display this text.\r\n */\r\n label?: string;\r\n};\r\n\r\nexport interface PopoverBottomSectionProps {\r\n /**\r\n * Optional. An array of PopoverActionButtonProps objects.\r\n * Each object represents an icon button to be displayed in the bottom section of the popover.\r\n */\r\n iconButtons?: PopoverActionButtonProps[];\r\n\r\n /**\r\n * Optional. A PopoverActionButtonProps object representing a text button to be displayed in the bottom section of the popover.\r\n */\r\n textButton?: PopoverActionButtonProps;\r\n};\r\n\r\nexport interface PopoverProps {\r\n /**\r\n * Optional. The size of the popover. It can be 'Small', 'Medium', or 'Large'.\r\n * Defaults to 'Medium' if not specified.\r\n */\r\n size?: Size.Small | Size.Medium | Size.Large;\r\n\r\n /**\r\n * Optional. Properties for the top section of the popover.\r\n */\r\n topSectionProps?: PopoverTopSectionProps;\r\n\r\n /**\r\n * Optional. Properties for the bottom section of the popover.\r\n */\r\n bottomSectionProps?: PopoverBottomSectionProps;\r\n\r\n /**\r\n * Required. The main content to be displayed in the popover.\r\n */\r\n mainContent: React.ReactNode;\r\n\r\n /**\r\n * Required. The children to be rendered inside the popover.\r\n */\r\n children: React.ReactNode;\r\n\r\n /**\r\n * Required. The position of the popover relative to the target element.\r\n * It can be 'Top', 'Bottom', 'Right', or 'Left'.\r\n */\r\n position: Position.Top | Position.Bottom | Position.Right | Position.Left;\r\n\r\n /**\r\n * Required. A boolean indicating whether the popover should be shown when the target element is clicked. Defaults to 'false', meaning that popover will be shown on mouse hover.\r\n */\r\n showOnClick: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether an arrow pointer should be shown on the popover.\r\n * Defaults to 'false' if not specified.\r\n */\r\n showArrowPointer?: boolean;\r\n};\r\n\r\nconst Popover: React.FunctionComponent<PopoverProps> = ({\r\n size = Size.Medium,\r\n topSectionProps,\r\n bottomSectionProps,\r\n mainContent,\r\n children,\r\n position,\r\n showOnClick = false,\r\n showArrowPointer = false,\r\n}) => {\r\n const [showPopover, setShowPopover] = React.useState(false);\r\n const theme = useTheme();\r\n const popoverRef = React.useRef<any>();\r\n\r\n React.useEffect(() => {\r\n const checkIfClickedOutside = (e: { target: any }) => {\r\n if (showPopover && popoverRef.current && !popoverRef.current.contains(e.target)) {\r\n setShowPopover(false);\r\n }\r\n };\r\n\r\n document.addEventListener('mousedown', checkIfClickedOutside);\r\n\r\n return () => {\r\n document.removeEventListener('mousedown', checkIfClickedOutside);\r\n };\r\n }, [showPopover]);\r\n\r\n return (\r\n <PopoverWrapper position={position} showOnClick={showOnClick} showPopover={showPopover}>\r\n <PopoverContainer size={size} position={position} ref={popoverRef} showArrowPointer={showArrowPointer}>\r\n {!!topSectionProps && (\r\n <PopoverTopSectionContainer size={size}>\r\n <TextContainer note={!!topSectionProps?.note} size={size}>\r\n {topSectionProps?.note && <NoteContainer size={size}>{topSectionProps.note}</NoteContainer>}\r\n <LabelContainer size={size}>{topSectionProps?.text}</LabelContainer>\r\n </TextContainer>\r\n\r\n {showOnClick && (\r\n <CloseButtonContainer size={size} data-testid={'closeBtn'}>\r\n <IconButton action={() => setShowPopover(false)} useTransparentBackground iconColor={COLORS.getColor('neutral_600', theme)} variant=\"secondary\" shape=\"circular\">\r\n <SystemIcons.Close />\r\n </IconButton>\r\n </CloseButtonContainer>\r\n )}\r\n </PopoverTopSectionContainer>\r\n )}\r\n\r\n <PopoverMiddleSectionContainer size={size}>{mainContent}</PopoverMiddleSectionContainer>\r\n\r\n {!!bottomSectionProps && (\r\n <PopoverBottomSectionContainer size={size}>\r\n {!!bottomSectionProps?.textButton?.icon && (\r\n <TextButtonContainer size={size} data-testid={'textBtn'}>\r\n <Button size={size} variant=\"secondary\" icon={bottomSectionProps.textButton.icon} onClick={bottomSectionProps.textButton.action}>\r\n {bottomSectionProps.textButton.label}\r\n </Button>\r\n </TextButtonContainer>\r\n )}\r\n\r\n <div className=\"bottom-flex\" />\r\n\r\n <IconButtonContainer size={size} data-testid={'iconBtn'}>\r\n {bottomSectionProps?.iconButtons?.map((iconButton) => (\r\n <IconButton action={iconButton.action} variant=\"secondary\" shape=\"circular\" useTransparentBackground>\r\n {iconButton.icon}\r\n </IconButton>\r\n ))}\r\n </IconButtonContainer>\r\n </PopoverBottomSectionContainer>\r\n )}\r\n </PopoverContainer>\r\n\r\n <div onClick={() => showOnClick && setShowPopover(!showPopover)}>\r\n {children}\r\n\r\n <div className=\"pointer-space\" />\r\n </div>\r\n </PopoverWrapper>\r\n );\r\n};\r\n\r\nexport default Popover;\r\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"Popover.js","names":["React","styled","useTheme","COLORS","ComponentTextStyle","ComponentXSStyling","Button","IconButton","SystemIcons","BOXSHADOWS","ComponentLStyling","ComponentMStyling","ComponentSStyling","ComponentXXSStyling","scrollBarStyling","Z_INDEXES","Position","Size","jsx","_jsx","jsxs","_jsxs","PopoverContainer","div","_templateObject","_taggedTemplateLiteral","props","$size","Small","Large","getColor","theme","BOXSHADOW_CENTERED","popover","$position","Bottom","Top","Left","Right","$showArrowPointer","renderArrowStyles","PopoverTopSectionContainer","_templateObject2","PopoverMiddleSectionContainer","_templateObject3","PopoverBottomSectionContainer","_templateObject4","TextContainer","_templateObject5","renderMargins","$note","NoteContainer","_templateObject6","Regular","LabelContainer","_templateObject7","Bold","CloseButtonContainer","_templateObject8","TextButtonContainer","_templateObject9","IconButtonContainer","_templateObject10","PopoverWrapper","_templateObject11","$showOnClick","concat","$showPopover","isNotePresent","size","position","Popover","_ref","_bottomSectionProps$t","_bottomSectionProps$i","_ref$size","Medium","topSectionProps","bottomSectionProps","mainContent","children","_ref$showOnClick","showOnClick","_ref$showArrowPointer","showArrowPointer","_React$useState","useState","_React$useState2","_slicedToArray","showPopover","setShowPopover","popoverRef","useRef","useEffect","checkIfClickedOutside","e","current","contains","target","document","addEventListener","removeEventListener","ref","note","text","action","useTransparentBackground","iconColor","variant","shape","Close","textButton","icon","onClick","label","className","iconButtons","map","iconButton","propTypes","_pt","string","isRequired","arrayOf","node","func","bool"],"sources":["../../src/Popover/Popover.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport styled, { useTheme } from 'styled-components';\r\nimport { COLORS, ComponentTextStyle, ComponentXSStyling } from '..';\r\nimport { Button, IconButton } from '../Button';\r\nimport { SystemIcons } from '../icons';\r\nimport { BOXSHADOWS, ComponentLStyling, ComponentMStyling, ComponentSStyling, ComponentXXSStyling, scrollBarStyling, Z_INDEXES } from '../styles';\r\nimport { Position, Size } from '../types';\r\n\r\nexport const PopoverContainer = styled.div<{ $size: Size; $position: Position; $showArrowPointer: boolean }>`\r\n //height: ${(props) => (props.$size === Size.Small ? '240px' : props.$size === Size.Large ? '480px' : '360px')};\r\n min-width: ${(props) => (props.$size === Size.Small ? '320px' : props.$size === Size.Large ? '640px' : '480px')};\r\n border-radius: 4px;\r\n background: ${props => COLORS.getColor('white', props.theme)};\r\n cursor: default;\r\n box-shadow: ${BOXSHADOWS.BOXSHADOW_CENTERED};\r\n\r\n position: absolute; \r\n visibility: hidden;\r\n opacity: 0;\r\n z-index: ${Z_INDEXES.popover};\r\n\r\n ${(props) => (props.$position == Position.Bottom ? 'right: 50%; top: calc(100% + 16px); transform: translateX(50%);' : '')}\r\n ${(props) => (props.$position == Position.Top ? 'right: 50%; bottom: calc(100% + 16px); transform: translateX(50%);' : '')}\r\n\r\n ${(props) => (props.$position == Position.Left ? 'bottom: 50%; right: calc(100% + 16px); transform: translateY(50%);' : '')}\r\n ${(props) => (props.$position == Position.Right ? 'bottom: 50%; left: calc(100% + 16px); transform: translateY(50%);' : '')}\r\n\r\n &::after {\r\n ${(props) => (props.$showArrowPointer ? renderArrowStyles(props.$position) : '')}\r\n`;\r\n\r\nexport const PopoverTopSectionContainer = styled.div<{ $size: Size }>`\r\n height: ${(props) => (props.$size === Size.Small ? '56px' : props.$size === Size.Large ? '72px' : '64px')};\r\n display: flex;\r\n`;\r\n\r\nexport const PopoverMiddleSectionContainer = styled.div<{ $size: Size }>`\r\n margin: 8px;\r\n height: ${(props) => (props.$size === Size.Small ? '104px' : props.$size === Size.Large ? '304px' : '208px')};\r\n padding: ${(props) => (props.$size === Size.Small ? '0 8px' : props.$size === Size.Large ? '0 16px' : '0 12px')};\r\n overflow-y: auto;\r\n ${scrollBarStyling(Size.Small)}\r\n`;\r\n\r\nexport const PopoverBottomSectionContainer = styled.div<{ $size: Size }>`\r\n height: ${(props) => (props.$size === Size.Small ? '64px' : props.$size === Size.Large ? '88px' : '72px')}; \r\n display: flex;\r\n\r\n .bottom-flex {\r\n flex: 1;\r\n }\r\n`;\r\n\r\nconst TextContainer = styled.div<{ $note: boolean; $size: Size }>`\r\n display: flex;\r\n flex-direction: column;\r\n margin: ${(props) => renderMargins(props.$note, props.$size)};\r\n flex-grow: 1;\r\n`;\r\n\r\nconst NoteContainer = styled.div<{ $size: Size }>`\r\n ${(props) =>\r\n props.$size === Size.Small\r\n ? ComponentXXSStyling(ComponentTextStyle.Regular, COLORS.getColor('neutral_600', props.theme))\r\n : props.$size === Size.Large\r\n ? ComponentSStyling(ComponentTextStyle.Regular, COLORS.getColor('neutral_600', props.theme))\r\n : ComponentXSStyling(ComponentTextStyle.Regular, COLORS.getColor('neutral_600', props.theme))}\r\n`;\r\n\r\nconst LabelContainer = styled.div<{ $size: Size }>`\r\n ${(props) =>\r\n props.$size === Size.Small\r\n ? ComponentSStyling(ComponentTextStyle.Bold, null)\r\n : props.$size === Size.Large\r\n ? ComponentLStyling(ComponentTextStyle.Bold, null)\r\n : ComponentMStyling(ComponentTextStyle.Bold, null)}\r\n`;\r\n\r\nconst CloseButtonContainer = styled.div<{ $size: Size }>`\r\n margin: ${(props) => (props.$size === Size.Small ? '4px 16px 4px 0' : props.$size === Size.Large ? '12px 24px 12px 0' : '8px 20px 8px 0')};\r\n`;\r\n\r\nconst TextButtonContainer = styled.div<{ $size: Size }>`\r\n margin: ${(props) => (props.$size === Size.Small ? '8px 0 8px 16px' : props.$size === Size.Large ? '16px 0 16px 24px' : '12px 0 12px 20px')};\r\n`;\r\n\r\nconst IconButtonContainer = styled.div<{ $size: Size }>`\r\n margin: ${(props) => (props.$size === Size.Small ? '8px 16px 8px 0' : props.$size === Size.Large ? '16px 24px 16px 0' : '12px 20px 12px 0')};\r\n display: flex;\r\n`;\r\n\r\nexport const PopoverWrapper = styled.div<{ $position: Position; $showOnClick: boolean; $showPopover: boolean }>`\r\n position: relative;\r\n\r\n .pointer-space {\r\n height: ${(props) => (props.$position === Position.Top || props.$position === Position.Bottom ? '16px' : '100%')};\r\n width: ${(props) => (props.$position === Position.Left || props.$position === Position.Right ? '16px' : '100%')};\r\n position: absolute;\r\n\r\n ${(props) => (props.$position === Position.Left ? 'right:100%; bottom: 0%' : '')};\r\n ${(props) => (props.$position === Position.Right ? 'left:100%; bottom: 0%' : '')};\r\n\r\n ${(props) => (props.$position === Position.Top ? 'bottom: 100%' : '')};\r\n ${(props) => (props.$position === Position.Bottom ? 'top: 100%' : '')};\r\n }\r\n\r\n ${(props) =>\r\n props.$showOnClick\r\n ? `${PopoverContainer} {\r\n visibility: ${props.$showPopover ? 'visible' : 'hidden'};\r\n opacity: ${props.$showPopover ? '1' : '0'};\r\n }\r\n cursor: pointer;`\r\n : `&:hover {\r\n ${PopoverContainer} {\r\n visibility: visible;\r\n opacity: 1;\r\n }\r\n }`}\r\n`;\r\n\r\nconst renderMargins = (isNotePresent: boolean, size: Size): string => {\r\n if (isNotePresent) {\r\n return size === Size.Small ? '10px 16px' : size === Size.Large ? '14px 24px' : '12px 20px';\r\n } else {\r\n return size === Size.Small ? '18px 16px' : size === Size.Large ? '24px' : '20px';\r\n }\r\n};\r\n\r\nconst renderArrowStyles = (position: Position) => {\r\n if (position === Position.Bottom) {\r\n return `height: 0px;\r\n width: 0px;\r\n border-top: 16px solid transparent;\r\n border-right: 12px solid transparent;\r\n border-bottom: 16px solid rgb(255,255,255);\r\n border-left: 12px solid transparent;\r\n content: \"\";\r\n position: absolute;\r\n right: calc(50% - 12px);\r\n bottom: calc(100% - 1px);`;\r\n }\r\n\r\n if (position === Position.Top) {\r\n return `height: 0px;\r\n width: 0px;\r\n border-top: 16px solid rgb(255,255,255);\r\n border-right: 12px solid transparent;\r\n border-bottom: 16px solid transparent;\r\n border-left: 12px solid transparent;\r\n content: \"\";\r\n position: absolute;\r\n right: calc(50% - 12px);\r\n top: calc(100% - 1px);`;\r\n }\r\n\r\n if (position === Position.Left) {\r\n return `height: 0px;\r\n width: 0px;\r\n border-top: 12px solid transparent;\r\n border-right: 16px solid transparent;\r\n border-bottom: 12px solid transparent;\r\n border-left: 16px solid rgb(255,255,255);\r\n content: \"\";\r\n position: absolute;\r\n left: calc(100% - 1px);\r\n bottom: calc(50% - 12px);`;\r\n }\r\n\r\n if (position === Position.Right) {\r\n return `height: 0px;\r\n width: 0px;\r\n border-top: 12px solid transparent;\r\n border-right: 16px solid rgb(255,255,255);\r\n border-bottom: 12px solid transparent;\r\n border-left: 16px solid transparent;\r\n content: \"\";\r\n position: absolute;\r\n right: calc(100% - 1px);\r\n bottom: calc(50% - 12px);`;\r\n }\r\n};\r\n\r\nexport interface PopoverTopSectionProps {\r\n /**\r\n * Required. The main text to be displayed in the top section of the popover.\r\n */\r\n text: string;\r\n\r\n /**\r\n * Optional. A note to be displayed below the main text in the top section of the popover.\r\n */\r\n note?: string;\r\n};\r\n\r\nexport interface PopoverActionButtonProps {\r\n /**\r\n * Required. The icon to be displayed on the button.\r\n */\r\n icon: React.ReactNode;\r\n\r\n /**\r\n * Required. The handler function to be called when the button is clicked.\r\n */\r\n action: () => void;\r\n\r\n /**\r\n * Optional. The label for the button. If provided, the button will display this text.\r\n */\r\n label?: string;\r\n};\r\n\r\nexport interface PopoverBottomSectionProps {\r\n /**\r\n * Optional. An array of PopoverActionButtonProps objects.\r\n * Each object represents an icon button to be displayed in the bottom section of the popover.\r\n */\r\n iconButtons?: PopoverActionButtonProps[];\r\n\r\n /**\r\n * Optional. A PopoverActionButtonProps object representing a text button to be displayed in the bottom section of the popover.\r\n */\r\n textButton?: PopoverActionButtonProps;\r\n};\r\n\r\nexport interface PopoverProps {\r\n /**\r\n * Optional. The size of the popover. It can be 'Small', 'Medium', or 'Large'.\r\n * Defaults to 'Medium' if not specified.\r\n */\r\n size?: Size.Small | Size.Medium | Size.Large;\r\n\r\n /**\r\n * Optional. Properties for the top section of the popover.\r\n */\r\n topSectionProps?: PopoverTopSectionProps;\r\n\r\n /**\r\n * Optional. Properties for the bottom section of the popover.\r\n */\r\n bottomSectionProps?: PopoverBottomSectionProps;\r\n\r\n /**\r\n * Required. The main content to be displayed in the popover.\r\n */\r\n mainContent: React.ReactNode;\r\n\r\n /**\r\n * Required. The children to be rendered inside the popover.\r\n */\r\n children: React.ReactNode;\r\n\r\n /**\r\n * Required. The position of the popover relative to the target element.\r\n * It can be 'Top', 'Bottom', 'Right', or 'Left'.\r\n */\r\n position: Position.Top | Position.Bottom | Position.Right | Position.Left;\r\n\r\n /**\r\n * Required. A boolean indicating whether the popover should be shown when the target element is clicked. Defaults to 'false', meaning that popover will be shown on mouse hover.\r\n */\r\n showOnClick: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether an arrow pointer should be shown on the popover.\r\n * Defaults to 'false' if not specified.\r\n */\r\n showArrowPointer?: boolean;\r\n};\r\n\r\nconst Popover: React.FunctionComponent<PopoverProps> = ({\r\n size = Size.Medium,\r\n topSectionProps,\r\n bottomSectionProps,\r\n mainContent,\r\n children,\r\n position,\r\n showOnClick = false,\r\n showArrowPointer = false,\r\n}) => {\r\n const [showPopover, setShowPopover] = React.useState(false);\r\n const theme = useTheme();\r\n const popoverRef = React.useRef<any>();\r\n\r\n React.useEffect(() => {\r\n const checkIfClickedOutside = (e: { target: any }) => {\r\n if (showPopover && popoverRef.current && !popoverRef.current.contains(e.target)) {\r\n setShowPopover(false);\r\n }\r\n };\r\n\r\n document.addEventListener('mousedown', checkIfClickedOutside);\r\n\r\n return () => {\r\n document.removeEventListener('mousedown', checkIfClickedOutside);\r\n };\r\n }, [showPopover]);\r\n\r\n return (\r\n <PopoverWrapper $position={position} $showOnClick={showOnClick} $showPopover={showPopover}>\r\n <PopoverContainer $size={size} $position={position} ref={popoverRef} $showArrowPointer={showArrowPointer}>\r\n {!!topSectionProps && (\r\n <PopoverTopSectionContainer $size={size}>\r\n <TextContainer $note={!!topSectionProps?.note} $size={size}>\r\n {topSectionProps?.note && <NoteContainer $size={size}>{topSectionProps.note}</NoteContainer>}\r\n <LabelContainer $size={size}>{topSectionProps?.text}</LabelContainer>\r\n </TextContainer>\r\n\r\n {showOnClick && (\r\n <CloseButtonContainer $size={size} data-testid={'closeBtn'}>\r\n <IconButton action={() => setShowPopover(false)} useTransparentBackground iconColor={COLORS.getColor('neutral_600', theme)} variant=\"secondary\" shape=\"circular\">\r\n <SystemIcons.Close />\r\n </IconButton>\r\n </CloseButtonContainer>\r\n )}\r\n </PopoverTopSectionContainer>\r\n )}\r\n\r\n <PopoverMiddleSectionContainer $size={size}>{mainContent}</PopoverMiddleSectionContainer>\r\n\r\n {!!bottomSectionProps && (\r\n <PopoverBottomSectionContainer $size={size}>\r\n {!!bottomSectionProps?.textButton?.icon && (\r\n <TextButtonContainer $size={size} data-testid={'textBtn'}>\r\n <Button size={size} variant=\"secondary\" icon={bottomSectionProps.textButton.icon} onClick={bottomSectionProps.textButton.action}>\r\n {bottomSectionProps.textButton.label}\r\n </Button>\r\n </TextButtonContainer>\r\n )}\r\n\r\n <div className=\"bottom-flex\" />\r\n\r\n <IconButtonContainer $size={size} data-testid={'iconBtn'}>\r\n {bottomSectionProps?.iconButtons?.map((iconButton) => (\r\n <IconButton action={iconButton.action} variant=\"secondary\" shape=\"circular\" useTransparentBackground>\r\n {iconButton.icon}\r\n </IconButton>\r\n ))}\r\n </IconButtonContainer>\r\n </PopoverBottomSectionContainer>\r\n )}\r\n </PopoverContainer>\r\n\r\n <div onClick={() => showOnClick && setShowPopover(!showPopover)}>\r\n {children}\r\n\r\n <div className=\"pointer-space\" />\r\n </div>\r\n </PopoverWrapper>\r\n );\r\n};\r\n\r\nexport default Popover;\r\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -24,26 +24,26 @@ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t =
|
|
|
24
24
|
var TextContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n border-radius: 0 8px 8px 0;\n display: flex;\n background: ", ";\n width: 100%;\n\n transition: background 100ms ease-in-out;\n align-items: center;\n\n padding: ", ";\n ", "\n"])), function (props) {
|
|
25
25
|
return _.COLORS.getColor('accent1_20', props.theme);
|
|
26
26
|
}, function (props) {
|
|
27
|
-
return props
|
|
27
|
+
return props.$size === _.Size.Small ? '6px 8px' : props.$size === _.Size.Large ? '20px 16px' : '12px 16px';
|
|
28
28
|
}, function (props) {
|
|
29
|
-
return props
|
|
29
|
+
return props.$size === _.Size.Small ? (0, _typography.ComponentSStyling)(_typography.ComponentTextStyle.Regular, null) : props.$size === _.Size.Large ? (0, _typography.ComponentLStyling)(_typography.ComponentTextStyle.Regular, null) : (0, _typography.ComponentMStyling)(_typography.ComponentTextStyle.Regular, null);
|
|
30
30
|
});
|
|
31
31
|
var TextWrapper = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])([""])));
|
|
32
32
|
var ButtonContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n border-radius: 8px 0 0 8px;\n display: flex;\n background: ", ";\n\n width: ", ";\n\n transition: background 100ms ease-in-out;\n\n .quiz-button-result-icon {\n height: ", ";\n width: ", ";\n }\n\n .radio-button-icon, .checkbox-icon {\n margin: auto;\n min-width: unset;\n background: transparent;\n\n svg {\n color: ", ";\n }\n\n &:hover {\n background: transparent;\n }\n\n &:active {\n background: transparent;\n }\n }\n\n .small {\n min-width: 32px;\n min-height: 32px;\n .radio-button-icon, .checkbox-icon {\n svg {\n height: 16px;\n width: 16px;\n }\n }\n }\n\n .medium {\n min-width: 48px;\n min-height: 48px;\n .radio-button-icon, .checkbox-icon {\n svg {\n height: 24px;\n width: 24px;\n }\n }\n }\n\n .large {\n min-width: 64px;\n min-height: 64px;\n .radio-button-icon, .checkbox-icon {\n svg {\n height: 32px;\n width: 32px;\n }\n }\n }\n"])), function (props) {
|
|
33
33
|
return _.COLORS.getColor('accent1_100', props.theme);
|
|
34
34
|
}, function (props) {
|
|
35
|
-
return props
|
|
35
|
+
return props.$size === _.Size.Small ? '32px' : props.$size === _.Size.Large ? '64px' : '48px';
|
|
36
36
|
}, function (props) {
|
|
37
|
-
return props
|
|
37
|
+
return props.$size === _.Size.Small ? '16px' : props.$size === _.Size.Large ? '32px' : '24px';
|
|
38
38
|
}, function (props) {
|
|
39
|
-
return props
|
|
39
|
+
return props.$size === _.Size.Small ? '32px' : props.$size === _.Size.Large ? '64px' : '48px';
|
|
40
40
|
}, function (props) {
|
|
41
41
|
return _.COLORS.getColor('accent1_600', props.theme);
|
|
42
42
|
});
|
|
43
43
|
var OptionContainer = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n cursor: pointer;\n max-width: 65ch; \n word-break: break-word;\n\n min-height: ", ";\n margin-bottom: ", ";\n\n &.selected {\n ", " {\n background: ", ";\n }\n ", " {\n background: ", ";\n }\n }\n \n &.disabled {\n cursor: not-allowed;\n \n ", " {\n pointer-events: none;\n background: ", ";\n }\n ", " {\n pointer-events: none;\n background: ", ";\n color: ", ";\n }\n\n .radio-button-icon, .checkbox-icon {\n background: transparent;\n }\n }\n\n &.correct {\n ", " { \n background: ", ";\n }\n ", " {\n background: ", ";\n svg {\n margin: auto;\n }\n }\n }\n\n &.incorrect {\n ", " { \n background: ", ";\n }\n ", " {\n background: ", ";\n svg {\n margin: auto;\n }\n }\n }\n\n &.partial {\n ", " { \n background: ", ";\n }\n ", " {\n background: ", ";\n svg {\n margin: auto;\n }\n }\n }\n\n &:focus,\n &.focus-state {\n ", "\n }\n\n &:hover,\n &.hover-state {\n .radio-button-icon, .checkbox-icon {\n background: transparent;\n }\n }\n\n &:active,\n &.active-state {\n .radio-button-icon, .checkbox-icon {\n background: transparent;\n }\n }\n\n &:hover:not(.disabled):not(.result),\n &.hover-state {\n ", " {\n background: ", ";\n }\n ", " {\n background: ", ";\n }\n \n .radio-button-icon, .checkbox-icon {\n background: transparent;\n svg {\n color: ", ";\n }\n }\n }\n\n &:active:not(.disabled):not(.result),\n &.active-state {\n ", " {\n background: ", ";\n transition: none;\n }\n ", " {\n background: ", ";\n transition: none;\n }\n\n .radio-button-icon, .checkbox-icon {\n background: transparent;\n svg {\n color: ", ";\n }\n }\n }\n"])), function (props) {
|
|
44
|
-
return props
|
|
44
|
+
return props.$size === _.Size.Small ? '32px' : props.$size === _.Size.Large ? '64px' : '48px';
|
|
45
45
|
}, function (props) {
|
|
46
|
-
return props
|
|
46
|
+
return props.$size === _.Size.Small ? '16px' : props.$size === _.Size.Large ? '32px' : '24px';
|
|
47
47
|
}, TextContainer, function (props) {
|
|
48
48
|
return _.COLORS.getColor('accent1_100', props.theme);
|
|
49
49
|
}, ButtonContainer, function (props) {
|
|
@@ -69,13 +69,13 @@ var OptionContainer = _styledComponents["default"].div(_templateObject4 || (_tem
|
|
|
69
69
|
}, _.focusStyles, ButtonContainer, function (props) {
|
|
70
70
|
return _.COLORS.getColor('accent1_300', props.theme);
|
|
71
71
|
}, TextContainer, function (props) {
|
|
72
|
-
return props
|
|
72
|
+
return props.$isSelected ? _.COLORS.getColor('accent1_200', props.theme) : _.COLORS.getColor('accent1_100', props.theme);
|
|
73
73
|
}, function (props) {
|
|
74
74
|
return _.COLORS.getColor('accent1_700', props.theme);
|
|
75
75
|
}, ButtonContainer, function (props) {
|
|
76
76
|
return _.COLORS.getColor('accent1_400', props.theme);
|
|
77
77
|
}, TextContainer, function (props) {
|
|
78
|
-
return props
|
|
78
|
+
return props.$isSelected ? _.COLORS.getColor('accent1_300', props.theme) : _.COLORS.getColor('accent1_200', props.theme);
|
|
79
79
|
}, function (props) {
|
|
80
80
|
return _.COLORS.getColor('accent1_800', props.theme);
|
|
81
81
|
});
|
|
@@ -115,10 +115,10 @@ var QuizButton = function QuizButton(_ref) {
|
|
|
115
115
|
var theme = (0, _styledComponents.useTheme)();
|
|
116
116
|
return /*#__PURE__*/(0, _jsxRuntime.jsxs)(OptionContainer, _objectSpread(_objectSpread({
|
|
117
117
|
onClick: onClick,
|
|
118
|
-
isSelected: selected,
|
|
118
|
+
$isSelected: selected,
|
|
119
119
|
tabIndex: disabled || resultType ? -1 : 0,
|
|
120
120
|
onMouseDown: _.defaultOnMouseDownHandler,
|
|
121
|
-
size: size,
|
|
121
|
+
$size: size,
|
|
122
122
|
className: 'quiz-button '.concat(selected ? ' selected' : '').concat(disabled ? ' disabled' : '').concat(resultType ? ' result ' + resultType : '').concat(className ? ' ' + className : ''),
|
|
123
123
|
"data-testid": 'container',
|
|
124
124
|
"aria-checked": selected,
|
|
@@ -127,7 +127,7 @@ var QuizButton = function QuizButton(_ref) {
|
|
|
127
127
|
children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(ButtonContainer, {
|
|
128
128
|
"data-testid": 'btnContainer',
|
|
129
129
|
className: 'quiz-button-icon',
|
|
130
|
-
size: size,
|
|
130
|
+
$size: size,
|
|
131
131
|
children: resultType ? renderResultContent(resultType, theme) : type === 'radio' ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_.RadioButton, {
|
|
132
132
|
selected: selected,
|
|
133
133
|
disabled: disabled,
|
|
@@ -146,9 +146,9 @@ var QuizButton = function QuizButton(_ref) {
|
|
|
146
146
|
}), /*#__PURE__*/(0, _jsxRuntime.jsx)(TextContainer, {
|
|
147
147
|
"data-testid": 'txtContainer',
|
|
148
148
|
className: 'quiz-button-text',
|
|
149
|
-
size: size,
|
|
149
|
+
$size: size,
|
|
150
150
|
children: /*#__PURE__*/(0, _jsxRuntime.jsx)(TextWrapper, {
|
|
151
|
-
size: size,
|
|
151
|
+
$size: size,
|
|
152
152
|
children: text
|
|
153
153
|
})
|
|
154
154
|
})]
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"QuizButton.cjs","names":["React","_interopRequireWildcard","require","_styledComponents","_","_typography","_jsxRuntime","_excluded","_templateObject","_templateObject2","_templateObject3","_templateObject4","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","TextContainer","styled","div","_taggedTemplateLiteral2","props","COLORS","getColor","theme","size","Size","Small","Large","ComponentSStyling","ComponentTextStyle","Regular","ComponentLStyling","ComponentMStyling","TextWrapper","ButtonContainer","OptionContainer","focusStyles","isSelected","renderResultContent","resultType","jsx","SystemIcons","CheckMark","color","className","Close","QuizButton","_ref","text","type","onClick","id","_ref$selected","selected","_ref$disabled","disabled","_ref$size","Medium","rest","_objectWithoutProperties2","useTheme","jsxs","tabIndex","onMouseDown","defaultOnMouseDownHandler","concat","role","children","RadioButton","tabIndexVal","select","Checkbox","propTypes","_propTypes","oneOf","string","isRequired","func","bool","_default","exports"],"sources":["../../src/QuizButton/QuizButton.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport styled, { useTheme } from 'styled-components';\r\nimport {Checkbox, COLORS, defaultOnMouseDownHandler, focusStyles, RadioButton, Size, SystemIcons} from '..';\r\nimport { ComponentLStyling, ComponentMStyling, ComponentSStyling, ComponentTextStyle } from '../styles/typography';\r\n\r\nconst TextContainer = styled.div<{size: Size}>`\r\n border-radius: 0 8px 8px 0;\r\n display: flex;\r\n background: ${props => COLORS.getColor('accent1_20', props.theme)};\r\n width: 100%;\r\n\r\n transition: background 100ms ease-in-out;\r\n align-items: center;\r\n\r\n padding: ${props=>props.size===Size.Small?'6px 8px':(props.size===Size.Large?'20px 16px':'12px 16px')};\r\n ${props=>props.size===Size.Small ? ComponentSStyling(ComponentTextStyle.Regular,null) : (props.size===Size.Large ? ComponentLStyling(ComponentTextStyle.Regular,null) : ComponentMStyling(ComponentTextStyle.Regular,null))}\r\n`;\r\n\r\nconst TextWrapper = styled.div<{size:Size}>``;\r\n\r\nconst ButtonContainer = styled.div<{size: Size}>`\r\n border-radius: 8px 0 0 8px;\r\n display: flex;\r\n background: ${props => COLORS.getColor('accent1_100', props.theme)};\r\n\r\n width: ${props=>props.size===Size.Small?'32px':(props.size===Size.Large?'64px':'48px')};\r\n\r\n transition: background 100ms ease-in-out;\r\n\r\n .quiz-button-result-icon {\r\n height: ${props=>props.size===Size.Small?'16px':(props.size===Size.Large?'32px':'24px')};\r\n width: ${props=>props.size===Size.Small?'32px':(props.size===Size.Large?'64px':'48px')};\r\n }\r\n\r\n .radio-button-icon, .checkbox-icon {\r\n margin: auto;\r\n min-width: unset;\r\n background: transparent;\r\n\r\n svg {\r\n color: ${props => COLORS.getColor('accent1_600', props.theme)};\r\n }\r\n\r\n &:hover {\r\n background: transparent;\r\n }\r\n\r\n &:active {\r\n background: transparent;\r\n }\r\n }\r\n\r\n .small {\r\n min-width: 32px;\r\n min-height: 32px;\r\n .radio-button-icon, .checkbox-icon {\r\n svg {\r\n height: 16px;\r\n width: 16px;\r\n }\r\n }\r\n }\r\n\r\n .medium {\r\n min-width: 48px;\r\n min-height: 48px;\r\n .radio-button-icon, .checkbox-icon {\r\n svg {\r\n height: 24px;\r\n width: 24px;\r\n }\r\n }\r\n }\r\n\r\n .large {\r\n min-width: 64px;\r\n min-height: 64px;\r\n .radio-button-icon, .checkbox-icon {\r\n svg {\r\n height: 32px;\r\n width: 32px;\r\n }\r\n }\r\n }\r\n`;\r\n\r\nconst OptionContainer = styled.div<{isSelected:boolean, size:Size}>`\r\n display: flex;\r\n flex-direction: row;\r\n cursor: pointer;\r\n max-width: 65ch; \r\n word-break: break-word;\r\n\r\n min-height: ${props=>props.size===Size.Small?'32px':(props.size===Size.Large?'64px':'48px')};\r\n margin-bottom: ${props=>props.size===Size.Small?'16px':(props.size===Size.Large?'32px':'24px')};\r\n\r\n &.selected {\r\n ${TextContainer} {\r\n background: ${props => COLORS.getColor('accent1_100', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('accent1_200', props.theme)};\r\n }\r\n }\r\n \r\n &.disabled {\r\n cursor: not-allowed;\r\n \r\n ${ButtonContainer} {\r\n pointer-events: none;\r\n background: ${props => COLORS.getColor('neutral_100', props.theme)};\r\n }\r\n ${TextContainer} {\r\n pointer-events: none;\r\n background: ${props => COLORS.getColor('neutral_20', props.theme)};\r\n color: ${props => COLORS.getColor('neutral_300', props.theme)};\r\n }\r\n\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n }\r\n }\r\n\r\n &.correct {\r\n ${TextContainer} { \r\n background: ${props => COLORS.getColor('correct_20', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('correct_400', props.theme)};\r\n svg {\r\n margin: auto;\r\n }\r\n }\r\n }\r\n\r\n &.incorrect {\r\n ${TextContainer} { \r\n background: ${props => COLORS.getColor('critical_20', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('critical_500', props.theme)};\r\n svg {\r\n margin: auto;\r\n }\r\n }\r\n }\r\n\r\n &.partial {\r\n ${TextContainer} { \r\n background: ${props => COLORS.getColor('warning_20', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('warning_400', props.theme)};\r\n svg {\r\n margin: auto;\r\n }\r\n }\r\n }\r\n\r\n &:focus,\r\n &.focus-state {\r\n ${focusStyles}\r\n }\r\n\r\n &:hover,\r\n &.hover-state {\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n }\r\n }\r\n\r\n &:active,\r\n &.active-state {\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n }\r\n }\r\n\r\n &:hover:not(.disabled):not(.result),\r\n &.hover-state {\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('accent1_300', props.theme)};\r\n }\r\n ${TextContainer} {\r\n background: ${props=>props.isSelected ? COLORS.getColor('accent1_200', props.theme) : COLORS.getColor('accent1_100', props.theme)};\r\n }\r\n \r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n svg {\r\n color: ${props => COLORS.getColor('accent1_700', props.theme)};\r\n }\r\n }\r\n }\r\n\r\n &:active:not(.disabled):not(.result),\r\n &.active-state {\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('accent1_400', props.theme)};\r\n transition: none;\r\n }\r\n ${TextContainer} {\r\n background: ${props=>props.isSelected ? COLORS.getColor('accent1_300', props.theme) : COLORS.getColor('accent1_200', props.theme)};\r\n transition: none;\r\n }\r\n\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n svg {\r\n color: ${props => COLORS.getColor('accent1_800', props.theme)};\r\n }\r\n }\r\n }\r\n`;\r\n\r\nconst renderResultContent = (resultType: string, theme: any) => {\r\n switch(resultType){\r\n case 'correct' : return <SystemIcons.CheckMark color={COLORS.getColor('white', theme)} className={'quiz-button-result-icon'}/>;\r\n\r\n case 'incorrect' : return <SystemIcons.Close color={COLORS.getColor('white', theme)} className={'quiz-button-result-icon'}/>;\r\n\r\n default : return <SystemIcons.Close color={COLORS.getColor('white', theme)} className={'quiz-button-result-icon'}/>;\r\n }\r\n};\r\n\r\nexport type QuizButtonProps = {\r\n /**\r\n * Optional. The result type of the quiz button. Can be 'correct', 'incorrect', or 'partial'.\r\n */\r\n resultType?: 'correct' | 'incorrect' | 'partial';\r\n\r\n /**\r\n * Required. The text to be displayed on the quiz button.\r\n */\r\n text: string;\r\n\r\n /**\r\n * Optional. A function to be called when the quiz button is clicked.\r\n */\r\n onClick?: (arg:any)=>void;\r\n\r\n /**\r\n * Required. The ID of the quiz button.\r\n */\r\n id: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the quiz button is selected.\r\n */\r\n selected?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the quiz button is disabled.\r\n */\r\n disabled?: boolean;\r\n\r\n /**\r\n * Optional. The size of the quiz button. Can be 'Small', 'Medium', or 'Large'.\r\n */\r\n size?: Size.Small | Size.Medium | Size.Large;\r\n\r\n /**\r\n * Required. The type of the quiz button. Can be 'radio' or 'checkbox'.\r\n */\r\n type: 'radio' | 'checkbox';\r\n} & Omit<React.HTMLAttributes<HTMLDivElement>, 'onClick' | 'id' | 'tabIndex' | 'onMouseDown'>\r\n\r\nconst QuizButton: React.FunctionComponent<QuizButtonProps> = ({\r\n text,\r\n type,\r\n onClick,\r\n resultType,\r\n id,\r\n className,\r\n selected = false,\r\n disabled = false,\r\n size = Size.Medium,\r\n ...rest\r\n }) => {\r\n\r\n const theme = useTheme();\r\n return ( \r\n <OptionContainer\r\n onClick={onClick}\r\n isSelected={selected}\r\n tabIndex={(disabled || resultType) ? -1 : 0}\r\n onMouseDown={defaultOnMouseDownHandler}\r\n size={size}\r\n className={'quiz-button '.concat(selected ? ' selected' : '')\r\n .concat(disabled ? ' disabled' : '')\r\n .concat(resultType ? ' result ' + resultType : '')\r\n .concat(className ? ' ' + className : '')}\r\n data-testid={'container'}\r\n aria-checked={selected}\r\n role={type === 'radio'? 'radio' : 'checkbox'}\r\n {...rest}>\r\n <ButtonContainer data-testid={'btnContainer'} className={'quiz-button-icon'} size={size}>\r\n {\r\n resultType ? renderResultContent(resultType, theme) : (\r\n type==='radio' ? <RadioButton selected={selected} disabled={disabled} size={size} tabIndexVal={-1}\r\n select={()=>{}} id={id}/> : <Checkbox selected={selected} disabled={disabled} size={size} tabIndexVal={-1}\r\n select={()=>{}} id={id}/>\r\n )\r\n }\r\n </ButtonContainer>\r\n\r\n <TextContainer data-testid={'txtContainer'} className={'quiz-button-text'} size={size}>\r\n <TextWrapper size={size}>\r\n {text}\r\n </TextWrapper>\r\n </TextContainer>\r\n </OptionContainer>\r\n );\r\n};\r\n\r\nexport default QuizButton;\r\n"],"mappings":";;;;;;;;;;;;AAAA,IAAAA,KAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,iBAAA,GAAAF,uBAAA,CAAAC,OAAA;AACA,IAAAE,CAAA,GAAAF,OAAA;AACA,IAAAG,WAAA,GAAAH,OAAA;AAAmH,IAAAI,WAAA,GAAAJ,OAAA;AAAA,IAAAK,SAAA;AAAA,IAAAC,eAAA,EAAAC,gBAAA,EAAAC,gBAAA,EAAAC,gBAAA;AAAA,SAAAC,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAZ,wBAAAY,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,gBAAAK,OAAA,CAAAL,CAAA,0BAAAA,CAAA,sBAAAA,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,cAAAR,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAAA,SAAAW,QAAAnB,CAAA,EAAAE,CAAA,QAAAC,CAAA,GAAAQ,MAAA,CAAAS,IAAA,CAAApB,CAAA,OAAAW,MAAA,CAAAU,qBAAA,QAAAC,CAAA,GAAAX,MAAA,CAAAU,qBAAA,CAAArB,CAAA,GAAAE,CAAA,KAAAoB,CAAA,GAAAA,CAAA,CAAAC,MAAA,WAAArB,CAAA,WAAAS,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAE,CAAA,EAAAsB,UAAA,OAAArB,CAAA,CAAAsB,IAAA,CAAAC,KAAA,CAAAvB,CAAA,EAAAmB,CAAA,YAAAnB,CAAA;AAAA,SAAAwB,cAAA3B,CAAA,aAAAE,CAAA,MAAAA,CAAA,GAAA0B,SAAA,CAAAC,MAAA,EAAA3B,CAAA,UAAAC,CAAA,WAAAyB,SAAA,CAAA1B,CAAA,IAAA0B,SAAA,CAAA1B,CAAA,QAAAA,CAAA,OAAAiB,OAAA,CAAAR,MAAA,CAAAR,CAAA,OAAA2B,OAAA,WAAA5B,CAAA,QAAA6B,gBAAA,aAAA/B,CAAA,EAAAE,CAAA,EAAAC,CAAA,CAAAD,CAAA,SAAAS,MAAA,CAAAqB,yBAAA,GAAArB,MAAA,CAAAsB,gBAAA,CAAAjC,CAAA,EAAAW,MAAA,CAAAqB,yBAAA,CAAA7B,CAAA,KAAAgB,OAAA,CAAAR,MAAA,CAAAR,CAAA,GAAA2B,OAAA,WAAA5B,CAAA,IAAAS,MAAA,CAAAC,cAAA,CAAAZ,CAAA,EAAAE,CAAA,EAAAS,MAAA,CAAAE,wBAAA,CAAAV,CAAA,EAAAD,CAAA,iBAAAF,CAAA;AAEnH,IAAMkC,aAAa,GAAGC,4BAAM,CAACC,GAAG,CAAAzC,eAAA,KAAAA,eAAA,OAAA0C,uBAAA,gNAGhB,UAAAC,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,YAAY,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAMtD,UAAAH,KAAK;EAAA,OAAEA,KAAK,CAACI,IAAI,KAAGC,MAAI,CAACC,KAAK,GAAC,SAAS,GAAEN,KAAK,CAACI,IAAI,KAAGC,MAAI,CAACE,KAAK,GAAC,WAAW,GAAC,WAAY;AAAA,GACnG,UAAAP,KAAK;EAAA,OAAEA,KAAK,CAACI,IAAI,KAAGC,MAAI,CAACC,KAAK,GAAG,IAAAE,6BAAiB,EAACC,8BAAkB,CAACC,OAAO,EAAC,IAAI,CAAC,GAAIV,KAAK,CAACI,IAAI,KAAGC,MAAI,CAACE,KAAK,GAAG,IAAAI,6BAAiB,EAACF,8BAAkB,CAACC,OAAO,EAAC,IAAI,CAAC,GAAG,IAAAE,6BAAiB,EAACH,8BAAkB,CAACC,OAAO,EAAC,IAAI,CAAE;AAAA,EAC5N;AAED,IAAMG,WAAW,GAAGhB,4BAAM,CAACC,GAAG,CAAAxC,gBAAA,KAAAA,gBAAA,OAAAyC,uBAAA,oBAAe;AAE7C,IAAMe,eAAe,GAAGjB,4BAAM,CAACC,GAAG,CAAAvC,gBAAA,KAAAA,gBAAA,OAAAwC,uBAAA,qhCAGlB,UAAAC,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAEzD,UAAAH,KAAK;EAAA,OAAEA,KAAK,CAACI,IAAI,KAAGC,MAAI,CAACC,KAAK,GAAC,MAAM,GAAEN,KAAK,CAACI,IAAI,KAAGC,MAAI,CAACE,KAAK,GAAC,MAAM,GAAC,MAAO;AAAA,GAK1E,UAAAP,KAAK;EAAA,OAAEA,KAAK,CAACI,IAAI,KAAGC,MAAI,CAACC,KAAK,GAAC,MAAM,GAAEN,KAAK,CAACI,IAAI,KAAGC,MAAI,CAACE,KAAK,GAAC,MAAM,GAAC,MAAO;AAAA,GAC9E,UAAAP,KAAK;EAAA,OAAEA,KAAK,CAACI,IAAI,KAAGC,MAAI,CAACC,KAAK,GAAC,MAAM,GAAEN,KAAK,CAACI,IAAI,KAAGC,MAAI,CAACE,KAAK,GAAC,MAAM,GAAC,MAAO;AAAA,GAS3E,UAAAP,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,EA4ClE;AAED,IAAMY,eAAe,GAAGlB,4BAAM,CAACC,GAAG,CAAAtC,gBAAA,KAAAA,gBAAA,OAAAuC,uBAAA,+7DAOlB,UAAAC,KAAK;EAAA,OAAEA,KAAK,CAACI,IAAI,KAAGC,MAAI,CAACC,KAAK,GAAC,MAAM,GAAEN,KAAK,CAACI,IAAI,KAAGC,MAAI,CAACE,KAAK,GAAC,MAAM,GAAC,MAAO;AAAA,GAC1E,UAAAP,KAAK;EAAA,OAAEA,KAAK,CAACI,IAAI,KAAGC,MAAI,CAACC,KAAK,GAAC,MAAM,GAAEN,KAAK,CAACI,IAAI,KAAGC,MAAI,CAACE,KAAK,GAAC,MAAM,GAAC,MAAO;AAAA,GAG1FX,aAAa,EACC,UAAAI,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAElEW,eAAe,EACD,UAAAd,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAOlEW,eAAe,EAED,UAAAd,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAElEP,aAAa,EAEC,UAAAI,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,YAAY,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GACxD,UAAAH,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAS7DP,aAAa,EACC,UAAAI,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,YAAY,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAEjEW,eAAe,EACD,UAAAd,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAQlEP,aAAa,EACC,UAAAI,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAElEW,eAAe,EACD,UAAAd,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,cAAc,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAQnEP,aAAa,EACC,UAAAI,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,YAAY,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAEjEW,eAAe,EACD,UAAAd,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GASlEa,aAAW,EAmBXF,eAAe,EACD,UAAAd,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAElEP,aAAa,EACC,UAAAI,KAAK;EAAA,OAAEA,KAAK,CAACiB,UAAU,GAAGhB,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC,GAAIF,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAMvH,UAAAH,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAO/DW,eAAe,EACD,UAAAd,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAGlEP,aAAa,EACC,UAAAI,KAAK;EAAA,OAAEA,KAAK,CAACiB,UAAU,GAAGhB,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC,GAAGF,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,GAOtH,UAAAH,KAAK;EAAA,OAAIC,QAAM,CAACC,QAAQ,CAAC,aAAa,EAAEF,KAAK,CAACG,KAAK,CAAC;AAAA,EAIpE;AAED,IAAMe,mBAAmB,GAAG,SAAtBA,mBAAmBA,CAAIC,UAAkB,EAAEhB,KAAU,EAAK;EAC9D,QAAOgB,UAAU;IACf,KAAK,SAAS;MAAG,oBAAO,IAAAhE,WAAA,CAAAiE,GAAA,EAACnE,CAAA,CAAAoE,WAAW,CAACC,SAAS;QAACC,KAAK,EAAEtB,QAAM,CAACC,QAAQ,CAAC,OAAO,EAAEC,KAAK,CAAE;QAACqB,SAAS,EAAE;MAA0B,CAAC,CAAC;IAE9H,KAAK,WAAW;MAAG,oBAAO,IAAArE,WAAA,CAAAiE,GAAA,EAACnE,CAAA,CAAAoE,WAAW,CAACI,KAAK;QAACF,KAAK,EAAEtB,QAAM,CAACC,QAAQ,CAAC,OAAO,EAAEC,KAAK,CAAE;QAACqB,SAAS,EAAE;MAA0B,CAAC,CAAC;IAE5H;MAAU,oBAAO,IAAArE,WAAA,CAAAiE,GAAA,EAACnE,CAAA,CAAAoE,WAAW,CAACI,KAAK;QAACF,KAAK,EAAEtB,QAAM,CAACC,QAAQ,CAAC,OAAO,EAAEC,KAAK,CAAE;QAACqB,SAAS,EAAE;MAA0B,CAAC,CAAC;EACrH;AACF,CAAC;AA4CD,IAAME,UAAoD,GAAG,SAAvDA,UAAoDA,CAAAC,IAAA,EAWU;EAAA,IAVJC,IAAI,GAAAD,IAAA,CAAJC,IAAI;IACJC,IAAI,GAAAF,IAAA,CAAJE,IAAI;IACJC,OAAO,GAAAH,IAAA,CAAPG,OAAO;IACPX,UAAU,GAAAQ,IAAA,CAAVR,UAAU;IACVY,EAAE,GAAAJ,IAAA,CAAFI,EAAE;IACFP,SAAS,GAAAG,IAAA,CAATH,SAAS;IAAAQ,aAAA,GAAAL,IAAA,CACTM,QAAQ;IAARA,QAAQ,GAAAD,aAAA,cAAG,KAAK,GAAAA,aAAA;IAAAE,aAAA,GAAAP,IAAA,CAChBQ,QAAQ;IAARA,QAAQ,GAAAD,aAAA,cAAG,KAAK,GAAAA,aAAA;IAAAE,SAAA,GAAAT,IAAA,CAChBvB,IAAI;IAAJA,IAAI,GAAAgC,SAAA,cAAG/B,MAAI,CAACgC,MAAM,GAAAD,SAAA;IACfE,IAAI,OAAAC,yBAAA,aAAAZ,IAAA,EAAAvE,SAAA;EAGrE,IAAM+C,KAAK,GAAG,IAAAqC,0BAAQ,EAAC,CAAC;EACxB,oBACE,IAAArF,WAAA,CAAAsF,IAAA,EAAC1B,eAAe,EAAA1B,aAAA,CAAAA,aAAA;IACdyC,OAAO,EAAEA,OAAQ;IACjBb,UAAU,EAAEgB,QAAS;IACrBS,QAAQ,EAAGP,QAAQ,IAAIhB,UAAU,GAAI,CAAC,CAAC,GAAG,CAAE;IAC5CwB,WAAW,EAAEC,2BAA0B;IACvCxC,IAAI,EAAEA,IAAK;IACXoB,SAAS,EAAE,cAAc,CAACqB,MAAM,CAACZ,QAAQ,GAAG,WAAW,GAAG,EAAE,CAAC,CAC1DY,MAAM,CAACV,QAAQ,GAAG,WAAW,GAAG,EAAE,CAAC,CACnCU,MAAM,CAAC1B,UAAU,GAAG,UAAU,GAAGA,UAAU,GAAG,EAAE,CAAC,CACjD0B,MAAM,CAACrB,SAAS,GAAG,GAAG,GAAGA,SAAS,GAAG,EAAE,CAAE;IAC5C,eAAa,WAAY;IACzB,gBAAcS,QAAS;IACvBa,IAAI,EAAEjB,IAAI,KAAK,OAAO,GAAE,OAAO,GAAG;EAAW,GACzCS,IAAI;IAAAS,QAAA,gBACN,IAAA5F,WAAA,CAAAiE,GAAA,EAACN,eAAe;MAAC,eAAa,cAAe;MAACU,SAAS,EAAE,kBAAmB;MAACpB,IAAI,EAAEA,IAAK;MAAA2C,QAAA,EAEpF5B,UAAU,GAAGD,mBAAmB,CAACC,UAAU,EAAEhB,KAAK,CAAC,GAC/B0B,IAAI,KAAG,OAAO,gBAAG,IAAA1E,WAAA,CAAAiE,GAAA,EAACnE,CAAA,CAAA+F,WAAW;QAACf,QAAQ,EAAEA,QAAS;QAACE,QAAQ,EAAEA,QAAS;QAAC/B,IAAI,EAAEA,IAAK;QAAC6C,WAAW,EAAE,CAAC,CAAE;QAClGC,MAAM,EAAE,SAAAA,OAAA,EAAI,CAAC,CAAE;QAACnB,EAAE,EAAEA;MAAG,CAAC,CAAC,gBAAG,IAAA5E,WAAA,CAAAiE,GAAA,EAACnE,CAAA,CAAAkG,QAAQ;QAAClB,QAAQ,EAAEA,QAAS;QAACE,QAAQ,EAAEA,QAAS;QAAC/B,IAAI,EAAEA,IAAK;QAAC6C,WAAW,EAAE,CAAC,CAAE;QAC1GC,MAAM,EAAE,SAAAA,OAAA,EAAI,CAAC,CAAE;QAACnB,EAAE,EAAEA;MAAG,CAAC;IACzB,CAEN,CAAC,eAElB,IAAA5E,WAAA,CAAAiE,GAAA,EAACxB,aAAa;MAAC,eAAa,cAAe;MAAC4B,SAAS,EAAE,kBAAmB;MAACpB,IAAI,EAAEA,IAAK;MAAA2C,QAAA,eACpF,IAAA5F,WAAA,CAAAiE,GAAA,EAACP,WAAW;QAACT,IAAI,EAAEA,IAAK;QAAA2C,QAAA,EACrBnB;MAAI,CACM;IAAC,CACD,CAAC;EAAA,EACH,CAAC;AAEtB,CAAC;AAACF,UAAA,CAAA0B,SAAA;EApFAjC,UAAU,EAAAkC,UAAA,YAAAC,KAAA,EAAG,SAAS,EAAG,WAAW,EAAG,SAAS;EAKhD1B,IAAI,EAAAyB,UAAA,YAAAE,MAAA,CAAAC,UAAA;EAKJ1B,OAAO,EAAAuB,UAAA,YAAAI,IAAA;EAKP1B,EAAE,EAAAsB,UAAA,YAAAE,MAAA,CAAAC,UAAA;EAKFvB,QAAQ,EAAAoB,UAAA,YAAAK,IAAA;EAKRvB,QAAQ,EAAAkB,UAAA,YAAAK,IAAA;EAUR7B,IAAI,EAAAwB,UAAA,YAAAC,KAAA,EAAE,OAAO,EAAG,UAAU,GAAAE;AAAA;AAAA,IAAAG,QAAA,GAmDbjC,UAAU;AAAAkC,OAAA,cAAAD,QAAA","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"QuizButton.cjs","names":["React","_interopRequireWildcard","require","_styledComponents","_","_typography","_jsxRuntime","_excluded","_templateObject","_templateObject2","_templateObject3","_templateObject4","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","TextContainer","styled","div","_taggedTemplateLiteral2","props","COLORS","getColor","theme","$size","Size","Small","Large","ComponentSStyling","ComponentTextStyle","Regular","ComponentLStyling","ComponentMStyling","TextWrapper","ButtonContainer","OptionContainer","focusStyles","$isSelected","renderResultContent","resultType","jsx","SystemIcons","CheckMark","color","className","Close","QuizButton","_ref","text","type","onClick","id","_ref$selected","selected","_ref$disabled","disabled","_ref$size","size","Medium","rest","_objectWithoutProperties2","useTheme","jsxs","tabIndex","onMouseDown","defaultOnMouseDownHandler","concat","role","children","RadioButton","tabIndexVal","select","Checkbox","propTypes","_propTypes","oneOf","string","isRequired","func","bool","_default","exports"],"sources":["../../src/QuizButton/QuizButton.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport styled, { useTheme } from 'styled-components';\r\nimport {Checkbox, COLORS, defaultOnMouseDownHandler, focusStyles, RadioButton, Size, SystemIcons} from '..';\r\nimport { ComponentLStyling, ComponentMStyling, ComponentSStyling, ComponentTextStyle } from '../styles/typography';\r\n\r\nconst TextContainer = styled.div<{$size: Size}>`\r\n border-radius: 0 8px 8px 0;\r\n display: flex;\r\n background: ${props => COLORS.getColor('accent1_20', props.theme)};\r\n width: 100%;\r\n\r\n transition: background 100ms ease-in-out;\r\n align-items: center;\r\n\r\n padding: ${props=>props.$size===Size.Small?'6px 8px':(props.$size===Size.Large?'20px 16px':'12px 16px')};\r\n ${props=>props.$size===Size.Small ? ComponentSStyling(ComponentTextStyle.Regular,null) : (props.$size===Size.Large ? ComponentLStyling(ComponentTextStyle.Regular,null) : ComponentMStyling(ComponentTextStyle.Regular,null))}\r\n`;\r\n\r\nconst TextWrapper = styled.div<{$size:Size}>``;\r\n\r\nconst ButtonContainer = styled.div<{$size: Size}>`\r\n border-radius: 8px 0 0 8px;\r\n display: flex;\r\n background: ${props => COLORS.getColor('accent1_100', props.theme)};\r\n\r\n width: ${props=>props.$size===Size.Small?'32px':(props.$size===Size.Large?'64px':'48px')};\r\n\r\n transition: background 100ms ease-in-out;\r\n\r\n .quiz-button-result-icon {\r\n height: ${props=>props.$size===Size.Small?'16px':(props.$size===Size.Large?'32px':'24px')};\r\n width: ${props=>props.$size===Size.Small?'32px':(props.$size===Size.Large?'64px':'48px')};\r\n }\r\n\r\n .radio-button-icon, .checkbox-icon {\r\n margin: auto;\r\n min-width: unset;\r\n background: transparent;\r\n\r\n svg {\r\n color: ${props => COLORS.getColor('accent1_600', props.theme)};\r\n }\r\n\r\n &:hover {\r\n background: transparent;\r\n }\r\n\r\n &:active {\r\n background: transparent;\r\n }\r\n }\r\n\r\n .small {\r\n min-width: 32px;\r\n min-height: 32px;\r\n .radio-button-icon, .checkbox-icon {\r\n svg {\r\n height: 16px;\r\n width: 16px;\r\n }\r\n }\r\n }\r\n\r\n .medium {\r\n min-width: 48px;\r\n min-height: 48px;\r\n .radio-button-icon, .checkbox-icon {\r\n svg {\r\n height: 24px;\r\n width: 24px;\r\n }\r\n }\r\n }\r\n\r\n .large {\r\n min-width: 64px;\r\n min-height: 64px;\r\n .radio-button-icon, .checkbox-icon {\r\n svg {\r\n height: 32px;\r\n width: 32px;\r\n }\r\n }\r\n }\r\n`;\r\n\r\nconst OptionContainer = styled.div<{$isSelected:boolean, $size:Size}>`\r\n display: flex;\r\n flex-direction: row;\r\n cursor: pointer;\r\n max-width: 65ch; \r\n word-break: break-word;\r\n\r\n min-height: ${props=>props.$size===Size.Small?'32px':(props.$size===Size.Large?'64px':'48px')};\r\n margin-bottom: ${props=>props.$size===Size.Small?'16px':(props.$size===Size.Large?'32px':'24px')};\r\n\r\n &.selected {\r\n ${TextContainer} {\r\n background: ${props => COLORS.getColor('accent1_100', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('accent1_200', props.theme)};\r\n }\r\n }\r\n \r\n &.disabled {\r\n cursor: not-allowed;\r\n \r\n ${ButtonContainer} {\r\n pointer-events: none;\r\n background: ${props => COLORS.getColor('neutral_100', props.theme)};\r\n }\r\n ${TextContainer} {\r\n pointer-events: none;\r\n background: ${props => COLORS.getColor('neutral_20', props.theme)};\r\n color: ${props => COLORS.getColor('neutral_300', props.theme)};\r\n }\r\n\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n }\r\n }\r\n\r\n &.correct {\r\n ${TextContainer} { \r\n background: ${props => COLORS.getColor('correct_20', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('correct_400', props.theme)};\r\n svg {\r\n margin: auto;\r\n }\r\n }\r\n }\r\n\r\n &.incorrect {\r\n ${TextContainer} { \r\n background: ${props => COLORS.getColor('critical_20', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('critical_500', props.theme)};\r\n svg {\r\n margin: auto;\r\n }\r\n }\r\n }\r\n\r\n &.partial {\r\n ${TextContainer} { \r\n background: ${props => COLORS.getColor('warning_20', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('warning_400', props.theme)};\r\n svg {\r\n margin: auto;\r\n }\r\n }\r\n }\r\n\r\n &:focus,\r\n &.focus-state {\r\n ${focusStyles}\r\n }\r\n\r\n &:hover,\r\n &.hover-state {\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n }\r\n }\r\n\r\n &:active,\r\n &.active-state {\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n }\r\n }\r\n\r\n &:hover:not(.disabled):not(.result),\r\n &.hover-state {\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('accent1_300', props.theme)};\r\n }\r\n ${TextContainer} {\r\n background: ${props=>props.$isSelected ? COLORS.getColor('accent1_200', props.theme) : COLORS.getColor('accent1_100', props.theme)};\r\n }\r\n \r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n svg {\r\n color: ${props => COLORS.getColor('accent1_700', props.theme)};\r\n }\r\n }\r\n }\r\n\r\n &:active:not(.disabled):not(.result),\r\n &.active-state {\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('accent1_400', props.theme)};\r\n transition: none;\r\n }\r\n ${TextContainer} {\r\n background: ${props=>props.$isSelected ? COLORS.getColor('accent1_300', props.theme) : COLORS.getColor('accent1_200', props.theme)};\r\n transition: none;\r\n }\r\n\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n svg {\r\n color: ${props => COLORS.getColor('accent1_800', props.theme)};\r\n }\r\n }\r\n }\r\n`;\r\n\r\nconst renderResultContent = (resultType: string, theme: any) => {\r\n switch(resultType){\r\n case 'correct' : return <SystemIcons.CheckMark color={COLORS.getColor('white', theme)} className={'quiz-button-result-icon'}/>;\r\n\r\n case 'incorrect' : return <SystemIcons.Close color={COLORS.getColor('white', theme)} className={'quiz-button-result-icon'}/>;\r\n\r\n default : return <SystemIcons.Close color={COLORS.getColor('white', theme)} className={'quiz-button-result-icon'}/>;\r\n }\r\n};\r\n\r\nexport type QuizButtonProps = {\r\n /**\r\n * Optional. The result type of the quiz button. Can be 'correct', 'incorrect', or 'partial'.\r\n */\r\n resultType?: 'correct' | 'incorrect' | 'partial';\r\n\r\n /**\r\n * Required. The text to be displayed on the quiz button.\r\n */\r\n text: string;\r\n\r\n /**\r\n * Optional. A function to be called when the quiz button is clicked.\r\n */\r\n onClick?: (arg:any)=>void;\r\n\r\n /**\r\n * Required. The ID of the quiz button.\r\n */\r\n id: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the quiz button is selected.\r\n */\r\n selected?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the quiz button is disabled.\r\n */\r\n disabled?: boolean;\r\n\r\n /**\r\n * Optional. The size of the quiz button. Can be 'Small', 'Medium', or 'Large'.\r\n */\r\n size?: Size.Small | Size.Medium | Size.Large;\r\n\r\n /**\r\n * Required. The type of the quiz button. Can be 'radio' or 'checkbox'.\r\n */\r\n type: 'radio' | 'checkbox';\r\n} & Omit<React.HTMLAttributes<HTMLDivElement>, 'onClick' | 'id' | 'tabIndex' | 'onMouseDown'>\r\n\r\nconst QuizButton: React.FunctionComponent<QuizButtonProps> = ({\r\n text,\r\n type,\r\n onClick,\r\n resultType,\r\n id,\r\n className,\r\n selected = false,\r\n disabled = false,\r\n size = Size.Medium,\r\n ...rest\r\n }) => {\r\n\r\n const theme = useTheme();\r\n return ( \r\n <OptionContainer\r\n onClick={onClick}\r\n $isSelected={selected}\r\n tabIndex={(disabled || resultType) ? -1 : 0}\r\n onMouseDown={defaultOnMouseDownHandler}\r\n $size={size}\r\n className={'quiz-button '.concat(selected ? ' selected' : '')\r\n .concat(disabled ? ' disabled' : '')\r\n .concat(resultType ? ' result ' + resultType : '')\r\n .concat(className ? ' ' + className : '')}\r\n data-testid={'container'}\r\n aria-checked={selected}\r\n role={type === 'radio'? 'radio' : 'checkbox'}\r\n {...rest}>\r\n <ButtonContainer data-testid={'btnContainer'} className={'quiz-button-icon'} $size={size}>\r\n {\r\n resultType ? renderResultContent(resultType, theme) : (\r\n type==='radio' ? <RadioButton selected={selected} disabled={disabled} size={size} tabIndexVal={-1}\r\n select={()=>{}} id={id}/> : <Checkbox selected={selected} disabled={disabled} size={size} tabIndexVal={-1}\r\n select={()=>{}} id={id}/>\r\n )\r\n }\r\n </ButtonContainer>\r\n\r\n <TextContainer data-testid={'txtContainer'} className={'quiz-button-text'} $size={size}>\r\n <TextWrapper $size={size}>\r\n {text}\r\n </TextWrapper>\r\n </TextContainer>\r\n </OptionContainer>\r\n );\r\n};\r\n\r\nexport default QuizButton;\r\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -15,26 +15,26 @@ import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
15
15
|
var TextContainer = styled.div(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n border-radius: 0 8px 8px 0;\n display: flex;\n background: ", ";\n width: 100%;\n\n transition: background 100ms ease-in-out;\n align-items: center;\n\n padding: ", ";\n ", "\n"])), function (props) {
|
|
16
16
|
return COLORS.getColor('accent1_20', props.theme);
|
|
17
17
|
}, function (props) {
|
|
18
|
-
return props
|
|
18
|
+
return props.$size === Size.Small ? '6px 8px' : props.$size === Size.Large ? '20px 16px' : '12px 16px';
|
|
19
19
|
}, function (props) {
|
|
20
|
-
return props
|
|
20
|
+
return props.$size === Size.Small ? ComponentSStyling(ComponentTextStyle.Regular, null) : props.$size === Size.Large ? ComponentLStyling(ComponentTextStyle.Regular, null) : ComponentMStyling(ComponentTextStyle.Regular, null);
|
|
21
21
|
});
|
|
22
22
|
var TextWrapper = styled.div(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral([""])));
|
|
23
23
|
var ButtonContainer = styled.div(_templateObject3 || (_templateObject3 = _taggedTemplateLiteral(["\n border-radius: 8px 0 0 8px;\n display: flex;\n background: ", ";\n\n width: ", ";\n\n transition: background 100ms ease-in-out;\n\n .quiz-button-result-icon {\n height: ", ";\n width: ", ";\n }\n\n .radio-button-icon, .checkbox-icon {\n margin: auto;\n min-width: unset;\n background: transparent;\n\n svg {\n color: ", ";\n }\n\n &:hover {\n background: transparent;\n }\n\n &:active {\n background: transparent;\n }\n }\n\n .small {\n min-width: 32px;\n min-height: 32px;\n .radio-button-icon, .checkbox-icon {\n svg {\n height: 16px;\n width: 16px;\n }\n }\n }\n\n .medium {\n min-width: 48px;\n min-height: 48px;\n .radio-button-icon, .checkbox-icon {\n svg {\n height: 24px;\n width: 24px;\n }\n }\n }\n\n .large {\n min-width: 64px;\n min-height: 64px;\n .radio-button-icon, .checkbox-icon {\n svg {\n height: 32px;\n width: 32px;\n }\n }\n }\n"])), function (props) {
|
|
24
24
|
return COLORS.getColor('accent1_100', props.theme);
|
|
25
25
|
}, function (props) {
|
|
26
|
-
return props
|
|
26
|
+
return props.$size === Size.Small ? '32px' : props.$size === Size.Large ? '64px' : '48px';
|
|
27
27
|
}, function (props) {
|
|
28
|
-
return props
|
|
28
|
+
return props.$size === Size.Small ? '16px' : props.$size === Size.Large ? '32px' : '24px';
|
|
29
29
|
}, function (props) {
|
|
30
|
-
return props
|
|
30
|
+
return props.$size === Size.Small ? '32px' : props.$size === Size.Large ? '64px' : '48px';
|
|
31
31
|
}, function (props) {
|
|
32
32
|
return COLORS.getColor('accent1_600', props.theme);
|
|
33
33
|
});
|
|
34
34
|
var OptionContainer = styled.div(_templateObject4 || (_templateObject4 = _taggedTemplateLiteral(["\n display: flex;\n flex-direction: row;\n cursor: pointer;\n max-width: 65ch; \n word-break: break-word;\n\n min-height: ", ";\n margin-bottom: ", ";\n\n &.selected {\n ", " {\n background: ", ";\n }\n ", " {\n background: ", ";\n }\n }\n \n &.disabled {\n cursor: not-allowed;\n \n ", " {\n pointer-events: none;\n background: ", ";\n }\n ", " {\n pointer-events: none;\n background: ", ";\n color: ", ";\n }\n\n .radio-button-icon, .checkbox-icon {\n background: transparent;\n }\n }\n\n &.correct {\n ", " { \n background: ", ";\n }\n ", " {\n background: ", ";\n svg {\n margin: auto;\n }\n }\n }\n\n &.incorrect {\n ", " { \n background: ", ";\n }\n ", " {\n background: ", ";\n svg {\n margin: auto;\n }\n }\n }\n\n &.partial {\n ", " { \n background: ", ";\n }\n ", " {\n background: ", ";\n svg {\n margin: auto;\n }\n }\n }\n\n &:focus,\n &.focus-state {\n ", "\n }\n\n &:hover,\n &.hover-state {\n .radio-button-icon, .checkbox-icon {\n background: transparent;\n }\n }\n\n &:active,\n &.active-state {\n .radio-button-icon, .checkbox-icon {\n background: transparent;\n }\n }\n\n &:hover:not(.disabled):not(.result),\n &.hover-state {\n ", " {\n background: ", ";\n }\n ", " {\n background: ", ";\n }\n \n .radio-button-icon, .checkbox-icon {\n background: transparent;\n svg {\n color: ", ";\n }\n }\n }\n\n &:active:not(.disabled):not(.result),\n &.active-state {\n ", " {\n background: ", ";\n transition: none;\n }\n ", " {\n background: ", ";\n transition: none;\n }\n\n .radio-button-icon, .checkbox-icon {\n background: transparent;\n svg {\n color: ", ";\n }\n }\n }\n"])), function (props) {
|
|
35
|
-
return props
|
|
35
|
+
return props.$size === Size.Small ? '32px' : props.$size === Size.Large ? '64px' : '48px';
|
|
36
36
|
}, function (props) {
|
|
37
|
-
return props
|
|
37
|
+
return props.$size === Size.Small ? '16px' : props.$size === Size.Large ? '32px' : '24px';
|
|
38
38
|
}, TextContainer, function (props) {
|
|
39
39
|
return COLORS.getColor('accent1_100', props.theme);
|
|
40
40
|
}, ButtonContainer, function (props) {
|
|
@@ -60,13 +60,13 @@ var OptionContainer = styled.div(_templateObject4 || (_templateObject4 = _tagged
|
|
|
60
60
|
}, focusStyles, ButtonContainer, function (props) {
|
|
61
61
|
return COLORS.getColor('accent1_300', props.theme);
|
|
62
62
|
}, TextContainer, function (props) {
|
|
63
|
-
return props
|
|
63
|
+
return props.$isSelected ? COLORS.getColor('accent1_200', props.theme) : COLORS.getColor('accent1_100', props.theme);
|
|
64
64
|
}, function (props) {
|
|
65
65
|
return COLORS.getColor('accent1_700', props.theme);
|
|
66
66
|
}, ButtonContainer, function (props) {
|
|
67
67
|
return COLORS.getColor('accent1_400', props.theme);
|
|
68
68
|
}, TextContainer, function (props) {
|
|
69
|
-
return props
|
|
69
|
+
return props.$isSelected ? COLORS.getColor('accent1_300', props.theme) : COLORS.getColor('accent1_200', props.theme);
|
|
70
70
|
}, function (props) {
|
|
71
71
|
return COLORS.getColor('accent1_800', props.theme);
|
|
72
72
|
});
|
|
@@ -106,10 +106,10 @@ var QuizButton = function QuizButton(_ref) {
|
|
|
106
106
|
var theme = useTheme();
|
|
107
107
|
return /*#__PURE__*/_jsxs(OptionContainer, _objectSpread(_objectSpread({
|
|
108
108
|
onClick: onClick,
|
|
109
|
-
isSelected: selected,
|
|
109
|
+
$isSelected: selected,
|
|
110
110
|
tabIndex: disabled || resultType ? -1 : 0,
|
|
111
111
|
onMouseDown: defaultOnMouseDownHandler,
|
|
112
|
-
size: size,
|
|
112
|
+
$size: size,
|
|
113
113
|
className: 'quiz-button '.concat(selected ? ' selected' : '').concat(disabled ? ' disabled' : '').concat(resultType ? ' result ' + resultType : '').concat(className ? ' ' + className : ''),
|
|
114
114
|
"data-testid": 'container',
|
|
115
115
|
"aria-checked": selected,
|
|
@@ -118,7 +118,7 @@ var QuizButton = function QuizButton(_ref) {
|
|
|
118
118
|
children: [/*#__PURE__*/_jsx(ButtonContainer, {
|
|
119
119
|
"data-testid": 'btnContainer',
|
|
120
120
|
className: 'quiz-button-icon',
|
|
121
|
-
size: size,
|
|
121
|
+
$size: size,
|
|
122
122
|
children: resultType ? renderResultContent(resultType, theme) : type === 'radio' ? /*#__PURE__*/_jsx(RadioButton, {
|
|
123
123
|
selected: selected,
|
|
124
124
|
disabled: disabled,
|
|
@@ -137,9 +137,9 @@ var QuizButton = function QuizButton(_ref) {
|
|
|
137
137
|
}), /*#__PURE__*/_jsx(TextContainer, {
|
|
138
138
|
"data-testid": 'txtContainer',
|
|
139
139
|
className: 'quiz-button-text',
|
|
140
|
-
size: size,
|
|
140
|
+
$size: size,
|
|
141
141
|
children: /*#__PURE__*/_jsx(TextWrapper, {
|
|
142
|
-
size: size,
|
|
142
|
+
$size: size,
|
|
143
143
|
children: text
|
|
144
144
|
})
|
|
145
145
|
})]
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"QuizButton.js","names":["React","styled","useTheme","Checkbox","COLORS","defaultOnMouseDownHandler","focusStyles","RadioButton","Size","SystemIcons","ComponentLStyling","ComponentMStyling","ComponentSStyling","ComponentTextStyle","jsx","_jsx","jsxs","_jsxs","TextContainer","div","_templateObject","_taggedTemplateLiteral","props","getColor","theme","size","Small","Large","Regular","TextWrapper","_templateObject2","ButtonContainer","_templateObject3","OptionContainer","_templateObject4","isSelected","renderResultContent","resultType","CheckMark","color","className","Close","QuizButton","_ref","text","type","onClick","id","_ref$selected","selected","_ref$disabled","disabled","_ref$size","Medium","rest","_objectWithoutProperties","_excluded","_objectSpread","tabIndex","onMouseDown","concat","role","children","tabIndexVal","select","propTypes","_pt","oneOf","string","isRequired","func","bool"],"sources":["../../src/QuizButton/QuizButton.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport styled, { useTheme } from 'styled-components';\r\nimport {Checkbox, COLORS, defaultOnMouseDownHandler, focusStyles, RadioButton, Size, SystemIcons} from '..';\r\nimport { ComponentLStyling, ComponentMStyling, ComponentSStyling, ComponentTextStyle } from '../styles/typography';\r\n\r\nconst TextContainer = styled.div<{size: Size}>`\r\n border-radius: 0 8px 8px 0;\r\n display: flex;\r\n background: ${props => COLORS.getColor('accent1_20', props.theme)};\r\n width: 100%;\r\n\r\n transition: background 100ms ease-in-out;\r\n align-items: center;\r\n\r\n padding: ${props=>props.size===Size.Small?'6px 8px':(props.size===Size.Large?'20px 16px':'12px 16px')};\r\n ${props=>props.size===Size.Small ? ComponentSStyling(ComponentTextStyle.Regular,null) : (props.size===Size.Large ? ComponentLStyling(ComponentTextStyle.Regular,null) : ComponentMStyling(ComponentTextStyle.Regular,null))}\r\n`;\r\n\r\nconst TextWrapper = styled.div<{size:Size}>``;\r\n\r\nconst ButtonContainer = styled.div<{size: Size}>`\r\n border-radius: 8px 0 0 8px;\r\n display: flex;\r\n background: ${props => COLORS.getColor('accent1_100', props.theme)};\r\n\r\n width: ${props=>props.size===Size.Small?'32px':(props.size===Size.Large?'64px':'48px')};\r\n\r\n transition: background 100ms ease-in-out;\r\n\r\n .quiz-button-result-icon {\r\n height: ${props=>props.size===Size.Small?'16px':(props.size===Size.Large?'32px':'24px')};\r\n width: ${props=>props.size===Size.Small?'32px':(props.size===Size.Large?'64px':'48px')};\r\n }\r\n\r\n .radio-button-icon, .checkbox-icon {\r\n margin: auto;\r\n min-width: unset;\r\n background: transparent;\r\n\r\n svg {\r\n color: ${props => COLORS.getColor('accent1_600', props.theme)};\r\n }\r\n\r\n &:hover {\r\n background: transparent;\r\n }\r\n\r\n &:active {\r\n background: transparent;\r\n }\r\n }\r\n\r\n .small {\r\n min-width: 32px;\r\n min-height: 32px;\r\n .radio-button-icon, .checkbox-icon {\r\n svg {\r\n height: 16px;\r\n width: 16px;\r\n }\r\n }\r\n }\r\n\r\n .medium {\r\n min-width: 48px;\r\n min-height: 48px;\r\n .radio-button-icon, .checkbox-icon {\r\n svg {\r\n height: 24px;\r\n width: 24px;\r\n }\r\n }\r\n }\r\n\r\n .large {\r\n min-width: 64px;\r\n min-height: 64px;\r\n .radio-button-icon, .checkbox-icon {\r\n svg {\r\n height: 32px;\r\n width: 32px;\r\n }\r\n }\r\n }\r\n`;\r\n\r\nconst OptionContainer = styled.div<{isSelected:boolean, size:Size}>`\r\n display: flex;\r\n flex-direction: row;\r\n cursor: pointer;\r\n max-width: 65ch; \r\n word-break: break-word;\r\n\r\n min-height: ${props=>props.size===Size.Small?'32px':(props.size===Size.Large?'64px':'48px')};\r\n margin-bottom: ${props=>props.size===Size.Small?'16px':(props.size===Size.Large?'32px':'24px')};\r\n\r\n &.selected {\r\n ${TextContainer} {\r\n background: ${props => COLORS.getColor('accent1_100', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('accent1_200', props.theme)};\r\n }\r\n }\r\n \r\n &.disabled {\r\n cursor: not-allowed;\r\n \r\n ${ButtonContainer} {\r\n pointer-events: none;\r\n background: ${props => COLORS.getColor('neutral_100', props.theme)};\r\n }\r\n ${TextContainer} {\r\n pointer-events: none;\r\n background: ${props => COLORS.getColor('neutral_20', props.theme)};\r\n color: ${props => COLORS.getColor('neutral_300', props.theme)};\r\n }\r\n\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n }\r\n }\r\n\r\n &.correct {\r\n ${TextContainer} { \r\n background: ${props => COLORS.getColor('correct_20', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('correct_400', props.theme)};\r\n svg {\r\n margin: auto;\r\n }\r\n }\r\n }\r\n\r\n &.incorrect {\r\n ${TextContainer} { \r\n background: ${props => COLORS.getColor('critical_20', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('critical_500', props.theme)};\r\n svg {\r\n margin: auto;\r\n }\r\n }\r\n }\r\n\r\n &.partial {\r\n ${TextContainer} { \r\n background: ${props => COLORS.getColor('warning_20', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('warning_400', props.theme)};\r\n svg {\r\n margin: auto;\r\n }\r\n }\r\n }\r\n\r\n &:focus,\r\n &.focus-state {\r\n ${focusStyles}\r\n }\r\n\r\n &:hover,\r\n &.hover-state {\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n }\r\n }\r\n\r\n &:active,\r\n &.active-state {\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n }\r\n }\r\n\r\n &:hover:not(.disabled):not(.result),\r\n &.hover-state {\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('accent1_300', props.theme)};\r\n }\r\n ${TextContainer} {\r\n background: ${props=>props.isSelected ? COLORS.getColor('accent1_200', props.theme) : COLORS.getColor('accent1_100', props.theme)};\r\n }\r\n \r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n svg {\r\n color: ${props => COLORS.getColor('accent1_700', props.theme)};\r\n }\r\n }\r\n }\r\n\r\n &:active:not(.disabled):not(.result),\r\n &.active-state {\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('accent1_400', props.theme)};\r\n transition: none;\r\n }\r\n ${TextContainer} {\r\n background: ${props=>props.isSelected ? COLORS.getColor('accent1_300', props.theme) : COLORS.getColor('accent1_200', props.theme)};\r\n transition: none;\r\n }\r\n\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n svg {\r\n color: ${props => COLORS.getColor('accent1_800', props.theme)};\r\n }\r\n }\r\n }\r\n`;\r\n\r\nconst renderResultContent = (resultType: string, theme: any) => {\r\n switch(resultType){\r\n case 'correct' : return <SystemIcons.CheckMark color={COLORS.getColor('white', theme)} className={'quiz-button-result-icon'}/>;\r\n\r\n case 'incorrect' : return <SystemIcons.Close color={COLORS.getColor('white', theme)} className={'quiz-button-result-icon'}/>;\r\n\r\n default : return <SystemIcons.Close color={COLORS.getColor('white', theme)} className={'quiz-button-result-icon'}/>;\r\n }\r\n};\r\n\r\nexport type QuizButtonProps = {\r\n /**\r\n * Optional. The result type of the quiz button. Can be 'correct', 'incorrect', or 'partial'.\r\n */\r\n resultType?: 'correct' | 'incorrect' | 'partial';\r\n\r\n /**\r\n * Required. The text to be displayed on the quiz button.\r\n */\r\n text: string;\r\n\r\n /**\r\n * Optional. A function to be called when the quiz button is clicked.\r\n */\r\n onClick?: (arg:any)=>void;\r\n\r\n /**\r\n * Required. The ID of the quiz button.\r\n */\r\n id: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the quiz button is selected.\r\n */\r\n selected?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the quiz button is disabled.\r\n */\r\n disabled?: boolean;\r\n\r\n /**\r\n * Optional. The size of the quiz button. Can be 'Small', 'Medium', or 'Large'.\r\n */\r\n size?: Size.Small | Size.Medium | Size.Large;\r\n\r\n /**\r\n * Required. The type of the quiz button. Can be 'radio' or 'checkbox'.\r\n */\r\n type: 'radio' | 'checkbox';\r\n} & Omit<React.HTMLAttributes<HTMLDivElement>, 'onClick' | 'id' | 'tabIndex' | 'onMouseDown'>\r\n\r\nconst QuizButton: React.FunctionComponent<QuizButtonProps> = ({\r\n text,\r\n type,\r\n onClick,\r\n resultType,\r\n id,\r\n className,\r\n selected = false,\r\n disabled = false,\r\n size = Size.Medium,\r\n ...rest\r\n }) => {\r\n\r\n const theme = useTheme();\r\n return ( \r\n <OptionContainer\r\n onClick={onClick}\r\n isSelected={selected}\r\n tabIndex={(disabled || resultType) ? -1 : 0}\r\n onMouseDown={defaultOnMouseDownHandler}\r\n size={size}\r\n className={'quiz-button '.concat(selected ? ' selected' : '')\r\n .concat(disabled ? ' disabled' : '')\r\n .concat(resultType ? ' result ' + resultType : '')\r\n .concat(className ? ' ' + className : '')}\r\n data-testid={'container'}\r\n aria-checked={selected}\r\n role={type === 'radio'? 'radio' : 'checkbox'}\r\n {...rest}>\r\n <ButtonContainer data-testid={'btnContainer'} className={'quiz-button-icon'} size={size}>\r\n {\r\n resultType ? renderResultContent(resultType, theme) : (\r\n type==='radio' ? <RadioButton selected={selected} disabled={disabled} size={size} tabIndexVal={-1}\r\n select={()=>{}} id={id}/> : <Checkbox selected={selected} disabled={disabled} size={size} tabIndexVal={-1}\r\n select={()=>{}} id={id}/>\r\n )\r\n }\r\n </ButtonContainer>\r\n\r\n <TextContainer data-testid={'txtContainer'} className={'quiz-button-text'} size={size}>\r\n <TextWrapper size={size}>\r\n {text}\r\n </TextWrapper>\r\n </TextContainer>\r\n </OptionContainer>\r\n );\r\n};\r\n\r\nexport default QuizButton;\r\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"QuizButton.js","names":["React","styled","useTheme","Checkbox","COLORS","defaultOnMouseDownHandler","focusStyles","RadioButton","Size","SystemIcons","ComponentLStyling","ComponentMStyling","ComponentSStyling","ComponentTextStyle","jsx","_jsx","jsxs","_jsxs","TextContainer","div","_templateObject","_taggedTemplateLiteral","props","getColor","theme","$size","Small","Large","Regular","TextWrapper","_templateObject2","ButtonContainer","_templateObject3","OptionContainer","_templateObject4","$isSelected","renderResultContent","resultType","CheckMark","color","className","Close","QuizButton","_ref","text","type","onClick","id","_ref$selected","selected","_ref$disabled","disabled","_ref$size","size","Medium","rest","_objectWithoutProperties","_excluded","_objectSpread","tabIndex","onMouseDown","concat","role","children","tabIndexVal","select","propTypes","_pt","oneOf","string","isRequired","func","bool"],"sources":["../../src/QuizButton/QuizButton.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport styled, { useTheme } from 'styled-components';\r\nimport {Checkbox, COLORS, defaultOnMouseDownHandler, focusStyles, RadioButton, Size, SystemIcons} from '..';\r\nimport { ComponentLStyling, ComponentMStyling, ComponentSStyling, ComponentTextStyle } from '../styles/typography';\r\n\r\nconst TextContainer = styled.div<{$size: Size}>`\r\n border-radius: 0 8px 8px 0;\r\n display: flex;\r\n background: ${props => COLORS.getColor('accent1_20', props.theme)};\r\n width: 100%;\r\n\r\n transition: background 100ms ease-in-out;\r\n align-items: center;\r\n\r\n padding: ${props=>props.$size===Size.Small?'6px 8px':(props.$size===Size.Large?'20px 16px':'12px 16px')};\r\n ${props=>props.$size===Size.Small ? ComponentSStyling(ComponentTextStyle.Regular,null) : (props.$size===Size.Large ? ComponentLStyling(ComponentTextStyle.Regular,null) : ComponentMStyling(ComponentTextStyle.Regular,null))}\r\n`;\r\n\r\nconst TextWrapper = styled.div<{$size:Size}>``;\r\n\r\nconst ButtonContainer = styled.div<{$size: Size}>`\r\n border-radius: 8px 0 0 8px;\r\n display: flex;\r\n background: ${props => COLORS.getColor('accent1_100', props.theme)};\r\n\r\n width: ${props=>props.$size===Size.Small?'32px':(props.$size===Size.Large?'64px':'48px')};\r\n\r\n transition: background 100ms ease-in-out;\r\n\r\n .quiz-button-result-icon {\r\n height: ${props=>props.$size===Size.Small?'16px':(props.$size===Size.Large?'32px':'24px')};\r\n width: ${props=>props.$size===Size.Small?'32px':(props.$size===Size.Large?'64px':'48px')};\r\n }\r\n\r\n .radio-button-icon, .checkbox-icon {\r\n margin: auto;\r\n min-width: unset;\r\n background: transparent;\r\n\r\n svg {\r\n color: ${props => COLORS.getColor('accent1_600', props.theme)};\r\n }\r\n\r\n &:hover {\r\n background: transparent;\r\n }\r\n\r\n &:active {\r\n background: transparent;\r\n }\r\n }\r\n\r\n .small {\r\n min-width: 32px;\r\n min-height: 32px;\r\n .radio-button-icon, .checkbox-icon {\r\n svg {\r\n height: 16px;\r\n width: 16px;\r\n }\r\n }\r\n }\r\n\r\n .medium {\r\n min-width: 48px;\r\n min-height: 48px;\r\n .radio-button-icon, .checkbox-icon {\r\n svg {\r\n height: 24px;\r\n width: 24px;\r\n }\r\n }\r\n }\r\n\r\n .large {\r\n min-width: 64px;\r\n min-height: 64px;\r\n .radio-button-icon, .checkbox-icon {\r\n svg {\r\n height: 32px;\r\n width: 32px;\r\n }\r\n }\r\n }\r\n`;\r\n\r\nconst OptionContainer = styled.div<{$isSelected:boolean, $size:Size}>`\r\n display: flex;\r\n flex-direction: row;\r\n cursor: pointer;\r\n max-width: 65ch; \r\n word-break: break-word;\r\n\r\n min-height: ${props=>props.$size===Size.Small?'32px':(props.$size===Size.Large?'64px':'48px')};\r\n margin-bottom: ${props=>props.$size===Size.Small?'16px':(props.$size===Size.Large?'32px':'24px')};\r\n\r\n &.selected {\r\n ${TextContainer} {\r\n background: ${props => COLORS.getColor('accent1_100', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('accent1_200', props.theme)};\r\n }\r\n }\r\n \r\n &.disabled {\r\n cursor: not-allowed;\r\n \r\n ${ButtonContainer} {\r\n pointer-events: none;\r\n background: ${props => COLORS.getColor('neutral_100', props.theme)};\r\n }\r\n ${TextContainer} {\r\n pointer-events: none;\r\n background: ${props => COLORS.getColor('neutral_20', props.theme)};\r\n color: ${props => COLORS.getColor('neutral_300', props.theme)};\r\n }\r\n\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n }\r\n }\r\n\r\n &.correct {\r\n ${TextContainer} { \r\n background: ${props => COLORS.getColor('correct_20', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('correct_400', props.theme)};\r\n svg {\r\n margin: auto;\r\n }\r\n }\r\n }\r\n\r\n &.incorrect {\r\n ${TextContainer} { \r\n background: ${props => COLORS.getColor('critical_20', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('critical_500', props.theme)};\r\n svg {\r\n margin: auto;\r\n }\r\n }\r\n }\r\n\r\n &.partial {\r\n ${TextContainer} { \r\n background: ${props => COLORS.getColor('warning_20', props.theme)};\r\n }\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('warning_400', props.theme)};\r\n svg {\r\n margin: auto;\r\n }\r\n }\r\n }\r\n\r\n &:focus,\r\n &.focus-state {\r\n ${focusStyles}\r\n }\r\n\r\n &:hover,\r\n &.hover-state {\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n }\r\n }\r\n\r\n &:active,\r\n &.active-state {\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n }\r\n }\r\n\r\n &:hover:not(.disabled):not(.result),\r\n &.hover-state {\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('accent1_300', props.theme)};\r\n }\r\n ${TextContainer} {\r\n background: ${props=>props.$isSelected ? COLORS.getColor('accent1_200', props.theme) : COLORS.getColor('accent1_100', props.theme)};\r\n }\r\n \r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n svg {\r\n color: ${props => COLORS.getColor('accent1_700', props.theme)};\r\n }\r\n }\r\n }\r\n\r\n &:active:not(.disabled):not(.result),\r\n &.active-state {\r\n ${ButtonContainer} {\r\n background: ${props => COLORS.getColor('accent1_400', props.theme)};\r\n transition: none;\r\n }\r\n ${TextContainer} {\r\n background: ${props=>props.$isSelected ? COLORS.getColor('accent1_300', props.theme) : COLORS.getColor('accent1_200', props.theme)};\r\n transition: none;\r\n }\r\n\r\n .radio-button-icon, .checkbox-icon {\r\n background: transparent;\r\n svg {\r\n color: ${props => COLORS.getColor('accent1_800', props.theme)};\r\n }\r\n }\r\n }\r\n`;\r\n\r\nconst renderResultContent = (resultType: string, theme: any) => {\r\n switch(resultType){\r\n case 'correct' : return <SystemIcons.CheckMark color={COLORS.getColor('white', theme)} className={'quiz-button-result-icon'}/>;\r\n\r\n case 'incorrect' : return <SystemIcons.Close color={COLORS.getColor('white', theme)} className={'quiz-button-result-icon'}/>;\r\n\r\n default : return <SystemIcons.Close color={COLORS.getColor('white', theme)} className={'quiz-button-result-icon'}/>;\r\n }\r\n};\r\n\r\nexport type QuizButtonProps = {\r\n /**\r\n * Optional. The result type of the quiz button. Can be 'correct', 'incorrect', or 'partial'.\r\n */\r\n resultType?: 'correct' | 'incorrect' | 'partial';\r\n\r\n /**\r\n * Required. The text to be displayed on the quiz button.\r\n */\r\n text: string;\r\n\r\n /**\r\n * Optional. A function to be called when the quiz button is clicked.\r\n */\r\n onClick?: (arg:any)=>void;\r\n\r\n /**\r\n * Required. The ID of the quiz button.\r\n */\r\n id: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the quiz button is selected.\r\n */\r\n selected?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the quiz button is disabled.\r\n */\r\n disabled?: boolean;\r\n\r\n /**\r\n * Optional. The size of the quiz button. Can be 'Small', 'Medium', or 'Large'.\r\n */\r\n size?: Size.Small | Size.Medium | Size.Large;\r\n\r\n /**\r\n * Required. The type of the quiz button. Can be 'radio' or 'checkbox'.\r\n */\r\n type: 'radio' | 'checkbox';\r\n} & Omit<React.HTMLAttributes<HTMLDivElement>, 'onClick' | 'id' | 'tabIndex' | 'onMouseDown'>\r\n\r\nconst QuizButton: React.FunctionComponent<QuizButtonProps> = ({\r\n text,\r\n type,\r\n onClick,\r\n resultType,\r\n id,\r\n className,\r\n selected = false,\r\n disabled = false,\r\n size = Size.Medium,\r\n ...rest\r\n }) => {\r\n\r\n const theme = useTheme();\r\n return ( \r\n <OptionContainer\r\n onClick={onClick}\r\n $isSelected={selected}\r\n tabIndex={(disabled || resultType) ? -1 : 0}\r\n onMouseDown={defaultOnMouseDownHandler}\r\n $size={size}\r\n className={'quiz-button '.concat(selected ? ' selected' : '')\r\n .concat(disabled ? ' disabled' : '')\r\n .concat(resultType ? ' result ' + resultType : '')\r\n .concat(className ? ' ' + className : '')}\r\n data-testid={'container'}\r\n aria-checked={selected}\r\n role={type === 'radio'? 'radio' : 'checkbox'}\r\n {...rest}>\r\n <ButtonContainer data-testid={'btnContainer'} className={'quiz-button-icon'} $size={size}>\r\n {\r\n resultType ? renderResultContent(resultType, theme) : (\r\n type==='radio' ? <RadioButton selected={selected} disabled={disabled} size={size} tabIndexVal={-1}\r\n select={()=>{}} id={id}/> : <Checkbox selected={selected} disabled={disabled} size={size} tabIndexVal={-1}\r\n select={()=>{}} id={id}/>\r\n )\r\n }\r\n </ButtonContainer>\r\n\r\n <TextContainer data-testid={'txtContainer'} className={'quiz-button-text'} $size={size}>\r\n <TextWrapper $size={size}>\r\n {text}\r\n </TextWrapper>\r\n </TextContainer>\r\n </OptionContainer>\r\n );\r\n};\r\n\r\nexport default QuizButton;\r\n"],"mappings":"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","ignoreList":[]}
|
package/dist/Table/Table.cjs
CHANGED
|
@@ -387,7 +387,7 @@ var Table = function Table(props) {
|
|
|
387
387
|
nextPage: nextPage,
|
|
388
388
|
prevPage: previousPage
|
|
389
389
|
})), showLoadingIndicator && /*#__PURE__*/(0, _jsxRuntime.jsx)(_TableStyles.StyledTableSpinner, {
|
|
390
|
-
zindex: loaderZIndex,
|
|
390
|
+
$zindex: loaderZIndex,
|
|
391
391
|
children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_LoadingIndicator.LoadingIndicator, {
|
|
392
392
|
size: _types.Size.Medium
|
|
393
393
|
})
|