@laerdal/life-react-components 6.0.0-dev.7.full → 6.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/Accordion/__tests__/AccordionMenu.test.tsx +42 -0
- package/dist/Accordion/__tests__/ContentAccordion.test.tsx +150 -0
- package/dist/AuthPage/__tests__/AuthPage.test.tsx +27 -0
- package/dist/Banners/__tests__/Banner.test.tsx +47 -0
- package/dist/Banners/__tests__/OverviewBanner.test.tsx +20 -0
- package/dist/Breadcrumb/__tests__/Breadcrumb.test.tsx +78 -0
- package/dist/Button/DualFunctionButton.cjs +4 -4
- package/dist/Button/DualFunctionButton.cjs.map +1 -1
- package/dist/Button/DualFunctionButton.d.ts +2 -2
- package/dist/Button/DualFunctionButton.js +4 -4
- package/dist/Button/DualFunctionButton.js.map +1 -1
- package/dist/Button/{Button.cjs → TextButton.cjs} +179 -92
- package/dist/Button/TextButton.cjs.map +1 -0
- package/dist/Button/TextButton.d.ts +70 -0
- package/dist/Button/{Button.js → TextButton.js} +178 -91
- package/dist/Button/TextButton.js.map +1 -0
- package/dist/Button/__tests__/BackButton.test.tsx +32 -0
- package/dist/Button/__tests__/Button.test.tsx +45 -0
- package/dist/Button/__tests__/DualButton.test.tsx +119 -0
- package/dist/Button/__tests__/TextButton.test.tsx +45 -0
- package/dist/Button/index.cjs +11 -11
- package/dist/Button/index.cjs.map +1 -1
- package/dist/Button/index.d.ts +2 -2
- package/dist/Button/index.js +2 -2
- package/dist/Button/index.js.map +1 -1
- package/dist/Card/HorizontalCard/__tests__/HorizontalCard.test.tsx +71 -0
- package/dist/Card/VerticalCard/{Card.cjs → VerticalCard.cjs} +62 -26
- package/dist/Card/VerticalCard/VerticalCard.cjs.map +1 -0
- package/dist/Card/VerticalCard/VerticalCard.d.ts +25 -0
- package/dist/Card/VerticalCard/{Card.js → VerticalCard.js} +62 -26
- package/dist/Card/VerticalCard/VerticalCard.js.map +1 -0
- package/dist/Card/VerticalCard/{CardBottomSection.cjs → VerticalCardBottomSection.cjs} +45 -27
- package/dist/Card/VerticalCard/VerticalCardBottomSection.cjs.map +1 -0
- package/dist/Card/VerticalCard/VerticalCardBottomSection.d.ts +53 -0
- package/dist/Card/VerticalCard/{CardBottomSection.js → VerticalCardBottomSection.js} +45 -27
- package/dist/Card/VerticalCard/VerticalCardBottomSection.js.map +1 -0
- package/dist/Card/VerticalCard/{CardMiddleSection.cjs → VerticalCardMiddleSection.cjs} +46 -23
- package/dist/Card/VerticalCard/VerticalCardMiddleSection.cjs.map +1 -0
- package/dist/Card/VerticalCard/VerticalCardMiddleSection.d.ts +42 -0
- package/dist/Card/VerticalCard/{CardMiddleSection.js → VerticalCardMiddleSection.js} +45 -23
- package/dist/Card/VerticalCard/VerticalCardMiddleSection.js.map +1 -0
- package/dist/Card/VerticalCard/{CardTopSection.cjs → VerticalCardTopSection.cjs} +18 -16
- package/dist/Card/VerticalCard/VerticalCardTopSection.cjs.map +1 -0
- package/dist/Card/VerticalCard/{CardTopSection.d.ts → VerticalCardTopSection.d.ts} +8 -8
- package/dist/Card/VerticalCard/{CardTopSection.js → VerticalCardTopSection.js} +17 -15
- package/dist/Card/VerticalCard/VerticalCardTopSection.js.map +1 -0
- package/dist/Card/VerticalCard/__tests__/VerticalCard.test.tsx +124 -0
- package/dist/Card/VerticalCard/index.cjs +25 -25
- package/dist/Card/VerticalCard/index.cjs.map +1 -1
- package/dist/Card/VerticalCard/index.d.ts +7 -7
- package/dist/Card/VerticalCard/index.js +7 -7
- package/dist/Card/VerticalCard/index.js.map +1 -1
- package/dist/Chips/ActionChip.cjs +6 -0
- package/dist/Chips/ActionChip.cjs.map +1 -1
- package/dist/Chips/ActionChip.js +6 -0
- package/dist/Chips/ActionChip.js.map +1 -1
- package/dist/Chips/ChipStyles.cjs +210 -31
- package/dist/Chips/ChipStyles.cjs.map +1 -1
- package/dist/Chips/ChipStyles.js +210 -31
- package/dist/Chips/ChipStyles.js.map +1 -1
- package/dist/Chips/ChoiceChips.cjs +1 -1
- package/dist/Chips/ChoiceChips.cjs.map +1 -1
- package/dist/Chips/ChoiceChips.js +1 -1
- package/dist/Chips/ChoiceChips.js.map +1 -1
- package/dist/Chips/FilterChip.cjs +8 -1
- package/dist/Chips/FilterChip.cjs.map +1 -1
- package/dist/Chips/FilterChip.js +8 -1
- package/dist/Chips/FilterChip.js.map +1 -1
- package/dist/Chips/InputChip.cjs +14 -0
- package/dist/Chips/InputChip.cjs.map +1 -1
- package/dist/Chips/InputChip.js +14 -0
- package/dist/Chips/InputChip.js.map +1 -1
- package/dist/Chips/__tests__/ActionChip.test.tsx +94 -0
- package/dist/Chips/__tests__/ChoiceChips.test.tsx +79 -0
- package/dist/Chips/__tests__/FilterChip.test.tsx +95 -0
- package/dist/Chips/__tests__/InputChip.test.tsx +155 -0
- package/dist/ChipsInput/ChipInputField.cjs +8 -2
- package/dist/ChipsInput/ChipInputField.cjs.map +1 -1
- package/dist/ChipsInput/ChipInputField.js +8 -2
- package/dist/ChipsInput/ChipInputField.js.map +1 -1
- package/dist/ChipsInput/__tests__/ChipDropdownInput.test.tsx +100 -0
- package/dist/ChipsInput/__tests__/ChipInputFields.test.tsx +155 -0
- package/dist/Dropdown/DropdownContent.cjs +2 -2
- package/dist/Dropdown/DropdownContent.cjs.map +1 -1
- package/dist/Dropdown/DropdownContent.js +2 -2
- package/dist/Dropdown/DropdownContent.js.map +1 -1
- package/dist/Dropdown/__tests__/DropdownFilter.test.tsx +39 -0
- package/dist/Footer/Components/FooterTop.cjs +3 -0
- package/dist/Footer/Components/FooterTop.cjs.map +1 -1
- package/dist/Footer/Components/FooterTop.js +3 -0
- package/dist/Footer/Components/FooterTop.js.map +1 -1
- package/dist/Footer/__tests__/Footer.test.tsx +182 -0
- package/dist/GlobalNavigationBar/Logo.cjs +2 -1
- package/dist/GlobalNavigationBar/Logo.cjs.map +1 -1
- package/dist/GlobalNavigationBar/Logo.js +2 -1
- package/dist/GlobalNavigationBar/Logo.js.map +1 -1
- package/dist/GlobalNavigationBar/__tests__/Logo.test.tsx +39 -0
- package/dist/GlobalNavigationBar/desktop/MainMenu.cjs +10 -1
- package/dist/GlobalNavigationBar/desktop/MainMenu.cjs.map +1 -1
- package/dist/GlobalNavigationBar/desktop/MainMenu.js +10 -1
- package/dist/GlobalNavigationBar/desktop/MainMenu.js.map +1 -1
- package/dist/GlobalNavigationBar/desktop/RightSideNav.cjs +5 -4
- package/dist/GlobalNavigationBar/desktop/RightSideNav.cjs.map +1 -1
- package/dist/GlobalNavigationBar/desktop/RightSideNav.js +6 -5
- package/dist/GlobalNavigationBar/desktop/RightSideNav.js.map +1 -1
- package/dist/GlobalNavigationBar/desktop/UserMenu.cjs +1 -1
- package/dist/GlobalNavigationBar/desktop/UserMenu.cjs.map +1 -1
- package/dist/GlobalNavigationBar/desktop/UserMenu.js +2 -2
- package/dist/GlobalNavigationBar/desktop/UserMenu.js.map +1 -1
- package/dist/GlobalNavigationBar/desktop/__tests__/DesktopActions.test.tsx +108 -0
- package/dist/GlobalNavigationBar/desktop/__tests__/ExtendedMainMenu.test.tsx +28 -0
- package/dist/GlobalNavigationBar/desktop/__tests__/MainMenu.test.tsx +55 -0
- package/dist/GlobalNavigationBar/desktop/__tests__/RightSideNav.test.tsx +45 -0
- package/dist/GlobalNavigationBar/desktop/__tests__/UserMenu.test.tsx +125 -0
- package/dist/GlobalNavigationBar/mobile/CommonStyles.cjs.map +1 -1
- package/dist/GlobalNavigationBar/mobile/CommonStyles.js.map +1 -1
- package/dist/GlobalNavigationBar/mobile/MobileActionContainer.cjs +1 -1
- package/dist/GlobalNavigationBar/mobile/MobileActionContainer.cjs.map +1 -1
- package/dist/GlobalNavigationBar/mobile/MobileActionContainer.js +2 -2
- package/dist/GlobalNavigationBar/mobile/MobileActionContainer.js.map +1 -1
- package/dist/GlobalNavigationBar/mobile/__tests__/MobileMenu.test.tsx +317 -0
- package/dist/GlobalNavigationBar/mobile/__tests__/MobileMenuContent.test.tsx +294 -0
- package/dist/GlobalNavigationBar/mobile/__tests__/MobileMenuHeader.test.tsx +195 -0
- package/dist/GlobalNavigationBar/types.cjs.map +1 -1
- package/dist/GlobalNavigationBar/types.d.ts +2 -2
- package/dist/GlobalNavigationBar/types.js.map +1 -1
- package/dist/HyperLink/HyperLink.cjs +18 -2
- package/dist/HyperLink/HyperLink.cjs.map +1 -1
- package/dist/HyperLink/HyperLink.d.ts +2 -0
- package/dist/HyperLink/HyperLink.js +18 -2
- package/dist/HyperLink/HyperLink.js.map +1 -1
- package/dist/HyperLink/styling.cjs +4 -0
- package/dist/HyperLink/styling.cjs.map +1 -1
- package/dist/HyperLink/styling.js +4 -0
- package/dist/HyperLink/styling.js.map +1 -1
- package/dist/InputFields/DatepickerField.cjs +21 -5
- package/dist/InputFields/DatepickerField.cjs.map +1 -1
- package/dist/InputFields/DatepickerField.d.ts +1 -1
- package/dist/InputFields/DatepickerField.js +21 -5
- package/dist/InputFields/DatepickerField.js.map +1 -1
- package/dist/InputFields/NumberField.cjs +4 -0
- package/dist/InputFields/NumberField.cjs.map +1 -1
- package/dist/InputFields/NumberField.js +4 -0
- package/dist/InputFields/NumberField.js.map +1 -1
- package/dist/InputFields/RadioButton.cjs +2 -2
- package/dist/InputFields/RadioButton.cjs.map +1 -1
- package/dist/InputFields/RadioButton.d.ts +4 -4
- package/dist/InputFields/RadioButton.js +2 -2
- package/dist/InputFields/RadioButton.js.map +1 -1
- package/dist/InputFields/__tests__/NumberField.test.tsx +67 -0
- package/dist/InputFields/__tests__/NumberInput.test.tsx +68 -0
- package/dist/InputFields/__tests__/QuickSearch.test.tsx +42 -0
- package/dist/InputFields/components/SearchBarInput.cjs +5 -0
- package/dist/InputFields/components/SearchBarInput.cjs.map +1 -1
- package/dist/InputFields/components/SearchBarInput.js +5 -0
- package/dist/InputFields/components/SearchBarInput.js.map +1 -1
- package/dist/LinearProgress/__tests__/LinearProgress.test.tsx +25 -0
- package/dist/List/__tests__/ListRow.test.tsx +18 -0
- package/dist/LoadingPage/__tests__/GlobalLoadingPage.test.tsx +23 -0
- package/dist/MiniProductCard/MiniProductCard.cjs +15 -1
- package/dist/MiniProductCard/MiniProductCard.cjs.map +1 -1
- package/dist/MiniProductCard/MiniProductCard.d.ts +1 -0
- package/dist/MiniProductCard/MiniProductCard.js +15 -1
- package/dist/MiniProductCard/MiniProductCard.js.map +1 -1
- package/dist/Modals/ModalContainer.cjs +102 -83
- package/dist/Modals/ModalContainer.cjs.map +1 -1
- package/dist/Modals/ModalContainer.d.ts +20 -1
- package/dist/Modals/ModalContainer.js +103 -84
- package/dist/Modals/ModalContainer.js.map +1 -1
- package/dist/Modals/ModalContent.cjs +7 -3
- package/dist/Modals/ModalContent.cjs.map +1 -1
- package/dist/Modals/ModalContent.js +8 -4
- package/dist/Modals/ModalContent.js.map +1 -1
- package/dist/Modals/ModalDialog.cjs +2 -2
- package/dist/Modals/ModalDialog.cjs.map +1 -1
- package/dist/Modals/ModalDialog.js +3 -3
- package/dist/Modals/ModalDialog.js.map +1 -1
- package/dist/Modals/ModalStyles.cjs +12 -0
- package/dist/Modals/ModalStyles.cjs.map +1 -1
- package/dist/Modals/ModalStyles.js +12 -0
- package/dist/Modals/ModalStyles.js.map +1 -1
- package/dist/Modals/ModalTypes.cjs.map +1 -1
- package/dist/Modals/ModalTypes.d.ts +3 -3
- package/dist/Modals/ModalTypes.js.map +1 -1
- package/dist/Modals/__tests__/Modal.test.tsx +169 -0
- package/dist/Modals/__tests__/ModalContainer.test.tsx +77 -0
- package/dist/Modals/__tests__/ModalContent.test.tsx +126 -0
- package/dist/NavItem/NavItem.cjs +7 -1
- package/dist/NavItem/NavItem.cjs.map +1 -1
- package/dist/NavItem/NavItem.js +7 -1
- package/dist/NavItem/NavItem.js.map +1 -1
- package/dist/NavItem/__tests__/NavItem.test.ts +6 -0
- package/dist/Navigation/NavigationProvider.cjs.map +1 -1
- package/dist/Navigation/NavigationProvider.d.ts +3 -0
- package/dist/Navigation/NavigationProvider.js.map +1 -1
- package/dist/NotificationDot/__tests__/NotificationDot.test.tsx +33 -0
- package/dist/Paginator/Paginator.cjs +18 -14
- package/dist/Paginator/Paginator.cjs.map +1 -1
- package/dist/Paginator/Paginator.d.ts +1 -5
- package/dist/Paginator/Paginator.js +18 -14
- package/dist/Paginator/Paginator.js.map +1 -1
- package/dist/Paginator/__tests__/Paginator.test.tsx +33 -0
- package/dist/Popover/Popover.cjs +1 -1
- package/dist/Popover/Popover.cjs.map +1 -1
- package/dist/Popover/Popover.js +2 -2
- package/dist/Popover/Popover.js.map +1 -1
- package/dist/Popover/__tests__/Popover.test.tsx +64 -0
- package/dist/ProfileButton/__tests__/ProfileButton.test.tsx +31 -0
- package/dist/QuizButton/__tests__/QuizButton.test.tsx +53 -0
- package/dist/SegmentControl/__tests__/SegmentControl.test.tsx +145 -0
- package/dist/SideMenu/SideMenuFooter.cjs +1 -1
- package/dist/SideMenu/SideMenuFooter.cjs.map +1 -1
- package/dist/SideMenu/SideMenuFooter.js +2 -2
- package/dist/SideMenu/SideMenuFooter.js.map +1 -1
- package/dist/SideMenu/__tests__/SideMenu.test.tsx +99 -0
- package/dist/SideMenu/types.cjs.map +1 -1
- package/dist/SideMenu/types.d.ts +2 -2
- package/dist/SideMenu/types.js.map +1 -1
- package/dist/Switcher/__tests__/SwitcherMenuItem.tsx +14 -0
- package/dist/Table/TableBody.cjs +1 -1
- 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 -1
- package/dist/Table/TableStyles.cjs.map +1 -1
- package/dist/Table/TableStyles.js +4 -1
- package/dist/Table/TableStyles.js.map +1 -1
- package/dist/Table/TableTypes.cjs.map +1 -1
- package/dist/Table/TableTypes.d.ts +2 -2
- package/dist/Table/TableTypes.js.map +1 -1
- package/dist/Table/__tests__/Table.test.tsx +499 -0
- package/dist/Tabs/VerticalTabs.cjs +1 -0
- package/dist/Tabs/VerticalTabs.cjs.map +1 -1
- package/dist/Tabs/VerticalTabs.js +1 -0
- package/dist/Tabs/VerticalTabs.js.map +1 -1
- package/dist/Tabs/__tests__/HorizontalTabs.test.tsx +95 -0
- package/dist/Tabs/__tests__/TabLink.test.tsx +40 -0
- package/dist/Tabs/__tests__/Tablist.test.tsx +37 -0
- package/dist/Tag/Tag.cjs +48 -12
- package/dist/Tag/Tag.cjs.map +1 -1
- package/dist/Tag/Tag.js +48 -12
- package/dist/Tag/Tag.js.map +1 -1
- package/dist/Tag/__tests__/Tag.test.tsx +86 -0
- package/dist/Tile/TileCommonItems.cjs +1 -1
- package/dist/Tile/TileCommonItems.cjs.map +1 -1
- package/dist/Tile/TileCommonItems.js +2 -2
- package/dist/Tile/TileCommonItems.js.map +1 -1
- package/dist/Tile/TileTypes.cjs.map +1 -1
- package/dist/Tile/TileTypes.d.ts +2 -2
- package/dist/Tile/TileTypes.js.map +1 -1
- package/dist/Toasters/Toast.cjs +1 -2
- package/dist/Toasters/Toast.cjs.map +1 -1
- package/dist/Toasters/Toast.js +2 -3
- package/dist/Toasters/Toast.js.map +1 -1
- package/dist/Toasters/__tests__/Toast.test.tsx +74 -0
- package/dist/Toggles/TogglerStyles.cjs +171 -15
- package/dist/Toggles/TogglerStyles.cjs.map +1 -1
- package/dist/Toggles/TogglerStyles.js +171 -15
- package/dist/Toggles/TogglerStyles.js.map +1 -1
- package/dist/Toggles/__tests__/ToggleButton.test.tsx +53 -0
- package/dist/Toggles/__tests__/ToggleSwitch.test.tsx +87 -0
- package/dist/Tooltips/__tests__/TooltipWrapper.test.tsx +16 -0
- package/dist/common/NavigationHelper.cjs +0 -28
- package/dist/common/NavigationHelper.cjs.map +1 -1
- package/dist/common/NavigationHelper.d.ts +0 -4
- package/dist/common/NavigationHelper.js +1 -22
- package/dist/common/NavigationHelper.js.map +1 -1
- package/dist/styles/colors.cjs +6 -0
- package/dist/styles/colors.cjs.map +1 -1
- package/dist/styles/colors.d.ts +6 -0
- package/dist/styles/colors.js +6 -0
- package/dist/styles/colors.js.map +1 -1
- package/dist/styles/design-tokens/dark/tokens.css +481 -0
- package/dist/styles/design-tokens/light/tokens.css +481 -0
- package/dist/styles/design-tokens/rqi_dark/tokens.css +481 -0
- package/dist/styles/design-tokens/rqi_light/tokens.css +481 -0
- package/dist/styles/global.cjs +4 -4
- package/dist/styles/global.cjs.map +1 -1
- package/dist/styles/global.js +4 -4
- package/dist/styles/global.js.map +1 -1
- package/dist/styles/react-datepicker.css +766 -0
- package/dist/styles/typography.cjs +4 -1
- package/dist/styles/typography.cjs.map +1 -1
- package/dist/styles/typography.js +4 -1
- package/dist/styles/typography.js.map +1 -1
- package/dist/test-utils.cjs +7 -1
- package/dist/test-utils.cjs.map +1 -1
- package/dist/test-utils.js +7 -1
- package/dist/test-utils.js.map +1 -1
- package/package.json +11 -6
- package/dist/Button/Button.cjs.map +0 -1
- package/dist/Button/Button.d.ts +0 -70
- package/dist/Button/Button.js.map +0 -1
- package/dist/Card/VerticalCard/Card.cjs.map +0 -1
- package/dist/Card/VerticalCard/Card.d.ts +0 -24
- package/dist/Card/VerticalCard/Card.js.map +0 -1
- package/dist/Card/VerticalCard/CardBottomSection.cjs.map +0 -1
- package/dist/Card/VerticalCard/CardBottomSection.d.ts +0 -49
- package/dist/Card/VerticalCard/CardBottomSection.js.map +0 -1
- package/dist/Card/VerticalCard/CardMiddleSection.cjs.map +0 -1
- package/dist/Card/VerticalCard/CardMiddleSection.d.ts +0 -37
- package/dist/Card/VerticalCard/CardMiddleSection.js.map +0 -1
- package/dist/Card/VerticalCard/CardTopSection.cjs.map +0 -1
- package/dist/Card/VerticalCard/CardTopSection.js.map +0 -1
- package/dist/GlobalNavigationBar/__tests__/GlobalNavigationBar.tests.d.ts +0 -1
- package/dist/GlobalNavigationBar/__tests__/Logo.tests.d.ts +0 -1
- package/dist/List/__tests__/ListRow.tests.d.ts +0 -1
- package/dist/Tabs/__tests__/TabLink.tests.d.ts +0 -1
- package/dist/Tabs/__tests__/Tablist.tests.d.ts +0 -2
- package/dist/common/Link.cjs +0 -45
- package/dist/common/Link.cjs.map +0 -1
- package/dist/common/Link.d.ts +0 -9
- package/dist/common/Link.js +0 -37
- package/dist/common/Link.js.map +0 -1
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import {act, fireEvent, render} from '../../../test-utils';
|
|
3
|
+
import MobileMenuHeader, {MobileMenuHeaderActions, MobileMenuHeaderWrapper} from '../MobileMenuHeader';
|
|
4
|
+
import {IconButtonStyled} from '../../../Button/Iconbutton';
|
|
5
|
+
import {MobileMenuButtonTypes, ProfileMenu} from '../../types';
|
|
6
|
+
import {ProfileButtonContainer} from '../../../ProfileButton/ProfileButton';
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
describe('MobileMenuHeader', () => {
|
|
13
|
+
const backSpy = jest.fn();
|
|
14
|
+
const closeSpy = jest.fn();
|
|
15
|
+
const subMenuOpenSpy = jest.fn();
|
|
16
|
+
const profileSpy = jest.fn();
|
|
17
|
+
const buttonSpy = jest.fn();
|
|
18
|
+
|
|
19
|
+
const profileButton: MobileMenuButtonTypes = {
|
|
20
|
+
type: 'profile',
|
|
21
|
+
action: profileSpy
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
const subMenuButton: MobileMenuButtonTypes = {
|
|
25
|
+
type: 'submenu',
|
|
26
|
+
menu: {
|
|
27
|
+
type: 'custom',
|
|
28
|
+
custom: () => <div>custom</div>,
|
|
29
|
+
},
|
|
30
|
+
icon: <i></i>
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
const leftButton: MobileMenuButtonTypes = {
|
|
34
|
+
type: 'action',
|
|
35
|
+
action: buttonSpy,
|
|
36
|
+
icon: <i></i>,
|
|
37
|
+
placement: 'left'
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
const rightButton: MobileMenuButtonTypes = {
|
|
41
|
+
type: 'action',
|
|
42
|
+
action: buttonSpy,
|
|
43
|
+
icon: <i></i>,
|
|
44
|
+
placement: 'right'
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
beforeEach(() => {
|
|
48
|
+
backSpy.mockReset();
|
|
49
|
+
closeSpy.mockReset();
|
|
50
|
+
subMenuOpenSpy.mockReset();
|
|
51
|
+
buttonSpy.mockReset();
|
|
52
|
+
profileSpy.mockReset();
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
it('should render', () => {
|
|
56
|
+
const wrapper = render(<MobileMenuHeader onClose={closeSpy}/>)
|
|
57
|
+
|
|
58
|
+
expect(wrapper.container.querySelector(`${MobileMenuHeaderWrapper}`)).toBeDefined();
|
|
59
|
+
});
|
|
60
|
+
|
|
61
|
+
it('should render only close button', () => {
|
|
62
|
+
const wrapper = render(<MobileMenuHeader onClose={closeSpy}/>)
|
|
63
|
+
|
|
64
|
+
expect(wrapper.container.querySelectorAll(`${IconButtonStyled}`)).toHaveLength(1);
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
it('should render label', () => {
|
|
68
|
+
const wrapper = render(<MobileMenuHeader onClose={closeSpy} label={'label'}/>)
|
|
69
|
+
|
|
70
|
+
expect(wrapper.queryByText('label')).toBeDefined();
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
it('should render close button and back button', () => {
|
|
74
|
+
const wrapper = render(<MobileMenuHeader onClose={closeSpy} onGoBack={backSpy}/>)
|
|
75
|
+
|
|
76
|
+
expect(wrapper.container.querySelectorAll(`${IconButtonStyled}`)).toHaveLength(2);
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
it('should render profile button', () => {
|
|
80
|
+
|
|
81
|
+
const wrapper = render(<MobileMenuHeader onClose={closeSpy} profile={
|
|
82
|
+
{
|
|
83
|
+
user:{
|
|
84
|
+
firstName: "name",
|
|
85
|
+
lastName: "last",
|
|
86
|
+
email: "mail",
|
|
87
|
+
},
|
|
88
|
+
sections:[]
|
|
89
|
+
}
|
|
90
|
+
} buttons={[profileButton]}/>)
|
|
91
|
+
|
|
92
|
+
expect(wrapper.container.querySelectorAll(`${ProfileButtonContainer}`)).toHaveLength(1);
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
it('should render button on the left', () => {
|
|
96
|
+
|
|
97
|
+
const wrapper = render(<MobileMenuHeader onClose={closeSpy} buttons={[leftButton]}/>)
|
|
98
|
+
|
|
99
|
+
expect(wrapper.container.querySelectorAll(`${MobileMenuHeaderWrapper} ${IconButtonStyled}`)).toHaveLength(2);
|
|
100
|
+
expect(wrapper.container.querySelectorAll(`${MobileMenuHeaderActions} ${IconButtonStyled}`)).toHaveLength(1);
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
it('should render button on the right', () => {
|
|
104
|
+
|
|
105
|
+
const wrapper = render(<MobileMenuHeader onClose={closeSpy} buttons={[rightButton]}/>)
|
|
106
|
+
|
|
107
|
+
expect(wrapper.container.querySelectorAll(`${MobileMenuHeaderWrapper} ${IconButtonStyled}`)).toHaveLength(2);
|
|
108
|
+
expect(wrapper.container.querySelectorAll(`${MobileMenuHeaderActions} ${IconButtonStyled}`)).toHaveLength(2);
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
it('should call onClose function when close button is clicked', () => {
|
|
112
|
+
const wrapper = render(<MobileMenuHeader onClose={closeSpy}/>)
|
|
113
|
+
|
|
114
|
+
act(() => {
|
|
115
|
+
fireEvent.click(wrapper.container.querySelector(`${IconButtonStyled}`)!);
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
expect(closeSpy).toHaveBeenCalled();
|
|
119
|
+
});
|
|
120
|
+
|
|
121
|
+
it('should call onGoBack function when back button is clicked', () => {
|
|
122
|
+
const wrapper = render(<MobileMenuHeader onClose={closeSpy} onGoBack={backSpy}/>)
|
|
123
|
+
|
|
124
|
+
act(() => {
|
|
125
|
+
fireEvent.click(wrapper.container.querySelectorAll(`${IconButtonStyled}`)[0]);
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
expect(backSpy).toHaveBeenCalled();
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
it('should call onSubMenuOpen function when submenu button is clicked', () => {
|
|
132
|
+
const wrapper = render(<MobileMenuHeader onClose={closeSpy} buttons={[subMenuButton]}
|
|
133
|
+
onSubMenuOpen={subMenuOpenSpy}/>)
|
|
134
|
+
|
|
135
|
+
act(() => {
|
|
136
|
+
fireEvent.click(wrapper.container.querySelectorAll(`${IconButtonStyled}`)[0]);
|
|
137
|
+
});
|
|
138
|
+
|
|
139
|
+
expect(subMenuOpenSpy).toHaveBeenCalled();
|
|
140
|
+
});
|
|
141
|
+
|
|
142
|
+
it('should call action when icon button is clicked', () => {
|
|
143
|
+
const wrapper = render(<MobileMenuHeader onClose={closeSpy} buttons={[leftButton]}/>)
|
|
144
|
+
|
|
145
|
+
act(() => {
|
|
146
|
+
fireEvent.click(wrapper.container.querySelectorAll(`${IconButtonStyled}`)[0]);
|
|
147
|
+
});
|
|
148
|
+
|
|
149
|
+
expect(buttonSpy).toHaveBeenCalled();
|
|
150
|
+
});
|
|
151
|
+
|
|
152
|
+
it('should call profile button action when profile button is clicked', () => {
|
|
153
|
+
|
|
154
|
+
const wrapper = render(<MobileMenuHeader onClose={closeSpy} profile={
|
|
155
|
+
{
|
|
156
|
+
user:{
|
|
157
|
+
firstName: "name",
|
|
158
|
+
lastName: "last",
|
|
159
|
+
email: "mail",
|
|
160
|
+
},
|
|
161
|
+
sections:[]
|
|
162
|
+
}
|
|
163
|
+
} buttons={[profileButton]}/>)
|
|
164
|
+
|
|
165
|
+
act(() => {
|
|
166
|
+
fireEvent.click(wrapper.container.querySelectorAll(`${IconButtonStyled}`)[0]);
|
|
167
|
+
});
|
|
168
|
+
|
|
169
|
+
expect(profileSpy).toHaveBeenCalled();
|
|
170
|
+
});
|
|
171
|
+
|
|
172
|
+
it('should call onSubMenuOpen when profile button is clicked and action is not provided', () => {
|
|
173
|
+
const profile = {
|
|
174
|
+
label: 'profile label',
|
|
175
|
+
sections: [],
|
|
176
|
+
user: {
|
|
177
|
+
lastName: 'lastname',
|
|
178
|
+
firstName: 'firstname',
|
|
179
|
+
email: 'email@email.com'
|
|
180
|
+
},
|
|
181
|
+
} as ProfileMenu;
|
|
182
|
+
const wrapper = render(<MobileMenuHeader onClose={closeSpy}
|
|
183
|
+
buttons={[{...profileButton, action: undefined}]}
|
|
184
|
+
profile={profile}
|
|
185
|
+
onSubMenuOpen={subMenuOpenSpy}/>)
|
|
186
|
+
|
|
187
|
+
act(() => {
|
|
188
|
+
fireEvent.click(wrapper.container.querySelectorAll(`${IconButtonStyled}`)[0]);
|
|
189
|
+
});
|
|
190
|
+
|
|
191
|
+
expect(subMenuOpenSpy).toHaveBeenCalled();
|
|
192
|
+
});
|
|
193
|
+
|
|
194
|
+
|
|
195
|
+
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.cjs","names":[],"sources":["../../src/GlobalNavigationBar/types.tsx"],"sourcesContent":["import React from 'react';\r\nimport { HyperlinkProps } from '../HyperLink/HyperLink';\r\nimport { IconButtonProps } from '../Button/Iconbutton';\r\nimport { ProfileButtonProps } from '../ProfileButton/ProfileButton';\r\nimport {
|
|
1
|
+
{"version":3,"file":"types.cjs","names":[],"sources":["../../src/GlobalNavigationBar/types.tsx"],"sourcesContent":["import React from 'react';\r\nimport { HyperlinkProps } from '../HyperLink/HyperLink';\r\nimport { IconButtonProps } from '../Button/Iconbutton';\r\nimport { ProfileButtonProps } from '../ProfileButton/ProfileButton';\r\nimport {TextButtonProps} from \"../Button/TextButton\";\r\nimport {TooltipProps} from \"../Tooltips/TooltipTypes\";\r\n\r\nexport interface MenuHyperLinkProps extends Pick<HyperlinkProps, 'id' | 'href' | 'onClick' | 'target'> {\r\n label: string;\r\n icon?: React.ReactElement<any>;\r\n}\r\n\r\nexport interface MenuButton extends Omit<TextButtonProps, 'onClick' | 'children' | 'size'> {\r\n label: string;\r\n action: () => void;\r\n\r\n tooltip?: TooltipProps;\r\n}\r\n\r\nexport interface MenuGroupFooter {\r\n header: string;\r\n note?: string;\r\n link?: MenuHyperLinkProps;\r\n}\r\n\r\nexport interface MenuGroupHeader {\r\n header: string;\r\n note?: string;\r\n link?: MenuHyperLinkProps;\r\n}\r\n\r\nexport interface MenuAccountInfo {\r\n firstName: string;\r\n lastName: string;\r\n email: string;\r\n link?: MenuHyperLinkProps;\r\n}\r\n\r\nexport interface ProfileMenu {\r\n label?: string;\r\n\r\n user: MenuAccountInfo;\r\n\r\n sections: MenuNavigationSection[];\r\n\r\n signOut?: MenuButton;\r\n}\r\n\r\nexport interface MenuIconSubMenuButton\r\n extends Omit<\r\n IconButtonProps,\r\n | 'type'\r\n | 'action'\r\n | 'shape'\r\n | 'variant'\r\n | 'hideOnLowWidth'\r\n | 'flatEdge'\r\n | 'isInMobileMenu'\r\n | 'useTransparentBackground'\r\n | 'shouldNotInteract'\r\n | 'iconColor'\r\n | 'unsetIconSize'\r\n | 'borderRadius'\r\n | 'focusBackgroundColor'\r\n | 'children'\r\n | 'invertFocus'\r\n > {\r\n type: 'submenu';\r\n icon: React.ReactNode;\r\n menu: MenuNavigationItemTypeGroup | MenuNavigationCustomSubMenu;\r\n placement?: 'left' | 'right';\r\n}\r\n\r\nexport interface MenuIconButton\r\n extends Omit<\r\n IconButtonProps,\r\n | 'type'\r\n | 'action'\r\n | 'shape'\r\n | 'variant'\r\n | 'hideOnLowWidth'\r\n | 'flatEdge'\r\n | 'isInMobileMenu'\r\n | 'useTransparentBackground'\r\n | 'shouldNotInteract'\r\n | 'iconColor'\r\n | 'unsetIconSize'\r\n | 'borderRadius'\r\n | 'focusBackgroundColor'\r\n | 'children'\r\n | 'invertFocus'\r\n > {\r\n type: 'action';\r\n icon: React.ReactNode;\r\n action: (button?: EventTarget) => boolean | void;\r\n placement?: 'left' | 'right';\r\n}\r\n\r\nexport interface MenuProfileButton extends Omit<ProfileButtonProps, 'type' | 'onClick' | 'initials' | 'hideOnLowWidth' | 'icon' | 'portraitSrc'> {\r\n type: 'profile';\r\n action?: (button?: EventTarget) => boolean | void;\r\n placement?: 'left' | 'right';\r\n}\r\n\r\nexport interface MenuSearchButton {\r\n type: 'search';\r\n placement?: 'left' | 'right';\r\n}\r\n\r\nexport interface MenuSwitcherButton\r\n extends Omit<\r\n IconButtonProps,\r\n | 'id'\r\n | 'type'\r\n | 'action'\r\n | 'shape'\r\n | 'variant'\r\n | 'hideOnLowWidth'\r\n | 'flatEdge'\r\n | 'isInMobileMenu'\r\n | 'useTransparentBackground'\r\n | 'shouldNotInteract'\r\n | 'iconColor'\r\n | 'unsetIconSize'\r\n | 'borderRadius'\r\n | 'focusBackgroundColor'\r\n | 'children'\r\n | 'invertFocus'\r\n > {\r\n type: 'switcher';\r\n placement?: 'left' | 'right';\r\n action?: (button?: EventTarget) => boolean | void;\r\n}\r\n\r\nexport type DesktopMenuButtonTypes = MenuIconButton | MenuProfileButton | MenuSwitcherButton;\r\nexport type MobileMenuButtonTypes = MenuIconSubMenuButton | MenuIconButton | MenuProfileButton | MenuSwitcherButton | MenuSearchButton;\r\n\r\nexport interface MobileNavigationMenuProps {\r\n label?: string;\r\n buttons?: MobileMenuButtonTypes[];\r\n\r\n header?: MenuGroupHeader;\r\n\r\n items?: (MenuNavigationItemTypeItem | MenuNavigationItemTypeGroup)[];\r\n\r\n footer?: MenuGroupFooter;\r\n action?: MenuButton;\r\n}\r\n\r\nexport interface DesktopNavigationMenuProps {\r\n buttons?: DesktopMenuButtonTypes[];\r\n items: (MenuNavigationItemTypeItem | MenuNavigationItemTypeDesktopGroup)[];\r\n action?: MenuButton;\r\n reverseRightSideOrder?: boolean;\r\n}\r\n\r\n// @ts-ignore\r\nexport interface MenuNavigationGroup<T = MenuNavigationItemTypeDesktopGroup | MenuNavigationItem | MenuNavigationSection | MenuNavigationGroup> {\r\n label: string;\r\n note?: string;\r\n\r\n buttons?: MobileMenuButtonTypes[];\r\n header?: MenuGroupHeader;\r\n\r\n items: T[];\r\n\r\n footer?: MenuGroupFooter;\r\n action?: MenuButton;\r\n}\r\n\r\nexport type MenuNavigationItem = {\r\n icon?: React.ReactNode;\r\n to: string;\r\n exact?: boolean;\r\n disabled?: boolean;\r\n external?: boolean;\r\n action?: (e: React.MouseEvent) => void;\r\n label: string;\r\n note?: string;\r\n pinned?: boolean;\r\n subItems?: MenuNavigationItem[];\r\n} & Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, 'onClick' | 'to' | 'exact' | 'onMouseDown'>;\r\n\r\nexport interface MenuNavigationSection<T = MenuNavigationItem> {\r\n divider?: boolean;\r\n pinned?: boolean;\r\n label?: string;\r\n items: T[];\r\n}\r\n\r\nexport type MenuNavigationItemTypeItem = MenuNavigationItem & {\r\n type?: 'item';\r\n};\r\n\r\nexport type MenuNavigationItemTypeDesktopGroup = {\r\n id: string;\r\n label?: string;\r\n disabled?: boolean;\r\n pinned?: boolean;\r\n type?: 'desktopgroup';\r\n expanded?: boolean;\r\n items: (MenuNavigationItemTypeItem | MenuNavigationItemTypeDesktopGroup)[];\r\n}\r\n\r\nexport type MenuNavigationItemTypeGroup = MenuNavigationGroup<MenuNavigationItemTypeItem | MenuNavigationItemTypeGroup | MenuNavigationItemTypeSection> & {\r\n type: 'group';\r\n icon?: React.ReactNode;\r\n pinned?: boolean;\r\n disabled?: boolean;\r\n};\r\n\r\nexport type MenuNavigationItemTypeSection = MenuNavigationSection<MenuNavigationItemTypeItem> & {\r\n type: 'section';\r\n};\r\n\r\nexport type MenuNavigationCustomSubMenu = {\r\n type: 'custom';\r\n label?: string;\r\n buttons?: MobileMenuButtonTypes[];\r\n custom: () => React.ReactNode;\r\n};\r\n"],"mappings":"","ignoreList":[]}
|
|
@@ -2,13 +2,13 @@ import React from 'react';
|
|
|
2
2
|
import { HyperlinkProps } from '../HyperLink/HyperLink';
|
|
3
3
|
import { IconButtonProps } from '../Button/Iconbutton';
|
|
4
4
|
import { ProfileButtonProps } from '../ProfileButton/ProfileButton';
|
|
5
|
-
import {
|
|
5
|
+
import { TextButtonProps } from "../Button/TextButton";
|
|
6
6
|
import { TooltipProps } from "../Tooltips/TooltipTypes";
|
|
7
7
|
export interface MenuHyperLinkProps extends Pick<HyperlinkProps, 'id' | 'href' | 'onClick' | 'target'> {
|
|
8
8
|
label: string;
|
|
9
9
|
icon?: React.ReactElement<any>;
|
|
10
10
|
}
|
|
11
|
-
export interface MenuButton extends Omit<
|
|
11
|
+
export interface MenuButton extends Omit<TextButtonProps, 'onClick' | 'children' | 'size'> {
|
|
12
12
|
label: string;
|
|
13
13
|
action: () => void;
|
|
14
14
|
tooltip?: TooltipProps;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","names":[],"sources":["../../src/GlobalNavigationBar/types.tsx"],"sourcesContent":["import React from 'react';\r\nimport { HyperlinkProps } from '../HyperLink/HyperLink';\r\nimport { IconButtonProps } from '../Button/Iconbutton';\r\nimport { ProfileButtonProps } from '../ProfileButton/ProfileButton';\r\nimport {
|
|
1
|
+
{"version":3,"file":"types.js","names":[],"sources":["../../src/GlobalNavigationBar/types.tsx"],"sourcesContent":["import React from 'react';\r\nimport { HyperlinkProps } from '../HyperLink/HyperLink';\r\nimport { IconButtonProps } from '../Button/Iconbutton';\r\nimport { ProfileButtonProps } from '../ProfileButton/ProfileButton';\r\nimport {TextButtonProps} from \"../Button/TextButton\";\r\nimport {TooltipProps} from \"../Tooltips/TooltipTypes\";\r\n\r\nexport interface MenuHyperLinkProps extends Pick<HyperlinkProps, 'id' | 'href' | 'onClick' | 'target'> {\r\n label: string;\r\n icon?: React.ReactElement<any>;\r\n}\r\n\r\nexport interface MenuButton extends Omit<TextButtonProps, 'onClick' | 'children' | 'size'> {\r\n label: string;\r\n action: () => void;\r\n\r\n tooltip?: TooltipProps;\r\n}\r\n\r\nexport interface MenuGroupFooter {\r\n header: string;\r\n note?: string;\r\n link?: MenuHyperLinkProps;\r\n}\r\n\r\nexport interface MenuGroupHeader {\r\n header: string;\r\n note?: string;\r\n link?: MenuHyperLinkProps;\r\n}\r\n\r\nexport interface MenuAccountInfo {\r\n firstName: string;\r\n lastName: string;\r\n email: string;\r\n link?: MenuHyperLinkProps;\r\n}\r\n\r\nexport interface ProfileMenu {\r\n label?: string;\r\n\r\n user: MenuAccountInfo;\r\n\r\n sections: MenuNavigationSection[];\r\n\r\n signOut?: MenuButton;\r\n}\r\n\r\nexport interface MenuIconSubMenuButton\r\n extends Omit<\r\n IconButtonProps,\r\n | 'type'\r\n | 'action'\r\n | 'shape'\r\n | 'variant'\r\n | 'hideOnLowWidth'\r\n | 'flatEdge'\r\n | 'isInMobileMenu'\r\n | 'useTransparentBackground'\r\n | 'shouldNotInteract'\r\n | 'iconColor'\r\n | 'unsetIconSize'\r\n | 'borderRadius'\r\n | 'focusBackgroundColor'\r\n | 'children'\r\n | 'invertFocus'\r\n > {\r\n type: 'submenu';\r\n icon: React.ReactNode;\r\n menu: MenuNavigationItemTypeGroup | MenuNavigationCustomSubMenu;\r\n placement?: 'left' | 'right';\r\n}\r\n\r\nexport interface MenuIconButton\r\n extends Omit<\r\n IconButtonProps,\r\n | 'type'\r\n | 'action'\r\n | 'shape'\r\n | 'variant'\r\n | 'hideOnLowWidth'\r\n | 'flatEdge'\r\n | 'isInMobileMenu'\r\n | 'useTransparentBackground'\r\n | 'shouldNotInteract'\r\n | 'iconColor'\r\n | 'unsetIconSize'\r\n | 'borderRadius'\r\n | 'focusBackgroundColor'\r\n | 'children'\r\n | 'invertFocus'\r\n > {\r\n type: 'action';\r\n icon: React.ReactNode;\r\n action: (button?: EventTarget) => boolean | void;\r\n placement?: 'left' | 'right';\r\n}\r\n\r\nexport interface MenuProfileButton extends Omit<ProfileButtonProps, 'type' | 'onClick' | 'initials' | 'hideOnLowWidth' | 'icon' | 'portraitSrc'> {\r\n type: 'profile';\r\n action?: (button?: EventTarget) => boolean | void;\r\n placement?: 'left' | 'right';\r\n}\r\n\r\nexport interface MenuSearchButton {\r\n type: 'search';\r\n placement?: 'left' | 'right';\r\n}\r\n\r\nexport interface MenuSwitcherButton\r\n extends Omit<\r\n IconButtonProps,\r\n | 'id'\r\n | 'type'\r\n | 'action'\r\n | 'shape'\r\n | 'variant'\r\n | 'hideOnLowWidth'\r\n | 'flatEdge'\r\n | 'isInMobileMenu'\r\n | 'useTransparentBackground'\r\n | 'shouldNotInteract'\r\n | 'iconColor'\r\n | 'unsetIconSize'\r\n | 'borderRadius'\r\n | 'focusBackgroundColor'\r\n | 'children'\r\n | 'invertFocus'\r\n > {\r\n type: 'switcher';\r\n placement?: 'left' | 'right';\r\n action?: (button?: EventTarget) => boolean | void;\r\n}\r\n\r\nexport type DesktopMenuButtonTypes = MenuIconButton | MenuProfileButton | MenuSwitcherButton;\r\nexport type MobileMenuButtonTypes = MenuIconSubMenuButton | MenuIconButton | MenuProfileButton | MenuSwitcherButton | MenuSearchButton;\r\n\r\nexport interface MobileNavigationMenuProps {\r\n label?: string;\r\n buttons?: MobileMenuButtonTypes[];\r\n\r\n header?: MenuGroupHeader;\r\n\r\n items?: (MenuNavigationItemTypeItem | MenuNavigationItemTypeGroup)[];\r\n\r\n footer?: MenuGroupFooter;\r\n action?: MenuButton;\r\n}\r\n\r\nexport interface DesktopNavigationMenuProps {\r\n buttons?: DesktopMenuButtonTypes[];\r\n items: (MenuNavigationItemTypeItem | MenuNavigationItemTypeDesktopGroup)[];\r\n action?: MenuButton;\r\n reverseRightSideOrder?: boolean;\r\n}\r\n\r\n// @ts-ignore\r\nexport interface MenuNavigationGroup<T = MenuNavigationItemTypeDesktopGroup | MenuNavigationItem | MenuNavigationSection | MenuNavigationGroup> {\r\n label: string;\r\n note?: string;\r\n\r\n buttons?: MobileMenuButtonTypes[];\r\n header?: MenuGroupHeader;\r\n\r\n items: T[];\r\n\r\n footer?: MenuGroupFooter;\r\n action?: MenuButton;\r\n}\r\n\r\nexport type MenuNavigationItem = {\r\n icon?: React.ReactNode;\r\n to: string;\r\n exact?: boolean;\r\n disabled?: boolean;\r\n external?: boolean;\r\n action?: (e: React.MouseEvent) => void;\r\n label: string;\r\n note?: string;\r\n pinned?: boolean;\r\n subItems?: MenuNavigationItem[];\r\n} & Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, 'onClick' | 'to' | 'exact' | 'onMouseDown'>;\r\n\r\nexport interface MenuNavigationSection<T = MenuNavigationItem> {\r\n divider?: boolean;\r\n pinned?: boolean;\r\n label?: string;\r\n items: T[];\r\n}\r\n\r\nexport type MenuNavigationItemTypeItem = MenuNavigationItem & {\r\n type?: 'item';\r\n};\r\n\r\nexport type MenuNavigationItemTypeDesktopGroup = {\r\n id: string;\r\n label?: string;\r\n disabled?: boolean;\r\n pinned?: boolean;\r\n type?: 'desktopgroup';\r\n expanded?: boolean;\r\n items: (MenuNavigationItemTypeItem | MenuNavigationItemTypeDesktopGroup)[];\r\n}\r\n\r\nexport type MenuNavigationItemTypeGroup = MenuNavigationGroup<MenuNavigationItemTypeItem | MenuNavigationItemTypeGroup | MenuNavigationItemTypeSection> & {\r\n type: 'group';\r\n icon?: React.ReactNode;\r\n pinned?: boolean;\r\n disabled?: boolean;\r\n};\r\n\r\nexport type MenuNavigationItemTypeSection = MenuNavigationSection<MenuNavigationItemTypeItem> & {\r\n type: 'section';\r\n};\r\n\r\nexport type MenuNavigationCustomSubMenu = {\r\n type: 'custom';\r\n label?: string;\r\n buttons?: MobileMenuButtonTypes[];\r\n custom: () => React.ReactNode;\r\n};\r\n"],"mappings":"","ignoreList":[]}
|
|
@@ -11,8 +11,9 @@ var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
|
11
11
|
var React = _interopRequireWildcard(require("react"));
|
|
12
12
|
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
13
13
|
var _styling = require("./styling");
|
|
14
|
+
var _Navigation = require("../Navigation");
|
|
14
15
|
var _jsxRuntime = require("react/jsx-runtime");
|
|
15
|
-
const _excluded = ["children", "target", "variant"];
|
|
16
|
+
const _excluded = ["children", "margin", "target", "variant"];
|
|
16
17
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
17
18
|
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
18
19
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
@@ -25,11 +26,25 @@ const StyledLink = exports.StyledLink = _styledComponents.default.a`
|
|
|
25
26
|
const HyperLink = _ref => {
|
|
26
27
|
let {
|
|
27
28
|
children,
|
|
29
|
+
margin,
|
|
28
30
|
target = '_blank',
|
|
29
31
|
variant = 'default'
|
|
30
32
|
} = _ref,
|
|
31
33
|
props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
|
|
34
|
+
const {
|
|
35
|
+
isActiveRoute,
|
|
36
|
+
navigate
|
|
37
|
+
} = (0, _Navigation.useNavigation)();
|
|
38
|
+
const onClick = e => {
|
|
39
|
+
if (props.onClick) props.onClick(e);else if (!props.external && navigate) {
|
|
40
|
+
navigate(props.href, false);
|
|
41
|
+
e?.preventDefault();
|
|
42
|
+
}
|
|
43
|
+
};
|
|
32
44
|
return /*#__PURE__*/(0, _jsxRuntime.jsx)(StyledLink, _objectSpread(_objectSpread({}, props), {}, {
|
|
45
|
+
className: props?.className + (isActiveRoute && isActiveRoute(props?.href, true) ? ' active' : ''),
|
|
46
|
+
onClick: onClick,
|
|
47
|
+
$margin: margin,
|
|
33
48
|
$variant: variant,
|
|
34
49
|
target: target,
|
|
35
50
|
rel: "noopener noreferrer",
|
|
@@ -44,7 +59,8 @@ HyperLink.propTypes = {
|
|
|
44
59
|
margin: _propTypes.default.string,
|
|
45
60
|
children: _propTypes.default.any,
|
|
46
61
|
className: _propTypes.default.string,
|
|
47
|
-
ref: _propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.func, _propTypes.default.object])
|
|
62
|
+
ref: _propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.func, _propTypes.default.object]),
|
|
63
|
+
external: _propTypes.default.bool
|
|
48
64
|
};
|
|
49
65
|
var _default = exports.default = HyperLink;
|
|
50
66
|
//# sourceMappingURL=HyperLink.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HyperLink.cjs","names":["React","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_styling","_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","StyledLink","exports","styled","props","$variant","invertedStyle","defaultStyle","$margin","HyperLink","_ref","children","target","variant","_objectWithoutProperties2","jsx","rel","propTypes","id","_propTypes","string","oneOf","isRequired","
|
|
1
|
+
{"version":3,"file":"HyperLink.cjs","names":["React","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_styling","_Navigation","_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","StyledLink","exports","styled","props","$variant","invertedStyle","defaultStyle","$margin","HyperLink","_ref","children","margin","target","variant","_objectWithoutProperties2","isActiveRoute","navigate","useNavigation","onClick","external","href","preventDefault","jsx","className","rel","propTypes","id","_propTypes","string","oneOf","isRequired","disabled","bool","any","ref","oneOfType","func","object","_default"],"sources":["../../src/HyperLink/HyperLink.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport styled from 'styled-components';\r\nimport { defaultStyle, invertedStyle } from './styling';\r\nimport { useNavigation } from '../Navigation';\r\n\r\nexport const StyledLink = styled.a<{\r\n $variant: 'default' | 'inverted' | 'styleless';\r\n $margin?: string;\r\n}>`\r\n cursor: pointer;\r\n ${(props) => (props.$variant === 'styleless' || !props.$variant ? '' : (props.$variant == 'inverted' ? invertedStyle : defaultStyle))}\r\n ${(props) => (props.$margin ? `margin: ${props.$margin};` : '')}\r\n`;\r\n\r\nexport interface HyperlinkProps extends React.AnchorHTMLAttributes<HTMLAnchorElement> {\r\n /** Id of the link component. */\r\n id?: string;\r\n /** Style variant of the link */\r\n variant: 'default' | 'inverted' | 'styleless';\r\n /** Href of the link component */\r\n href: string;\r\n /** If set then user can not interact with the link. */\r\n disabled?: boolean;\r\n /** Custom value of margin style. */\r\n margin?: string;\r\n /** Content of the Hyperlink */\r\n children?: any;\r\n /** Custom className to set to the link. */\r\n className?: string;\r\n /** Ref for Hyperlink. */\r\n ref?: React.Ref<HTMLAnchorElement>;\r\n /** If this flag is set, then Hyperlink will behave like anchor tag, otherwise it will use 'navigate' method of NavigationProvider */\r\n external?: boolean;\r\n}\r\n\r\nconst HyperLink: React.FunctionComponent<HyperlinkProps> = ({ children, margin, target = '_blank', variant = 'default', ...props }: HyperlinkProps) => {\r\n const {isActiveRoute, navigate} = useNavigation();\r\n const onClick = (e: any) => {\r\n if(props.onClick)\r\n props.onClick(e);\r\n else if(!props.external && navigate)\r\n {\r\n navigate(props.href, false);\r\n e?.preventDefault();\r\n }\r\n };\r\n\r\n return (\r\n <StyledLink {...props} className={props?.className + (isActiveRoute && isActiveRoute(props?.href, true) ? ' active' : '')} onClick={onClick} $margin={margin} $variant={variant} target={target} rel=\"noopener noreferrer\">\r\n {children}\r\n </StyledLink>\r\n );\r\n};\r\n\r\nexport default HyperLink;\r\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -20,6 +20,8 @@ export interface HyperlinkProps extends React.AnchorHTMLAttributes<HTMLAnchorEle
|
|
|
20
20
|
className?: string;
|
|
21
21
|
/** Ref for Hyperlink. */
|
|
22
22
|
ref?: React.Ref<HTMLAnchorElement>;
|
|
23
|
+
/** If this flag is set, then Hyperlink will behave like anchor tag, otherwise it will use 'navigate' method of NavigationProvider */
|
|
24
|
+
external?: boolean;
|
|
23
25
|
}
|
|
24
26
|
declare const HyperLink: React.FunctionComponent<HyperlinkProps>;
|
|
25
27
|
export default HyperLink;
|
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
|
2
2
|
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
|
|
3
3
|
import _pt from "prop-types";
|
|
4
|
-
const _excluded = ["children", "target", "variant"];
|
|
4
|
+
const _excluded = ["children", "margin", "target", "variant"];
|
|
5
5
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
6
6
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
7
7
|
import * as React from 'react';
|
|
8
8
|
import styled from 'styled-components';
|
|
9
9
|
import { defaultStyle, invertedStyle } from './styling';
|
|
10
|
+
import { useNavigation } from '../Navigation';
|
|
10
11
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
11
12
|
export const StyledLink = styled.a`
|
|
12
13
|
cursor: pointer;
|
|
@@ -16,11 +17,25 @@ export const StyledLink = styled.a`
|
|
|
16
17
|
const HyperLink = _ref => {
|
|
17
18
|
let {
|
|
18
19
|
children,
|
|
20
|
+
margin,
|
|
19
21
|
target = '_blank',
|
|
20
22
|
variant = 'default'
|
|
21
23
|
} = _ref,
|
|
22
24
|
props = _objectWithoutProperties(_ref, _excluded);
|
|
25
|
+
const {
|
|
26
|
+
isActiveRoute,
|
|
27
|
+
navigate
|
|
28
|
+
} = useNavigation();
|
|
29
|
+
const onClick = e => {
|
|
30
|
+
if (props.onClick) props.onClick(e);else if (!props.external && navigate) {
|
|
31
|
+
navigate(props.href, false);
|
|
32
|
+
e?.preventDefault();
|
|
33
|
+
}
|
|
34
|
+
};
|
|
23
35
|
return /*#__PURE__*/_jsx(StyledLink, _objectSpread(_objectSpread({}, props), {}, {
|
|
36
|
+
className: props?.className + (isActiveRoute && isActiveRoute(props?.href, true) ? ' active' : ''),
|
|
37
|
+
onClick: onClick,
|
|
38
|
+
$margin: margin,
|
|
24
39
|
$variant: variant,
|
|
25
40
|
target: target,
|
|
26
41
|
rel: "noopener noreferrer",
|
|
@@ -35,7 +50,8 @@ HyperLink.propTypes = {
|
|
|
35
50
|
margin: _pt.string,
|
|
36
51
|
children: _pt.any,
|
|
37
52
|
className: _pt.string,
|
|
38
|
-
ref: _pt.oneOfType([_pt.string, _pt.func, _pt.object])
|
|
53
|
+
ref: _pt.oneOfType([_pt.string, _pt.func, _pt.object]),
|
|
54
|
+
external: _pt.bool
|
|
39
55
|
};
|
|
40
56
|
export default HyperLink;
|
|
41
57
|
//# sourceMappingURL=HyperLink.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HyperLink.js","names":["React","styled","defaultStyle","invertedStyle","jsx","_jsx","StyledLink","a","props","$variant","$margin","HyperLink","_ref","children","target","variant","_objectWithoutProperties","_excluded","_objectSpread","rel","propTypes","id","_pt","string","oneOf","isRequired","
|
|
1
|
+
{"version":3,"file":"HyperLink.js","names":["React","styled","defaultStyle","invertedStyle","useNavigation","jsx","_jsx","StyledLink","a","props","$variant","$margin","HyperLink","_ref","children","margin","target","variant","_objectWithoutProperties","_excluded","isActiveRoute","navigate","onClick","e","external","href","preventDefault","_objectSpread","className","rel","propTypes","id","_pt","string","oneOf","isRequired","disabled","bool","any","ref","oneOfType","func","object"],"sources":["../../src/HyperLink/HyperLink.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport styled from 'styled-components';\r\nimport { defaultStyle, invertedStyle } from './styling';\r\nimport { useNavigation } from '../Navigation';\r\n\r\nexport const StyledLink = styled.a<{\r\n $variant: 'default' | 'inverted' | 'styleless';\r\n $margin?: string;\r\n}>`\r\n cursor: pointer;\r\n ${(props) => (props.$variant === 'styleless' || !props.$variant ? '' : (props.$variant == 'inverted' ? invertedStyle : defaultStyle))}\r\n ${(props) => (props.$margin ? `margin: ${props.$margin};` : '')}\r\n`;\r\n\r\nexport interface HyperlinkProps extends React.AnchorHTMLAttributes<HTMLAnchorElement> {\r\n /** Id of the link component. */\r\n id?: string;\r\n /** Style variant of the link */\r\n variant: 'default' | 'inverted' | 'styleless';\r\n /** Href of the link component */\r\n href: string;\r\n /** If set then user can not interact with the link. */\r\n disabled?: boolean;\r\n /** Custom value of margin style. */\r\n margin?: string;\r\n /** Content of the Hyperlink */\r\n children?: any;\r\n /** Custom className to set to the link. */\r\n className?: string;\r\n /** Ref for Hyperlink. */\r\n ref?: React.Ref<HTMLAnchorElement>;\r\n /** If this flag is set, then Hyperlink will behave like anchor tag, otherwise it will use 'navigate' method of NavigationProvider */\r\n external?: boolean;\r\n}\r\n\r\nconst HyperLink: React.FunctionComponent<HyperlinkProps> = ({ children, margin, target = '_blank', variant = 'default', ...props }: HyperlinkProps) => {\r\n const {isActiveRoute, navigate} = useNavigation();\r\n const onClick = (e: any) => {\r\n if(props.onClick)\r\n props.onClick(e);\r\n else if(!props.external && navigate)\r\n {\r\n navigate(props.href, false);\r\n e?.preventDefault();\r\n }\r\n };\r\n\r\n return (\r\n <StyledLink {...props} className={props?.className + (isActiveRoute && isActiveRoute(props?.href, true) ? ' active' : '')} onClick={onClick} $margin={margin} $variant={variant} target={target} rel=\"noopener noreferrer\">\r\n {children}\r\n </StyledLink>\r\n );\r\n};\r\n\r\nexport default HyperLink;\r\n"],"mappings":";;;;;;AAAA,OAAO,KAAKA,KAAK,MAAM,OAAO;AAC9B,OAAOC,MAAM,MAAM,mBAAmB;AACtC,SAASC,YAAY,EAAEC,aAAa,QAAQ,WAAW;AACvD,SAASC,aAAa,QAAQ,eAAe;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAE9C,OAAO,MAAMC,UAAU,GAAGN,MAAM,CAACO,CAG/B;AACF;AACA,IAAKC,KAAK,IAAMA,KAAK,CAACC,QAAQ,KAAK,WAAW,IAAI,CAACD,KAAK,CAACC,QAAQ,GAAG,EAAE,GAAID,KAAK,CAACC,QAAQ,IAAI,UAAU,GAAGP,aAAa,GAAGD,YAAc;AACvI,IAAKO,KAAK,IAAMA,KAAK,CAACE,OAAO,GAAG,WAAWF,KAAK,CAACE,OAAO,GAAG,GAAG,EAAG;AACjE,CAAC;AAuBD,MAAMC,SAAkD,GAAGC,IAAA,IAA4F;EAAA,IAA3F;MAAEC,QAAQ;MAAEC,MAAM;MAAEC,MAAM,GAAG,QAAQ;MAAEC,OAAO,GAAG;IAAoC,CAAC,GAAAJ,IAAA;IAAvBJ,KAAK,GAAAS,wBAAA,CAAAL,IAAA,EAAAM,SAAA;EAC9H,MAAM;IAACC,aAAa;IAAEC;EAAQ,CAAC,GAAGjB,aAAa,CAAC,CAAC;EACjD,MAAMkB,OAAO,GAAIC,CAAM,IAAK;IAC1B,IAAGd,KAAK,CAACa,OAAO,EACdb,KAAK,CAACa,OAAO,CAACC,CAAC,CAAC,CAAC,KACd,IAAG,CAACd,KAAK,CAACe,QAAQ,IAAIH,QAAQ,EACnC;MACEA,QAAQ,CAACZ,KAAK,CAACgB,IAAI,EAAE,KAAK,CAAC;MAC3BF,CAAC,EAAEG,cAAc,CAAC,CAAC;IACrB;EACF,CAAC;EAED,oBACEpB,IAAA,CAACC,UAAU,EAAAoB,aAAA,CAAAA,aAAA,KAAKlB,KAAK;IAAEmB,SAAS,EAAEnB,KAAK,EAAEmB,SAAS,IAAIR,aAAa,IAAIA,aAAa,CAACX,KAAK,EAAEgB,IAAI,EAAE,IAAI,CAAC,GAAG,SAAS,GAAG,EAAE,CAAE;IAACH,OAAO,EAAEA,OAAQ;IAACX,OAAO,EAAEI,MAAO;IAACL,QAAQ,EAAEO,OAAQ;IAACD,MAAM,EAAEA,MAAO;IAACa,GAAG,EAAC,qBAAqB;IAAAf,QAAA,EACvNA;EAAQ,EACC,CAAC;AAEjB,CAAC;AAACF,SAAA,CAAAkB,SAAA;EApCAC,EAAE,EAAAC,GAAA,CAAAC,MAAA;EAEFhB,OAAO,EAAAe,GAAA,CAAAE,KAAA,EAAE,SAAS,EAAG,UAAU,EAAG,WAAW,GAAAC,UAAA;EAE7CV,IAAI,EAAAO,GAAA,CAAAC,MAAA,CAAAE,UAAA;EAEJC,QAAQ,EAAAJ,GAAA,CAAAK,IAAA;EAERtB,MAAM,EAAAiB,GAAA,CAAAC,MAAA;EAENnB,QAAQ,EAAAkB,GAAA,CAAAM,GAAA;EAERV,SAAS,EAAAI,GAAA,CAAAC,MAAA;EAETM,GAAG,EAAAP,GAAA,CAAAQ,SAAA,EAAAR,GAAA,CAAAC,MAAA,EAAAD,GAAA,CAAAS,IAAA,EAAAT,GAAA,CAAAU,MAAA;EAEHlB,QAAQ,EAAAQ,GAAA,CAAAK;AAAA;AAsBV,eAAezB,SAAS","ignoreList":[]}
|
|
@@ -13,6 +13,10 @@ const defaultStyle = exports.defaultStyle = (0, _styledComponents.css)`
|
|
|
13
13
|
text-decoration-style: solid;
|
|
14
14
|
text-underline-offset: 2px;
|
|
15
15
|
text-decoration-line: none;
|
|
16
|
+
color: ${props => _.COLORS.generateToken({
|
|
17
|
+
componentType: 'text-link',
|
|
18
|
+
defaultVariant: 'primary'
|
|
19
|
+
}, props.theme)};
|
|
16
20
|
|
|
17
21
|
&:link {
|
|
18
22
|
font-weight: 700;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styling.cjs","names":["_styledComponents","require","_","defaultStyle","exports","css","props","COLORS","generateToken","componentType","defaultVariant","theme","state","isOnFill","invertedStyle","getColor"],"sources":["../../src/HyperLink/styling.ts"],"sourcesContent":["import { css } from 'styled-components';\r\nimport { COLORS } from '..';\r\n\r\nexport const defaultStyle = css`\r\n outline: none;\r\n padding: 2px 0;\r\n text-decoration-thickness: 2px;\r\n text-decoration-style: solid;\r\n text-underline-offset: 2px;\r\n text-decoration-line: none;\r\n\r\n &:link {\r\n font-weight: 700;\r\n color: ${props => COLORS.generateToken({componentType:'text-link', defaultVariant: 'primary' }, props.theme)};\r\n }\r\n\r\n &:visited {\r\n color: ${props => COLORS.generateToken({componentType:'text-link', defaultVariant: 'primary', state: 'active' }, props.theme)};\r\n }\r\n\r\n &:hover,\r\n &.hover-state {\r\n color: ${props => COLORS.generateToken({componentType:'text-link', defaultVariant: 'primary' }, props.theme)};\r\n text-decoration-line: underline;\r\n }\r\n\r\n &:focus,\r\n &.focus-state {\r\n border-radius: 2px;\r\n background: ${props => COLORS.generateToken({componentType:'bg-fill', defaultVariant: 'primary', state: 'active'}, props.theme)};\r\n color: ${props => COLORS.generateToken({componentType:'text', isOnFill: true, defaultVariant: 'primary' }, props.theme)};\r\n }\r\n\r\n &:active,\r\n &.active-state {\r\n border-radius: 2px;\r\n background: ${props => COLORS.generateToken({componentType:'bg-fill', defaultVariant: 'primary', state: 'active'}, props.theme)};\r\n color: ${props => COLORS.generateToken({componentType:'text', isOnFill: true, defaultVariant: 'primary' }, props.theme)};\r\n }\r\n\r\n\r\n &:focus:hover,\r\n &:active:hover,\r\n &.active-state:hover,\r\n &.focus-state:hover{\r\n text-decoration-line: none;\r\n color: ${props => COLORS.generateToken({componentType:'text', isOnFill: true, defaultVariant: 'primary' }, props.theme)};\r\n opacity: 0.9;\r\n }\r\n`;\r\n\r\nexport const invertedStyle = css`\r\n outline: none;\r\n padding: 2px 0;\r\n\r\n text-decoration-thickness: 2px;\r\n text-decoration-style: solid;\r\n text-underline-offset: 2px;\r\n text-decoration-line: underline;\r\n\r\n &:link {\r\n font-weight: 700;\r\n color: ${props => COLORS.getColor('white', props.theme)};\r\n }\r\n\r\n &:visited {\r\n color: ${props => COLORS.getColor('neutral_100', props.theme)};\r\n }\r\n\r\n &:focus,\r\n &.focus-state {\r\n border-radius: 2px;\r\n text-decoration-line: none;\r\n background: ${props => COLORS.getColor('white', props.theme)};\r\n color: ${props => COLORS.getColor('neutral_800', props.theme)};\r\n }\r\n\r\n &:hover,\r\n &.hover-state {\r\n text-decoration-line: none;\r\n }\r\n\r\n &:active,\r\n &.active-state {\r\n border-radius: 2px;\r\n text-decoration-line: none;\r\n background: ${props => COLORS.getColor('white', props.theme)};\r\n color: ${props => COLORS.getColor('neutral_800', props.theme)};\r\n }\r\n\r\n &:focus:hover,\r\n &:active:hover {\r\n text-decoration-line: none;\r\n color: ${props => COLORS.getColor('neutral_800', props.theme)};\r\n opacity: 0.9;\r\n }\r\n`;\r\n"],"mappings":";;;;;;AAAA,IAAAA,iBAAA,GAAAC,OAAA;AACA,IAAAC,CAAA,GAAAD,OAAA;AAEO,MAAME,YAAY,GAAAC,OAAA,CAAAD,YAAA,GAAG,IAAAE,qBAAG;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,
|
|
1
|
+
{"version":3,"file":"styling.cjs","names":["_styledComponents","require","_","defaultStyle","exports","css","props","COLORS","generateToken","componentType","defaultVariant","theme","state","isOnFill","invertedStyle","getColor"],"sources":["../../src/HyperLink/styling.ts"],"sourcesContent":["import { css } from 'styled-components';\r\nimport { COLORS } from '..';\r\n\r\nexport const defaultStyle = css`\r\n outline: none;\r\n padding: 2px 0;\r\n text-decoration-thickness: 2px;\r\n text-decoration-style: solid;\r\n text-underline-offset: 2px;\r\n text-decoration-line: none;\r\n color: ${props => COLORS.generateToken({componentType:'text-link', defaultVariant: 'primary' }, props.theme)};\r\n\r\n &:link {\r\n font-weight: 700;\r\n color: ${props => COLORS.generateToken({componentType:'text-link', defaultVariant: 'primary' }, props.theme)};\r\n }\r\n\r\n &:visited {\r\n color: ${props => COLORS.generateToken({componentType:'text-link', defaultVariant: 'primary', state: 'active' }, props.theme)};\r\n }\r\n\r\n &:hover,\r\n &.hover-state {\r\n color: ${props => COLORS.generateToken({componentType:'text-link', defaultVariant: 'primary' }, props.theme)};\r\n text-decoration-line: underline;\r\n }\r\n\r\n &:focus,\r\n &.focus-state {\r\n border-radius: 2px;\r\n background: ${props => COLORS.generateToken({componentType:'bg-fill', defaultVariant: 'primary', state: 'active'}, props.theme)};\r\n color: ${props => COLORS.generateToken({componentType:'text', isOnFill: true, defaultVariant: 'primary' }, props.theme)};\r\n }\r\n\r\n &:active,\r\n &.active-state {\r\n border-radius: 2px;\r\n background: ${props => COLORS.generateToken({componentType:'bg-fill', defaultVariant: 'primary', state: 'active'}, props.theme)};\r\n color: ${props => COLORS.generateToken({componentType:'text', isOnFill: true, defaultVariant: 'primary' }, props.theme)};\r\n }\r\n\r\n\r\n &:focus:hover,\r\n &:active:hover,\r\n &.active-state:hover,\r\n &.focus-state:hover{\r\n text-decoration-line: none;\r\n color: ${props => COLORS.generateToken({componentType:'text', isOnFill: true, defaultVariant: 'primary' }, props.theme)};\r\n opacity: 0.9;\r\n }\r\n`;\r\n\r\nexport const invertedStyle = css`\r\n outline: none;\r\n padding: 2px 0;\r\n\r\n text-decoration-thickness: 2px;\r\n text-decoration-style: solid;\r\n text-underline-offset: 2px;\r\n text-decoration-line: underline;\r\n\r\n &:link {\r\n font-weight: 700;\r\n color: ${props => COLORS.getColor('white', props.theme)};\r\n }\r\n\r\n &:visited {\r\n color: ${props => COLORS.getColor('neutral_100', props.theme)};\r\n }\r\n\r\n &:focus,\r\n &.focus-state {\r\n border-radius: 2px;\r\n text-decoration-line: none;\r\n background: ${props => COLORS.getColor('white', props.theme)};\r\n color: ${props => COLORS.getColor('neutral_800', props.theme)};\r\n }\r\n\r\n &:hover,\r\n &.hover-state {\r\n text-decoration-line: none;\r\n }\r\n\r\n &:active,\r\n &.active-state {\r\n border-radius: 2px;\r\n text-decoration-line: none;\r\n background: ${props => COLORS.getColor('white', props.theme)};\r\n color: ${props => COLORS.getColor('neutral_800', props.theme)};\r\n }\r\n\r\n &:focus:hover,\r\n &:active:hover {\r\n text-decoration-line: none;\r\n color: ${props => COLORS.getColor('neutral_800', props.theme)};\r\n opacity: 0.9;\r\n }\r\n`;\r\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -7,6 +7,10 @@ export const defaultStyle = css`
|
|
|
7
7
|
text-decoration-style: solid;
|
|
8
8
|
text-underline-offset: 2px;
|
|
9
9
|
text-decoration-line: none;
|
|
10
|
+
color: ${props => COLORS.generateToken({
|
|
11
|
+
componentType: 'text-link',
|
|
12
|
+
defaultVariant: 'primary'
|
|
13
|
+
}, props.theme)};
|
|
10
14
|
|
|
11
15
|
&:link {
|
|
12
16
|
font-weight: 700;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styling.js","names":["css","COLORS","defaultStyle","props","generateToken","componentType","defaultVariant","theme","state","isOnFill","invertedStyle","getColor"],"sources":["../../src/HyperLink/styling.ts"],"sourcesContent":["import { css } from 'styled-components';\r\nimport { COLORS } from '..';\r\n\r\nexport const defaultStyle = css`\r\n outline: none;\r\n padding: 2px 0;\r\n text-decoration-thickness: 2px;\r\n text-decoration-style: solid;\r\n text-underline-offset: 2px;\r\n text-decoration-line: none;\r\n\r\n &:link {\r\n font-weight: 700;\r\n color: ${props => COLORS.generateToken({componentType:'text-link', defaultVariant: 'primary' }, props.theme)};\r\n }\r\n\r\n &:visited {\r\n color: ${props => COLORS.generateToken({componentType:'text-link', defaultVariant: 'primary', state: 'active' }, props.theme)};\r\n }\r\n\r\n &:hover,\r\n &.hover-state {\r\n color: ${props => COLORS.generateToken({componentType:'text-link', defaultVariant: 'primary' }, props.theme)};\r\n text-decoration-line: underline;\r\n }\r\n\r\n &:focus,\r\n &.focus-state {\r\n border-radius: 2px;\r\n background: ${props => COLORS.generateToken({componentType:'bg-fill', defaultVariant: 'primary', state: 'active'}, props.theme)};\r\n color: ${props => COLORS.generateToken({componentType:'text', isOnFill: true, defaultVariant: 'primary' }, props.theme)};\r\n }\r\n\r\n &:active,\r\n &.active-state {\r\n border-radius: 2px;\r\n background: ${props => COLORS.generateToken({componentType:'bg-fill', defaultVariant: 'primary', state: 'active'}, props.theme)};\r\n color: ${props => COLORS.generateToken({componentType:'text', isOnFill: true, defaultVariant: 'primary' }, props.theme)};\r\n }\r\n\r\n\r\n &:focus:hover,\r\n &:active:hover,\r\n &.active-state:hover,\r\n &.focus-state:hover{\r\n text-decoration-line: none;\r\n color: ${props => COLORS.generateToken({componentType:'text', isOnFill: true, defaultVariant: 'primary' }, props.theme)};\r\n opacity: 0.9;\r\n }\r\n`;\r\n\r\nexport const invertedStyle = css`\r\n outline: none;\r\n padding: 2px 0;\r\n\r\n text-decoration-thickness: 2px;\r\n text-decoration-style: solid;\r\n text-underline-offset: 2px;\r\n text-decoration-line: underline;\r\n\r\n &:link {\r\n font-weight: 700;\r\n color: ${props => COLORS.getColor('white', props.theme)};\r\n }\r\n\r\n &:visited {\r\n color: ${props => COLORS.getColor('neutral_100', props.theme)};\r\n }\r\n\r\n &:focus,\r\n &.focus-state {\r\n border-radius: 2px;\r\n text-decoration-line: none;\r\n background: ${props => COLORS.getColor('white', props.theme)};\r\n color: ${props => COLORS.getColor('neutral_800', props.theme)};\r\n }\r\n\r\n &:hover,\r\n &.hover-state {\r\n text-decoration-line: none;\r\n }\r\n\r\n &:active,\r\n &.active-state {\r\n border-radius: 2px;\r\n text-decoration-line: none;\r\n background: ${props => COLORS.getColor('white', props.theme)};\r\n color: ${props => COLORS.getColor('neutral_800', props.theme)};\r\n }\r\n\r\n &:focus:hover,\r\n &:active:hover {\r\n text-decoration-line: none;\r\n color: ${props => COLORS.getColor('neutral_800', props.theme)};\r\n opacity: 0.9;\r\n }\r\n`;\r\n"],"mappings":"AAAA,SAASA,GAAG,QAAQ,mBAAmB;AACvC,SAASC,MAAM,QAAQ,IAAI;AAE3B,OAAO,MAAMC,YAAY,GAAGF,GAAG;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,
|
|
1
|
+
{"version":3,"file":"styling.js","names":["css","COLORS","defaultStyle","props","generateToken","componentType","defaultVariant","theme","state","isOnFill","invertedStyle","getColor"],"sources":["../../src/HyperLink/styling.ts"],"sourcesContent":["import { css } from 'styled-components';\r\nimport { COLORS } from '..';\r\n\r\nexport const defaultStyle = css`\r\n outline: none;\r\n padding: 2px 0;\r\n text-decoration-thickness: 2px;\r\n text-decoration-style: solid;\r\n text-underline-offset: 2px;\r\n text-decoration-line: none;\r\n color: ${props => COLORS.generateToken({componentType:'text-link', defaultVariant: 'primary' }, props.theme)};\r\n\r\n &:link {\r\n font-weight: 700;\r\n color: ${props => COLORS.generateToken({componentType:'text-link', defaultVariant: 'primary' }, props.theme)};\r\n }\r\n\r\n &:visited {\r\n color: ${props => COLORS.generateToken({componentType:'text-link', defaultVariant: 'primary', state: 'active' }, props.theme)};\r\n }\r\n\r\n &:hover,\r\n &.hover-state {\r\n color: ${props => COLORS.generateToken({componentType:'text-link', defaultVariant: 'primary' }, props.theme)};\r\n text-decoration-line: underline;\r\n }\r\n\r\n &:focus,\r\n &.focus-state {\r\n border-radius: 2px;\r\n background: ${props => COLORS.generateToken({componentType:'bg-fill', defaultVariant: 'primary', state: 'active'}, props.theme)};\r\n color: ${props => COLORS.generateToken({componentType:'text', isOnFill: true, defaultVariant: 'primary' }, props.theme)};\r\n }\r\n\r\n &:active,\r\n &.active-state {\r\n border-radius: 2px;\r\n background: ${props => COLORS.generateToken({componentType:'bg-fill', defaultVariant: 'primary', state: 'active'}, props.theme)};\r\n color: ${props => COLORS.generateToken({componentType:'text', isOnFill: true, defaultVariant: 'primary' }, props.theme)};\r\n }\r\n\r\n\r\n &:focus:hover,\r\n &:active:hover,\r\n &.active-state:hover,\r\n &.focus-state:hover{\r\n text-decoration-line: none;\r\n color: ${props => COLORS.generateToken({componentType:'text', isOnFill: true, defaultVariant: 'primary' }, props.theme)};\r\n opacity: 0.9;\r\n }\r\n`;\r\n\r\nexport const invertedStyle = css`\r\n outline: none;\r\n padding: 2px 0;\r\n\r\n text-decoration-thickness: 2px;\r\n text-decoration-style: solid;\r\n text-underline-offset: 2px;\r\n text-decoration-line: underline;\r\n\r\n &:link {\r\n font-weight: 700;\r\n color: ${props => COLORS.getColor('white', props.theme)};\r\n }\r\n\r\n &:visited {\r\n color: ${props => COLORS.getColor('neutral_100', props.theme)};\r\n }\r\n\r\n &:focus,\r\n &.focus-state {\r\n border-radius: 2px;\r\n text-decoration-line: none;\r\n background: ${props => COLORS.getColor('white', props.theme)};\r\n color: ${props => COLORS.getColor('neutral_800', props.theme)};\r\n }\r\n\r\n &:hover,\r\n &.hover-state {\r\n text-decoration-line: none;\r\n }\r\n\r\n &:active,\r\n &.active-state {\r\n border-radius: 2px;\r\n text-decoration-line: none;\r\n background: ${props => COLORS.getColor('white', props.theme)};\r\n color: ${props => COLORS.getColor('neutral_800', props.theme)};\r\n }\r\n\r\n &:focus:hover,\r\n &:active:hover {\r\n text-decoration-line: none;\r\n color: ${props => COLORS.getColor('neutral_800', props.theme)};\r\n opacity: 0.9;\r\n }\r\n`;\r\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -21,7 +21,7 @@ var _DatepickerFieldHeader = require("./DatepickerFieldHeader");
|
|
|
21
21
|
var _styles = require("../styles");
|
|
22
22
|
var _TooltipOverflow = _interopRequireDefault(require("../Tooltips/TooltipOverflow"));
|
|
23
23
|
var _styling = require("./styling");
|
|
24
|
-
require("
|
|
24
|
+
require("../styles/react-datepicker.css");
|
|
25
25
|
var _common = require("../common");
|
|
26
26
|
var _types = require("../types");
|
|
27
27
|
var _jsxRuntime = require("react/jsx-runtime");
|
|
@@ -175,6 +175,10 @@ const DatePickerContainer = _styledComponents.default.div`
|
|
|
175
175
|
|
|
176
176
|
.react-datepicker__month {
|
|
177
177
|
margin: 0px;
|
|
178
|
+
background: ${props => _colors.default.generateToken({
|
|
179
|
+
componentType: 'bg-surface',
|
|
180
|
+
defaultVariant: 'high'
|
|
181
|
+
}, props.theme)};
|
|
178
182
|
}
|
|
179
183
|
|
|
180
184
|
.react-datepicker__triangle {
|
|
@@ -271,7 +275,10 @@ const DatePickerContainer = _styledComponents.default.div`
|
|
|
271
275
|
|
|
272
276
|
|
|
273
277
|
.react-datepicker__year-text {
|
|
274
|
-
background: ${props => _colors.default.
|
|
278
|
+
background: ${props => _colors.default.generateToken({
|
|
279
|
+
componentType: 'bg-surface',
|
|
280
|
+
defaultVariant: 'high'
|
|
281
|
+
}, props.theme)};
|
|
275
282
|
border: none;
|
|
276
283
|
display: inline-flex;
|
|
277
284
|
justify-content: center;
|
|
@@ -293,7 +300,10 @@ const DatePickerContainer = _styledComponents.default.div`
|
|
|
293
300
|
componentType: 'text',
|
|
294
301
|
defaultVariant: 'subtle'
|
|
295
302
|
}, props.theme)};
|
|
296
|
-
background: ${props => _colors.default.
|
|
303
|
+
background: ${props => _colors.default.generateToken({
|
|
304
|
+
componentType: 'bg-surface',
|
|
305
|
+
defaultVariant: 'high'
|
|
306
|
+
}, props.theme)};
|
|
297
307
|
font-weight: 400;
|
|
298
308
|
border: none;
|
|
299
309
|
}
|
|
@@ -312,7 +322,10 @@ const DatePickerContainer = _styledComponents.default.div`
|
|
|
312
322
|
}
|
|
313
323
|
|
|
314
324
|
.react-datepicker__day, .react-datepicker__quarter-text {
|
|
315
|
-
background: ${props => _colors.default.
|
|
325
|
+
background: ${props => _colors.default.generateToken({
|
|
326
|
+
componentType: 'bg-surface',
|
|
327
|
+
defaultVariant: 'high'
|
|
328
|
+
}, props.theme)};
|
|
316
329
|
border: none;
|
|
317
330
|
display: inline-flex;
|
|
318
331
|
justify-content: center;
|
|
@@ -331,7 +344,10 @@ const DatePickerContainer = _styledComponents.default.div`
|
|
|
331
344
|
componentType: 'text',
|
|
332
345
|
defaultVariant: 'subtle'
|
|
333
346
|
}, props.theme)};
|
|
334
|
-
background: ${props => _colors.default.
|
|
347
|
+
background: ${props => _colors.default.generateToken({
|
|
348
|
+
componentType: 'bg-surface',
|
|
349
|
+
defaultVariant: 'high'
|
|
350
|
+
}, props.theme)};
|
|
335
351
|
flex-grow: 1;
|
|
336
352
|
font-weight: 400;
|
|
337
353
|
border: none;
|