@dxc-technology/halstack-react 11.0.0 → 12.0.1
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/BackgroundColorContext.d.ts +1 -10
- package/BackgroundColorContext.js +3 -8
- package/HalstackContext.d.ts +32 -145
- package/HalstackContext.js +3 -7
- package/accordion/Accordion.accessibility.test.d.ts +1 -0
- package/accordion/Accordion.accessibility.test.js +71 -0
- package/accordion/Accordion.js +18 -35
- package/accordion/Accordion.stories.tsx +7 -49
- package/accordion/Accordion.test.d.ts +1 -0
- package/accordion/Accordion.test.js +3 -3
- package/accordion/types.d.ts +1 -1
- package/accordion-group/AccordionGroup.accessibility.test.d.ts +1 -0
- package/accordion-group/AccordionGroup.accessibility.test.js +82 -0
- package/accordion-group/AccordionGroup.d.ts +2 -3
- package/accordion-group/AccordionGroup.js +4 -4
- package/accordion-group/AccordionGroup.stories.tsx +23 -23
- package/accordion-group/AccordionGroup.test.d.ts +1 -0
- package/accordion-group/AccordionGroup.test.js +5 -9
- package/accordion-group/AccordionGroupAccordion.js +3 -3
- package/accordion-group/AccordionGroupContext.d.ts +3 -0
- package/accordion-group/AccordionGroupContext.js +8 -0
- package/accordion-group/types.d.ts +1 -1
- package/action-icon/ActionIcon.accessibility.test.d.ts +1 -0
- package/action-icon/ActionIcon.accessibility.test.js +63 -0
- package/action-icon/ActionIcon.d.ts +4 -0
- package/action-icon/ActionIcon.js +48 -0
- package/action-icon/ActionIcon.stories.tsx +41 -0
- package/action-icon/ActionIcon.test.d.ts +1 -0
- package/action-icon/ActionIcon.test.js +64 -0
- package/action-icon/types.d.ts +26 -0
- package/action-icon/types.js +5 -0
- package/alert/Alert.accessibility.test.d.ts +1 -0
- package/alert/Alert.accessibility.test.js +95 -0
- package/alert/Alert.js +21 -75
- package/alert/Alert.test.d.ts +1 -0
- package/alert/Alert.test.js +1 -1
- package/badge/Badge.accessibility.test.d.ts +1 -0
- package/badge/Badge.accessibility.test.js +129 -0
- package/badge/Badge.d.ts +1 -1
- package/badge/Badge.js +141 -28
- package/badge/Badge.stories.tsx +210 -0
- package/badge/Badge.test.d.ts +1 -0
- package/badge/Badge.test.js +30 -0
- package/badge/types.d.ts +52 -3
- package/box/Box.accessibility.test.d.ts +1 -0
- package/box/Box.accessibility.test.js +33 -0
- package/box/Box.js +2 -5
- package/box/Box.test.d.ts +1 -0
- package/box/Box.test.js +1 -1
- package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
- package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
- package/breadcrumbs/Breadcrumbs.d.ts +4 -0
- package/breadcrumbs/Breadcrumbs.js +79 -0
- package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
- package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
- package/breadcrumbs/Breadcrumbs.test.js +169 -0
- package/breadcrumbs/Item.d.ts +4 -0
- package/breadcrumbs/Item.js +52 -0
- package/breadcrumbs/dropdownTheme.d.ts +53 -0
- package/breadcrumbs/dropdownTheme.js +62 -0
- package/breadcrumbs/types.d.ts +16 -0
- package/breadcrumbs/types.js +5 -0
- package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
- package/bulleted-list/BulletedList.accessibility.test.js +119 -0
- package/bulleted-list/BulletedList.js +16 -23
- package/bulleted-list/BulletedList.stories.tsx +1 -2
- package/button/Button.accessibility.test.d.ts +1 -0
- package/button/Button.accessibility.test.js +127 -0
- package/button/Button.js +16 -16
- package/button/Button.stories.tsx +34 -53
- package/button/Button.test.d.ts +1 -0
- package/button/Button.test.js +4 -2
- package/button/types.d.ts +1 -1
- package/card/Card.accessibility.test.d.ts +1 -0
- package/card/Card.accessibility.test.js +36 -0
- package/card/Card.js +3 -2
- package/card/Card.test.d.ts +1 -0
- package/card/Card.test.js +1 -1
- package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
- package/checkbox/Checkbox.accessibility.test.js +87 -0
- package/checkbox/Checkbox.js +36 -44
- package/checkbox/Checkbox.test.d.ts +1 -0
- package/checkbox/Checkbox.test.js +1 -1
- package/chip/Chip.accessibility.test.d.ts +1 -0
- package/chip/Chip.accessibility.test.js +69 -0
- package/chip/Chip.js +20 -26
- package/chip/Chip.stories.tsx +67 -50
- package/chip/Chip.test.d.ts +1 -0
- package/chip/Chip.test.js +5 -5
- package/chip/types.d.ts +35 -12
- package/common/coreTokens.d.ts +105 -14
- package/common/coreTokens.js +40 -22
- package/common/fonts.css +2 -0
- package/common/variables.d.ts +31 -141
- package/common/variables.js +104 -214
- package/container/Container.d.ts +4 -0
- package/container/Container.js +194 -0
- package/container/Container.stories.tsx +214 -0
- package/container/types.d.ts +74 -0
- package/container/types.js +5 -0
- package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
- package/contextual-menu/ContextualMenu.accessibility.test.js +98 -0
- package/contextual-menu/ContextualMenu.d.ts +5 -0
- package/contextual-menu/ContextualMenu.js +88 -0
- package/contextual-menu/ContextualMenu.stories.tsx +232 -0
- package/contextual-menu/ContextualMenu.test.d.ts +1 -0
- package/contextual-menu/ContextualMenu.test.js +205 -0
- package/contextual-menu/GroupItem.d.ts +4 -0
- package/contextual-menu/GroupItem.js +67 -0
- package/contextual-menu/ItemAction.d.ts +4 -0
- package/contextual-menu/ItemAction.js +51 -0
- package/contextual-menu/MenuItem.d.ts +4 -0
- package/contextual-menu/MenuItem.js +29 -0
- package/contextual-menu/SingleItem.d.ts +4 -0
- package/contextual-menu/SingleItem.js +38 -0
- package/contextual-menu/types.d.ts +58 -0
- package/contextual-menu/types.js +5 -0
- package/date-input/Calendar.js +1 -1
- package/date-input/DateInput.accessibility.test.d.ts +1 -0
- package/date-input/DateInput.accessibility.test.js +230 -0
- package/date-input/DateInput.js +19 -20
- package/date-input/DateInput.stories.tsx +15 -8
- package/date-input/DateInput.test.d.ts +1 -0
- package/date-input/DateInput.test.js +9 -8
- package/date-input/DatePicker.js +13 -7
- package/date-input/YearPicker.js +1 -1
- package/date-input/types.d.ts +2 -2
- package/dialog/Dialog.accessibility.test.d.ts +1 -0
- package/dialog/Dialog.accessibility.test.js +69 -0
- package/dialog/Dialog.js +11 -25
- package/dialog/Dialog.stories.tsx +175 -0
- package/dialog/Dialog.test.d.ts +1 -0
- package/dialog/Dialog.test.js +113 -49
- package/divider/Divider.accessibility.test.d.ts +1 -0
- package/divider/Divider.accessibility.test.js +33 -0
- package/divider/Divider.d.ts +4 -0
- package/divider/Divider.js +36 -0
- package/divider/Divider.stories.tsx +223 -0
- package/divider/Divider.test.d.ts +1 -0
- package/divider/Divider.test.js +38 -0
- package/divider/types.d.ts +21 -0
- package/divider/types.js +5 -0
- package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
- package/dropdown/Dropdown.accessibility.test.js +184 -0
- package/dropdown/Dropdown.js +37 -51
- package/dropdown/Dropdown.stories.tsx +15 -26
- package/dropdown/Dropdown.test.d.ts +1 -0
- package/dropdown/Dropdown.test.js +100 -70
- package/dropdown/DropdownMenu.js +4 -4
- package/dropdown/DropdownMenuItem.js +8 -4
- package/dropdown/types.d.ts +3 -5
- package/file-input/FileInput.accessibility.test.d.ts +1 -0
- package/file-input/FileInput.accessibility.test.js +167 -0
- package/file-input/FileInput.js +127 -145
- package/file-input/FileInput.test.d.ts +1 -0
- package/file-input/FileInput.test.js +125 -129
- package/file-input/FileItem.js +18 -28
- package/file-input/types.d.ts +1 -1
- package/footer/Footer.accessibility.test.d.ts +1 -0
- package/footer/Footer.accessibility.test.js +125 -0
- package/footer/Footer.d.ts +1 -1
- package/footer/Footer.js +36 -31
- package/footer/Footer.stories.tsx +58 -2
- package/footer/Footer.test.d.ts +1 -0
- package/footer/Footer.test.js +1 -1
- package/footer/Icons.d.ts +1 -0
- package/footer/Icons.js +52 -16
- package/footer/types.d.ts +8 -8
- package/header/Header.accessibility.test.d.ts +1 -0
- package/header/Header.accessibility.test.js +94 -0
- package/header/Header.js +20 -41
- package/header/Header.stories.tsx +16 -0
- package/header/Header.test.d.ts +1 -0
- package/header/Header.test.js +1 -1
- package/header/Icons.js +1 -6
- package/header/types.d.ts +4 -3
- package/heading/Heading.accessibility.test.d.ts +1 -0
- package/heading/Heading.accessibility.test.js +33 -0
- package/heading/Heading.js +1 -1
- package/heading/Heading.test.d.ts +1 -0
- package/heading/Heading.test.js +1 -14
- package/icon/Icon.accessibility.test.d.ts +1 -0
- package/icon/Icon.accessibility.test.js +30 -0
- package/icon/Icon.d.ts +4 -0
- package/icon/Icon.js +33 -0
- package/icon/Icon.stories.tsx +28 -0
- package/icon/types.d.ts +4 -0
- package/icon/types.js +5 -0
- package/image/Image.accessibility.test.d.ts +1 -0
- package/image/Image.accessibility.test.js +56 -0
- package/image/Image.js +1 -1
- package/image/Image.stories.tsx +3 -1
- package/layout/ApplicationLayout.d.ts +1 -1
- package/layout/ApplicationLayout.js +10 -7
- package/layout/Icons.d.ts +0 -1
- package/layout/Icons.js +1 -11
- package/link/Link.accessibility.test.d.ts +1 -0
- package/link/Link.accessibility.test.js +108 -0
- package/link/Link.js +8 -6
- package/link/Link.stories.tsx +4 -4
- package/link/Link.test.d.ts +1 -0
- package/link/Link.test.js +1 -1
- package/link/types.d.ts +1 -1
- package/main.d.ts +8 -3
- package/main.js +38 -9
- package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
- package/nav-tabs/NavTabs.accessibility.test.js +44 -0
- package/nav-tabs/NavTabs.d.ts +1 -2
- package/nav-tabs/NavTabs.js +25 -7
- package/nav-tabs/NavTabs.stories.tsx +44 -24
- package/nav-tabs/NavTabs.test.d.ts +1 -0
- package/nav-tabs/NavTabs.test.js +12 -10
- package/nav-tabs/NavTabsContext.d.ts +3 -0
- package/nav-tabs/NavTabsContext.js +8 -0
- package/nav-tabs/Tab.js +23 -23
- package/nav-tabs/types.d.ts +1 -1
- package/number-input/NumberInput.accessibility.test.d.ts +1 -0
- package/number-input/NumberInput.accessibility.test.js +228 -0
- package/number-input/NumberInput.d.ts +0 -7
- package/number-input/NumberInput.js +24 -5
- package/number-input/NumberInput.test.d.ts +1 -0
- package/number-input/NumberInput.test.js +166 -7
- package/number-input/NumberInputContext.d.ts +3 -0
- package/number-input/NumberInputContext.js +8 -0
- package/number-input/types.d.ts +6 -0
- package/package.json +20 -18
- package/paginator/Paginator.accessibility.test.d.ts +1 -0
- package/paginator/Paginator.accessibility.test.js +79 -0
- package/paginator/Paginator.js +14 -14
- package/paginator/Paginator.test.d.ts +1 -0
- package/paginator/Paginator.test.js +1 -1
- package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
- package/paragraph/Paragraph.accessibility.test.js +28 -0
- package/paragraph/Paragraph.js +2 -7
- package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
- package/password-input/PasswordInput.accessibility.test.js +153 -0
- package/password-input/PasswordInput.js +7 -7
- package/password-input/PasswordInput.stories.tsx +0 -1
- package/password-input/PasswordInput.test.d.ts +1 -0
- package/password-input/PasswordInput.test.js +5 -5
- package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
- package/progress-bar/ProgressBar.accessibility.test.js +35 -0
- package/progress-bar/ProgressBar.js +11 -15
- package/progress-bar/ProgressBar.test.d.ts +1 -0
- package/progress-bar/ProgressBar.test.js +1 -1
- package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
- package/quick-nav/QuickNav.accessibility.test.js +57 -0
- package/quick-nav/QuickNav.js +1 -1
- package/radio-group/Radio.js +6 -9
- package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
- package/radio-group/RadioGroup.accessibility.test.js +97 -0
- package/radio-group/RadioGroup.js +15 -17
- package/radio-group/RadioGroup.test.d.ts +1 -0
- package/radio-group/RadioGroup.test.js +3 -5
- package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
- package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
- package/resultset-table/ResultsetTable.d.ts +4 -1
- package/resultset-table/ResultsetTable.js +25 -13
- package/resultset-table/ResultsetTable.stories.tsx +118 -5
- package/resultset-table/ResultsetTable.test.d.ts +1 -0
- package/resultset-table/ResultsetTable.test.js +76 -1
- package/resultset-table/types.d.ts +40 -7
- package/select/Listbox.js +24 -16
- package/select/Option.js +19 -10
- package/select/Select.accessibility.test.d.ts +1 -0
- package/select/Select.accessibility.test.js +228 -0
- package/select/Select.js +72 -54
- package/select/Select.stories.tsx +59 -111
- package/select/Select.test.d.ts +1 -0
- package/select/Select.test.js +393 -459
- package/select/types.d.ts +3 -3
- package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
- package/sidenav/Sidenav.accessibility.test.js +59 -0
- package/sidenav/Sidenav.js +21 -19
- package/sidenav/Sidenav.stories.tsx +4 -9
- package/sidenav/Sidenav.test.d.ts +1 -0
- package/sidenav/Sidenav.test.js +1 -1
- package/sidenav/types.d.ts +2 -2
- package/slider/Slider.accessibility.test.d.ts +1 -0
- package/slider/Slider.accessibility.test.js +104 -0
- package/slider/Slider.js +31 -42
- package/slider/Slider.stories.tsx +180 -0
- package/slider/Slider.test.d.ts +1 -0
- package/slider/Slider.test.js +12 -9
- package/spinner/Spinner.accessibility.test.d.ts +1 -0
- package/spinner/Spinner.accessibility.test.js +96 -0
- package/spinner/Spinner.js +12 -16
- package/spinner/Spinner.test.d.ts +1 -0
- package/spinner/Spinner.test.js +1 -1
- package/status-light/StatusLight.accessibility.test.d.ts +1 -0
- package/status-light/StatusLight.accessibility.test.js +157 -0
- package/status-light/StatusLight.d.ts +4 -0
- package/status-light/StatusLight.js +51 -0
- package/status-light/StatusLight.stories.tsx +74 -0
- package/status-light/StatusLight.test.d.ts +1 -0
- package/status-light/StatusLight.test.js +25 -0
- package/status-light/types.d.ts +17 -0
- package/status-light/types.js +5 -0
- package/switch/Switch.accessibility.test.d.ts +1 -0
- package/switch/Switch.accessibility.test.js +98 -0
- package/switch/Switch.js +29 -37
- package/switch/Switch.stories.tsx +12 -0
- package/switch/Switch.test.d.ts +1 -0
- package/switch/Switch.test.js +1 -1
- package/table/DropdownTheme.js +62 -0
- package/table/Table.accessibility.test.d.ts +1 -0
- package/table/Table.accessibility.test.js +93 -0
- package/table/Table.d.ts +6 -2
- package/table/Table.js +74 -12
- package/table/Table.stories.tsx +309 -2
- package/table/Table.test.d.ts +1 -0
- package/table/Table.test.js +92 -1
- package/table/types.d.ts +28 -0
- package/tabs/Tab.js +13 -9
- package/tabs/Tabs.accessibility.test.d.ts +1 -0
- package/tabs/Tabs.accessibility.test.js +56 -0
- package/tabs/Tabs.js +12 -24
- package/tabs/Tabs.stories.tsx +8 -4
- package/tabs/Tabs.test.d.ts +1 -0
- package/tabs/Tabs.test.js +20 -38
- package/tabs/types.d.ts +2 -2
- package/tag/Tag.accessibility.test.d.ts +1 -0
- package/tag/Tag.accessibility.test.js +69 -0
- package/tag/Tag.js +7 -7
- package/tag/Tag.stories.tsx +4 -7
- package/tag/Tag.test.d.ts +1 -0
- package/tag/Tag.test.js +5 -13
- package/tag/types.d.ts +2 -2
- package/text-input/Suggestion.js +1 -1
- package/text-input/Suggestions.js +19 -14
- package/text-input/TextInput.accessibility.test.d.ts +1 -0
- package/text-input/TextInput.accessibility.test.js +321 -0
- package/text-input/TextInput.js +103 -126
- package/text-input/TextInput.stories.tsx +17 -8
- package/text-input/TextInput.test.d.ts +1 -0
- package/text-input/TextInput.test.js +97 -80
- package/textarea/Textarea.accessibility.test.d.ts +1 -0
- package/textarea/Textarea.accessibility.test.js +155 -0
- package/textarea/Textarea.js +13 -21
- package/textarea/Textarea.stories.tsx +0 -1
- package/textarea/Textarea.test.d.ts +1 -0
- package/textarea/Textarea.test.js +1 -1
- package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
- package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
- package/toggle-group/ToggleGroup.js +11 -16
- package/toggle-group/ToggleGroup.stories.tsx +3 -3
- package/toggle-group/ToggleGroup.test.d.ts +1 -0
- package/toggle-group/ToggleGroup.test.js +1 -1
- package/toggle-group/types.d.ts +2 -2
- package/typography/Typography.accessibility.test.d.ts +1 -0
- package/typography/Typography.accessibility.test.js +339 -0
- package/useTheme.d.ts +31 -141
- package/utils/BaseTypography.js +1 -1
- package/utils/FocusLock.js +16 -6
- package/wizard/Wizard.accessibility.test.d.ts +1 -0
- package/wizard/Wizard.accessibility.test.js +55 -0
- package/wizard/Wizard.js +14 -25
- package/wizard/Wizard.stories.tsx +19 -0
- package/wizard/Wizard.test.d.ts +1 -0
- package/wizard/Wizard.test.js +1 -1
- package/wizard/types.d.ts +2 -2
- package/common/OpenSans.css +0 -69
- package/common/fonts/OpenSans-Bold.ttf +0 -0
- package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
- package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
- package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
- package/common/fonts/OpenSans-Italic.ttf +0 -0
- package/common/fonts/OpenSans-Light.ttf +0 -0
- package/common/fonts/OpenSans-LightItalic.ttf +0 -0
- package/common/fonts/OpenSans-Regular.ttf +0 -0
- package/common/fonts/OpenSans-SemiBold.ttf +0 -0
- package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
- package/date-input/Icons.d.ts +0 -6
- package/date-input/Icons.js +0 -58
- package/paginator/Icons.d.ts +0 -5
- package/paginator/Icons.js +0 -40
- package/password-input/Icons.d.ts +0 -6
- package/password-input/Icons.js +0 -35
- package/select/Icons.d.ts +0 -10
- package/select/Icons.js +0 -89
- package/sidenav/Icons.d.ts +0 -7
- package/sidenav/Icons.js +0 -47
- package/text-input/Icons.d.ts +0 -8
- package/text-input/Icons.js +0 -56
- /package/{layout → sidenav}/SidenavContext.d.ts +0 -0
- /package/{layout → sidenav}/SidenavContext.js +0 -0
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
5
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
6
|
+
var _react = _interopRequireDefault(require("react"));
|
|
7
|
+
var _react2 = require("@testing-library/react");
|
|
8
|
+
var _axeHelper = require("../../test/accessibility/axe-helper.js");
|
|
9
|
+
var _Footer = _interopRequireDefault(require("./Footer"));
|
|
10
|
+
var _disabledRules = require("../../test/accessibility/rules/specific/footer/disabledRules.js");
|
|
11
|
+
var disabledRules = {
|
|
12
|
+
rules: _disabledRules.disabledRules.reduce(function (rulesObj, rule) {
|
|
13
|
+
rulesObj[rule] = {
|
|
14
|
+
enabled: false
|
|
15
|
+
};
|
|
16
|
+
return rulesObj;
|
|
17
|
+
}, {})
|
|
18
|
+
};
|
|
19
|
+
var social = [{
|
|
20
|
+
href: "https://www.linkedin.com/company/dxctechnology",
|
|
21
|
+
logo: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
22
|
+
version: "1.1",
|
|
23
|
+
x: "0px",
|
|
24
|
+
y: "0px",
|
|
25
|
+
viewBox: "0 0 438.536 438.536",
|
|
26
|
+
fill: "currentColor"
|
|
27
|
+
}, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
|
|
28
|
+
d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M133.618,367.157H67.666V169.016h65.952V367.157z M127.626,132.332 c-6.851,6.567-15.893,9.851-27.124,9.851h-0.288c-10.848,0-19.648-3.284-26.407-9.851c-6.76-6.567-10.138-14.703-10.138-24.41 c0-9.897,3.476-18.083,10.421-24.556c6.95-6.471,15.942-9.708,26.98-9.708c11.039,0,19.89,3.237,26.553,9.708 c6.661,6.473,10.088,14.659,10.277,24.556C137.899,117.625,134.477,125.761,127.626,132.332z M370.873,367.157h-65.952v-105.92 c0-29.879-11.036-44.823-33.116-44.823c-8.374,0-15.42,2.331-21.128,6.995c-5.715,4.661-9.996,10.324-12.847,16.991 c-1.335,3.422-1.999,8.75-1.999,15.981v110.775h-65.952c0.571-119.529,0.571-185.579,0-198.142h65.952v27.974 c13.867-21.681,33.558-32.544,59.101-32.544c22.84,0,41.21,7.52,55.104,22.554c13.895,15.037,20.841,37.214,20.841,66.519v113.64 H370.873z"
|
|
29
|
+
}))),
|
|
30
|
+
title: "Linkedin"
|
|
31
|
+
}, {
|
|
32
|
+
href: "https://x.com/dxctechnology",
|
|
33
|
+
logo: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
34
|
+
width: "256",
|
|
35
|
+
height: "256",
|
|
36
|
+
viewBox: "0 0 256 256",
|
|
37
|
+
fill: "none",
|
|
38
|
+
xmlns: "http://www.w3.org/2000/svg"
|
|
39
|
+
}, /*#__PURE__*/_react["default"].createElement("rect", {
|
|
40
|
+
width: "256",
|
|
41
|
+
height: "256",
|
|
42
|
+
rx: "40",
|
|
43
|
+
fill: "white"
|
|
44
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
45
|
+
d: "M140.192 118.205L187.848 64H176.556L135.158 111.056L102.117 64H64L113.975 135.163L64 192H75.2914L118.982 142.296L153.883 192H192L140.192 118.205ZM124.722 135.787L119.65 128.697L79.3634 72.3294H96.7094L129.232 117.837L134.282 124.927L176.551 184.076H159.205L124.722 135.787Z",
|
|
46
|
+
fill: "#0F1419"
|
|
47
|
+
})),
|
|
48
|
+
title: "X"
|
|
49
|
+
}, {
|
|
50
|
+
href: "https://www.facebook.com/DXCTechnology/",
|
|
51
|
+
logo: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
52
|
+
version: "1.1",
|
|
53
|
+
x: "0px",
|
|
54
|
+
y: "0px",
|
|
55
|
+
viewBox: "0 0 438.536 438.536",
|
|
56
|
+
fill: "currentColor",
|
|
57
|
+
width: "1000px",
|
|
58
|
+
height: "500px"
|
|
59
|
+
}, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
|
|
60
|
+
d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M373.155,225.548h-49.963V406.84h-74.802V225.548H210.99V163.02h37.401v-37.402 c0-26.838,6.283-47.107,18.843-60.813c12.559-13.706,33.304-20.555,62.242-20.555h49.963v62.526h-31.401 c-10.663,0-17.467,1.853-20.417,5.568c-2.949,3.711-4.428,10.23-4.428,19.558v31.119h56.534L373.155,225.548z"
|
|
61
|
+
}))),
|
|
62
|
+
title: "Facebook"
|
|
63
|
+
}];
|
|
64
|
+
var bottom = [{
|
|
65
|
+
href: "https://www.linkedin.com/company/dxctechnology",
|
|
66
|
+
text: "Linkedin"
|
|
67
|
+
}, {
|
|
68
|
+
href: "https://x.com/dxctechnology",
|
|
69
|
+
text: "X"
|
|
70
|
+
}, {
|
|
71
|
+
href: "https://www.facebook.com/DXCTechnology/",
|
|
72
|
+
text: "Facebook"
|
|
73
|
+
}];
|
|
74
|
+
describe("Footer component accessibility tests", function () {
|
|
75
|
+
it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
76
|
+
var _render, container, results;
|
|
77
|
+
return _regenerator["default"].wrap(function _callee$(_context) {
|
|
78
|
+
while (1) switch (_context.prev = _context.next) {
|
|
79
|
+
case 0:
|
|
80
|
+
_render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Footer["default"], {
|
|
81
|
+
copyright: "Copyright",
|
|
82
|
+
socialLinks: social,
|
|
83
|
+
bottomLinks: bottom,
|
|
84
|
+
margin: "small",
|
|
85
|
+
mode: "default"
|
|
86
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("a", {
|
|
87
|
+
href: "https://www.linkedin.com/company/dxctechnology"
|
|
88
|
+
}, "Linkedin")))), container = _render.container;
|
|
89
|
+
_context.next = 3;
|
|
90
|
+
return (0, _axeHelper.axe)(container, disabledRules);
|
|
91
|
+
case 3:
|
|
92
|
+
results = _context.sent;
|
|
93
|
+
expect(results).toHaveNoViolations();
|
|
94
|
+
case 5:
|
|
95
|
+
case "end":
|
|
96
|
+
return _context.stop();
|
|
97
|
+
}
|
|
98
|
+
}, _callee);
|
|
99
|
+
})));
|
|
100
|
+
it("Should not have basic accessibility issues for reduced mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
101
|
+
var _render2, container, results;
|
|
102
|
+
return _regenerator["default"].wrap(function _callee2$(_context2) {
|
|
103
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
104
|
+
case 0:
|
|
105
|
+
_render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Footer["default"], {
|
|
106
|
+
copyright: "Copyright",
|
|
107
|
+
socialLinks: social,
|
|
108
|
+
bottomLinks: bottom,
|
|
109
|
+
margin: "small",
|
|
110
|
+
mode: "reduced"
|
|
111
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("a", {
|
|
112
|
+
href: "https://www.linkedin.com/company/dxctechnology"
|
|
113
|
+
}, "Linkedin")))), container = _render2.container;
|
|
114
|
+
_context2.next = 3;
|
|
115
|
+
return (0, _axeHelper.axe)(container, disabledRules);
|
|
116
|
+
case 3:
|
|
117
|
+
results = _context2.sent;
|
|
118
|
+
expect(results).toHaveNoViolations();
|
|
119
|
+
case 5:
|
|
120
|
+
case "end":
|
|
121
|
+
return _context2.stop();
|
|
122
|
+
}
|
|
123
|
+
}, _callee2);
|
|
124
|
+
})));
|
|
125
|
+
});
|
package/footer/Footer.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import FooterPropsType from "./types";
|
|
3
|
-
declare const DxcFooter: ({ socialLinks, bottomLinks, copyright, children, margin, tabIndex, }: FooterPropsType) => JSX.Element;
|
|
3
|
+
declare const DxcFooter: ({ socialLinks, bottomLinks, copyright, children, margin, tabIndex, mode, }: FooterPropsType) => JSX.Element;
|
|
4
4
|
export default DxcFooter;
|
package/footer/Footer.js
CHANGED
|
@@ -1,24 +1,23 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
var
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
5
|
Object.defineProperty(exports, "__esModule", {
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
8
|
exports["default"] = void 0;
|
|
9
|
-
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
10
9
|
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
11
10
|
var _react = _interopRequireWildcard(require("react"));
|
|
12
11
|
var _styledComponents = _interopRequireWildcard(require("styled-components"));
|
|
13
12
|
var _variables = require("../common/variables");
|
|
14
13
|
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
15
14
|
var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
|
|
16
|
-
var _BackgroundColorContext = require("../BackgroundColorContext");
|
|
17
15
|
var _Icons = require("./Icons");
|
|
18
16
|
var _Flex = _interopRequireDefault(require("../flex/Flex"));
|
|
17
|
+
var _Icon = _interopRequireDefault(require("../icon/Icon"));
|
|
19
18
|
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10;
|
|
20
19
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
21
|
-
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" !=
|
|
20
|
+
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; }
|
|
22
21
|
var DxcFooter = function DxcFooter(_ref) {
|
|
23
22
|
var socialLinks = _ref.socialLinks,
|
|
24
23
|
bottomLinks = _ref.bottomLinks,
|
|
@@ -26,31 +25,31 @@ var DxcFooter = function DxcFooter(_ref) {
|
|
|
26
25
|
children = _ref.children,
|
|
27
26
|
margin = _ref.margin,
|
|
28
27
|
_ref$tabIndex = _ref.tabIndex,
|
|
29
|
-
tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex
|
|
28
|
+
tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex,
|
|
29
|
+
_ref$mode = _ref.mode,
|
|
30
|
+
mode = _ref$mode === void 0 ? "default" : _ref$mode;
|
|
30
31
|
var colorsTheme = (0, _useTheme["default"])();
|
|
31
32
|
var translatedLabels = (0, _useTranslatedLabels["default"])();
|
|
32
33
|
var footerLogo = (0, _react.useMemo)(function () {
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
alt: translatedLabels.formFields.logoAlternativeText,
|
|
39
|
-
src: colorsTheme.footer.logo
|
|
40
|
-
});
|
|
41
|
-
}
|
|
42
|
-
return colorsTheme.footer.logo;
|
|
34
|
+
return !colorsTheme.footer.logo ? mode === "default" ? _Icons.dxcLogo : _Icons.dxcSmallLogo : typeof colorsTheme.footer.logo === "string" ? /*#__PURE__*/_react["default"].createElement(LogoImg, {
|
|
35
|
+
mode: mode,
|
|
36
|
+
alt: translatedLabels.formFields.logoAlternativeText,
|
|
37
|
+
src: colorsTheme.footer.logo
|
|
38
|
+
}) : colorsTheme.footer.logo;
|
|
43
39
|
}, [colorsTheme]);
|
|
44
40
|
return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
|
|
45
41
|
theme: colorsTheme.footer
|
|
46
42
|
}, /*#__PURE__*/_react["default"].createElement(FooterContainer, {
|
|
47
|
-
margin: margin
|
|
43
|
+
margin: margin,
|
|
44
|
+
mode: mode
|
|
48
45
|
}, /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
|
|
49
46
|
justifyContent: "space-between",
|
|
50
47
|
alignItems: "center",
|
|
51
48
|
wrap: "wrap",
|
|
52
49
|
gap: "1.5rem"
|
|
53
|
-
}, /*#__PURE__*/_react["default"].createElement(LogoContainer,
|
|
50
|
+
}, /*#__PURE__*/_react["default"].createElement(LogoContainer, {
|
|
51
|
+
mode: mode
|
|
52
|
+
}, footerLogo), mode === "default" && /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, socialLinks === null || socialLinks === void 0 ? void 0 : socialLinks.map(function (link, index) {
|
|
54
53
|
return /*#__PURE__*/_react["default"].createElement(SocialAnchor, {
|
|
55
54
|
href: link.href,
|
|
56
55
|
tabIndex: tabIndex,
|
|
@@ -58,12 +57,10 @@ var DxcFooter = function DxcFooter(_ref) {
|
|
|
58
57
|
"aria-label": link.title,
|
|
59
58
|
key: "social".concat(index).concat(link.href),
|
|
60
59
|
index: index
|
|
61
|
-
}, /*#__PURE__*/_react["default"].createElement(SocialIconContainer, null, typeof link.logo === "string" ? /*#__PURE__*/_react["default"].createElement("
|
|
62
|
-
|
|
60
|
+
}, /*#__PURE__*/_react["default"].createElement(SocialIconContainer, null, typeof link.logo === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
|
|
61
|
+
icon: link.logo
|
|
63
62
|
}) : link.logo));
|
|
64
|
-
}))), /*#__PURE__*/_react["default"].createElement(ChildComponents, null, /*#__PURE__*/_react["default"].createElement(
|
|
65
|
-
color: colorsTheme.footer.backgroundColor
|
|
66
|
-
}, children)), /*#__PURE__*/_react["default"].createElement(BottomContainer, null, /*#__PURE__*/_react["default"].createElement(BottomLinks, null, bottomLinks === null || bottomLinks === void 0 ? void 0 : bottomLinks.map(function (link, index) {
|
|
63
|
+
}))), /*#__PURE__*/_react["default"].createElement(ChildComponents, null, children), mode === "default" && /*#__PURE__*/_react["default"].createElement(BottomContainer, null, /*#__PURE__*/_react["default"].createElement(BottomLinks, null, bottomLinks === null || bottomLinks === void 0 ? void 0 : bottomLinks.map(function (link, index) {
|
|
67
64
|
return /*#__PURE__*/_react["default"].createElement("span", {
|
|
68
65
|
key: "bottom".concat(index).concat(link.text)
|
|
69
66
|
}, /*#__PURE__*/_react["default"].createElement(BottomLink, {
|
|
@@ -72,13 +69,19 @@ var DxcFooter = function DxcFooter(_ref) {
|
|
|
72
69
|
}, link.text));
|
|
73
70
|
})), /*#__PURE__*/_react["default"].createElement(Copyright, null, copyright || translatedLabels.footer.copyrightText(new Date().getFullYear())))));
|
|
74
71
|
};
|
|
75
|
-
var FooterContainer = _styledComponents["default"].footer(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n flex-direction:
|
|
76
|
-
return props.theme.
|
|
72
|
+
var FooterContainer = _styledComponents["default"].footer(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n box-sizing: border-box;\n display: flex;\n flex-direction: ", ";\n justify-content: space-between;\n margin-top: ", ";\n min-height: ", ";\n width: 100%;\n gap: ", ";\n @media (min-width: ", "rem) {\n padding: ", ";\n }\n @media (max-width: ", "rem) {\n padding: 20px;\n flex-direction: column;\n }\n"])), function (props) {
|
|
73
|
+
return props.theme.backgroundColor;
|
|
77
74
|
}, function (props) {
|
|
78
|
-
return props
|
|
75
|
+
return (props === null || props === void 0 ? void 0 : props.mode) === "default" ? "column" : "row";
|
|
79
76
|
}, function (props) {
|
|
80
|
-
return props.
|
|
81
|
-
},
|
|
77
|
+
return props.margin ? _variables.spaces[props.margin] : "0px";
|
|
78
|
+
}, function (props) {
|
|
79
|
+
return (props === null || props === void 0 ? void 0 : props.mode) === "default" ? props.theme.height : "40px";
|
|
80
|
+
}, function (props) {
|
|
81
|
+
return (props === null || props === void 0 ? void 0 : props.mode) === "default" ? "0px" : "32px";
|
|
82
|
+
}, _variables.responsiveSizes.small, function (props) {
|
|
83
|
+
return (props === null || props === void 0 ? void 0 : props.mode) === "default" ? "24px 32px" : "12px 32px";
|
|
84
|
+
}, _variables.responsiveSizes.small);
|
|
82
85
|
var BottomContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n align-items: flex-end;\n\n @media (min-width: ", "rem) {\n flex-direction: row;\n }\n @media (max-width: ", "rem) {\n flex-direction: column;\n align-items: center;\n }\n\n border-top: ", ";\n margin-top: 16px;\n"])), _variables.responsiveSizes.small, _variables.responsiveSizes.small, function (props) {
|
|
83
86
|
return "".concat(props.theme.bottomLinksDividerThickness, " ").concat(props.theme.bottomLinksDividerStyle, " ").concat(props.theme.bottomLinksDividerColor);
|
|
84
87
|
});
|
|
@@ -97,24 +100,26 @@ var Copyright = _styledComponents["default"].div(_templateObject4 || (_templateO
|
|
|
97
100
|
return props.theme.copyrightFontColor;
|
|
98
101
|
}, _variables.responsiveSizes.small, _variables.responsiveSizes.small);
|
|
99
102
|
var LogoContainer = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n max-height: ", ";\n width: ", ";\n"])), function (props) {
|
|
100
|
-
return props.theme.logoHeight;
|
|
103
|
+
return (props === null || props === void 0 ? void 0 : props.mode) === "default" ? props.theme.logoHeight : "16px";
|
|
101
104
|
}, function (props) {
|
|
102
105
|
return props.theme.logoWidth;
|
|
103
106
|
});
|
|
104
107
|
var LogoImg = _styledComponents["default"].img(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n max-height: ", ";\n width: ", ";\n"])), function (props) {
|
|
105
|
-
return props.theme.logoHeight;
|
|
108
|
+
return (props === null || props === void 0 ? void 0 : props.mode) === "default" ? props.theme.logoHeight : "16px";
|
|
106
109
|
}, function (props) {
|
|
107
110
|
return props.theme.logoWidth;
|
|
108
111
|
});
|
|
109
112
|
var SocialAnchor = _styledComponents["default"].a(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n margin-left: ", ";\n border-radius: 4px;\n\n &:focus {\n outline: 2px solid #0095ff;\n outline-offset: 2px;\n }\n"])), function (props) {
|
|
110
113
|
return props.index === 0 ? "0px" : props.theme.socialLinksGutter;
|
|
111
114
|
});
|
|
112
|
-
var SocialIconContainer = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n
|
|
115
|
+
var SocialIconContainer = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n color: ", ";\n overflow: hidden;\n font-size: ", ";\n\n svg {\n height: ", ";\n width: ", ";\n }\n"])), function (props) {
|
|
116
|
+
return props.theme.socialLinksColor;
|
|
117
|
+
}, function (props) {
|
|
113
118
|
return props.theme.socialLinksSize;
|
|
114
119
|
}, function (props) {
|
|
115
120
|
return props.theme.socialLinksSize;
|
|
116
121
|
}, function (props) {
|
|
117
|
-
return props.theme.
|
|
122
|
+
return props.theme.socialLinksSize;
|
|
118
123
|
});
|
|
119
124
|
var BottomLinks = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n flex-wrap: wrap;\n align-self: center;\n padding-top: ", ";\n color: #fff;\n\n @media (min-width: ", "rem) {\n max-width: 60%;\n }\n @media (max-width: ", "rem) {\n max-width: 100%;\n width: 100%;\n }\n\n & > span:not(:first-child):before {\n content: \"\xB7\";\n padding: 0 0.5rem;\n }\n"])), function (props) {
|
|
120
125
|
return props.theme.bottomLinksDividerSpacing;
|
|
@@ -3,12 +3,16 @@ import DxcFooter from "./Footer";
|
|
|
3
3
|
import Title from "../../.storybook/components/Title";
|
|
4
4
|
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
5
5
|
import { HalstackProvider } from "../HalstackContext";
|
|
6
|
+
import DxcFlex from "../flex/Flex";
|
|
7
|
+
import DxcTypography from "../typography/Typography";
|
|
8
|
+
import preview from "../../.storybook/preview";
|
|
9
|
+
import { disabledRules } from "../../test/accessibility/rules/specific/footer/disabledRules";
|
|
6
10
|
|
|
7
11
|
const social = [
|
|
8
12
|
{
|
|
9
13
|
href: "https://www.linkedin.com/company/dxctechnology",
|
|
10
14
|
logo: (
|
|
11
|
-
<svg version="1.1"
|
|
15
|
+
<svg version="1.1" x="0px" y="0px" viewBox="0 0 438.536 438.536" fill="currentColor">
|
|
12
16
|
<g>
|
|
13
17
|
<path
|
|
14
18
|
d="M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123
|
|
@@ -46,7 +50,6 @@ const social = [
|
|
|
46
50
|
logo: (
|
|
47
51
|
<svg
|
|
48
52
|
version="1.1"
|
|
49
|
-
id="Capa_1"
|
|
50
53
|
x="0px"
|
|
51
54
|
y="0px"
|
|
52
55
|
viewBox="0 0 438.536 438.536"
|
|
@@ -70,6 +73,24 @@ const social = [
|
|
|
70
73
|
},
|
|
71
74
|
];
|
|
72
75
|
|
|
76
|
+
const socialMaterialIcons = [
|
|
77
|
+
{
|
|
78
|
+
href: "https://www.linkedin.com/company/dxctechnology",
|
|
79
|
+
logo: "person",
|
|
80
|
+
title: "Linkedin",
|
|
81
|
+
},
|
|
82
|
+
{
|
|
83
|
+
href: "https://x.com/dxctechnology",
|
|
84
|
+
logo: "group",
|
|
85
|
+
title: "X",
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
href: "https://www.facebook.com/DXCTechnology/",
|
|
89
|
+
logo: "thumb_up",
|
|
90
|
+
title: "Facebook",
|
|
91
|
+
},
|
|
92
|
+
];
|
|
93
|
+
|
|
73
94
|
const bottom = [
|
|
74
95
|
{
|
|
75
96
|
href: "https://www.linkedin.com/company/dxctechnology",
|
|
@@ -88,6 +109,16 @@ const bottom = [
|
|
|
88
109
|
export default {
|
|
89
110
|
title: "Footer",
|
|
90
111
|
component: DxcFooter,
|
|
112
|
+
parameters: {
|
|
113
|
+
a11y: {
|
|
114
|
+
config: {
|
|
115
|
+
rules: [
|
|
116
|
+
...disabledRules.map((ruleId) => ({ id: ruleId, enabled: false })),
|
|
117
|
+
...preview?.parameters?.a11y?.config?.rules,
|
|
118
|
+
],
|
|
119
|
+
},
|
|
120
|
+
},
|
|
121
|
+
},
|
|
91
122
|
};
|
|
92
123
|
|
|
93
124
|
const opinionatedTheme = {
|
|
@@ -99,6 +130,11 @@ const opinionatedTheme = {
|
|
|
99
130
|
},
|
|
100
131
|
};
|
|
101
132
|
|
|
133
|
+
const info = [
|
|
134
|
+
{ label: "Example Label", text: "Example" },
|
|
135
|
+
{ label: "Example Label", text: "Example" },
|
|
136
|
+
];
|
|
137
|
+
|
|
102
138
|
export const Chromatic = () => (
|
|
103
139
|
<>
|
|
104
140
|
<ExampleContainer>
|
|
@@ -113,6 +149,14 @@ export const Chromatic = () => (
|
|
|
113
149
|
</div>
|
|
114
150
|
</DxcFooter>
|
|
115
151
|
</ExampleContainer>
|
|
152
|
+
<ExampleContainer>
|
|
153
|
+
<Title title="With children, copyright, bottom links and social links from material" theme="light" level={4} />
|
|
154
|
+
<DxcFooter copyright="Copyright" socialLinks={socialMaterialIcons} bottomLinks={bottom}>
|
|
155
|
+
<div>
|
|
156
|
+
<a href="https://www.linkedin.com/company/dxctechnology">Linkedin</a>
|
|
157
|
+
</div>
|
|
158
|
+
</DxcFooter>
|
|
159
|
+
</ExampleContainer>
|
|
116
160
|
<ExampleContainer pseudoState="pseudo-focus">
|
|
117
161
|
<Title title="Focused bottom and social links" theme="light" level={4} />
|
|
118
162
|
<DxcFooter copyright="Copyright" socialLinks={social} bottomLinks={bottom}>
|
|
@@ -121,6 +165,18 @@ export const Chromatic = () => (
|
|
|
121
165
|
</div>
|
|
122
166
|
</DxcFooter>
|
|
123
167
|
</ExampleContainer>
|
|
168
|
+
<ExampleContainer>
|
|
169
|
+
<Title title="Reduced" theme="light" level={4} />
|
|
170
|
+
<DxcFooter mode="reduced">
|
|
171
|
+
<DxcFlex justifyContent="center" alignItems="center" gap={"1rem"}>
|
|
172
|
+
{info.map((tag, index) => (
|
|
173
|
+
<DxcTypography color="white" key={`tag${index}${tag.label}${tag.text}`}>
|
|
174
|
+
{tag.label}: {tag.text}
|
|
175
|
+
</DxcTypography>
|
|
176
|
+
))}
|
|
177
|
+
</DxcFlex>
|
|
178
|
+
</DxcFooter>
|
|
179
|
+
</ExampleContainer>
|
|
124
180
|
<Title title="Margins" theme="light" level={2} />
|
|
125
181
|
<ExampleContainer>
|
|
126
182
|
<Title title="Xxsmall margin" theme="light" level={4} />
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
package/footer/Footer.test.js
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
4
|
var _react = _interopRequireDefault(require("react"));
|
|
5
5
|
var _react2 = require("@testing-library/react");
|
|
6
|
-
var _Footer = _interopRequireDefault(require("./Footer
|
|
6
|
+
var _Footer = _interopRequireDefault(require("./Footer"));
|
|
7
7
|
var social = [{
|
|
8
8
|
href: "https://www.test.com/social",
|
|
9
9
|
logo: "https://developer.apple.com/design/human-interface-guidelines/foundations/app-icons/images/icon-and-image-large-icon-settings_2x.png",
|
package/footer/Icons.d.ts
CHANGED
package/footer/Icons.js
CHANGED
|
@@ -4,68 +4,104 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
4
4
|
Object.defineProperty(exports, "__esModule", {
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
7
|
-
exports.dxcLogo = void 0;
|
|
7
|
+
exports.dxcSmallLogo = exports.dxcLogo = void 0;
|
|
8
8
|
var _react = _interopRequireDefault(require("react"));
|
|
9
9
|
var dxcLogo = exports.dxcLogo = /*#__PURE__*/_react["default"].createElement("svg", {
|
|
10
|
-
id: "g10",
|
|
11
10
|
xmlns: "http://www.w3.org/2000/svg",
|
|
12
11
|
width: "100%",
|
|
13
12
|
height: "32",
|
|
14
13
|
viewBox: "0 0 280.781 32"
|
|
15
|
-
}, /*#__PURE__*/_react["default"].createElement("title", null, "DXC Logo"), /*#__PURE__*/_react["default"].createElement("g", {
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
14
|
+
}, /*#__PURE__*/_react["default"].createElement("title", null, "DXC Logo"), /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
|
|
15
|
+
d: "M171.5-54.124v12.539h-3.6V-54.124h-4.973v-3.191h13.54v3.191H171.5",
|
|
16
|
+
transform: "translate(-68.528 65.45)",
|
|
17
|
+
fill: "#fff"
|
|
18
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
19
|
+
d: "M189.96-41.585V-57.315h12.326v3.079h-8.753v3.191h7.7v3.078h-7.7v3.3h8.87v3.078H189.96",
|
|
20
|
+
transform: "translate(-77.56 65.45)",
|
|
21
|
+
fill: "#fff"
|
|
22
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
23
|
+
d: "M223.558-41.438a8.1,8.1,0,0,1-8.382-8.1v-.045a8.161,8.161,0,0,1,8.522-8.146,8.6,8.6,0,0,1,6.444,2.431l-2.289,2.543a6.133,6.133,0,0,0-4.178-1.778,4.743,4.743,0,0,0-4.738,4.905v.045a4.752,4.752,0,0,0,4.738,4.95,6,6,0,0,0,4.295-1.845l2.288,2.228a8.491,8.491,0,0,1-6.7,2.813",
|
|
24
|
+
transform: "translate(-86.019 65.583)",
|
|
25
|
+
fill: "#fff"
|
|
26
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
27
|
+
d: "M254.988-41.585V-47.9h-6.63v6.315h-3.6V-57.315h3.6v6.225h6.63v-6.225h3.594v15.731h-3.594",
|
|
28
|
+
transform: "translate(-95.903 65.45)",
|
|
29
|
+
fill: "#fff"
|
|
30
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
31
|
+
d: "M285.991-41.585l-7.914-10v10h-3.549V-57.315h3.316l7.657,9.685v-9.685h3.549v15.731h-3.058",
|
|
32
|
+
transform: "translate(-105.869 65.45)",
|
|
33
|
+
fill: "#fff"
|
|
34
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
35
|
+
d: "M317.2-49.583a4.869,4.869,0,0,0-4.949-4.95,4.793,4.793,0,0,0-4.9,4.905v.045a4.869,4.869,0,0,0,4.949,4.95,4.793,4.793,0,0,0,4.9-4.905Zm-4.949,8.145c-5.043,0-8.661-3.623-8.661-8.1v-.045c0-4.478,3.666-8.146,8.708-8.146s8.66,3.623,8.66,8.1v.045c0,4.477-3.664,8.145-8.708,8.145",
|
|
36
|
+
transform: "translate(-115.631 65.583)",
|
|
37
|
+
fill: "#fff"
|
|
38
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
39
|
+
d: "M336.786-41.585V-57.315h3.6v12.584h8.148v3.146H336.786",
|
|
40
|
+
transform: "translate(-126.654 65.45)",
|
|
41
|
+
fill: "#fff"
|
|
42
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
43
|
+
d: "M372.78-49.583a4.87,4.87,0,0,0-4.949-4.95,4.794,4.794,0,0,0-4.9,4.905v.045a4.869,4.869,0,0,0,4.949,4.95,4.794,4.794,0,0,0,4.9-4.905Zm-4.949,8.145c-5.043,0-8.662-3.623-8.662-8.1v-.045c0-4.478,3.666-8.146,8.708-8.146s8.661,3.623,8.661,8.1v.045c0,4.477-3.666,8.145-8.708,8.145",
|
|
44
|
+
transform: "translate(-135.016 65.583)",
|
|
45
|
+
fill: "#fff"
|
|
46
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
47
|
+
d: "M399.735-41.438c-5.09,0-8.592-3.443-8.592-8.1v-.045a8.243,8.243,0,0,1,8.568-8.146,9.18,9.18,0,0,1,6.42,2.16l-2.265,2.634a6.141,6.141,0,0,0-4.272-1.6,4.807,4.807,0,0,0-4.692,4.905v.045a4.8,4.8,0,0,0,4.949,4.995,5.89,5.89,0,0,0,3.384-.945v-2.25h-3.618v-2.992h7.1v6.841a10.837,10.837,0,0,1-6.98,2.5",
|
|
48
|
+
transform: "translate(-145.284 65.583)",
|
|
49
|
+
fill: "#fff"
|
|
50
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
51
|
+
d: "M428.664-47.855v6.27h-3.6v-6.2l-6.28-9.528h4.2L426.89-51l3.968-6.315h4.085l-6.28,9.46",
|
|
52
|
+
transform: "translate(-154.162 65.45)",
|
|
53
|
+
fill: "#fff"
|
|
54
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
55
|
+
d: "M84.218-55.737a10.063,10.063,0,0,1,2.589-4.4,9.792,9.792,0,0,1,6.985-2.77h11.328V-69.3H93.792a17.041,17.041,0,0,0-11.8,4.759,16.344,16.344,0,0,0-3.547,5.115,13.247,13.247,0,0,0-1.122,3.688Zm0,4.877a10.065,10.065,0,0,0,2.589,4.4,9.793,9.793,0,0,0,6.985,2.77h11.328V-37.3H93.792a17.042,17.042,0,0,1-11.8-4.759,16.339,16.339,0,0,1-3.547-5.114,13.251,13.251,0,0,1-1.122-3.688ZM63.1-47.98,54.45-37.3H45.873l12.957-16-12.957-16H54.45L63.1-58.619l8.65-10.68h8.578l-12.957,16,12.957,16H71.749ZM48.875-55.737a13.212,13.212,0,0,0-1.122-3.688,16.359,16.359,0,0,0-3.546-5.115,17.043,17.043,0,0,0-11.8-4.759H21.08v6.393H32.408a9.79,9.79,0,0,1,6.985,2.77,10.072,10.072,0,0,1,2.59,4.4Zm0,4.877a13.215,13.215,0,0,1-1.122,3.688,16.353,16.353,0,0,1-3.546,5.114,17.044,17.044,0,0,1-11.8,4.759H21.08v-6.393H32.408a9.791,9.791,0,0,0,6.985-2.77,10.074,10.074,0,0,0,2.59-4.4h6.892",
|
|
56
|
+
transform: "translate(-21.08 69.298)",
|
|
57
|
+
fill: "#fff"
|
|
58
|
+
})));
|
|
59
|
+
var dxcSmallLogo = exports.dxcSmallLogo = /*#__PURE__*/_react["default"].createElement("svg", {
|
|
60
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
61
|
+
width: "100%",
|
|
62
|
+
height: "16",
|
|
63
|
+
viewBox: "0 0 280.781 32"
|
|
64
|
+
}, /*#__PURE__*/_react["default"].createElement("title", null, "DXC Logo"), /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
|
|
19
65
|
d: "M171.5-54.124v12.539h-3.6V-54.124h-4.973v-3.191h13.54v3.191H171.5",
|
|
20
66
|
transform: "translate(-68.528 65.45)",
|
|
21
67
|
fill: "#fff"
|
|
22
68
|
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
23
|
-
id: "path16",
|
|
24
69
|
d: "M189.96-41.585V-57.315h12.326v3.079h-8.753v3.191h7.7v3.078h-7.7v3.3h8.87v3.078H189.96",
|
|
25
70
|
transform: "translate(-77.56 65.45)",
|
|
26
71
|
fill: "#fff"
|
|
27
72
|
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
28
|
-
id: "path18",
|
|
29
73
|
d: "M223.558-41.438a8.1,8.1,0,0,1-8.382-8.1v-.045a8.161,8.161,0,0,1,8.522-8.146,8.6,8.6,0,0,1,6.444,2.431l-2.289,2.543a6.133,6.133,0,0,0-4.178-1.778,4.743,4.743,0,0,0-4.738,4.905v.045a4.752,4.752,0,0,0,4.738,4.95,6,6,0,0,0,4.295-1.845l2.288,2.228a8.491,8.491,0,0,1-6.7,2.813",
|
|
30
74
|
transform: "translate(-86.019 65.583)",
|
|
31
75
|
fill: "#fff"
|
|
32
76
|
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
33
|
-
id: "path20",
|
|
34
77
|
d: "M254.988-41.585V-47.9h-6.63v6.315h-3.6V-57.315h3.6v6.225h6.63v-6.225h3.594v15.731h-3.594",
|
|
35
78
|
transform: "translate(-95.903 65.45)",
|
|
36
79
|
fill: "#fff"
|
|
37
80
|
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
38
|
-
id: "path22",
|
|
39
81
|
d: "M285.991-41.585l-7.914-10v10h-3.549V-57.315h3.316l7.657,9.685v-9.685h3.549v15.731h-3.058",
|
|
40
82
|
transform: "translate(-105.869 65.45)",
|
|
41
83
|
fill: "#fff"
|
|
42
84
|
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
43
|
-
id: "path24",
|
|
44
85
|
d: "M317.2-49.583a4.869,4.869,0,0,0-4.949-4.95,4.793,4.793,0,0,0-4.9,4.905v.045a4.869,4.869,0,0,0,4.949,4.95,4.793,4.793,0,0,0,4.9-4.905Zm-4.949,8.145c-5.043,0-8.661-3.623-8.661-8.1v-.045c0-4.478,3.666-8.146,8.708-8.146s8.66,3.623,8.66,8.1v.045c0,4.477-3.664,8.145-8.708,8.145",
|
|
45
86
|
transform: "translate(-115.631 65.583)",
|
|
46
87
|
fill: "#fff"
|
|
47
88
|
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
48
|
-
id: "path26",
|
|
49
89
|
d: "M336.786-41.585V-57.315h3.6v12.584h8.148v3.146H336.786",
|
|
50
90
|
transform: "translate(-126.654 65.45)",
|
|
51
91
|
fill: "#fff"
|
|
52
92
|
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
53
|
-
id: "path28",
|
|
54
93
|
d: "M372.78-49.583a4.87,4.87,0,0,0-4.949-4.95,4.794,4.794,0,0,0-4.9,4.905v.045a4.869,4.869,0,0,0,4.949,4.95,4.794,4.794,0,0,0,4.9-4.905Zm-4.949,8.145c-5.043,0-8.662-3.623-8.662-8.1v-.045c0-4.478,3.666-8.146,8.708-8.146s8.661,3.623,8.661,8.1v.045c0,4.477-3.666,8.145-8.708,8.145",
|
|
55
94
|
transform: "translate(-135.016 65.583)",
|
|
56
95
|
fill: "#fff"
|
|
57
96
|
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
58
|
-
id: "path30",
|
|
59
97
|
d: "M399.735-41.438c-5.09,0-8.592-3.443-8.592-8.1v-.045a8.243,8.243,0,0,1,8.568-8.146,9.18,9.18,0,0,1,6.42,2.16l-2.265,2.634a6.141,6.141,0,0,0-4.272-1.6,4.807,4.807,0,0,0-4.692,4.905v.045a4.8,4.8,0,0,0,4.949,4.995,5.89,5.89,0,0,0,3.384-.945v-2.25h-3.618v-2.992h7.1v6.841a10.837,10.837,0,0,1-6.98,2.5",
|
|
60
98
|
transform: "translate(-145.284 65.583)",
|
|
61
99
|
fill: "#fff"
|
|
62
100
|
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
63
|
-
id: "path32",
|
|
64
101
|
d: "M428.664-47.855v6.27h-3.6v-6.2l-6.28-9.528h4.2L426.89-51l3.968-6.315h4.085l-6.28,9.46",
|
|
65
102
|
transform: "translate(-154.162 65.45)",
|
|
66
103
|
fill: "#fff"
|
|
67
104
|
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
68
|
-
id: "path34",
|
|
69
105
|
d: "M84.218-55.737a10.063,10.063,0,0,1,2.589-4.4,9.792,9.792,0,0,1,6.985-2.77h11.328V-69.3H93.792a17.041,17.041,0,0,0-11.8,4.759,16.344,16.344,0,0,0-3.547,5.115,13.247,13.247,0,0,0-1.122,3.688Zm0,4.877a10.065,10.065,0,0,0,2.589,4.4,9.793,9.793,0,0,0,6.985,2.77h11.328V-37.3H93.792a17.042,17.042,0,0,1-11.8-4.759,16.339,16.339,0,0,1-3.547-5.114,13.251,13.251,0,0,1-1.122-3.688ZM63.1-47.98,54.45-37.3H45.873l12.957-16-12.957-16H54.45L63.1-58.619l8.65-10.68h8.578l-12.957,16,12.957,16H71.749ZM48.875-55.737a13.212,13.212,0,0,0-1.122-3.688,16.359,16.359,0,0,0-3.546-5.115,17.043,17.043,0,0,0-11.8-4.759H21.08v6.393H32.408a9.79,9.79,0,0,1,6.985,2.77,10.072,10.072,0,0,1,2.59,4.4Zm0,4.877a13.215,13.215,0,0,1-1.122,3.688,16.353,16.353,0,0,1-3.546,5.114,17.044,17.044,0,0,1-11.8,4.759H21.08v-6.393H32.408a9.791,9.791,0,0,0,6.985-2.77,10.074,10.074,0,0,0,2.59-4.4h6.892",
|
|
70
106
|
transform: "translate(-21.08 69.298)",
|
|
71
107
|
fill: "#fff"
|
package/footer/types.d.ts
CHANGED
|
@@ -1,11 +1,5 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
|
|
3
|
-
type Size = {
|
|
4
|
-
top?: Space;
|
|
5
|
-
bottom?: Space;
|
|
6
|
-
left?: Space;
|
|
7
|
-
right?: Space;
|
|
8
|
-
};
|
|
9
3
|
type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
|
|
10
4
|
type SocialLink = {
|
|
11
5
|
/**
|
|
@@ -13,7 +7,7 @@ type SocialLink = {
|
|
|
13
7
|
*/
|
|
14
8
|
href: string;
|
|
15
9
|
/**
|
|
16
|
-
*
|
|
10
|
+
* Material Symbol name or SVG element as the icon used for the link.
|
|
17
11
|
*/
|
|
18
12
|
logo: string | SVG;
|
|
19
13
|
/**
|
|
@@ -54,11 +48,17 @@ type FooterPropsType = {
|
|
|
54
48
|
/**
|
|
55
49
|
* Size of the top margin to be applied to the footer.
|
|
56
50
|
*/
|
|
57
|
-
margin?: Space
|
|
51
|
+
margin?: Space;
|
|
58
52
|
/**
|
|
59
53
|
* Value of the tabindex for all interactive elements, except those
|
|
60
54
|
* inside the custom area.
|
|
61
55
|
*/
|
|
62
56
|
tabIndex?: number;
|
|
57
|
+
/**
|
|
58
|
+
* Determines the visual style and layout
|
|
59
|
+
* - "default": The default mode with full content and styling.
|
|
60
|
+
* - "reduced": A reduced mode with minimal content and styling.
|
|
61
|
+
*/
|
|
62
|
+
mode?: "default" | "reduced";
|
|
63
63
|
};
|
|
64
64
|
export default FooterPropsType;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|