@laerdal/life-react-components 6.0.7 → 6.0.8-dev.3.full

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.
@@ -1 +1 @@
1
- {"version":3,"file":"DropdownContent.js","names":["React","styled","TextButton","Size","DropdownContentButtonStyling","ComponentLStyling","ComponentXLStyling","ComponentMStyling","ComponentSStyling","ComponentTextStyle","COLORS","scrollBarStyling","Checkbox","RadioButton","Z_INDEXES","MenuItem","jsx","_jsx","Fragment","_Fragment","jsxs","_jsxs","MAX_MENU_HEIGHT","AVG_OPTION_HEIGHT","OFFSET_BEFORE_SHOW","DropdownContentContainer","div","props","generateToken","componentType","defaultVariant","theme","dropdown","$isButton","$offsetLeft","$offsetTop","$size","Large","Medium","$scrollable","$maxHeight","DropdownContentItemsContainer","hover","active","focus","DropdownContentListContainer","$itemsType","Small","DropdownContentMenuContentContainer","Bold","Regular","DividerContainer","DropdownContentTopItemContainer","DropdownContentActionButtonContainer","Overlay","modal","DropdownContent","forwardRef","_ref","ref","id","customizationProps","alignLeft","isButton","size","isOpen","width","setIsOpen","filter","focused","setFocused","selectedValues","setSelectedValues","messageOnNoResults","outline","containerRef","onActiveDescendantChanged","ariaRolesType","isUp","setIsUp","useState","locationDefined","setLocationDefined","offset","setOffset","top","left","dropdownContentRef","useRef","itemsType","itemsListRef","actionButtonRef","determineDropUp","options","items","rect","current","getBoundingClientRect","windowHeight","window","innerHeight","menuHeight","Math","min","length","instOffsetWithMenu","height","up","setNewFocusedElement","index","newFocusedElement","elRefs","oldFocusedElement","classList","remove","add","scrollIntoView","block","inline","getFilteredItems","filtrationString","toUpperCase","x","value","includes","displayLabel","findNextActiveIndex","direction","i","disabled","handleKeyDown","e","key","preventDefault","focusedNow","arrLength","haveTopItem","undefined","target","focusedElement","click","useEffect","document","addEventListener","removeEventListener","scrollPosition","handleScroll","scrollTop","useLayoutEffect","getCorrectRef","createRef","setElRefs","Array","fill","map","_","pinTopItem","multiSelect","getSuggestions","suggestion","elRef","blur","observer","IntersectionObserver","entries","isIntersecting","activeElement","threshold","rootMargin","observe","calculateOffset","disconnect","handleItemClick","selected","item","newValue","onValueUpdate","getTopItem","visibleItems","allSelected","some","y","showTopItem","suggestions","find","c","selectedFirst","children","role","iconPointerEventsTransparent","onFocus","tabIndexVal","className","select","label","newValues","semiSelected","tabIndex","onClickHandler","stopPropagation","getElements","customContent","style","cls","$alignLeft","scrollable","maxHeight","onScroll","$outline","menuContent","action","actionLabel","icon","actionIcon","loading","actionLoading","actionDisabled","variant","actionVariant","onClick","propTypes","_pt","bool","isRequired","shape","oneOf","node","string","func","arrayOf","noteLabel","showDividerAbove","locked","oneOfType","number"],"sources":["../../src/Dropdown/DropdownContent.tsx"],"sourcesContent":["import React, { MutableRefObject, useCallback } from 'react';\r\nimport styled, { css } from 'styled-components';\r\nimport TextButton from '../Button/TextButton';\r\nimport { Size } from '../types';\r\nimport { DropdownContentButtonStyling } from './CommonStyling';\r\nimport { ComponentLStyling, ComponentXLStyling, ComponentMStyling, ComponentSStyling, ComponentTextStyle } from '../styles/typography';\r\nimport { COLORS, focusStyles, scrollBarStyling } from '../styles';\r\nimport { Checkbox, RadioButton } from '../InputFields';\r\nimport { Z_INDEXES } from '../styles/z-indexes';\r\nimport MenuItem from '../MenuItem/MenuItem';\r\nimport { defaultOnMouseDownHandler } from '../common';\r\n\r\nconst MAX_MENU_HEIGHT = 240;\r\nconst AVG_OPTION_HEIGHT = 48;\r\nconst OFFSET_BEFORE_SHOW = 1000000;\r\n\r\nexport const DropdownContentContainer = styled.div<{ $offsetTop: string; $offsetLeft: string; $isButton: boolean; $alignLeft?: boolean; $size?: Size; $scrollable?: boolean; $maxHeight?: string }>`\r\n display: none;\r\n pointer-events: auto;\r\n position: absolute;\r\n background-color: ${props => COLORS.generateToken({componentType:'bg-surface', defaultVariant:'default'}, props.theme)};\r\n\r\n z-index: ${Z_INDEXES.dropdown};\r\n margin: ${(props) => (props.$isButton ? '-4px' : '4px 0px')};\r\n\r\n inset: 0px auto auto 100%;\r\n\r\n &.show {\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n &.down,\r\n &.up {\r\n ${(props) => `transform: translate(${props.$offsetLeft}, ${props.$offsetTop});`}\r\n }\r\n }\r\n\r\n &.outline:focus:after {\r\n content: '';\r\n pointer-events: none;\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n right: 0;\r\n bottom: 0;\r\n outline: 4px solid black;\r\n outline-offset: 2px;\r\n border-radius: 2px;\r\n }\r\n\r\n &:focus {\r\n outline: none;\r\n }\r\n\r\n ${(props) => (props.$isButton ? DropdownContentButtonStyling : '')};\r\n\r\n box-sizing: border-box;\r\n box-shadow: 0 8px 16px 0 rgba(0, 0, 0, 0.15);\r\n padding: 4px 0px;\r\n\r\n min-width: ${(props) => (props.$size == Size.Large ? '320px' : props.$size == Size.Medium ? '280px' : '240px')};\r\n border-radius: ${(props) => (props.$size == Size.Large ? '10px' : props.$size == Size.Medium ? '8px' : '6px')};\r\n\r\n max-height: ${(props) => (!props.$scrollable ? 'auto' : props.$maxHeight ? props.$maxHeight : props.$size == Size.Large ? '320px' : props.$size == Size.Medium ? '280px' : '240px')};\r\n`;\r\n\r\nexport const DropdownContentItemsContainer = styled.div<{ $size?: Size }>`\r\n > *:hover {\r\n z-index: ${Z_INDEXES.hover};\r\n }\r\n\r\n > *:active,\r\n > *.active {\r\n z-index: ${Z_INDEXES.active};\r\n }\r\n\r\n > *:focus {\r\n z-index: ${Z_INDEXES.focus};\r\n }\r\n`;\r\n\r\nexport const DropdownContentListContainer = styled.div<{ $scrollable?: boolean; $size?: Size; $itemsType?: string; $outline?: boolean }>`\r\n ${(props) => (props.$scrollable ? 'overflow-y: scroll;' : '')}\r\n ${(props) => (props.$scrollable ? 'margin-right: 6px;' : '')}\r\n ${(props) => (props.$scrollable ? 'padding-right: 6px;' : '')}\r\n ${(props) => (props.$itemsType != 'normal' ? 'margin-left: 4px;' : '')}\r\n div.divider {\r\n display: block;\r\n width: calc(100% - 40px);\r\n margin-left: 16px;\r\n border-top: 1px solid #e5e5e5;\r\n position: absolute;\r\n top: 0px;\r\n }\r\n\r\n ${DropdownContentItemsContainer} {\r\n padding-top: ${(props) => (props.$size == Size.Large ? '8px' : props.$size == Size.Medium ? '4px' : '0px')};\r\n padding-bottom: ${(props) => (props.$size == Size.Large ? '8px' : props.$size == Size.Medium ? '4px' : '0px')};\r\n\r\n word-break: break-word;\r\n }\r\n\r\n *:focus {\r\n outline: none !important;\r\n }\r\n\r\n ${scrollBarStyling(Size.Small)}\r\n`;\r\n\r\nconst DropdownContentMenuContentContainer = styled.div<{ $size?: Size }>`\r\n h1,\r\n h2,\r\n h3 {\r\n margin-block-start: 0px;\r\n margin-block-end: 0px;\r\n ${(props) => props.$size == Size.Large && ComponentXLStyling(ComponentTextStyle.Bold, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => props.$size == Size.Medium && ComponentLStyling(ComponentTextStyle.Bold, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => (props.$size == Size.Small || !props.$size) && ComponentMStyling(ComponentTextStyle.Bold, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n padding: ${(props) => (props.$size == Size.Small || !props.$size ? '10px 16px 6px' : props.$size == Size.Medium ? '16px 24px 8px' : '16px 32px 8px')};\r\n }\r\n\r\n p {\r\n margin-block-start: 0px;\r\n margin-block-end: 0px;\r\n ${(props) => props.$size == Size.Large && ComponentLStyling(ComponentTextStyle.Regular, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => props.$size == Size.Medium && ComponentMStyling(ComponentTextStyle.Regular, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => (props.$size == Size.Small || !props.$size) && ComponentSStyling(ComponentTextStyle.Regular, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n padding: ${(props) => (props.$size == Size.Small || !props.$size ? '8px 16px' : props.$size == Size.Medium ? '12px 24px' : '16px 32px')};\r\n }\r\n`;\r\n\r\nconst DividerContainer = styled.div<{ $size?: Size }>`\r\n position: relative;\r\n\r\n margin-top: ${(props) => (props.$size == Size.Large ? '16px' : props.$size == Size.Medium ? '12px' : props.$size == Size.Small || !props.$size ? '8px' : '6px')};\r\n\r\n div.divider {\r\n width: 100%;\r\n margin: 0px;\r\n }\r\n`;\r\n\r\nconst DropdownContentTopItemContainer = styled.div<{ $size?: Size }>`\r\n border-bottom-style: solid;\r\n border-bottom-color: ${props => COLORS.generateToken({componentType:'border', defaultVariant:'subtle'}, props.theme)};\r\n border-bottom-width: 1px;\r\n margin-right: 22px;\r\n`;\r\n\r\nconst DropdownContentActionButtonContainer = styled.div<{ $size?: Size; $scrollable?: boolean }>`\r\n ${(props) => (props.$scrollable ? `border-top: 1px solid ${COLORS.generateToken({componentType:'border', defaultVariant:'subtle'}, props.theme)};` : '')}\r\n ${(props) => (props.$scrollable ? 'margin-top: 4px;' : '')}\r\n\r\n padding: ${(props) => (props.$size === Size.Small || !props.$size ? '4px 16px 0px' : props.$size === Size.Medium ? '12px 16px 8px' : '16px 16px 12px')};\r\n\r\n button {\r\n width: 100%;\r\n }\r\n`;\r\n\r\nconst Overlay = styled.div`\r\n position: relative;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n pointer-events: none;\r\n z-index: ${Z_INDEXES.modal};\r\n`;\r\n\r\nexport interface DropdownItem {\r\n /** Required. Value of the DropdownItem. */\r\n value: string;\r\n /** Optional. Display label to show in the MenuItem. If not provided then 'value' will be used as label. */\r\n displayLabel?: string;\r\n /** Optional. Note label to be shown under the Display label in the MenuItem. */\r\n noteLabel?: string;\r\n /** */\r\n suggestion?: boolean;\r\n /** Optional. Show dividing line on the top of the item. */\r\n showDividerAbove?: boolean;\r\n /** Optional. If disabled user can not interact with the item. */\r\n disabled?: boolean;\r\n /** Optional. If item is locked then user can not interact with the item and 'lock' icon is shown on the right side of the item. */\r\n locked?: boolean;\r\n /** Optional. Icon to be shown on the left side of the menu item */\r\n icon?: React.ReactNode;\r\n /** */\r\n customContent?: React.ReactNode;\r\n}\r\n\r\nexport interface DropdownCustomizationProps {\r\n itemsType?: 'radio' | 'checkbox' | 'normal';\r\n menuContent?: React.ReactNode;\r\n scrollable?: boolean;\r\n multiSelect?: boolean;\r\n maxHeight?: string;\r\n actionLabel?: string;\r\n actionVariant?: 'primary' | 'secondary' | 'tertiary' | undefined;\r\n actionIcon?: React.ReactNode;\r\n actionLoading?: boolean;\r\n actionDisabled?: boolean;\r\n action: () => boolean | void | undefined;\r\n pinTopItem?: boolean;\r\n onValueUpdate: (values: string[]) => boolean | void | undefined;\r\n items: DropdownItem[];\r\n}\r\n\r\nexport interface DropdownProps {\r\n isButton: boolean;\r\n customizationProps: DropdownCustomizationProps;\r\n alignLeft?: boolean;\r\n isOpen: boolean;\r\n setIsOpen: (open: boolean) => void;\r\n size?: Size.Small | Size.Medium | Size.Large;\r\n id: string;\r\n filter: string;\r\n width?: string;\r\n onActiveDescendantChanged?: (descendantId?: string) => void;\r\n selectedValues: string[];\r\n setSelectedValues: (val: string[]) => void;\r\n messageOnNoResults: string;\r\n focused: number | null;\r\n setFocused: (focused: number | null) => void;\r\n outline?: boolean;\r\n containerRef: React.RefObject<HTMLDivElement | null>;\r\n ariaRolesType?: 'input' | 'menu';\r\n}\r\n\r\nconst DropdownContent = React.forwardRef<HTMLDivElement, DropdownProps>(\r\n (\r\n {\r\n id,\r\n customizationProps,\r\n alignLeft,\r\n isButton,\r\n size,\r\n isOpen,\r\n width,\r\n setIsOpen,\r\n filter,\r\n focused,\r\n setFocused,\r\n selectedValues,\r\n setSelectedValues,\r\n messageOnNoResults,\r\n outline,\r\n containerRef,\r\n onActiveDescendantChanged,\r\n ariaRolesType = 'menu',\r\n },\r\n ref,\r\n ) => {\r\n const [isUp, setIsUp] = React.useState<boolean>(false);\r\n const [locationDefined, setLocationDefined] = React.useState<boolean>(false);\r\n const [offset, setOffset] = React.useState<{ top: string; left: string }>({ top: '0', left: '0' });\r\n\r\n const dropdownContentRef = (ref as MutableRefObject<HTMLDivElement>) ?? React.useRef<HTMLDivElement>(null);\r\n\r\n if (!customizationProps.itemsType) customizationProps.itemsType = 'normal';\r\n if (!size) size = Size.Small;\r\n\r\n const itemsListRef = React.useRef<HTMLDivElement>(null);\r\n const actionButtonRef = React.useRef<HTMLButtonElement>(null);\r\n\r\n const determineDropUp = () => {\r\n const options = customizationProps.items;\r\n\r\n const rect = containerRef.current!.getBoundingClientRect();\r\n\r\n const windowHeight = window.innerHeight;\r\n const menuHeight = Math.min(MAX_MENU_HEIGHT, options.length * AVG_OPTION_HEIGHT);\r\n const instOffsetWithMenu = rect.top + rect.height + menuHeight;\r\n\r\n const up = instOffsetWithMenu >= windowHeight;\r\n\r\n setOffset({\r\n top: up ? `calc(-100% - ${rect.height}px ${isButton ? '' : '- 8px'})` : '0',\r\n left: alignLeft ? `calc(-${rect.width}px)` : `calc(-100%)`,\r\n });\r\n\r\n setIsUp(up);\r\n setLocationDefined(true);\r\n };\r\n\r\n const setNewFocusedElement = (index: number) => {\r\n if (outline) dropdownContentRef.current?.focus();\r\n\r\n const newFocusedElement = elRefs[index];\r\n if (onActiveDescendantChanged) onActiveDescendantChanged(index == 0 ? `${id}_topitem` : `${id}_${index}`);\r\n\r\n const oldFocusedElement = focused || focused === 0 ? elRefs[focused] : null;\r\n if (newFocusedElement && newFocusedElement !== oldFocusedElement) {\r\n setFocused(index);\r\n oldFocusedElement?.current?.classList.remove('dropdown-hover');\r\n\r\n newFocusedElement.current?.classList.add('dropdown-hover');\r\n newFocusedElement.current?.scrollIntoView({\r\n block: 'nearest',\r\n inline: 'nearest',\r\n });\r\n }\r\n };\r\n\r\n const getFilteredItems = () => {\r\n const filtrationString = (filter ?? '').toUpperCase();\r\n return customizationProps.items.filter((x) => x?.value?.toUpperCase().includes(filtrationString) || x?.displayLabel?.toUpperCase().includes(filtrationString));\r\n };\r\n\r\n const findNextActiveIndex = (index: number, direction: number, items: DropdownItem[]) => {\r\n for (let i = index + direction; i > 0 && i <= items.length; i += direction) {\r\n if (!items[i - 1]?.disabled) {\r\n return i;\r\n }\r\n }\r\n\r\n return index;\r\n };\r\n\r\n const handleKeyDown = (e: KeyboardEvent) => {\r\n if (isOpen) {\r\n if (e.key === 'ArrowUp' || e.key === 'Up') {\r\n e.preventDefault();\r\n let focusedNow = focused || focused === 0 ? focused : arrLength + 1;\r\n if (!!focusedNow) {\r\n focusedNow = focusedNow === 1 && haveTopItem() ? 0 : findNextActiveIndex(focusedNow, -1, getFilteredItems());\r\n\r\n setNewFocusedElement(focusedNow);\r\n }\r\n } else if (e.key === 'ArrowDown' || e.key === 'Down') {\r\n e.preventDefault();\r\n let focusedNow = focused;\r\n\r\n focusedNow = !!focusedNow || focusedNow === 0 ? findNextActiveIndex(focusedNow, 1, getFilteredItems()) : haveTopItem() ? 0 : 1;\r\n\r\n setNewFocusedElement(focusedNow);\r\n } else if (e.key === 'Escape' || e.key === 'Esc') {\r\n setIsOpen(false);\r\n setFocused(null);\r\n if (onActiveDescendantChanged) onActiveDescendantChanged(undefined);\r\n } else if ((e.key === 'Enter' || e.key === ' ') && focused !== null && e.target !== actionButtonRef?.current) {\r\n e.preventDefault();\r\n const focusedElement = elRefs[focused];\r\n if (focusedElement) {\r\n focusedElement.current?.click();\r\n }\r\n if (onActiveDescendantChanged) onActiveDescendantChanged(undefined);\r\n }\r\n }\r\n };\r\n\r\n React.useEffect(() => {\r\n document.addEventListener('keydown', handleKeyDown);\r\n return () => {\r\n document.removeEventListener('keydown', handleKeyDown);\r\n };\r\n });\r\n\r\n const scrollPosition = React.useRef<number | undefined>(0);\r\n const handleScroll = () => {\r\n scrollPosition.current = itemsListRef.current?.scrollTop;\r\n };\r\n React.useLayoutEffect(() => {\r\n if (itemsListRef.current) itemsListRef.current.scrollTop = scrollPosition.current ?? 0;\r\n }, [selectedValues]);\r\n\r\n const getCorrectRef = (ref: React.RefObject<HTMLElement | null>): React.RefObject<HTMLElement | null> => {\r\n switch (customizationProps.itemsType) {\r\n case 'normal':\r\n return (ref as React.RefObject<HTMLButtonElement | null>) || React.createRef<HTMLButtonElement>();\r\n default:\r\n return (ref as React.RefObject<HTMLDivElement | null>) || React.createRef<HTMLDivElement>();\r\n }\r\n };\r\n\r\n const arrLength = getFilteredItems().length;\r\n const [elRefs, setElRefs] = React.useState<React.RefObject<HTMLElement | null>[]>([]);\r\n\r\n React.useEffect(() => {\r\n if (elRefs?.length !== arrLength) {\r\n setFocused(null);\r\n }\r\n\r\n setElRefs((elRefs) =>\r\n Array(arrLength + 1)\r\n .fill(null)\r\n .map((_, i) => getCorrectRef(elRefs[i])),\r\n );\r\n }, [isOpen, arrLength]);\r\n\r\n React.useLayoutEffect(() => {\r\n isOpen && !locationDefined && determineDropUp();\r\n }, [isOpen, locationDefined]);\r\n\r\n const haveTopItem = () => {\r\n if (!customizationProps.pinTopItem) return false;\r\n\r\n if (customizationProps.itemsType === 'radio' && selectedValues && selectedValues?.length > 0) return true;\r\n else if (customizationProps.itemsType === 'checkbox' && (customizationProps.multiSelect || selectedValues?.length > 0)) return true;\r\n else if (customizationProps.itemsType === 'normal' && getSuggestions()?.length > 0) return true;\r\n return false;\r\n };\r\n\r\n const getSuggestions = () => {\r\n return getFilteredItems().filter((x) => x.suggestion);\r\n };\r\n\r\n /**\r\n * when dropdown opens set correct position of focused item\r\n * */\r\n React.useLayoutEffect(() => {\r\n if (isOpen && (focused || focused === 0)) {\r\n setNewFocusedElement(focused === 0 && !haveTopItem() ? 1 : focused);\r\n }\r\n }, [isOpen, focused]);\r\n\r\n /**\r\n * Reset dropdown content state on close\r\n * */\r\n React.useEffect(() => {\r\n if (!isOpen) {\r\n setLocationDefined(false);\r\n for (let elRef of elRefs) {\r\n elRef.current?.classList.remove('dropdown-hover');\r\n }\r\n setFocused(null);\r\n if(onActiveDescendantChanged) onActiveDescendantChanged(undefined);\r\n dropdownContentRef.current?.classList.remove('outline');\r\n dropdownContentRef.current?.blur();\r\n } else {\r\n if (outline) {\r\n dropdownContentRef.current?.classList.add('outline');\r\n dropdownContentRef.current?.focus();\r\n }\r\n }\r\n }, [isOpen, dropdownContentRef, focused, outline]);\r\n\r\n /**\r\n * Scroll item container to top when dropdown opens\r\n * */\r\n React.useEffect(() => {\r\n if (isOpen && itemsListRef.current) {\r\n itemsListRef.current.scrollTop = 0;\r\n }\r\n }, [isOpen]);\r\n\r\n React.useEffect(() => {\r\n if (isOpen) {\r\n const observer = new IntersectionObserver(function (entries) {\r\n if (!entries[0].isIntersecting) {\r\n setIsOpen(false);\r\n //@ts-ignore\r\n document?.activeElement?.blur();\r\n }\r\n }, {threshold: [0], rootMargin: '8px'});\r\n\r\n observer.observe(containerRef.current!);\r\n\r\n calculateOffset();\r\n window.addEventListener('scroll', calculateOffset, true);\r\n window.addEventListener('resize', calculateOffset);\r\n\r\n return () => {\r\n observer.disconnect();\r\n window.removeEventListener('scroll', calculateOffset, true);\r\n window.removeEventListener('resize', calculateOffset);\r\n }\r\n }\r\n return () => {};\r\n }, [isOpen]);\r\n\r\n const handleItemClick = (selected: boolean, item: DropdownItem) => {\r\n let newValue: string[] = [];\r\n if (customizationProps.multiSelect) {\r\n if (selected) newValue = [...selectedValues, item.value];\r\n else newValue = selectedValues.filter((x) => x != item.value);\r\n } else newValue = selected ? [item.value] : [];\r\n\r\n setSelectedValues(newValue);\r\n if (customizationProps.onValueUpdate && customizationProps.onValueUpdate(newValue)) {\r\n setIsOpen(false);\r\n }\r\n };\r\n\r\n const getTopItem = () => {\r\n if (!customizationProps.pinTopItem) return;\r\n const visibleItems = getFilteredItems();\r\n const allSelected = selectedValues?.filter((x) => visibleItems.some((y) => y.value == x)).length == visibleItems.length;\r\n let showTopItem = false;\r\n const suggestions = getSuggestions();\r\n const displayLabel = selectedValues[0] ? customizationProps.items?.find((c) => c.value === selectedValues[0])?.displayLabel : undefined;\r\n if (customizationProps.itemsType == 'radio' && selectedValues && selectedValues?.length > 0) showTopItem = true;\r\n else if (customizationProps.itemsType == 'checkbox' && (customizationProps.multiSelect || selectedValues?.length > 0)) showTopItem = true;\r\n else if (customizationProps.itemsType == 'normal' && suggestions.length > 0) showTopItem = true;\r\n\r\n if (!showTopItem) return;\r\n\r\n const selectedFirst = selectedValues.length > 0 ? visibleItems.find((x) => x.value == selectedValues[0]) : null;\r\n\r\n return (\r\n <DropdownContentTopItemContainer $size={size}>\r\n {customizationProps.itemsType === 'radio' && (\r\n <RadioButton\r\n ref={elRefs[0] as React.RefObject<HTMLDivElement | null>}\r\n role='menuitemradio'\r\n iconPointerEventsTransparent={true}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_topitem`)}\r\n tabIndexVal={-1}\r\n className={`${focused === 0 ? 'dropdown-hover' : ''}`}\r\n select={() => {}}\r\n label={selectedFirst?.displayLabel ?? selectedFirst?.value}\r\n size={size}\r\n id={`${id}_topitem`}\r\n selected={true}\r\n />\r\n )}\r\n {customizationProps.itemsType === 'checkbox' && (\r\n <Checkbox\r\n ref={elRefs[0] as React.RefObject<HTMLDivElement | null>}\r\n role='menuitemcheckbox'\r\n tabIndexVal={-1}\r\n className={`${focused === 0 ? 'dropdown-hover' : ''}`}\r\n select={(selected: boolean) => {\r\n if (!customizationProps.multiSelect) return;\r\n\r\n const newValues = selected ? visibleItems.map((x) => x.value) : [];\r\n setSelectedValues(newValues);\r\n if (customizationProps.onValueUpdate && customizationProps.onValueUpdate(newValues)) setIsOpen(false);\r\n }}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_topitem`)}\r\n iconPointerEventsTransparent={true}\r\n semiSelected={customizationProps.multiSelect && !allSelected && selectedValues?.length > 0}\r\n size={size}\r\n id={`${id}_checkbox_selectall`}\r\n label={customizationProps.multiSelect ? 'Select all' : selectedFirst?.displayLabel ?? selectedFirst?.value}\r\n selected={!customizationProps.multiSelect || allSelected}\r\n />\r\n )}\r\n {customizationProps.itemsType === 'normal' && (\r\n <>\r\n {suggestions.map((x) => (\r\n <MenuItem\r\n role={ariaRolesType == 'input' ? 'option' : 'menu'} \r\n key={`${id}_topitem_${x.value}`}\r\n item={x}\r\n size={size}\r\n active={false}\r\n tabIndex={-1}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_topitem`)}\r\n className={`${focused === 0 ? 'dropdown-hover' : ''}`}\r\n ref={elRefs[0] as React.RefObject<HTMLButtonElement | null>}\r\n id={`${id}_topitem`}\r\n onClickHandler={(e: any) => {\r\n e.stopPropagation();\r\n customizationProps.onValueUpdate([x.value]);\r\n setSelectedValues([x.value]);\r\n setIsOpen(false);\r\n setFocused(null);\r\n }}\r\n />\r\n ))}\r\n </>\r\n )}\r\n </DropdownContentTopItemContainer>\r\n );\r\n };\r\n\r\n const getElements = (messageOnNoResults: string, size: Size.Small | Size.Medium | Size.Large) => {\r\n if (getFilteredItems().length === 0) {\r\n return <MenuItem item={{ value: messageOnNoResults, disabled: true }} size={size} id=\"noResultsFound\" active={false} onClickHandler={(e) => {}} />;\r\n }\r\n return (\r\n <DropdownContentItemsContainer $size={size}>\r\n {getFilteredItems()\r\n .filter((x) => x && (customizationProps.itemsType != 'normal' || !x.suggestion))\r\n .map((item, index) => {\r\n return (\r\n <React.Fragment key={`key_${id}_${item.value}`}>\r\n {item.customContent}\r\n {!item.customContent && customizationProps.itemsType == 'radio' && (\r\n <RadioButton\r\n role='menuitemradio'\r\n select={(selected: boolean) => handleItemClick(selected, item)}\r\n ref={elRefs[index + 1] as React.RefObject<HTMLDivElement | null>}\r\n size={size}\r\n tabIndexVal={-1}\r\n className={`${index + 1 === focused ? 'dropdown-hover' : ''}`}\r\n iconPointerEventsTransparent={true}\r\n disabled={item?.disabled}\r\n key={`key_${id}_${index + 1}`}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_${index + 1}`)}\r\n id={`${id}_${index + 1}`}\r\n label={item.displayLabel ?? item.value}\r\n selected={selectedValues?.includes(item.value)}\r\n />\r\n )}\r\n {!item.customContent && customizationProps.itemsType == 'checkbox' && (\r\n <Checkbox\r\n role='menuitemcheckbox'\r\n select={(selected: boolean) => handleItemClick(selected, item)}\r\n iconPointerEventsTransparent={true}\r\n disabled={item?.disabled}\r\n className={`${index + 1 === focused ? 'dropdown-hover' : ''}`}\r\n ref={elRefs[index + 1] as React.RefObject<HTMLDivElement | null>}\r\n size={size}\r\n tabIndexVal={-1}\r\n key={`key_${id}_${index + 1}`}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_${index + 1}`)}\r\n id={`${id}_${index + 1}`}\r\n label={item.displayLabel ?? item.value}\r\n selected={selectedValues?.includes(item.value)}\r\n />\r\n )}\r\n {!item.customContent && (customizationProps.itemsType == 'normal' || !customizationProps.itemsType) && (\r\n <MenuItem\r\n role={ariaRolesType == 'input' ? 'option' : 'menu'} \r\n key={`key_${id}_${index + 1}`}\r\n id={`${id}_${index + 1}`}\r\n item={item}\r\n tabIndex={-1}\r\n className={`${index + 1 === focused ? 'dropdown-hover' : ''}`}\r\n size={size}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_${index + 1}`)}\r\n active={selectedValues?.includes(item.value)}\r\n ref={elRefs[index + 1] as React.RefObject<HTMLButtonElement | null>}\r\n onClickHandler={(e: any) => {\r\n e.stopPropagation();\r\n customizationProps.onValueUpdate([item.value]);\r\n setSelectedValues([item.value]);\r\n setIsOpen(false);\r\n setFocused(null);\r\n }}\r\n />\r\n )}\r\n </React.Fragment>\r\n );\r\n })}\r\n </DropdownContentItemsContainer>\r\n );\r\n };\r\n\r\n const calculateOffset = () => {\r\n const rect = containerRef?.current?.getBoundingClientRect();\r\n if (rect) {\r\n dropdownContentRef.current.style.width = width ?? `${rect.width}px`;\r\n }\r\n determineDropUp();\r\n };\r\n\r\n const cls = `${isOpen ? 'show' : ''} ${isOpen && outline ? 'outline' : ''} ${locationDefined ? (isUp ? 'up' : 'down') : ''}`;\r\n\r\n return (\r\n <Overlay>\r\n <DropdownContentContainer\r\n role={ariaRolesType == \"menu\" ? \"menu\" : \"optionlist\"}\r\n ref={dropdownContentRef}\r\n $size={size}\r\n $offsetTop={offset.top}\r\n id={id}\r\n $offsetLeft={offset.left}\r\n tabIndex={-1}\r\n $isButton={isButton}\r\n $alignLeft={alignLeft}\r\n $scrollable={customizationProps.scrollable}\r\n $maxHeight={customizationProps.maxHeight}\r\n className={cls}>\r\n <DropdownContentListContainer\r\n tabIndex={-1}\r\n role=\"group\"\r\n $size={size}\r\n $itemsType={customizationProps.itemsType}\r\n onScroll={handleScroll}\r\n ref={itemsListRef}\r\n $outline={outline}\r\n $scrollable={customizationProps.scrollable}>\r\n {customizationProps.menuContent && (\r\n <DropdownContentMenuContentContainer $size={size}>\r\n {customizationProps.menuContent}\r\n <DividerContainer $size={size}>\r\n <div className=\"divider\" />\r\n </DividerContainer>\r\n </DropdownContentMenuContentContainer>\r\n )}\r\n {customizationProps.pinTopItem && getTopItem()}\r\n {getElements(messageOnNoResults, size)}\r\n </DropdownContentListContainer>\r\n {customizationProps.action && customizationProps.actionLabel && (\r\n <DropdownContentActionButtonContainer $size={size} $scrollable={customizationProps.scrollable}>\r\n <TextButton\r\n width=\"100%\"\r\n role=\"menuitem\"\r\n icon={customizationProps.actionIcon}\r\n ref={actionButtonRef}\r\n loading={customizationProps.actionLoading}\r\n disabled={customizationProps.actionDisabled}\r\n variant={customizationProps.actionVariant ?? 'primary'}\r\n size={size}\r\n onClick={() => customizationProps.action() && setIsOpen(false)}>\r\n {customizationProps.actionLabel}\r\n </TextButton>\r\n </DropdownContentActionButtonContainer>\r\n )}\r\n </DropdownContentContainer>\r\n </Overlay>\r\n );\r\n },\r\n);\r\n\r\nexport default DropdownContent;\r\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"DropdownContent.js","names":["React","styled","TextButton","Size","DropdownContentButtonStyling","ComponentLStyling","ComponentXLStyling","ComponentMStyling","ComponentSStyling","ComponentTextStyle","COLORS","scrollBarStyling","Checkbox","RadioButton","Z_INDEXES","MenuItem","jsx","_jsx","Fragment","_Fragment","jsxs","_jsxs","MAX_MENU_HEIGHT","AVG_OPTION_HEIGHT","OFFSET_BEFORE_SHOW","DropdownContentContainer","div","props","generateToken","componentType","defaultVariant","theme","dropdown","$isButton","$offsetLeft","$offsetTop","$size","Large","Medium","$scrollable","$maxHeight","DropdownContentItemsContainer","hover","active","focus","DropdownContentListContainer","$itemsType","Small","DropdownContentMenuContentContainer","Bold","Regular","DividerContainer","DropdownContentTopItemContainer","DropdownContentActionButtonContainer","Overlay","modal","DropdownContent","forwardRef","_ref","ref","id","customizationProps","alignLeft","isButton","size","isOpen","width","setIsOpen","filter","focused","setFocused","selectedValues","setSelectedValues","messageOnNoResults","outline","containerRef","onActiveDescendantChanged","ariaRolesType","isUp","setIsUp","useState","locationDefined","setLocationDefined","offset","setOffset","top","left","dropdownContentRef","useRef","itemsType","itemsListRef","actionButtonRef","determineDropUp","options","items","rect","current","getBoundingClientRect","windowHeight","window","innerHeight","windowWidth","innerWidth","isMobile","menuHeight","Math","min","length","instOffsetWithMenu","height","up","leftOffset","dropdownWidth","rightEdge","right","setNewFocusedElement","index","newFocusedElement","elRefs","oldFocusedElement","classList","remove","add","scrollIntoView","block","inline","getFilteredItems","filtrationString","toUpperCase","x","value","includes","displayLabel","findNextActiveIndex","direction","i","disabled","handleKeyDown","e","key","preventDefault","focusedNow","arrLength","haveTopItem","undefined","target","focusedElement","click","useEffect","document","addEventListener","removeEventListener","scrollPosition","handleScroll","scrollTop","useLayoutEffect","getCorrectRef","createRef","setElRefs","Array","fill","map","_","pinTopItem","multiSelect","getSuggestions","suggestion","elRef","blur","observer","IntersectionObserver","entries","isIntersecting","activeElement","threshold","rootMargin","observe","calculateOffset","disconnect","handleItemClick","selected","item","newValue","onValueUpdate","getTopItem","visibleItems","allSelected","some","y","showTopItem","suggestions","find","c","selectedFirst","children","role","iconPointerEventsTransparent","onFocus","tabIndexVal","className","select","label","newValues","semiSelected","tabIndex","onClickHandler","stopPropagation","getElements","customContent","maxWidth","parseInt","style","cls","$alignLeft","scrollable","maxHeight","onScroll","$outline","menuContent","action","actionLabel","icon","actionIcon","loading","actionLoading","actionDisabled","variant","actionVariant","onClick","propTypes","_pt","bool","isRequired","shape","oneOf","node","string","func","arrayOf","noteLabel","showDividerAbove","locked","oneOfType","number"],"sources":["../../src/Dropdown/DropdownContent.tsx"],"sourcesContent":["import React, { MutableRefObject, useCallback } from 'react';\r\nimport styled, { css } from 'styled-components';\r\nimport TextButton from '../Button/TextButton';\r\nimport { Size } from '../types';\r\nimport { DropdownContentButtonStyling } from './CommonStyling';\r\nimport { ComponentLStyling, ComponentXLStyling, ComponentMStyling, ComponentSStyling, ComponentTextStyle } from '../styles/typography';\r\nimport { COLORS, focusStyles, scrollBarStyling } from '../styles';\r\nimport { Checkbox, RadioButton } from '../InputFields';\r\nimport { Z_INDEXES } from '../styles/z-indexes';\r\nimport MenuItem from '../MenuItem/MenuItem';\r\nimport { defaultOnMouseDownHandler } from '../common';\r\n\r\nconst MAX_MENU_HEIGHT = 240;\r\nconst AVG_OPTION_HEIGHT = 48;\r\nconst OFFSET_BEFORE_SHOW = 1000000;\r\n\r\nexport const DropdownContentContainer = styled.div<{ $offsetTop: string; $offsetLeft: string; $isButton: boolean; $alignLeft?: boolean; $size?: Size; $scrollable?: boolean; $maxHeight?: string }>`\r\n display: none;\r\n pointer-events: auto;\r\n position: absolute;\r\n background-color: ${props => COLORS.generateToken({componentType:'bg-surface', defaultVariant:'default'}, props.theme)};\r\n\r\n z-index: ${Z_INDEXES.dropdown};\r\n margin: ${(props) => (props.$isButton ? '-4px' : '4px 0px')};\r\n\r\n inset: 0px auto auto 100%;\r\n\r\n &.show {\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n &.down,\r\n &.up {\r\n ${(props) => `transform: translate(${props.$offsetLeft}, ${props.$offsetTop});`}\r\n }\r\n }\r\n\r\n &.outline:focus:after {\r\n content: '';\r\n pointer-events: none;\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n right: 0;\r\n bottom: 0;\r\n outline: 4px solid black;\r\n outline-offset: 2px;\r\n border-radius: 2px;\r\n }\r\n\r\n &:focus {\r\n outline: none;\r\n }\r\n\r\n ${(props) => (props.$isButton ? DropdownContentButtonStyling : '')};\r\n\r\n box-sizing: border-box;\r\n box-shadow: 0 8px 16px 0 rgba(0, 0, 0, 0.15);\r\n padding: 4px 0px;\r\n\r\n min-width: ${(props) => (props.$size == Size.Large ? '320px' : props.$size == Size.Medium ? '280px' : '240px')};\r\n border-radius: ${(props) => (props.$size == Size.Large ? '10px' : props.$size == Size.Medium ? '8px' : '6px')};\r\n\r\n max-height: ${(props) => (!props.$scrollable ? 'auto' : props.$maxHeight ? props.$maxHeight : props.$size == Size.Large ? '320px' : props.$size == Size.Medium ? '280px' : '240px')};\r\n\r\n /* Mobile-specific responsive adjustments */\r\n @media (max-width: 767px) {\r\n min-width: ${(props) => (props.$size == Size.Large ? '260px' : props.$size == Size.Medium ? '220px' : '180px')};\r\n max-width: calc(100vw - 16px); /* Prevent overflow on mobile */\r\n \r\n /* Override positioning for mobile to prevent overflow */\r\n &.show {\r\n &.down,\r\n &.up {\r\n /* Use transform only for vertical positioning on mobile */\r\n transform: translate(0, ${props => props.$offsetTop}) !important;\r\n }\r\n }\r\n }\r\n`;\r\n\r\nexport const DropdownContentItemsContainer = styled.div<{ $size?: Size }>`\r\n > *:hover {\r\n z-index: ${Z_INDEXES.hover};\r\n }\r\n\r\n > *:active,\r\n > *.active {\r\n z-index: ${Z_INDEXES.active};\r\n }\r\n\r\n > *:focus {\r\n z-index: ${Z_INDEXES.focus};\r\n }\r\n`;\r\n\r\nexport const DropdownContentListContainer = styled.div<{ $scrollable?: boolean; $size?: Size; $itemsType?: string; $outline?: boolean }>`\r\n ${(props) => (props.$scrollable ? 'overflow-y: scroll;' : '')}\r\n ${(props) => (props.$scrollable ? 'margin-right: 6px;' : '')}\r\n ${(props) => (props.$scrollable ? 'padding-right: 6px;' : '')}\r\n ${(props) => (props.$itemsType != 'normal' ? 'margin-left: 4px;' : '')}\r\n div.divider {\r\n display: block;\r\n width: calc(100% - 40px);\r\n margin-left: 16px;\r\n border-top: 1px solid #e5e5e5;\r\n position: absolute;\r\n top: 0px;\r\n }\r\n\r\n ${DropdownContentItemsContainer} {\r\n padding-top: ${(props) => (props.$size == Size.Large ? '8px' : props.$size == Size.Medium ? '4px' : '0px')};\r\n padding-bottom: ${(props) => (props.$size == Size.Large ? '8px' : props.$size == Size.Medium ? '4px' : '0px')};\r\n\r\n word-break: break-word;\r\n }\r\n\r\n *:focus {\r\n outline: none !important;\r\n }\r\n\r\n ${scrollBarStyling(Size.Small)}\r\n`;\r\n\r\nconst DropdownContentMenuContentContainer = styled.div<{ $size?: Size }>`\r\n h1,\r\n h2,\r\n h3 {\r\n margin-block-start: 0px;\r\n margin-block-end: 0px;\r\n ${(props) => props.$size == Size.Large && ComponentXLStyling(ComponentTextStyle.Bold, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => props.$size == Size.Medium && ComponentLStyling(ComponentTextStyle.Bold, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => (props.$size == Size.Small || !props.$size) && ComponentMStyling(ComponentTextStyle.Bold, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n padding: ${(props) => (props.$size == Size.Small || !props.$size ? '10px 16px 6px' : props.$size == Size.Medium ? '16px 24px 8px' : '16px 32px 8px')};\r\n }\r\n\r\n p {\r\n margin-block-start: 0px;\r\n margin-block-end: 0px;\r\n ${(props) => props.$size == Size.Large && ComponentLStyling(ComponentTextStyle.Regular, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => props.$size == Size.Medium && ComponentMStyling(ComponentTextStyle.Regular, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n ${(props) => (props.$size == Size.Small || !props.$size) && ComponentSStyling(ComponentTextStyle.Regular, COLORS.generateToken({ componentType: 'text', defaultVariant: 'subtle' }, props.theme))}\r\n padding: ${(props) => (props.$size == Size.Small || !props.$size ? '8px 16px' : props.$size == Size.Medium ? '12px 24px' : '16px 32px')};\r\n }\r\n`;\r\n\r\nconst DividerContainer = styled.div<{ $size?: Size }>`\r\n position: relative;\r\n\r\n margin-top: ${(props) => (props.$size == Size.Large ? '16px' : props.$size == Size.Medium ? '12px' : props.$size == Size.Small || !props.$size ? '8px' : '6px')};\r\n\r\n div.divider {\r\n width: 100%;\r\n margin: 0px;\r\n }\r\n`;\r\n\r\nconst DropdownContentTopItemContainer = styled.div<{ $size?: Size }>`\r\n border-bottom-style: solid;\r\n border-bottom-color: ${props => COLORS.generateToken({componentType:'border', defaultVariant:'subtle'}, props.theme)};\r\n border-bottom-width: 1px;\r\n margin-right: 22px;\r\n`;\r\n\r\nconst DropdownContentActionButtonContainer = styled.div<{ $size?: Size; $scrollable?: boolean }>`\r\n ${(props) => (props.$scrollable ? `border-top: 1px solid ${COLORS.generateToken({componentType:'border', defaultVariant:'subtle'}, props.theme)};` : '')}\r\n ${(props) => (props.$scrollable ? 'margin-top: 4px;' : '')}\r\n\r\n padding: ${(props) => (props.$size === Size.Small || !props.$size ? '4px 16px 0px' : props.$size === Size.Medium ? '12px 16px 8px' : '16px 16px 12px')};\r\n\r\n button {\r\n width: 100%;\r\n }\r\n`;\r\n\r\nconst Overlay = styled.div`\r\n position: relative;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n pointer-events: none;\r\n z-index: ${Z_INDEXES.modal};\r\n`;\r\n\r\nexport interface DropdownItem {\r\n /** Required. Value of the DropdownItem. */\r\n value: string;\r\n /** Optional. Display label to show in the MenuItem. If not provided then 'value' will be used as label. */\r\n displayLabel?: string;\r\n /** Optional. Note label to be shown under the Display label in the MenuItem. */\r\n noteLabel?: string;\r\n /** */\r\n suggestion?: boolean;\r\n /** Optional. Show dividing line on the top of the item. */\r\n showDividerAbove?: boolean;\r\n /** Optional. If disabled user can not interact with the item. */\r\n disabled?: boolean;\r\n /** Optional. If item is locked then user can not interact with the item and 'lock' icon is shown on the right side of the item. */\r\n locked?: boolean;\r\n /** Optional. Icon to be shown on the left side of the menu item */\r\n icon?: React.ReactNode;\r\n /** */\r\n customContent?: React.ReactNode;\r\n}\r\n\r\nexport interface DropdownCustomizationProps {\r\n itemsType?: 'radio' | 'checkbox' | 'normal';\r\n menuContent?: React.ReactNode;\r\n scrollable?: boolean;\r\n multiSelect?: boolean;\r\n maxHeight?: string;\r\n actionLabel?: string;\r\n actionVariant?: 'primary' | 'secondary' | 'tertiary' | undefined;\r\n actionIcon?: React.ReactNode;\r\n actionLoading?: boolean;\r\n actionDisabled?: boolean;\r\n action: () => boolean | void | undefined;\r\n pinTopItem?: boolean;\r\n onValueUpdate: (values: string[]) => boolean | void | undefined;\r\n items: DropdownItem[];\r\n}\r\n\r\nexport interface DropdownProps {\r\n isButton: boolean;\r\n customizationProps: DropdownCustomizationProps;\r\n alignLeft?: boolean;\r\n isOpen: boolean;\r\n setIsOpen: (open: boolean) => void;\r\n size?: Size.Small | Size.Medium | Size.Large;\r\n id: string;\r\n filter: string;\r\n width?: string;\r\n onActiveDescendantChanged?: (descendantId?: string) => void;\r\n selectedValues: string[];\r\n setSelectedValues: (val: string[]) => void;\r\n messageOnNoResults: string;\r\n focused: number | null;\r\n setFocused: (focused: number | null) => void;\r\n outline?: boolean;\r\n containerRef: React.RefObject<HTMLDivElement | null>;\r\n ariaRolesType?: 'input' | 'menu';\r\n}\r\n\r\nconst DropdownContent = React.forwardRef<HTMLDivElement, DropdownProps>(\r\n (\r\n {\r\n id,\r\n customizationProps,\r\n alignLeft,\r\n isButton,\r\n size,\r\n isOpen,\r\n width,\r\n setIsOpen,\r\n filter,\r\n focused,\r\n setFocused,\r\n selectedValues,\r\n setSelectedValues,\r\n messageOnNoResults,\r\n outline,\r\n containerRef,\r\n onActiveDescendantChanged,\r\n ariaRolesType = 'menu',\r\n },\r\n ref,\r\n ) => {\r\n const [isUp, setIsUp] = React.useState<boolean>(false);\r\n const [locationDefined, setLocationDefined] = React.useState<boolean>(false);\r\n const [offset, setOffset] = React.useState<{ top: string; left: string }>({ top: '0', left: '0' });\r\n\r\n const dropdownContentRef = (ref as MutableRefObject<HTMLDivElement>) ?? React.useRef<HTMLDivElement>(null);\r\n\r\n if (!customizationProps.itemsType) customizationProps.itemsType = 'normal';\r\n if (!size) size = Size.Small;\r\n\r\n const itemsListRef = React.useRef<HTMLDivElement>(null);\r\n const actionButtonRef = React.useRef<HTMLButtonElement>(null);\r\n\r\n const determineDropUp = () => {\r\n const options = customizationProps.items;\r\n\r\n const rect = containerRef.current!.getBoundingClientRect();\r\n\r\n const windowHeight = window.innerHeight;\r\n const windowWidth = window.innerWidth;\r\n \r\n // Mobile-specific adjustments\r\n const isMobile = windowWidth < 768;\r\n const menuHeight = Math.min(MAX_MENU_HEIGHT, options.length * AVG_OPTION_HEIGHT);\r\n const instOffsetWithMenu = rect.top + rect.height + menuHeight;\r\n\r\n const up = instOffsetWithMenu >= windowHeight;\r\n\r\n // Mobile-specific positioning\r\n let leftOffset = alignLeft ? `calc(-${rect.width}px)` : `calc(-100%)`;\r\n \r\n if (isMobile) {\r\n // Ensure dropdown doesn't go off-screen on mobile\r\n const dropdownWidth = size == Size.Large ? 320 : size == Size.Medium ? 280 : 240;\r\n const rightEdge = rect.right + (alignLeft ? 0 : dropdownWidth);\r\n if (rightEdge > windowWidth) {\r\n leftOffset = `calc(-${rect.width}px - ${rightEdge - windowWidth + 8}px)`;\r\n }\r\n \r\n // If still going off-screen, align to the right edge of viewport\r\n if (rect.left + dropdownWidth > windowWidth) {\r\n leftOffset = `calc(-${dropdownWidth}px + ${windowWidth - rect.right}px)`;\r\n }\r\n }\r\n\r\n setOffset({\r\n top: up ? `calc(-100% - ${rect.height}px ${isButton ? '' : '- 8px'})` : '0',\r\n left: leftOffset,\r\n });\r\n\r\n setIsUp(up);\r\n setLocationDefined(true);\r\n };\r\n\r\n const setNewFocusedElement = (index: number) => {\r\n if (outline) dropdownContentRef.current?.focus();\r\n\r\n const newFocusedElement = elRefs[index];\r\n if (onActiveDescendantChanged) onActiveDescendantChanged(index == 0 ? `${id}_topitem` : `${id}_${index}`);\r\n\r\n const oldFocusedElement = focused || focused === 0 ? elRefs[focused] : null;\r\n if (newFocusedElement && newFocusedElement !== oldFocusedElement) {\r\n setFocused(index);\r\n oldFocusedElement?.current?.classList.remove('dropdown-hover');\r\n\r\n newFocusedElement.current?.classList.add('dropdown-hover');\r\n newFocusedElement.current?.scrollIntoView({\r\n block: 'nearest',\r\n inline: 'nearest',\r\n });\r\n }\r\n };\r\n\r\n const getFilteredItems = () => {\r\n const filtrationString = (filter ?? '').toUpperCase();\r\n return customizationProps.items.filter((x) => x?.value?.toUpperCase().includes(filtrationString) || x?.displayLabel?.toUpperCase().includes(filtrationString));\r\n };\r\n\r\n const findNextActiveIndex = (index: number, direction: number, items: DropdownItem[]) => {\r\n for (let i = index + direction; i > 0 && i <= items.length; i += direction) {\r\n if (!items[i - 1]?.disabled) {\r\n return i;\r\n }\r\n }\r\n\r\n return index;\r\n };\r\n\r\n const handleKeyDown = (e: KeyboardEvent) => {\r\n if (isOpen) {\r\n if (e.key === 'ArrowUp' || e.key === 'Up') {\r\n e.preventDefault();\r\n let focusedNow = focused || focused === 0 ? focused : arrLength + 1;\r\n if (!!focusedNow) {\r\n focusedNow = focusedNow === 1 && haveTopItem() ? 0 : findNextActiveIndex(focusedNow, -1, getFilteredItems());\r\n\r\n setNewFocusedElement(focusedNow);\r\n }\r\n } else if (e.key === 'ArrowDown' || e.key === 'Down') {\r\n e.preventDefault();\r\n let focusedNow = focused;\r\n\r\n focusedNow = !!focusedNow || focusedNow === 0 ? findNextActiveIndex(focusedNow, 1, getFilteredItems()) : haveTopItem() ? 0 : 1;\r\n\r\n setNewFocusedElement(focusedNow);\r\n } else if (e.key === 'Escape' || e.key === 'Esc') {\r\n setIsOpen(false);\r\n setFocused(null);\r\n if (onActiveDescendantChanged) onActiveDescendantChanged(undefined);\r\n } else if ((e.key === 'Enter' || e.key === ' ') && focused !== null && e.target !== actionButtonRef?.current) {\r\n e.preventDefault();\r\n const focusedElement = elRefs[focused];\r\n if (focusedElement) {\r\n focusedElement.current?.click();\r\n }\r\n if (onActiveDescendantChanged) onActiveDescendantChanged(undefined);\r\n }\r\n }\r\n };\r\n\r\n React.useEffect(() => {\r\n document.addEventListener('keydown', handleKeyDown);\r\n return () => {\r\n document.removeEventListener('keydown', handleKeyDown);\r\n };\r\n });\r\n\r\n const scrollPosition = React.useRef<number | undefined>(0);\r\n const handleScroll = () => {\r\n scrollPosition.current = itemsListRef.current?.scrollTop;\r\n };\r\n React.useLayoutEffect(() => {\r\n if (itemsListRef.current) itemsListRef.current.scrollTop = scrollPosition.current ?? 0;\r\n }, [selectedValues]);\r\n\r\n const getCorrectRef = (ref: React.RefObject<HTMLElement | null>): React.RefObject<HTMLElement | null> => {\r\n switch (customizationProps.itemsType) {\r\n case 'normal':\r\n return (ref as React.RefObject<HTMLButtonElement | null>) || React.createRef<HTMLButtonElement>();\r\n default:\r\n return (ref as React.RefObject<HTMLDivElement | null>) || React.createRef<HTMLDivElement>();\r\n }\r\n };\r\n\r\n const arrLength = getFilteredItems().length;\r\n const [elRefs, setElRefs] = React.useState<React.RefObject<HTMLElement | null>[]>([]);\r\n\r\n React.useEffect(() => {\r\n if (elRefs?.length !== arrLength) {\r\n setFocused(null);\r\n }\r\n\r\n setElRefs((elRefs) =>\r\n Array(arrLength + 1)\r\n .fill(null)\r\n .map((_, i) => getCorrectRef(elRefs[i])),\r\n );\r\n }, [isOpen, arrLength]);\r\n\r\n React.useLayoutEffect(() => {\r\n isOpen && !locationDefined && determineDropUp();\r\n }, [isOpen, locationDefined]);\r\n\r\n const haveTopItem = () => {\r\n if (!customizationProps.pinTopItem) return false;\r\n\r\n if (customizationProps.itemsType === 'radio' && selectedValues && selectedValues?.length > 0) return true;\r\n else if (customizationProps.itemsType === 'checkbox' && (customizationProps.multiSelect || selectedValues?.length > 0)) return true;\r\n else if (customizationProps.itemsType === 'normal' && getSuggestions()?.length > 0) return true;\r\n return false;\r\n };\r\n\r\n const getSuggestions = () => {\r\n return getFilteredItems().filter((x) => x.suggestion);\r\n };\r\n\r\n /**\r\n * when dropdown opens set correct position of focused item\r\n * */\r\n React.useLayoutEffect(() => {\r\n if (isOpen && (focused || focused === 0)) {\r\n setNewFocusedElement(focused === 0 && !haveTopItem() ? 1 : focused);\r\n }\r\n }, [isOpen, focused]);\r\n\r\n /**\r\n * Reset dropdown content state on close\r\n * */\r\n React.useEffect(() => {\r\n if (!isOpen) {\r\n setLocationDefined(false);\r\n for (let elRef of elRefs) {\r\n elRef.current?.classList.remove('dropdown-hover');\r\n }\r\n setFocused(null);\r\n if(onActiveDescendantChanged) onActiveDescendantChanged(undefined);\r\n dropdownContentRef.current?.classList.remove('outline');\r\n dropdownContentRef.current?.blur();\r\n } else {\r\n if (outline) {\r\n dropdownContentRef.current?.classList.add('outline');\r\n dropdownContentRef.current?.focus();\r\n }\r\n }\r\n }, [isOpen, dropdownContentRef, focused, outline]);\r\n\r\n /**\r\n * Scroll item container to top when dropdown opens\r\n * */\r\n React.useEffect(() => {\r\n if (isOpen && itemsListRef.current) {\r\n itemsListRef.current.scrollTop = 0;\r\n }\r\n }, [isOpen]);\r\n\r\n React.useEffect(() => {\r\n if (isOpen) {\r\n const observer = new IntersectionObserver(function (entries) {\r\n if (!entries[0].isIntersecting) {\r\n setIsOpen(false);\r\n //@ts-ignore\r\n document?.activeElement?.blur();\r\n }\r\n }, {threshold: [0], rootMargin: '8px'});\r\n\r\n observer.observe(containerRef.current!);\r\n\r\n calculateOffset();\r\n window.addEventListener('scroll', calculateOffset, true);\r\n window.addEventListener('resize', calculateOffset);\r\n\r\n return () => {\r\n observer.disconnect();\r\n window.removeEventListener('scroll', calculateOffset, true);\r\n window.removeEventListener('resize', calculateOffset);\r\n }\r\n }\r\n return () => {};\r\n }, [isOpen]);\r\n\r\n const handleItemClick = (selected: boolean, item: DropdownItem) => {\r\n let newValue: string[] = [];\r\n if (customizationProps.multiSelect) {\r\n if (selected) newValue = [...selectedValues, item.value];\r\n else newValue = selectedValues.filter((x) => x != item.value);\r\n } else newValue = selected ? [item.value] : [];\r\n\r\n setSelectedValues(newValue);\r\n if (customizationProps.onValueUpdate && customizationProps.onValueUpdate(newValue)) {\r\n setIsOpen(false);\r\n }\r\n };\r\n\r\n const getTopItem = () => {\r\n if (!customizationProps.pinTopItem) return;\r\n const visibleItems = getFilteredItems();\r\n const allSelected = selectedValues?.filter((x) => visibleItems.some((y) => y.value == x)).length == visibleItems.length;\r\n let showTopItem = false;\r\n const suggestions = getSuggestions();\r\n const displayLabel = selectedValues[0] ? customizationProps.items?.find((c) => c.value === selectedValues[0])?.displayLabel : undefined;\r\n if (customizationProps.itemsType == 'radio' && selectedValues && selectedValues?.length > 0) showTopItem = true;\r\n else if (customizationProps.itemsType == 'checkbox' && (customizationProps.multiSelect || selectedValues?.length > 0)) showTopItem = true;\r\n else if (customizationProps.itemsType == 'normal' && suggestions.length > 0) showTopItem = true;\r\n\r\n if (!showTopItem) return;\r\n\r\n const selectedFirst = selectedValues.length > 0 ? visibleItems.find((x) => x.value == selectedValues[0]) : null;\r\n\r\n return (\r\n <DropdownContentTopItemContainer $size={size}>\r\n {customizationProps.itemsType === 'radio' && (\r\n <RadioButton\r\n ref={elRefs[0] as React.RefObject<HTMLDivElement | null>}\r\n role='menuitemradio'\r\n iconPointerEventsTransparent={true}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_topitem`)}\r\n tabIndexVal={-1}\r\n className={`${focused === 0 ? 'dropdown-hover' : ''}`}\r\n select={() => {}}\r\n label={selectedFirst?.displayLabel ?? selectedFirst?.value}\r\n size={size}\r\n id={`${id}_topitem`}\r\n selected={true}\r\n />\r\n )}\r\n {customizationProps.itemsType === 'checkbox' && (\r\n <Checkbox\r\n ref={elRefs[0] as React.RefObject<HTMLDivElement | null>}\r\n role='menuitemcheckbox'\r\n tabIndexVal={-1}\r\n className={`${focused === 0 ? 'dropdown-hover' : ''}`}\r\n select={(selected: boolean) => {\r\n if (!customizationProps.multiSelect) return;\r\n\r\n const newValues = selected ? visibleItems.map((x) => x.value) : [];\r\n setSelectedValues(newValues);\r\n if (customizationProps.onValueUpdate && customizationProps.onValueUpdate(newValues)) setIsOpen(false);\r\n }}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_topitem`)}\r\n iconPointerEventsTransparent={true}\r\n semiSelected={customizationProps.multiSelect && !allSelected && selectedValues?.length > 0}\r\n size={size}\r\n id={`${id}_checkbox_selectall`}\r\n label={customizationProps.multiSelect ? 'Select all' : selectedFirst?.displayLabel ?? selectedFirst?.value}\r\n selected={!customizationProps.multiSelect || allSelected}\r\n />\r\n )}\r\n {customizationProps.itemsType === 'normal' && (\r\n <>\r\n {suggestions.map((x) => (\r\n <MenuItem\r\n role={ariaRolesType == 'input' ? 'option' : 'menu'} \r\n key={`${id}_topitem_${x.value}`}\r\n item={x}\r\n size={size}\r\n active={false}\r\n tabIndex={-1}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_topitem`)}\r\n className={`${focused === 0 ? 'dropdown-hover' : ''}`}\r\n ref={elRefs[0] as React.RefObject<HTMLButtonElement | null>}\r\n id={`${id}_topitem`}\r\n onClickHandler={(e: any) => {\r\n e.stopPropagation();\r\n customizationProps.onValueUpdate([x.value]);\r\n setSelectedValues([x.value]);\r\n setIsOpen(false);\r\n setFocused(null);\r\n }}\r\n />\r\n ))}\r\n </>\r\n )}\r\n </DropdownContentTopItemContainer>\r\n );\r\n };\r\n\r\n const getElements = (messageOnNoResults: string, size: Size.Small | Size.Medium | Size.Large) => {\r\n if (getFilteredItems().length === 0) {\r\n return <MenuItem item={{ value: messageOnNoResults, disabled: true }} size={size} id=\"noResultsFound\" active={false} onClickHandler={(e) => {}} />;\r\n }\r\n return (\r\n <DropdownContentItemsContainer $size={size}>\r\n {getFilteredItems()\r\n .filter((x) => x && (customizationProps.itemsType != 'normal' || !x.suggestion))\r\n .map((item, index) => {\r\n return (\r\n <React.Fragment key={`key_${id}_${item.value}`}>\r\n {item.customContent}\r\n {!item.customContent && customizationProps.itemsType == 'radio' && (\r\n <RadioButton\r\n role='menuitemradio'\r\n select={(selected: boolean) => handleItemClick(selected, item)}\r\n ref={elRefs[index + 1] as React.RefObject<HTMLDivElement | null>}\r\n size={size}\r\n tabIndexVal={-1}\r\n className={`${index + 1 === focused ? 'dropdown-hover' : ''}`}\r\n iconPointerEventsTransparent={true}\r\n disabled={item?.disabled}\r\n key={`key_${id}_${index + 1}`}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_${index + 1}`)}\r\n id={`${id}_${index + 1}`}\r\n label={item.displayLabel ?? item.value}\r\n selected={selectedValues?.includes(item.value)}\r\n />\r\n )}\r\n {!item.customContent && customizationProps.itemsType == 'checkbox' && (\r\n <Checkbox\r\n role='menuitemcheckbox'\r\n select={(selected: boolean) => handleItemClick(selected, item)}\r\n iconPointerEventsTransparent={true}\r\n disabled={item?.disabled}\r\n className={`${index + 1 === focused ? 'dropdown-hover' : ''}`}\r\n ref={elRefs[index + 1] as React.RefObject<HTMLDivElement | null>}\r\n size={size}\r\n tabIndexVal={-1}\r\n key={`key_${id}_${index + 1}`}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_${index + 1}`)}\r\n id={`${id}_${index + 1}`}\r\n label={item.displayLabel ?? item.value}\r\n selected={selectedValues?.includes(item.value)}\r\n />\r\n )}\r\n {!item.customContent && (customizationProps.itemsType == 'normal' || !customizationProps.itemsType) && (\r\n <MenuItem\r\n role={ariaRolesType == 'input' ? 'option' : 'menu'} \r\n key={`key_${id}_${index + 1}`}\r\n id={`${id}_${index + 1}`}\r\n item={item}\r\n tabIndex={-1}\r\n className={`${index + 1 === focused ? 'dropdown-hover' : ''}`}\r\n size={size}\r\n onFocus={(e) => onActiveDescendantChanged && onActiveDescendantChanged(`${id}_${index + 1}`)}\r\n active={selectedValues?.includes(item.value)}\r\n ref={elRefs[index + 1] as React.RefObject<HTMLButtonElement | null>}\r\n onClickHandler={(e: any) => {\r\n e.stopPropagation();\r\n customizationProps.onValueUpdate([item.value]);\r\n setSelectedValues([item.value]);\r\n setIsOpen(false);\r\n setFocused(null);\r\n }}\r\n />\r\n )}\r\n </React.Fragment>\r\n );\r\n })}\r\n </DropdownContentItemsContainer>\r\n );\r\n };\r\n\r\n const calculateOffset = () => {\r\n const rect = containerRef?.current?.getBoundingClientRect();\r\n if (rect) {\r\n const isMobile = window.innerWidth < 768;\r\n \r\n // On mobile, ensure dropdown width doesn't exceed viewport\r\n if (isMobile) {\r\n const maxWidth = Math.min(\r\n width ? parseInt(width) : rect.width,\r\n window.innerWidth - 32 // Leave some padding\r\n );\r\n dropdownContentRef.current.style.width = `${maxWidth}px`;\r\n } else {\r\n dropdownContentRef.current.style.width = width ?? `${rect.width}px`;\r\n }\r\n }\r\n determineDropUp();\r\n };\r\n\r\n const cls = `${isOpen ? 'show' : ''} ${isOpen && outline ? 'outline' : ''} ${locationDefined ? (isUp ? 'up' : 'down') : ''}`;\r\n\r\n return (\r\n <Overlay>\r\n <DropdownContentContainer\r\n role={ariaRolesType == \"menu\" ? \"menu\" : \"optionlist\"}\r\n ref={dropdownContentRef}\r\n $size={size}\r\n $offsetTop={offset.top}\r\n id={id}\r\n $offsetLeft={offset.left}\r\n tabIndex={-1}\r\n $isButton={isButton}\r\n $alignLeft={alignLeft}\r\n $scrollable={customizationProps.scrollable}\r\n $maxHeight={customizationProps.maxHeight}\r\n className={cls}>\r\n <DropdownContentListContainer\r\n tabIndex={-1}\r\n role=\"group\"\r\n $size={size}\r\n $itemsType={customizationProps.itemsType}\r\n onScroll={handleScroll}\r\n ref={itemsListRef}\r\n $outline={outline}\r\n $scrollable={customizationProps.scrollable}>\r\n {customizationProps.menuContent && (\r\n <DropdownContentMenuContentContainer $size={size}>\r\n {customizationProps.menuContent}\r\n <DividerContainer $size={size}>\r\n <div className=\"divider\" />\r\n </DividerContainer>\r\n </DropdownContentMenuContentContainer>\r\n )}\r\n {customizationProps.pinTopItem && getTopItem()}\r\n {getElements(messageOnNoResults, size)}\r\n </DropdownContentListContainer>\r\n {customizationProps.action && customizationProps.actionLabel && (\r\n <DropdownContentActionButtonContainer $size={size} $scrollable={customizationProps.scrollable}>\r\n <TextButton\r\n width=\"100%\"\r\n role=\"menuitem\"\r\n icon={customizationProps.actionIcon}\r\n ref={actionButtonRef}\r\n loading={customizationProps.actionLoading}\r\n disabled={customizationProps.actionDisabled}\r\n variant={customizationProps.actionVariant ?? 'primary'}\r\n size={size}\r\n onClick={() => customizationProps.action() && setIsOpen(false)}>\r\n {customizationProps.actionLabel}\r\n </TextButton>\r\n </DropdownContentActionButtonContainer>\r\n )}\r\n </DropdownContentContainer>\r\n </Overlay>\r\n );\r\n },\r\n);\r\n\r\nexport default DropdownContent;\r\n"],"mappings":"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","ignoreList":[]}
@@ -11,14 +11,6 @@ describe('Logo', () => {
11
11
  navigate: (path: string, isExternal: boolean) => {}
12
12
  };
13
13
 
14
-
15
- it('should render Laerdal logo', () => {
16
- const wrapper = render(<NavigationProvider {...navProps}><Logo name={'name'}/></NavigationProvider>);
17
-
18
- expect(wrapper.getByText('name')).toBeDefined();
19
- expect(wrapper.getByText('Laerdal logo')).toBeDefined();
20
- });
21
-
22
14
  it('should render beta tag', () => {
23
15
  const wrapper = render(<NavigationProvider {...navProps}><Logo name={'name'} showBetaTag={true}/></NavigationProvider>);
24
16
 
@@ -26,7 +26,8 @@ const RichTextFieldContainer = exports.RichTextFieldContainer = _styledComponent
26
26
  .quill {
27
27
  width: 100%;
28
28
  margin-bottom: 4px;
29
- overflow: hidden;
29
+ overflow: visible;
30
+ position: relative;
30
31
 
31
32
  box-shadow: inset 0 0 0 1px ${props => _styles.COLORS.generateToken({
32
33
  componentType: 'border',
@@ -103,6 +104,20 @@ const RichTextFieldContainer = exports.RichTextFieldContainer = _styledComponent
103
104
  componentType: 'border',
104
105
  defaultVariant: 'subtle'
105
106
  }, props.theme)};
107
+ position: relative;
108
+ z-index: 1;
109
+ }
110
+
111
+ .ql-tooltip {
112
+ z-index: 1000 !important;
113
+ position: absolute !important;
114
+ left: 0 !important;
115
+ right: auto !important;
116
+ transform: none !important;
117
+ }
118
+
119
+ .ql-tooltip.ql-editing {
120
+ left: 8px !important;
106
121
  }
107
122
 
108
123
  .quill.valid .ql-toolbar,
@@ -119,7 +134,7 @@ const RichTextFieldContainer = exports.RichTextFieldContainer = _styledComponent
119
134
 
120
135
  .ql-container.ql-snow {
121
136
  border: none;
122
- overflow-y: hidden;
137
+ overflow-y: visible;
123
138
  padding: 8px;
124
139
  }
125
140
 
@@ -135,12 +150,13 @@ const RichTextFieldContainer = exports.RichTextFieldContainer = _styledComponent
135
150
 
136
151
  .quill {
137
152
  flex: none;
138
- overflow: initial;
153
+ overflow: visible;
139
154
  }
140
155
 
141
156
  .ql-container {
142
157
  flex: none;
143
158
  resize: vertical;
159
+ overflow-y: hidden;
144
160
  }
145
161
 
146
162
  .ql-editor {
@@ -1 +1 @@
1
- {"version":3,"file":"RichTextField.cjs","names":["_react","_interopRequireDefault","require","_reactQuillNew","_styledComponents","_interopRequireWildcard","_styling","_types","_styles","_systemicons","_jsxRuntime","_excluded","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","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","RichTextFieldContainer","exports","styled","div","props","COLORS","generateToken","componentType","defaultVariant","theme","state","ComponentSStyling","ComponentTextStyle","Regular","Italic","ComponentMStyling","scrollBarStyling","Size","Small","readOnlyState","RichTextFieldFormats","defaultToolBarOptions","header","RichTextField","React","forwardRef","_ref","ref","readOnly","disabled","validationMessage","note","size","Medium","resizable","modules","formats","rest","_objectWithoutProperties2","useTheme","m","toolbar","f","values","Image","Video","Formula","jsxs","className","children","jsx","ValidationMessage","type","States","Invalid","Valid","CheckMark","color","TechnicalWarning","NoteMessage","icon","message","propTypes","id","_propTypes","string","placeholder","bool","objectOf","any","arrayOf","oneOf","onKeyDown","func","onKeyPress","onKeyUp","value","isRequired","onChange"],"sources":["../../src/InputFields/RichTextField.tsx"],"sourcesContent":["import React from 'react';\r\nimport ReactQuill, { EmitterSource } from \"react-quill-new\";\r\nimport {TextFieldNote} from \"./types\";\r\nimport styled, { useTheme } from \"styled-components\";\r\nimport {NoteMessage, readOnlyState, ValidationMessage} from \"./styling\";\r\nimport {Size, States} from \"../types\";\r\nimport {COLORS, ComponentMStyling, ComponentSStyling, ComponentTextStyle, scrollBarStyling} from \"../styles\";\r\nimport {CheckMark, TechnicalWarning} from \"../icons/systemicons\";\r\nimport 'react-quill-new/dist/quill.snow.css';\r\n\r\nexport const RichTextFieldContainer = styled.div`\r\n .quill {\r\n width: 100%;\r\n margin-bottom: 4px;\r\n overflow: hidden;\r\n\r\n box-shadow: inset 0 0 0 1px ${props => COLORS.generateToken({componentType:'border', defaultVariant:'default'}, props.theme)};\r\n border-radius: 4px;\r\n }\r\n\r\n .quill.valid {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.generateToken({componentType:'border', defaultVariant:'positive'}, props.theme)};\r\n }\r\n\r\n .quill.invalid {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.generateToken({componentType:'border', defaultVariant:'critical'}, props.theme)};\r\n }\r\n\r\n .quill:hover {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.generateToken({componentType:'border', state:'hover'}, props.theme)};\r\n }\r\n\r\n .quill:focus-within {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.generateToken({componentType:'border', state:'hover'}, props.theme)};\r\n }\r\n\r\n .ql-editor,\r\n .ql-editor p{\r\n ${props => ComponentSStyling(ComponentTextStyle.Regular, COLORS.generateToken({componentType:'text', defaultVariant:'default'}, props.theme))}\r\n }\r\n\r\n .ql-editor.ql-blank::before {\r\n ${props => ComponentSStyling(ComponentTextStyle.Italic, COLORS.generateToken({componentType:'text', defaultVariant:'subtle'}, props.theme))}\r\n }\r\n\r\n &.medium {\r\n .ql-editor,\r\n .ql-editor p{\r\n ${props => ComponentMStyling(ComponentTextStyle.Regular, COLORS.generateToken({componentType:'text', defaultVariant:'default'}, props.theme))}\r\n }\r\n\r\n .ql-editor.ql-blank::before {\r\n ${props => ComponentMStyling(ComponentTextStyle.Italic, COLORS.generateToken({componentType:'text', defaultVariant:'subtle'}, props.theme))}\r\n }\r\n }\r\n\r\n .ql-toolbar.ql-snow {\r\n border: none;\r\n padding: 8px 7px;\r\n margin: 0 1px;\r\n border-bottom: 1px solid ${props => COLORS.generateToken({componentType:'border', defaultVariant:'subtle'}, props.theme)};\r\n }\r\n\r\n .quill.valid .ql-toolbar,\r\n .quill.invalid .ql-toolbar,\r\n .quill:hover .ql-toolbar,\r\n .quill:focus-within .ql-toolbar {\r\n padding: 8px 6px;\r\n margin: 0 2px;\r\n }\r\n\r\n .ql-container {\r\n font-family: unset !important;\r\n }\r\n\r\n .ql-container.ql-snow {\r\n border: none;\r\n overflow-y: hidden;\r\n padding: 8px;\r\n }\r\n\r\n .ql-editor {\r\n padding: 8px;\r\n overflow-y: auto;\r\n\r\n ${scrollBarStyling(Size.Small)}\r\n }\r\n\r\n &.resizable {\r\n height: initial;\r\n\r\n .quill {\r\n flex: none;\r\n overflow: initial;\r\n }\r\n\r\n .ql-container {\r\n flex: none;\r\n resize: vertical;\r\n }\r\n\r\n .ql-editor {\r\n height: 100%;\r\n }\r\n }\r\n\r\n &.readonly {\r\n .quill {\r\n ${readOnlyState}\r\n }\r\n }\r\n\r\n &.disabled {\r\n cursor: not-allowed;\r\n\r\n .quill {\r\n pointer-events: none;\r\n box-shadow: inset 0 0 0 1px ${props => COLORS.generateToken({componentType:'border', state:'disabled'}, props.theme)};\r\n color: ${props => COLORS.generateToken({componentType:'text', state:'disabled'}, props.theme)};\r\n\r\n .ql-editor.ql-blank::before {\r\n color: ${props => COLORS.generateToken({componentType:'text', state:'disabled'}, props.theme)};\r\n }\r\n }\r\n }\r\n`;\r\n\r\nexport enum RichTextFieldFormats {\r\n Background = 'background',\r\n Bold = 'bold',\r\n Color = 'color',\r\n Font = 'font',\r\n Code = 'code',\r\n Italic = 'italic',\r\n Link = 'link',\r\n Size = 'size',\r\n Strike = 'strike',\r\n Script = 'script',\r\n Underline = 'underline',\r\n Blockquote = 'blockquote',\r\n Header = 'header',\r\n Indent = 'indent',\r\n List = 'list',\r\n Align = 'align',\r\n Direction = 'direction',\r\n CodeBlock = 'code-block',\r\n Formula = 'formula',\r\n Image = 'image',\r\n Video = 'video'\r\n}\r\n\r\nconst defaultToolBarOptions = [\r\n [{header: [1, 2, 3, false]}],\r\n ['bold', 'italic', 'underline', 'strike'],\r\n [{'list': 'ordered'}, {'list': 'bullet'}],\r\n ['link'],\r\n ['clean']\r\n];\r\n\r\nexport interface RichTextFieldProps {\r\n /**\r\n * Optional. The ID of the rich text field.\r\n */\r\n id?: string;\r\n\r\n /**\r\n * Optional. The CSS class name of the rich text field.\r\n */\r\n className?: string;\r\n\r\n /**\r\n * Optional. The placeholder text to be displayed in the rich text field when it is empty.\r\n */\r\n placeholder?: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the rich text field is read-only.\r\n */\r\n readOnly?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the rich text field is disabled.\r\n */\r\n disabled?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the rich text field is resizable.\r\n */\r\n resizable?: boolean;\r\n\r\n /**\r\n * Optional. An object containing the modules to be used by the rich text field.\r\n */\r\n modules?: Record<string, unknown>;\r\n\r\n /**\r\n * Optional. An array of formats to be used by the rich text field.\r\n */\r\n formats?: RichTextFieldFormats[];\r\n\r\n /**\r\n * Optional. A function to be called when the rich text field gains focus.\r\n */\r\n onFocus?(selection: ReactQuill.Range, source: EmitterSource, editor: ReactQuill.UnprivilegedEditor): void;\r\n\r\n /**\r\n * Optional. A function to be called when the rich text field loses focus.\r\n */\r\n onBlur?(previousSelection: ReactQuill.Range, source: EmitterSource, editor: ReactQuill.UnprivilegedEditor): void;\r\n\r\n /**\r\n * Optional. A function to be called when a keydown event occurs in the rich text field.\r\n */\r\n onKeyDown?: React.EventHandler<any>;\r\n\r\n /**\r\n * Optional. A function to be called when a keypress event occurs in the rich text field.\r\n */\r\n onKeyPress?: React.EventHandler<any>;\r\n\r\n /**\r\n * Optional. A function to be called when a keyup event occurs in the rich text field.\r\n */\r\n onKeyUp?: React.EventHandler<any>;\r\n\r\n /**\r\n * Required. The current value of the rich text field.\r\n */\r\n value: any;\r\n\r\n /**\r\n * Required. A function to be called when the value of the rich text field changes.\r\n */\r\n onChange: (value: any) => void;\r\n\r\n /**\r\n * Optional. The validation message to be displayed when the rich text field is in an error state.\r\n */\r\n validationMessage?: string;\r\n\r\n /**\r\n * Optional. A note to be displayed below the rich text field.\r\n */\r\n note?: TextFieldNote;\r\n\r\n /**\r\n * Optional. The size of the rich text field. Can be 'Small' or 'Medium'.\r\n */\r\n size?: Size.Small | Size.Medium;\r\n\r\n /**\r\n * Optional. The state of the rich text field. Can be 'Invalid' or 'Valid'.\r\n */\r\n state?: States.Invalid | States.Valid;\r\n}\r\n\r\nexport const RichTextField = React.forwardRef<any, RichTextFieldProps>(({\r\n readOnly,\r\n disabled,\r\n validationMessage,\r\n note,\r\n size = Size.Medium,\r\n state,\r\n resizable,\r\n modules,\r\n formats,\r\n ...rest\r\n }: RichTextFieldProps, ref) => {\r\n\r\n const theme = useTheme();\r\n let m = {...(modules ?? {}), toolbar: modules?.toolbar ?? defaultToolBarOptions};\r\n let f = formats ?? Object.values(RichTextFieldFormats).filter(a => a !== RichTextFieldFormats.Image && a !== RichTextFieldFormats.Video && a !== RichTextFieldFormats.Formula);\r\n\r\n return (\r\n <RichTextFieldContainer\r\n className={`${resizable ? 'resizable' : ''} ${size} ${state || ''} ${readOnly ? 'readonly' : ''} ${disabled ? 'disabled' : ''}`}>\r\n <ReactQuill ref={ref}\r\n readOnly={readOnly || disabled}\r\n modules={m}\r\n theme={'snow'}\r\n formats={f}\r\n {...rest}\r\n />\r\n {validationMessage && (\r\n <ValidationMessage className={size || ''} type={state ?? States.Invalid}>\r\n {\r\n state === States.Valid\r\n ? <CheckMark color={COLORS.generateToken({componentType:'text', defaultVariant:'positive'}, theme)}/>\r\n : <TechnicalWarning color={COLORS.generateToken({componentType:'text', defaultVariant:'critical'}, theme)}/>\r\n }\r\n <span>{validationMessage}</span>\r\n </ValidationMessage>\r\n )}\r\n {note && !disabled && (\r\n <NoteMessage className={size}>\r\n {note.icon}\r\n <span>{note.message}</span>\r\n </NoteMessage>\r\n )}\r\n </RichTextFieldContainer>\r\n )\r\n});"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"RichTextField.cjs","names":["_react","_interopRequireDefault","require","_reactQuillNew","_styledComponents","_interopRequireWildcard","_styling","_types","_styles","_systemicons","_jsxRuntime","_excluded","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","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","RichTextFieldContainer","exports","styled","div","props","COLORS","generateToken","componentType","defaultVariant","theme","state","ComponentSStyling","ComponentTextStyle","Regular","Italic","ComponentMStyling","scrollBarStyling","Size","Small","readOnlyState","RichTextFieldFormats","defaultToolBarOptions","header","RichTextField","React","forwardRef","_ref","ref","readOnly","disabled","validationMessage","note","size","Medium","resizable","modules","formats","rest","_objectWithoutProperties2","useTheme","m","toolbar","f","values","Image","Video","Formula","jsxs","className","children","jsx","ValidationMessage","type","States","Invalid","Valid","CheckMark","color","TechnicalWarning","NoteMessage","icon","message","propTypes","id","_propTypes","string","placeholder","bool","objectOf","any","arrayOf","oneOf","onKeyDown","func","onKeyPress","onKeyUp","value","isRequired","onChange"],"sources":["../../src/InputFields/RichTextField.tsx"],"sourcesContent":["import React from 'react';\r\nimport ReactQuill, { EmitterSource } from \"react-quill-new\";\r\nimport {TextFieldNote} from \"./types\";\r\nimport styled, { useTheme } from \"styled-components\";\r\nimport {NoteMessage, readOnlyState, ValidationMessage} from \"./styling\";\r\nimport {Size, States} from \"../types\";\r\nimport {COLORS, ComponentMStyling, ComponentSStyling, ComponentTextStyle, scrollBarStyling} from \"../styles\";\r\nimport {CheckMark, TechnicalWarning} from \"../icons/systemicons\";\r\nimport 'react-quill-new/dist/quill.snow.css';\r\n\r\nexport const RichTextFieldContainer = styled.div`\r\n .quill {\r\n width: 100%;\r\n margin-bottom: 4px;\r\n overflow: visible;\r\n position: relative;\r\n\r\n box-shadow: inset 0 0 0 1px ${props => COLORS.generateToken({componentType:'border', defaultVariant:'default'}, props.theme)};\r\n border-radius: 4px;\r\n }\r\n\r\n .quill.valid {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.generateToken({componentType:'border', defaultVariant:'positive'}, props.theme)};\r\n }\r\n\r\n .quill.invalid {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.generateToken({componentType:'border', defaultVariant:'critical'}, props.theme)};\r\n }\r\n\r\n .quill:hover {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.generateToken({componentType:'border', state:'hover'}, props.theme)};\r\n }\r\n\r\n .quill:focus-within {\r\n box-shadow: inset 0 0 0 2px ${props => COLORS.generateToken({componentType:'border', state:'hover'}, props.theme)};\r\n }\r\n\r\n .ql-editor,\r\n .ql-editor p{\r\n ${props => ComponentSStyling(ComponentTextStyle.Regular, COLORS.generateToken({componentType:'text', defaultVariant:'default'}, props.theme))}\r\n }\r\n\r\n .ql-editor.ql-blank::before {\r\n ${props => ComponentSStyling(ComponentTextStyle.Italic, COLORS.generateToken({componentType:'text', defaultVariant:'subtle'}, props.theme))}\r\n }\r\n\r\n &.medium {\r\n .ql-editor,\r\n .ql-editor p{\r\n ${props => ComponentMStyling(ComponentTextStyle.Regular, COLORS.generateToken({componentType:'text', defaultVariant:'default'}, props.theme))}\r\n }\r\n\r\n .ql-editor.ql-blank::before {\r\n ${props => ComponentMStyling(ComponentTextStyle.Italic, COLORS.generateToken({componentType:'text', defaultVariant:'subtle'}, props.theme))}\r\n }\r\n }\r\n\r\n .ql-toolbar.ql-snow {\r\n border: none;\r\n padding: 8px 7px;\r\n margin: 0 1px;\r\n border-bottom: 1px solid ${props => COLORS.generateToken({componentType:'border', defaultVariant:'subtle'}, props.theme)};\r\n position: relative;\r\n z-index: 1;\r\n }\r\n\r\n .ql-tooltip {\r\n z-index: 1000 !important;\r\n position: absolute !important;\r\n left: 0 !important;\r\n right: auto !important;\r\n transform: none !important;\r\n }\r\n\r\n .ql-tooltip.ql-editing {\r\n left: 8px !important;\r\n }\r\n\r\n .quill.valid .ql-toolbar,\r\n .quill.invalid .ql-toolbar,\r\n .quill:hover .ql-toolbar,\r\n .quill:focus-within .ql-toolbar {\r\n padding: 8px 6px;\r\n margin: 0 2px;\r\n }\r\n\r\n .ql-container {\r\n font-family: unset !important;\r\n }\r\n\r\n .ql-container.ql-snow {\r\n border: none;\r\n overflow-y: visible;\r\n padding: 8px;\r\n }\r\n\r\n .ql-editor {\r\n padding: 8px;\r\n overflow-y: auto;\r\n\r\n ${scrollBarStyling(Size.Small)}\r\n }\r\n\r\n &.resizable {\r\n height: initial;\r\n\r\n .quill {\r\n flex: none;\r\n overflow: visible;\r\n }\r\n\r\n .ql-container {\r\n flex: none;\r\n resize: vertical;\r\n overflow-y: hidden;\r\n }\r\n\r\n .ql-editor {\r\n height: 100%;\r\n }\r\n }\r\n\r\n &.readonly {\r\n .quill {\r\n ${readOnlyState}\r\n }\r\n }\r\n\r\n &.disabled {\r\n cursor: not-allowed;\r\n\r\n .quill {\r\n pointer-events: none;\r\n box-shadow: inset 0 0 0 1px ${props => COLORS.generateToken({componentType:'border', state:'disabled'}, props.theme)};\r\n color: ${props => COLORS.generateToken({componentType:'text', state:'disabled'}, props.theme)};\r\n\r\n .ql-editor.ql-blank::before {\r\n color: ${props => COLORS.generateToken({componentType:'text', state:'disabled'}, props.theme)};\r\n }\r\n }\r\n }\r\n`;\r\n\r\nexport enum RichTextFieldFormats {\r\n Background = 'background',\r\n Bold = 'bold',\r\n Color = 'color',\r\n Font = 'font',\r\n Code = 'code',\r\n Italic = 'italic',\r\n Link = 'link',\r\n Size = 'size',\r\n Strike = 'strike',\r\n Script = 'script',\r\n Underline = 'underline',\r\n Blockquote = 'blockquote',\r\n Header = 'header',\r\n Indent = 'indent',\r\n List = 'list',\r\n Align = 'align',\r\n Direction = 'direction',\r\n CodeBlock = 'code-block',\r\n Formula = 'formula',\r\n Image = 'image',\r\n Video = 'video'\r\n}\r\n\r\nconst defaultToolBarOptions = [\r\n [{header: [1, 2, 3, false]}],\r\n ['bold', 'italic', 'underline', 'strike'],\r\n [{'list': 'ordered'}, {'list': 'bullet'}],\r\n ['link'],\r\n ['clean']\r\n];\r\n\r\nexport interface RichTextFieldProps {\r\n /**\r\n * Optional. The ID of the rich text field.\r\n */\r\n id?: string;\r\n\r\n /**\r\n * Optional. The CSS class name of the rich text field.\r\n */\r\n className?: string;\r\n\r\n /**\r\n * Optional. The placeholder text to be displayed in the rich text field when it is empty.\r\n */\r\n placeholder?: string;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the rich text field is read-only.\r\n */\r\n readOnly?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the rich text field is disabled.\r\n */\r\n disabled?: boolean;\r\n\r\n /**\r\n * Optional. A boolean indicating whether the rich text field is resizable.\r\n */\r\n resizable?: boolean;\r\n\r\n /**\r\n * Optional. An object containing the modules to be used by the rich text field.\r\n */\r\n modules?: Record<string, unknown>;\r\n\r\n /**\r\n * Optional. An array of formats to be used by the rich text field.\r\n */\r\n formats?: RichTextFieldFormats[];\r\n\r\n /**\r\n * Optional. A function to be called when the rich text field gains focus.\r\n */\r\n onFocus?(selection: ReactQuill.Range, source: EmitterSource, editor: ReactQuill.UnprivilegedEditor): void;\r\n\r\n /**\r\n * Optional. A function to be called when the rich text field loses focus.\r\n */\r\n onBlur?(previousSelection: ReactQuill.Range, source: EmitterSource, editor: ReactQuill.UnprivilegedEditor): void;\r\n\r\n /**\r\n * Optional. A function to be called when a keydown event occurs in the rich text field.\r\n */\r\n onKeyDown?: React.EventHandler<any>;\r\n\r\n /**\r\n * Optional. A function to be called when a keypress event occurs in the rich text field.\r\n */\r\n onKeyPress?: React.EventHandler<any>;\r\n\r\n /**\r\n * Optional. A function to be called when a keyup event occurs in the rich text field.\r\n */\r\n onKeyUp?: React.EventHandler<any>;\r\n\r\n /**\r\n * Required. The current value of the rich text field.\r\n */\r\n value: any;\r\n\r\n /**\r\n * Required. A function to be called when the value of the rich text field changes.\r\n */\r\n onChange: (value: any) => void;\r\n\r\n /**\r\n * Optional. The validation message to be displayed when the rich text field is in an error state.\r\n */\r\n validationMessage?: string;\r\n\r\n /**\r\n * Optional. A note to be displayed below the rich text field.\r\n */\r\n note?: TextFieldNote;\r\n\r\n /**\r\n * Optional. The size of the rich text field. Can be 'Small' or 'Medium'.\r\n */\r\n size?: Size.Small | Size.Medium;\r\n\r\n /**\r\n * Optional. The state of the rich text field. Can be 'Invalid' or 'Valid'.\r\n */\r\n state?: States.Invalid | States.Valid;\r\n}\r\n\r\nexport const RichTextField = React.forwardRef<any, RichTextFieldProps>(({\r\n readOnly,\r\n disabled,\r\n validationMessage,\r\n note,\r\n size = Size.Medium,\r\n state,\r\n resizable,\r\n modules,\r\n formats,\r\n ...rest\r\n }: RichTextFieldProps, ref) => {\r\n\r\n const theme = useTheme();\r\n let m = {...(modules ?? {}), toolbar: modules?.toolbar ?? defaultToolBarOptions};\r\n let f = formats ?? Object.values(RichTextFieldFormats).filter(a => a !== RichTextFieldFormats.Image && a !== RichTextFieldFormats.Video && a !== RichTextFieldFormats.Formula);\r\n\r\n return (\r\n <RichTextFieldContainer\r\n className={`${resizable ? 'resizable' : ''} ${size} ${state || ''} ${readOnly ? 'readonly' : ''} ${disabled ? 'disabled' : ''}`}>\r\n <ReactQuill ref={ref}\r\n readOnly={readOnly || disabled}\r\n modules={m}\r\n theme={'snow'}\r\n formats={f}\r\n {...rest}\r\n />\r\n {validationMessage && (\r\n <ValidationMessage className={size || ''} type={state ?? States.Invalid}>\r\n {\r\n state === States.Valid\r\n ? <CheckMark color={COLORS.generateToken({componentType:'text', defaultVariant:'positive'}, theme)}/>\r\n : <TechnicalWarning color={COLORS.generateToken({componentType:'text', defaultVariant:'critical'}, theme)}/>\r\n }\r\n <span>{validationMessage}</span>\r\n </ValidationMessage>\r\n )}\r\n {note && !disabled && (\r\n <NoteMessage className={size}>\r\n {note.icon}\r\n <span>{note.message}</span>\r\n </NoteMessage>\r\n )}\r\n </RichTextFieldContainer>\r\n )\r\n});"],"mappings":"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","ignoreList":[]}
@@ -17,7 +17,8 @@ export const RichTextFieldContainer = styled.div`
17
17
  .quill {
18
18
  width: 100%;
19
19
  margin-bottom: 4px;
20
- overflow: hidden;
20
+ overflow: visible;
21
+ position: relative;
21
22
 
22
23
  box-shadow: inset 0 0 0 1px ${props => COLORS.generateToken({
23
24
  componentType: 'border',
@@ -94,6 +95,20 @@ export const RichTextFieldContainer = styled.div`
94
95
  componentType: 'border',
95
96
  defaultVariant: 'subtle'
96
97
  }, props.theme)};
98
+ position: relative;
99
+ z-index: 1;
100
+ }
101
+
102
+ .ql-tooltip {
103
+ z-index: 1000 !important;
104
+ position: absolute !important;
105
+ left: 0 !important;
106
+ right: auto !important;
107
+ transform: none !important;
108
+ }
109
+
110
+ .ql-tooltip.ql-editing {
111
+ left: 8px !important;
97
112
  }
98
113
 
99
114
  .quill.valid .ql-toolbar,
@@ -110,7 +125,7 @@ export const RichTextFieldContainer = styled.div`
110
125
 
111
126
  .ql-container.ql-snow {
112
127
  border: none;
113
- overflow-y: hidden;
128
+ overflow-y: visible;
114
129
  padding: 8px;
115
130
  }
116
131
 
@@ -126,12 +141,13 @@ export const RichTextFieldContainer = styled.div`
126
141
 
127
142
  .quill {
128
143
  flex: none;
129
- overflow: initial;
144
+ overflow: visible;
130
145
  }
131
146
 
132
147
  .ql-container {
133
148
  flex: none;
134
149
  resize: vertical;
150
+ overflow-y: hidden;
135
151
  }
136
152
 
137
153
  .ql-editor {