@cloudscape-design/components-themeable 3.0.1212 → 3.0.1214
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/lib/internal/manifest.json +1 -1
- package/lib/internal/scss/internal/components/card/styles.scss +1 -0
- package/lib/internal/scss/internal/components/dropdown/styles.scss +4 -0
- package/lib/internal/scss/internal/generated/custom-css-properties/index.scss +1 -1
- package/lib/internal/scss/internal/styles/typography/constants.scss +1 -0
- package/lib/internal/scss/internal/styles/typography/mixins.scss +26 -11
- package/lib/internal/scss/wizard/styles.scss +21 -6
- package/lib/internal/template/button-dropdown/internal.js +1 -1
- package/lib/internal/template/button-dropdown/internal.js.map +1 -1
- package/lib/internal/template/cards/styles.css.js +38 -38
- package/lib/internal/template/cards/styles.scoped.css +40 -39
- package/lib/internal/template/cards/styles.selectors.js +38 -38
- package/lib/internal/template/date-picker/index.js +1 -1
- package/lib/internal/template/date-picker/index.js.map +1 -1
- package/lib/internal/template/date-range-picker/dropdown.d.ts +2 -2
- package/lib/internal/template/date-range-picker/dropdown.d.ts.map +1 -1
- package/lib/internal/template/date-range-picker/dropdown.js +2 -2
- package/lib/internal/template/date-range-picker/dropdown.js.map +1 -1
- package/lib/internal/template/date-range-picker/index.js +2 -2
- package/lib/internal/template/date-range-picker/index.js.map +1 -1
- package/lib/internal/template/header/styles.css.js +34 -34
- package/lib/internal/template/header/styles.scoped.css +55 -52
- package/lib/internal/template/header/styles.selectors.js +34 -34
- package/lib/internal/template/help-panel/styles.css.js +6 -6
- package/lib/internal/template/help-panel/styles.scoped.css +72 -67
- package/lib/internal/template/help-panel/styles.selectors.js +6 -6
- package/lib/internal/template/internal/base-component/styles.scoped.css +3 -1
- package/lib/internal/template/internal/components/card/styles.css.js +11 -11
- package/lib/internal/template/internal/components/card/styles.scoped.css +26 -24
- package/lib/internal/template/internal/components/card/styles.selectors.js +11 -11
- package/lib/internal/template/internal/components/dropdown/index.d.ts +1 -1
- package/lib/internal/template/internal/components/dropdown/index.d.ts.map +1 -1
- package/lib/internal/template/internal/components/dropdown/index.js +35 -6
- package/lib/internal/template/internal/components/dropdown/index.js.map +1 -1
- package/lib/internal/template/internal/components/dropdown/interfaces.d.ts +19 -2
- package/lib/internal/template/internal/components/dropdown/interfaces.d.ts.map +1 -1
- package/lib/internal/template/internal/components/dropdown/interfaces.js.map +1 -1
- package/lib/internal/template/internal/components/dropdown/styles.css.js +20 -20
- package/lib/internal/template/internal/components/dropdown/styles.scoped.css +67 -37
- package/lib/internal/template/internal/components/dropdown/styles.selectors.js +20 -20
- package/lib/internal/template/internal/environment.js +2 -2
- package/lib/internal/template/internal/environment.json +2 -2
- package/lib/internal/template/internal/generated/styles/tokens.d.ts +1 -0
- package/lib/internal/template/internal/generated/styles/tokens.js +1 -0
- package/lib/internal/template/internal/generated/theming/index.cjs +5 -0
- package/lib/internal/template/internal/generated/theming/index.cjs.d.ts +9 -0
- package/lib/internal/template/internal/generated/theming/index.d.ts +9 -0
- package/lib/internal/template/internal/generated/theming/index.js +5 -0
- package/lib/internal/template/popover/styles.css.js +57 -57
- package/lib/internal/template/popover/styles.scoped.css +91 -89
- package/lib/internal/template/popover/styles.selectors.js +57 -57
- package/lib/internal/template/side-navigation/styles.css.js +30 -30
- package/lib/internal/template/side-navigation/styles.scoped.css +47 -46
- package/lib/internal/template/side-navigation/styles.selectors.js +30 -30
- package/lib/internal/template/text-content/styles.css.js +1 -1
- package/lib/internal/template/text-content/styles.scoped.css +65 -60
- package/lib/internal/template/text-content/styles.selectors.js +1 -1
- package/lib/internal/template/top-navigation/styles.css.js +47 -47
- package/lib/internal/template/top-navigation/styles.scoped.css +66 -65
- package/lib/internal/template/top-navigation/styles.selectors.js +47 -47
- package/lib/internal/template/wizard/internal.d.ts.map +1 -1
- package/lib/internal/template/wizard/internal.js +6 -2
- package/lib/internal/template/wizard/internal.js.map +1 -1
- package/lib/internal/template/wizard/styles.css.js +30 -30
- package/lib/internal/template/wizard/styles.scoped.css +76 -63
- package/lib/internal/template/wizard/styles.selectors.js +30 -30
- package/lib/internal/template/wizard/wizard-form.d.ts +0 -1
- package/lib/internal/template/wizard/wizard-form.d.ts.map +1 -1
- package/lib/internal/template/wizard/wizard-form.js +1 -4
- package/lib/internal/template/wizard/wizard-form.js.map +1 -1
- package/lib/internal/template/wizard/wizard-navigation.d.ts.map +1 -1
- package/lib/internal/template/wizard/wizard-navigation.js +13 -86
- package/lib/internal/template/wizard/wizard-navigation.js.map +1 -1
- package/lib/internal/template/wizard/wizard-step-list.d.ts +27 -0
- package/lib/internal/template/wizard/wizard-step-list.d.ts.map +1 -0
- package/lib/internal/template/wizard/wizard-step-list.js +105 -0
- package/lib/internal/template/wizard/wizard-step-list.js.map +1 -0
- package/lib/internal/template/wizard/wizard-step-navigation-expandable.d.ts +16 -0
- package/lib/internal/template/wizard/wizard-step-navigation-expandable.d.ts.map +1 -0
- package/lib/internal/template/wizard/wizard-step-navigation-expandable.js +18 -0
- package/lib/internal/template/wizard/wizard-step-navigation-expandable.js.map +1 -0
- package/package.json +1 -1
|
@@ -2,111 +2,38 @@
|
|
|
2
2
|
// SPDX-License-Identifier: Apache-2.0
|
|
3
3
|
import React from 'react';
|
|
4
4
|
import clsx from 'clsx';
|
|
5
|
+
import { useUniqueId } from '@cloudscape-design/component-toolkit/internal';
|
|
5
6
|
import InternalBox from '../box/internal';
|
|
6
7
|
import { useVisualRefresh } from '../internal/hooks/use-visual-mode';
|
|
7
8
|
import InternalLink from '../link/internal';
|
|
8
9
|
import { getNavigationActionDetail } from './analytics-metadata/utils';
|
|
10
|
+
import WizardStepList, { getStepStatus, StepStatusValues } from './wizard-step-list';
|
|
9
11
|
import analyticsSelectors from './analytics-metadata/styles.css.js';
|
|
10
12
|
import styles from './styles.css.js';
|
|
11
|
-
var Statuses;
|
|
12
|
-
(function (Statuses) {
|
|
13
|
-
Statuses["Active"] = "active";
|
|
14
|
-
Statuses["Unvisited"] = "unvisited";
|
|
15
|
-
Statuses["Visited"] = "visited";
|
|
16
|
-
Statuses["Next"] = "next";
|
|
17
|
-
})(Statuses || (Statuses = {}));
|
|
18
13
|
export default function Navigation({ activeStepIndex, farthestStepIndex, allowSkipTo, hidden, i18nStrings, isLoadingNextStep, onStepClick, onSkipToClick, steps, }) {
|
|
19
14
|
const isVisualRefresh = useVisualRefresh();
|
|
20
|
-
return (React.createElement("nav", { className: clsx(styles.navigation, hidden && styles.hidden, isVisualRefresh && styles.refresh), "aria-label": i18nStrings.navigationAriaLabel },
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
return Statuses.Active;
|
|
25
|
-
}
|
|
26
|
-
if (isLoadingNextStep) {
|
|
27
|
-
return Statuses.Unvisited;
|
|
28
|
-
}
|
|
29
|
-
if (farthestStepIndex >= index) {
|
|
30
|
-
return Statuses.Visited;
|
|
31
|
-
}
|
|
32
|
-
if (allowSkipTo && canSkip(activeStepIndex + 1, index)) {
|
|
33
|
-
return Statuses.Next;
|
|
34
|
-
}
|
|
35
|
-
return Statuses.Unvisited;
|
|
36
|
-
}
|
|
37
|
-
function canSkip(fromIndex, toIndex) {
|
|
38
|
-
let index = fromIndex;
|
|
39
|
-
do {
|
|
40
|
-
if (!steps[index].isOptional) {
|
|
41
|
-
return false;
|
|
42
|
-
}
|
|
43
|
-
index++;
|
|
44
|
-
} while (index < toIndex);
|
|
45
|
-
return true;
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
function NavigationStepVisualRefresh({ i18nStrings, index, onStepClick, onSkipToClick, status, step, }) {
|
|
49
|
-
function handleStepInteraction() {
|
|
50
|
-
if (status === Statuses.Visited) {
|
|
51
|
-
onStepClick(index);
|
|
52
|
-
}
|
|
53
|
-
if (status === Statuses.Next) {
|
|
54
|
-
onSkipToClick(index);
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
const state = {
|
|
58
|
-
active: 'active',
|
|
59
|
-
unvisited: 'disabled',
|
|
60
|
-
visited: 'enabled',
|
|
61
|
-
next: 'enabled',
|
|
62
|
-
}[status];
|
|
63
|
-
const linkClassName = clsx(styles['navigation-link'], {
|
|
64
|
-
[styles['navigation-link-active']]: status === Statuses.Active,
|
|
65
|
-
[styles['navigation-link-disabled']]: status === Statuses.Unvisited,
|
|
66
|
-
});
|
|
67
|
-
return (React.createElement("li", { className: clsx(styles[`${state}`], styles['navigation-link-item']) },
|
|
68
|
-
React.createElement("hr", null),
|
|
69
|
-
React.createElement("span", { className: clsx(styles.number, styles['navigation-link-label']) },
|
|
70
|
-
i18nStrings.stepNumberLabel && i18nStrings.stepNumberLabel(index + 1),
|
|
71
|
-
step.isOptional && React.createElement("i", null, ` - ${i18nStrings.optional}`)),
|
|
72
|
-
React.createElement("a", { className: linkClassName, "aria-current": status === Statuses.Active ? 'step' : undefined, "aria-disabled": status === Statuses.Unvisited ? 'true' : undefined, onClick: event => {
|
|
73
|
-
event.preventDefault();
|
|
74
|
-
handleStepInteraction();
|
|
75
|
-
}, onKeyDown: event => {
|
|
76
|
-
if (event.key === ' ' || event.key === 'Enter') {
|
|
77
|
-
event.preventDefault();
|
|
78
|
-
}
|
|
79
|
-
// Enter activates the button on key down instead of key up.
|
|
80
|
-
if (event.key === 'Enter') {
|
|
81
|
-
handleStepInteraction();
|
|
82
|
-
}
|
|
83
|
-
}, onKeyUp: event => {
|
|
84
|
-
// Emulate button behavior, which also fires on space.
|
|
85
|
-
if (event.key === ' ') {
|
|
86
|
-
handleStepInteraction();
|
|
87
|
-
}
|
|
88
|
-
}, role: "button", tabIndex: status === Statuses.Visited || status === Statuses.Next ? 0 : undefined, ...(status === Statuses.Unvisited
|
|
89
|
-
? {}
|
|
90
|
-
: getNavigationActionDetail(index, 'step', true, `.${analyticsSelectors['step-title']}`)) },
|
|
91
|
-
React.createElement("div", { className: styles.circle }),
|
|
92
|
-
React.createElement("span", { className: clsx(styles.title, analyticsSelectors['step-title']) }, step.title))));
|
|
15
|
+
return (React.createElement("nav", { className: clsx(styles.navigation, hidden && styles.hidden, isVisualRefresh && styles.refresh), "aria-label": i18nStrings.navigationAriaLabel }, isVisualRefresh ? (React.createElement(WizardStepList, { activeStepIndex: activeStepIndex, farthestStepIndex: farthestStepIndex, allowSkipTo: allowSkipTo, i18nStrings: i18nStrings, isLoadingNextStep: isLoadingNextStep, onStepClick: onStepClick, onSkipToClick: onSkipToClick, steps: steps })) : (React.createElement("ul", null, steps.map((step, index) => {
|
|
16
|
+
const status = getStepStatus(index, activeStepIndex, farthestStepIndex, isLoadingNextStep, allowSkipTo, steps);
|
|
17
|
+
return (React.createElement(NavigationStepClassic, { i18nStrings: i18nStrings, index: index, key: index, onStepClick: onStepClick, onSkipToClick: onSkipToClick, status: status, step: step }));
|
|
18
|
+
})))));
|
|
93
19
|
}
|
|
94
20
|
function NavigationStepClassic({ i18nStrings, index, onStepClick, onSkipToClick, status, step }) {
|
|
95
|
-
const spanClassName = clsx(styles['navigation-link'], status ===
|
|
96
|
-
|
|
21
|
+
const spanClassName = clsx(styles['navigation-link'], status === StepStatusValues.Active ? styles['navigation-link-active'] : styles['navigation-link-disabled']);
|
|
22
|
+
const optionalDescriptionId = useUniqueId('wizard-step-optional-');
|
|
23
|
+
return (React.createElement("li", { className: styles['navigation-link-item'], ...(status === StepStatusValues.Unvisited
|
|
97
24
|
? {}
|
|
98
25
|
: getNavigationActionDetail(index, 'step', true, `.${analyticsSelectors['step-title']}`)) },
|
|
99
26
|
React.createElement(InternalBox, { variant: "small", className: styles['navigation-link-label'], display: "block", margin: { bottom: 'xxs' } },
|
|
100
27
|
i18nStrings.stepNumberLabel && i18nStrings.stepNumberLabel(index + 1),
|
|
101
|
-
step.isOptional && React.createElement("i",
|
|
102
|
-
React.createElement("div", null, status ===
|
|
28
|
+
step.isOptional && React.createElement("i", { id: optionalDescriptionId }, ` - ${i18nStrings.optional}`)),
|
|
29
|
+
React.createElement("div", null, status === StepStatusValues.Visited || status === StepStatusValues.Next ? (React.createElement(InternalLink, { className: clsx(styles['navigation-link'], analyticsSelectors['step-title']), onFollow: evt => {
|
|
103
30
|
evt.preventDefault();
|
|
104
|
-
if (status ===
|
|
31
|
+
if (status === StepStatusValues.Visited) {
|
|
105
32
|
onStepClick(index);
|
|
106
33
|
}
|
|
107
34
|
else {
|
|
108
35
|
onSkipToClick(index);
|
|
109
36
|
}
|
|
110
|
-
}, variant: "primary" }, step.title)) : (React.createElement("span", { className: clsx(spanClassName, analyticsSelectors['step-title']), "aria-current": status ===
|
|
37
|
+
}, variant: "primary", nativeAttributes: step.isOptional ? { 'aria-describedby': optionalDescriptionId } : undefined }, step.title)) : (React.createElement("span", { className: clsx(spanClassName, analyticsSelectors['step-title']), "aria-current": status === StepStatusValues.Active ? 'step' : undefined, "aria-disabled": status === StepStatusValues.Active ? undefined : 'true', "aria-describedby": step.isOptional ? optionalDescriptionId : undefined }, step.title)))));
|
|
111
38
|
}
|
|
112
39
|
//# sourceMappingURL=wizard-navigation.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"wizard-navigation.js","sourceRoot":"","sources":["../../../src/wizard/wizard-navigation.tsx"],"names":[],"mappings":"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","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport React from 'react';\nimport clsx from 'clsx';\n\nimport InternalBox from '../box/internal';\nimport { useVisualRefresh } from '../internal/hooks/use-visual-mode';\nimport InternalLink from '../link/internal';\nimport { getNavigationActionDetail } from './analytics-metadata/utils';\nimport { WizardProps } from './interfaces';\n\nimport analyticsSelectors from './analytics-metadata/styles.css.js';\nimport styles from './styles.css.js';\n\ninterface NavigationProps {\n activeStepIndex: number;\n farthestStepIndex: number;\n allowSkipTo: boolean;\n hidden: boolean;\n i18nStrings: WizardProps.I18nStrings;\n isLoadingNextStep: boolean;\n onStepClick: (stepIndex: number) => void;\n onSkipToClick: (stepIndex: number) => void;\n steps: ReadonlyArray<WizardProps.Step>;\n}\n\ninterface NavigationStepProps {\n i18nStrings: WizardProps.I18nStrings;\n index: number;\n onStepClick: (stepIndex: number) => void;\n onSkipToClick: (stepIndex: number) => void;\n status: string;\n step: WizardProps.Step;\n}\n\nenum Statuses {\n Active = 'active',\n Unvisited = 'unvisited',\n Visited = 'visited',\n Next = 'next',\n}\n\nexport default function Navigation({\n activeStepIndex,\n farthestStepIndex,\n allowSkipTo,\n hidden,\n i18nStrings,\n isLoadingNextStep,\n onStepClick,\n onSkipToClick,\n steps,\n}: NavigationProps) {\n const isVisualRefresh = useVisualRefresh();\n return (\n <nav\n className={clsx(styles.navigation, hidden && styles.hidden, isVisualRefresh && styles.refresh)}\n aria-label={i18nStrings.navigationAriaLabel}\n >\n <ul className={clsx(isVisualRefresh && styles.refresh)}>\n {steps.map((step, index: number) =>\n isVisualRefresh ? (\n <NavigationStepVisualRefresh\n i18nStrings={i18nStrings}\n index={index}\n key={index}\n onStepClick={onStepClick}\n onSkipToClick={onSkipToClick}\n status={getStatus(index)}\n step={step}\n />\n ) : (\n <NavigationStepClassic\n i18nStrings={i18nStrings}\n index={index}\n key={index}\n onStepClick={onStepClick}\n onSkipToClick={onSkipToClick}\n status={getStatus(index)}\n step={step}\n />\n )\n )}\n </ul>\n </nav>\n );\n\n function getStatus(index: number) {\n if (activeStepIndex === index) {\n return Statuses.Active;\n }\n if (isLoadingNextStep) {\n return Statuses.Unvisited;\n }\n if (farthestStepIndex >= index) {\n return Statuses.Visited;\n }\n if (allowSkipTo && canSkip(activeStepIndex + 1, index)) {\n return Statuses.Next;\n }\n return Statuses.Unvisited;\n }\n\n function canSkip(fromIndex: number, toIndex: number) {\n let index = fromIndex;\n do {\n if (!steps[index].isOptional) {\n return false;\n }\n index++;\n } while (index < toIndex);\n return true;\n }\n}\n\nfunction NavigationStepVisualRefresh({\n i18nStrings,\n index,\n onStepClick,\n onSkipToClick,\n status,\n step,\n}: NavigationStepProps) {\n function handleStepInteraction() {\n if (status === Statuses.Visited) {\n onStepClick(index);\n }\n if (status === Statuses.Next) {\n onSkipToClick(index);\n }\n }\n\n const state = {\n active: 'active',\n unvisited: 'disabled',\n visited: 'enabled',\n next: 'enabled',\n }[status];\n\n const linkClassName = clsx(styles['navigation-link'], {\n [styles['navigation-link-active']]: status === Statuses.Active,\n [styles['navigation-link-disabled']]: status === Statuses.Unvisited,\n });\n\n return (\n <li className={clsx(styles[`${state}`], styles['navigation-link-item'])}>\n <hr />\n\n <span className={clsx(styles.number, styles['navigation-link-label'])}>\n {i18nStrings.stepNumberLabel && i18nStrings.stepNumberLabel(index + 1)}\n {step.isOptional && <i>{` - ${i18nStrings.optional}`}</i>}\n </span>\n\n <a\n className={linkClassName}\n aria-current={status === Statuses.Active ? 'step' : undefined}\n aria-disabled={status === Statuses.Unvisited ? 'true' : undefined}\n onClick={event => {\n event.preventDefault();\n handleStepInteraction();\n }}\n onKeyDown={event => {\n if (event.key === ' ' || event.key === 'Enter') {\n event.preventDefault();\n }\n // Enter activates the button on key down instead of key up.\n if (event.key === 'Enter') {\n handleStepInteraction();\n }\n }}\n onKeyUp={event => {\n // Emulate button behavior, which also fires on space.\n if (event.key === ' ') {\n handleStepInteraction();\n }\n }}\n role=\"button\"\n tabIndex={status === Statuses.Visited || status === Statuses.Next ? 0 : undefined}\n {...(status === Statuses.Unvisited\n ? {}\n : getNavigationActionDetail(index, 'step', true, `.${analyticsSelectors['step-title']}`))}\n >\n <div className={styles.circle} />\n\n <span className={clsx(styles.title, analyticsSelectors['step-title'])}>{step.title}</span>\n </a>\n </li>\n );\n}\n\nfunction NavigationStepClassic({ i18nStrings, index, onStepClick, onSkipToClick, status, step }: NavigationStepProps) {\n const spanClassName = clsx(\n styles['navigation-link'],\n status === Statuses.Active ? styles['navigation-link-active'] : styles['navigation-link-disabled']\n );\n\n return (\n <li\n className={styles['navigation-link-item']}\n {...(status === Statuses.Unvisited\n ? {}\n : getNavigationActionDetail(index, 'step', true, `.${analyticsSelectors['step-title']}`))}\n >\n <InternalBox\n variant=\"small\"\n className={styles['navigation-link-label']}\n display=\"block\"\n margin={{ bottom: 'xxs' }}\n >\n {i18nStrings.stepNumberLabel && i18nStrings.stepNumberLabel(index + 1)}\n {step.isOptional && <i>{` - ${i18nStrings.optional}`}</i>}\n </InternalBox>\n <div>\n {status === Statuses.Visited || status === Statuses.Next ? (\n <InternalLink\n className={clsx(styles['navigation-link'], analyticsSelectors['step-title'])}\n onFollow={evt => {\n evt.preventDefault();\n if (status === Statuses.Visited) {\n onStepClick(index);\n } else {\n onSkipToClick(index);\n }\n }}\n variant=\"primary\"\n >\n {step.title}\n </InternalLink>\n ) : (\n <span\n className={clsx(spanClassName, analyticsSelectors['step-title'])}\n aria-current={status === Statuses.Active ? 'step' : undefined}\n aria-disabled={status === Statuses.Active ? undefined : 'true'}\n >\n {step.title}\n </span>\n )}\n </div>\n </li>\n );\n}\n"]}
|
|
1
|
+
{"version":3,"file":"wizard-navigation.js","sourceRoot":"","sources":["../../../src/wizard/wizard-navigation.tsx"],"names":[],"mappings":"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","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport React from 'react';\nimport clsx from 'clsx';\n\nimport { useUniqueId } from '@cloudscape-design/component-toolkit/internal';\n\nimport InternalBox from '../box/internal';\nimport { useVisualRefresh } from '../internal/hooks/use-visual-mode';\nimport InternalLink from '../link/internal';\nimport { getNavigationActionDetail } from './analytics-metadata/utils';\nimport { WizardProps } from './interfaces';\nimport WizardStepList, { getStepStatus, StepStatus, StepStatusValues } from './wizard-step-list';\n\nimport analyticsSelectors from './analytics-metadata/styles.css.js';\nimport styles from './styles.css.js';\n\ninterface NavigationProps {\n activeStepIndex: number;\n farthestStepIndex: number;\n allowSkipTo: boolean;\n hidden: boolean;\n i18nStrings: WizardProps.I18nStrings;\n isLoadingNextStep: boolean;\n onStepClick: (stepIndex: number) => void;\n onSkipToClick: (stepIndex: number) => void;\n steps: ReadonlyArray<WizardProps.Step>;\n}\n\ninterface NavigationStepProps {\n i18nStrings: WizardProps.I18nStrings;\n index: number;\n onStepClick: (stepIndex: number) => void;\n onSkipToClick: (stepIndex: number) => void;\n status: StepStatus;\n step: WizardProps.Step;\n}\n\nexport default function Navigation({\n activeStepIndex,\n farthestStepIndex,\n allowSkipTo,\n hidden,\n i18nStrings,\n isLoadingNextStep,\n onStepClick,\n onSkipToClick,\n steps,\n}: NavigationProps) {\n const isVisualRefresh = useVisualRefresh();\n\n return (\n <nav\n className={clsx(styles.navigation, hidden && styles.hidden, isVisualRefresh && styles.refresh)}\n aria-label={i18nStrings.navigationAriaLabel}\n >\n {isVisualRefresh ? (\n <WizardStepList\n activeStepIndex={activeStepIndex}\n farthestStepIndex={farthestStepIndex}\n allowSkipTo={allowSkipTo}\n i18nStrings={i18nStrings}\n isLoadingNextStep={isLoadingNextStep}\n onStepClick={onStepClick}\n onSkipToClick={onSkipToClick}\n steps={steps}\n />\n ) : (\n <ul>\n {steps.map((step, index: number) => {\n const status = getStepStatus(\n index,\n activeStepIndex,\n farthestStepIndex,\n isLoadingNextStep,\n allowSkipTo,\n steps\n );\n return (\n <NavigationStepClassic\n i18nStrings={i18nStrings}\n index={index}\n key={index}\n onStepClick={onStepClick}\n onSkipToClick={onSkipToClick}\n status={status}\n step={step}\n />\n );\n })}\n </ul>\n )}\n </nav>\n );\n}\n\nfunction NavigationStepClassic({ i18nStrings, index, onStepClick, onSkipToClick, status, step }: NavigationStepProps) {\n const spanClassName = clsx(\n styles['navigation-link'],\n status === StepStatusValues.Active ? styles['navigation-link-active'] : styles['navigation-link-disabled']\n );\n const optionalDescriptionId = useUniqueId('wizard-step-optional-');\n\n return (\n <li\n className={styles['navigation-link-item']}\n {...(status === StepStatusValues.Unvisited\n ? {}\n : getNavigationActionDetail(index, 'step', true, `.${analyticsSelectors['step-title']}`))}\n >\n <InternalBox\n variant=\"small\"\n className={styles['navigation-link-label']}\n display=\"block\"\n margin={{ bottom: 'xxs' }}\n >\n {i18nStrings.stepNumberLabel && i18nStrings.stepNumberLabel(index + 1)}\n {step.isOptional && <i id={optionalDescriptionId}>{` - ${i18nStrings.optional}`}</i>}\n </InternalBox>\n <div>\n {status === StepStatusValues.Visited || status === StepStatusValues.Next ? (\n <InternalLink\n className={clsx(styles['navigation-link'], analyticsSelectors['step-title'])}\n onFollow={evt => {\n evt.preventDefault();\n if (status === StepStatusValues.Visited) {\n onStepClick(index);\n } else {\n onSkipToClick(index);\n }\n }}\n variant=\"primary\"\n nativeAttributes={step.isOptional ? { 'aria-describedby': optionalDescriptionId } : undefined}\n >\n {step.title}\n </InternalLink>\n ) : (\n <span\n className={clsx(spanClassName, analyticsSelectors['step-title'])}\n aria-current={status === StepStatusValues.Active ? 'step' : undefined}\n aria-disabled={status === StepStatusValues.Active ? undefined : 'true'}\n aria-describedby={step.isOptional ? optionalDescriptionId : undefined}\n >\n {step.title}\n </span>\n )}\n </div>\n </li>\n );\n}\n"]}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { WizardProps } from './interfaces';
|
|
2
|
+
export declare const StepStatusValues: {
|
|
3
|
+
readonly Active: "active";
|
|
4
|
+
readonly Visited: "visited";
|
|
5
|
+
readonly Unvisited: "unvisited";
|
|
6
|
+
readonly Next: "next";
|
|
7
|
+
};
|
|
8
|
+
export type StepStatus = (typeof StepStatusValues)[keyof typeof StepStatusValues];
|
|
9
|
+
export interface WizardStepListProps {
|
|
10
|
+
activeStepIndex: number;
|
|
11
|
+
farthestStepIndex: number;
|
|
12
|
+
allowSkipTo: boolean;
|
|
13
|
+
i18nStrings: WizardProps.I18nStrings;
|
|
14
|
+
isLoadingNextStep: boolean;
|
|
15
|
+
onStepClick: (stepIndex: number) => void;
|
|
16
|
+
onSkipToClick: (stepIndex: number) => void;
|
|
17
|
+
steps: ReadonlyArray<WizardProps.Step>;
|
|
18
|
+
}
|
|
19
|
+
export declare function getStepStatus(index: number, activeStepIndex: number, farthestStepIndex: number, isLoadingNextStep: boolean, allowSkipTo: boolean, steps: ReadonlyArray<{
|
|
20
|
+
isOptional?: boolean;
|
|
21
|
+
}>): StepStatus;
|
|
22
|
+
export declare function canSkip(fromIndex: number, toIndex: number, steps: ReadonlyArray<{
|
|
23
|
+
isOptional?: boolean;
|
|
24
|
+
}>): boolean;
|
|
25
|
+
export declare function handleStepNavigation(stepIndex: number, status: StepStatus, onStepClick: (index: number) => void, onSkipToClick: (index: number) => void): void;
|
|
26
|
+
export default function WizardStepList({ activeStepIndex, farthestStepIndex, allowSkipTo, i18nStrings, isLoadingNextStep, onStepClick, onSkipToClick, steps, }: WizardStepListProps): JSX.Element;
|
|
27
|
+
//# sourceMappingURL=wizard-step-list.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wizard-step-list.d.ts","sourceRoot":"","sources":["../../../src/wizard/wizard-step-list.tsx"],"names":[],"mappings":"AAQA,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAK3C,eAAO,MAAM,gBAAgB;;;;;CAKnB,CAAC;AAEX,MAAM,MAAM,UAAU,GAAG,CAAC,OAAO,gBAAgB,CAAC,CAAC,MAAM,OAAO,gBAAgB,CAAC,CAAC;AAElF,MAAM,WAAW,mBAAmB;IAClC,eAAe,EAAE,MAAM,CAAC;IACxB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,WAAW,EAAE,OAAO,CAAC;IACrB,WAAW,EAAE,WAAW,CAAC,WAAW,CAAC;IACrC,iBAAiB,EAAE,OAAO,CAAC;IAC3B,WAAW,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IACzC,aAAa,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IAC3C,KAAK,EAAE,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;CACxC;AAED,wBAAgB,aAAa,CAC3B,KAAK,EAAE,MAAM,EACb,eAAe,EAAE,MAAM,EACvB,iBAAiB,EAAE,MAAM,EACzB,iBAAiB,EAAE,OAAO,EAC1B,WAAW,EAAE,OAAO,EACpB,KAAK,EAAE,aAAa,CAAC;IAAE,UAAU,CAAC,EAAE,OAAO,CAAA;CAAE,CAAC,GAC7C,UAAU,CAqBZ;AAED,wBAAgB,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,aAAa,CAAC;IAAE,UAAU,CAAC,EAAE,OAAO,CAAA;CAAE,CAAC,GAAG,OAAO,CAWnH;AAED,wBAAgB,oBAAoB,CAClC,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,UAAU,EAClB,WAAW,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,EACpC,aAAa,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,GACrC,IAAI,CAMN;AAED,MAAM,CAAC,OAAO,UAAU,cAAc,CAAC,EACrC,eAAe,EACf,iBAAiB,EACjB,WAAW,EACX,WAAW,EACX,iBAAiB,EACjB,WAAW,EACX,aAAa,EACb,KAAK,GACN,EAAE,mBAAmB,eAoBrB"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import clsx from 'clsx';
|
|
5
|
+
import { useUniqueId } from '@cloudscape-design/component-toolkit/internal';
|
|
6
|
+
import { getNavigationActionDetail } from './analytics-metadata/utils';
|
|
7
|
+
import analyticsSelectors from './analytics-metadata/styles.css.js';
|
|
8
|
+
import styles from './styles.css.js';
|
|
9
|
+
export const StepStatusValues = {
|
|
10
|
+
Active: 'active',
|
|
11
|
+
Visited: 'visited',
|
|
12
|
+
Unvisited: 'unvisited',
|
|
13
|
+
Next: 'next',
|
|
14
|
+
};
|
|
15
|
+
export function getStepStatus(index, activeStepIndex, farthestStepIndex, isLoadingNextStep, allowSkipTo, steps) {
|
|
16
|
+
var _a;
|
|
17
|
+
if (activeStepIndex === index) {
|
|
18
|
+
return StepStatusValues.Active;
|
|
19
|
+
}
|
|
20
|
+
if (isLoadingNextStep) {
|
|
21
|
+
return StepStatusValues.Unvisited;
|
|
22
|
+
}
|
|
23
|
+
if (farthestStepIndex >= index) {
|
|
24
|
+
return StepStatusValues.Visited;
|
|
25
|
+
}
|
|
26
|
+
if (allowSkipTo && index > activeStepIndex) {
|
|
27
|
+
// Can we skip to this step? (all steps between current and this one are optional)
|
|
28
|
+
if (canSkip(activeStepIndex + 1, index, steps)) {
|
|
29
|
+
return StepStatusValues.Next;
|
|
30
|
+
}
|
|
31
|
+
// Immediate next step is also navigable if it's optional
|
|
32
|
+
if (index === activeStepIndex + 1 && ((_a = steps[index]) === null || _a === void 0 ? void 0 : _a.isOptional)) {
|
|
33
|
+
return StepStatusValues.Next;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
return StepStatusValues.Unvisited;
|
|
37
|
+
}
|
|
38
|
+
export function canSkip(fromIndex, toIndex, steps) {
|
|
39
|
+
// Can't skip if there are no steps to skip over
|
|
40
|
+
if (fromIndex >= toIndex) {
|
|
41
|
+
return false;
|
|
42
|
+
}
|
|
43
|
+
for (let i = fromIndex; i < toIndex; i++) {
|
|
44
|
+
if (!steps[i].isOptional) {
|
|
45
|
+
return false;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
return true;
|
|
49
|
+
}
|
|
50
|
+
export function handleStepNavigation(stepIndex, status, onStepClick, onSkipToClick) {
|
|
51
|
+
if (status === StepStatusValues.Visited) {
|
|
52
|
+
onStepClick(stepIndex);
|
|
53
|
+
}
|
|
54
|
+
else if (status === StepStatusValues.Next) {
|
|
55
|
+
onSkipToClick(stepIndex);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
export default function WizardStepList({ activeStepIndex, farthestStepIndex, allowSkipTo, i18nStrings, isLoadingNextStep, onStepClick, onSkipToClick, steps, }) {
|
|
59
|
+
return (React.createElement("ul", { className: styles.refresh }, steps.map((step, index) => (React.createElement(WizardStepListItem, { key: index, index: index, step: step, activeStepIndex: activeStepIndex, farthestStepIndex: farthestStepIndex, allowSkipTo: allowSkipTo, i18nStrings: i18nStrings, isLoadingNextStep: isLoadingNextStep, onStepClick: onStepClick, onSkipToClick: onSkipToClick, steps: steps })))));
|
|
60
|
+
}
|
|
61
|
+
function WizardStepListItem({ index, step, activeStepIndex, farthestStepIndex, allowSkipTo, i18nStrings, isLoadingNextStep, onStepClick, onSkipToClick, steps, }) {
|
|
62
|
+
var _a, _b;
|
|
63
|
+
const status = getStepStatus(index, activeStepIndex, farthestStepIndex, isLoadingNextStep, allowSkipTo, steps);
|
|
64
|
+
const isClickable = status === StepStatusValues.Visited || status === StepStatusValues.Next;
|
|
65
|
+
const stepLabel = (_a = i18nStrings.stepNumberLabel) === null || _a === void 0 ? void 0 : _a.call(i18nStrings, index + 1);
|
|
66
|
+
const fullStepLabel = `${stepLabel}: ${step.title}`;
|
|
67
|
+
const optionalDescriptionId = useUniqueId('wizard-step-optional-');
|
|
68
|
+
const state = {
|
|
69
|
+
active: 'active',
|
|
70
|
+
unvisited: 'disabled',
|
|
71
|
+
visited: 'enabled',
|
|
72
|
+
next: 'enabled',
|
|
73
|
+
}[status];
|
|
74
|
+
const handleInteraction = () => handleStepNavigation(index, status, onStepClick, onSkipToClick);
|
|
75
|
+
return (React.createElement("li", { className: clsx(styles[`${state}`], styles['navigation-link-item']) },
|
|
76
|
+
React.createElement("hr", null),
|
|
77
|
+
React.createElement("span", { className: clsx(styles.number, styles['navigation-link-label']) }, (_b = i18nStrings.stepNumberLabel) === null || _b === void 0 ? void 0 :
|
|
78
|
+
_b.call(i18nStrings, index + 1),
|
|
79
|
+
step.isOptional && React.createElement("i", { id: optionalDescriptionId }, ` - ${i18nStrings.optional}`)),
|
|
80
|
+
React.createElement("a", { className: clsx(styles['navigation-link'], {
|
|
81
|
+
[styles['navigation-link-active']]: status === StepStatusValues.Active,
|
|
82
|
+
[styles['navigation-link-disabled']]: status === StepStatusValues.Unvisited,
|
|
83
|
+
}), "aria-current": status === StepStatusValues.Active ? 'step' : undefined, "aria-disabled": status === StepStatusValues.Unvisited ? 'true' : undefined, onClick: event => {
|
|
84
|
+
event.preventDefault();
|
|
85
|
+
handleInteraction();
|
|
86
|
+
}, onKeyDown: event => {
|
|
87
|
+
if (event.key === ' ' || event.key === 'Enter') {
|
|
88
|
+
event.preventDefault();
|
|
89
|
+
}
|
|
90
|
+
// Enter activates the button on key down instead of key up.
|
|
91
|
+
if (event.key === 'Enter') {
|
|
92
|
+
handleInteraction();
|
|
93
|
+
}
|
|
94
|
+
}, onKeyUp: event => {
|
|
95
|
+
// Emulate button behavior, which also fires on space.
|
|
96
|
+
if (event.key === ' ') {
|
|
97
|
+
handleInteraction();
|
|
98
|
+
}
|
|
99
|
+
}, role: "button", tabIndex: isClickable ? 0 : undefined, "aria-label": fullStepLabel, "aria-describedby": step.isOptional ? optionalDescriptionId : undefined, ...(status === StepStatusValues.Unvisited
|
|
100
|
+
? {}
|
|
101
|
+
: getNavigationActionDetail(index, 'step', true, `.${analyticsSelectors['step-title']}`)) },
|
|
102
|
+
React.createElement("div", { className: styles.circle }),
|
|
103
|
+
React.createElement("span", { className: clsx(styles.title, analyticsSelectors['step-title']) }, step.title))));
|
|
104
|
+
}
|
|
105
|
+
//# sourceMappingURL=wizard-step-list.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wizard-step-list.js","sourceRoot":"","sources":["../../../src/wizard/wizard-step-list.tsx"],"names":[],"mappings":"AAAA,qEAAqE;AACrE,sCAAsC;AACtC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,IAAI,MAAM,MAAM,CAAC;AAExB,OAAO,EAAE,WAAW,EAAE,MAAM,+CAA+C,CAAC;AAE5E,OAAO,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAC;AAGvE,OAAO,kBAAkB,MAAM,oCAAoC,CAAC;AACpE,OAAO,MAAM,MAAM,iBAAiB,CAAC;AAErC,MAAM,CAAC,MAAM,gBAAgB,GAAG;IAC9B,MAAM,EAAE,QAAQ;IAChB,OAAO,EAAE,SAAS;IAClB,SAAS,EAAE,WAAW;IACtB,IAAI,EAAE,MAAM;CACJ,CAAC;AAeX,MAAM,UAAU,aAAa,CAC3B,KAAa,EACb,eAAuB,EACvB,iBAAyB,EACzB,iBAA0B,EAC1B,WAAoB,EACpB,KAA8C;;IAE9C,IAAI,eAAe,KAAK,KAAK,EAAE,CAAC;QAC9B,OAAO,gBAAgB,CAAC,MAAM,CAAC;IACjC,CAAC;IACD,IAAI,iBAAiB,EAAE,CAAC;QACtB,OAAO,gBAAgB,CAAC,SAAS,CAAC;IACpC,CAAC;IACD,IAAI,iBAAiB,IAAI,KAAK,EAAE,CAAC;QAC/B,OAAO,gBAAgB,CAAC,OAAO,CAAC;IAClC,CAAC;IACD,IAAI,WAAW,IAAI,KAAK,GAAG,eAAe,EAAE,CAAC;QAC3C,kFAAkF;QAClF,IAAI,OAAO,CAAC,eAAe,GAAG,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,EAAE,CAAC;YAC/C,OAAO,gBAAgB,CAAC,IAAI,CAAC;QAC/B,CAAC;QACD,yDAAyD;QACzD,IAAI,KAAK,KAAK,eAAe,GAAG,CAAC,KAAI,MAAA,KAAK,CAAC,KAAK,CAAC,0CAAE,UAAU,CAAA,EAAE,CAAC;YAC9D,OAAO,gBAAgB,CAAC,IAAI,CAAC;QAC/B,CAAC;IACH,CAAC;IACD,OAAO,gBAAgB,CAAC,SAAS,CAAC;AACpC,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,SAAiB,EAAE,OAAe,EAAE,KAA8C;IACxG,gDAAgD;IAChD,IAAI,SAAS,IAAI,OAAO,EAAE,CAAC;QACzB,OAAO,KAAK,CAAC;IACf,CAAC;IACD,KAAK,IAAI,CAAC,GAAG,SAAS,EAAE,CAAC,GAAG,OAAO,EAAE,CAAC,EAAE,EAAE,CAAC;QACzC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC;YACzB,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,UAAU,oBAAoB,CAClC,SAAiB,EACjB,MAAkB,EAClB,WAAoC,EACpC,aAAsC;IAEtC,IAAI,MAAM,KAAK,gBAAgB,CAAC,OAAO,EAAE,CAAC;QACxC,WAAW,CAAC,SAAS,CAAC,CAAC;IACzB,CAAC;SAAM,IAAI,MAAM,KAAK,gBAAgB,CAAC,IAAI,EAAE,CAAC;QAC5C,aAAa,CAAC,SAAS,CAAC,CAAC;IAC3B,CAAC;AACH,CAAC;AAED,MAAM,CAAC,OAAO,UAAU,cAAc,CAAC,EACrC,eAAe,EACf,iBAAiB,EACjB,WAAW,EACX,WAAW,EACX,iBAAiB,EACjB,WAAW,EACX,aAAa,EACb,KAAK,GACe;IACpB,OAAO,CACL,4BAAI,SAAS,EAAE,MAAM,CAAC,OAAO,IAC1B,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAC1B,oBAAC,kBAAkB,IACjB,GAAG,EAAE,KAAK,EACV,KAAK,EAAE,KAAK,EACZ,IAAI,EAAE,IAAI,EACV,eAAe,EAAE,eAAe,EAChC,iBAAiB,EAAE,iBAAiB,EACpC,WAAW,EAAE,WAAW,EACxB,WAAW,EAAE,WAAW,EACxB,iBAAiB,EAAE,iBAAiB,EACpC,WAAW,EAAE,WAAW,EACxB,aAAa,EAAE,aAAa,EAC5B,KAAK,EAAE,KAAK,GACZ,CACH,CAAC,CACC,CACN,CAAC;AACJ,CAAC;AAeD,SAAS,kBAAkB,CAAC,EAC1B,KAAK,EACL,IAAI,EACJ,eAAe,EACf,iBAAiB,EACjB,WAAW,EACX,WAAW,EACX,iBAAiB,EACjB,WAAW,EACX,aAAa,EACb,KAAK,GACmB;;IACxB,MAAM,MAAM,GAAG,aAAa,CAAC,KAAK,EAAE,eAAe,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,WAAW,EAAE,KAAK,CAAC,CAAC;IAC/G,MAAM,WAAW,GAAG,MAAM,KAAK,gBAAgB,CAAC,OAAO,IAAI,MAAM,KAAK,gBAAgB,CAAC,IAAI,CAAC;IAC5F,MAAM,SAAS,GAAG,MAAA,WAAW,CAAC,eAAe,4DAAG,KAAK,GAAG,CAAC,CAAC,CAAC;IAC3D,MAAM,aAAa,GAAG,GAAG,SAAS,KAAK,IAAI,CAAC,KAAK,EAAE,CAAC;IACpD,MAAM,qBAAqB,GAAG,WAAW,CAAC,uBAAuB,CAAC,CAAC;IACnE,MAAM,KAAK,GAAG;QACZ,MAAM,EAAE,QAAQ;QAChB,SAAS,EAAE,UAAU;QACrB,OAAO,EAAE,SAAS;QAClB,IAAI,EAAE,SAAS;KAChB,CAAC,MAAM,CAAC,CAAC;IAEV,MAAM,iBAAiB,GAAG,GAAG,EAAE,CAAC,oBAAoB,CAAC,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,aAAa,CAAC,CAAC;IAEhG,OAAO,CACL,4BAAI,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,MAAM,CAAC,sBAAsB,CAAC,CAAC;QACrE,+BAAM;QAEN,8BAAM,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,uBAAuB,CAAC,CAAC,IAClE,MAAA,WAAW,CAAC,eAAe;iCAAG,KAAK,GAAG,CAAC,CAAC;YACxC,IAAI,CAAC,UAAU,IAAI,2BAAG,EAAE,EAAE,qBAAqB,IAAG,MAAM,WAAW,CAAC,QAAQ,EAAE,CAAK,CAC/E;QAEP,2BACE,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,EAAE;gBACzC,CAAC,MAAM,CAAC,wBAAwB,CAAC,CAAC,EAAE,MAAM,KAAK,gBAAgB,CAAC,MAAM;gBACtE,CAAC,MAAM,CAAC,0BAA0B,CAAC,CAAC,EAAE,MAAM,KAAK,gBAAgB,CAAC,SAAS;aAC5E,CAAC,kBACY,MAAM,KAAK,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,mBACtD,MAAM,KAAK,gBAAgB,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,EACzE,OAAO,EAAE,KAAK,CAAC,EAAE;gBACf,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,iBAAiB,EAAE,CAAC;YACtB,CAAC,EACD,SAAS,EAAE,KAAK,CAAC,EAAE;gBACjB,IAAI,KAAK,CAAC,GAAG,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,EAAE,CAAC;oBAC/C,KAAK,CAAC,cAAc,EAAE,CAAC;gBACzB,CAAC;gBACD,4DAA4D;gBAC5D,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,EAAE,CAAC;oBAC1B,iBAAiB,EAAE,CAAC;gBACtB,CAAC;YACH,CAAC,EACD,OAAO,EAAE,KAAK,CAAC,EAAE;gBACf,sDAAsD;gBACtD,IAAI,KAAK,CAAC,GAAG,KAAK,GAAG,EAAE,CAAC;oBACtB,iBAAiB,EAAE,CAAC;gBACtB,CAAC;YACH,CAAC,EACD,IAAI,EAAC,QAAQ,EACb,QAAQ,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,gBACzB,aAAa,sBACP,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,SAAS,KACjE,CAAC,MAAM,KAAK,gBAAgB,CAAC,SAAS;gBACxC,CAAC,CAAC,EAAE;gBACJ,CAAC,CAAC,yBAAyB,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,kBAAkB,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;YAE3F,6BAAK,SAAS,EAAE,MAAM,CAAC,MAAM,GAAI;YAEjC,8BAAM,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,kBAAkB,CAAC,YAAY,CAAC,CAAC,IAAG,IAAI,CAAC,KAAK,CAAQ,CACxF,CACD,CACN,CAAC;AACJ,CAAC","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport React from 'react';\nimport clsx from 'clsx';\n\nimport { useUniqueId } from '@cloudscape-design/component-toolkit/internal';\n\nimport { getNavigationActionDetail } from './analytics-metadata/utils';\nimport { WizardProps } from './interfaces';\n\nimport analyticsSelectors from './analytics-metadata/styles.css.js';\nimport styles from './styles.css.js';\n\nexport const StepStatusValues = {\n Active: 'active',\n Visited: 'visited',\n Unvisited: 'unvisited',\n Next: 'next',\n} as const;\n\nexport type StepStatus = (typeof StepStatusValues)[keyof typeof StepStatusValues];\n\nexport interface WizardStepListProps {\n activeStepIndex: number;\n farthestStepIndex: number;\n allowSkipTo: boolean;\n i18nStrings: WizardProps.I18nStrings;\n isLoadingNextStep: boolean;\n onStepClick: (stepIndex: number) => void;\n onSkipToClick: (stepIndex: number) => void;\n steps: ReadonlyArray<WizardProps.Step>;\n}\n\nexport function getStepStatus(\n index: number,\n activeStepIndex: number,\n farthestStepIndex: number,\n isLoadingNextStep: boolean,\n allowSkipTo: boolean,\n steps: ReadonlyArray<{ isOptional?: boolean }>\n): StepStatus {\n if (activeStepIndex === index) {\n return StepStatusValues.Active;\n }\n if (isLoadingNextStep) {\n return StepStatusValues.Unvisited;\n }\n if (farthestStepIndex >= index) {\n return StepStatusValues.Visited;\n }\n if (allowSkipTo && index > activeStepIndex) {\n // Can we skip to this step? (all steps between current and this one are optional)\n if (canSkip(activeStepIndex + 1, index, steps)) {\n return StepStatusValues.Next;\n }\n // Immediate next step is also navigable if it's optional\n if (index === activeStepIndex + 1 && steps[index]?.isOptional) {\n return StepStatusValues.Next;\n }\n }\n return StepStatusValues.Unvisited;\n}\n\nexport function canSkip(fromIndex: number, toIndex: number, steps: ReadonlyArray<{ isOptional?: boolean }>): boolean {\n // Can't skip if there are no steps to skip over\n if (fromIndex >= toIndex) {\n return false;\n }\n for (let i = fromIndex; i < toIndex; i++) {\n if (!steps[i].isOptional) {\n return false;\n }\n }\n return true;\n}\n\nexport function handleStepNavigation(\n stepIndex: number,\n status: StepStatus,\n onStepClick: (index: number) => void,\n onSkipToClick: (index: number) => void\n): void {\n if (status === StepStatusValues.Visited) {\n onStepClick(stepIndex);\n } else if (status === StepStatusValues.Next) {\n onSkipToClick(stepIndex);\n }\n}\n\nexport default function WizardStepList({\n activeStepIndex,\n farthestStepIndex,\n allowSkipTo,\n i18nStrings,\n isLoadingNextStep,\n onStepClick,\n onSkipToClick,\n steps,\n}: WizardStepListProps) {\n return (\n <ul className={styles.refresh}>\n {steps.map((step, index) => (\n <WizardStepListItem\n key={index}\n index={index}\n step={step}\n activeStepIndex={activeStepIndex}\n farthestStepIndex={farthestStepIndex}\n allowSkipTo={allowSkipTo}\n i18nStrings={i18nStrings}\n isLoadingNextStep={isLoadingNextStep}\n onStepClick={onStepClick}\n onSkipToClick={onSkipToClick}\n steps={steps}\n />\n ))}\n </ul>\n );\n}\n\ninterface WizardStepListItemProps {\n index: number;\n step: WizardProps.Step;\n activeStepIndex: number;\n farthestStepIndex: number;\n allowSkipTo: boolean;\n i18nStrings: WizardProps.I18nStrings;\n isLoadingNextStep: boolean;\n onStepClick: (stepIndex: number) => void;\n onSkipToClick: (stepIndex: number) => void;\n steps: ReadonlyArray<WizardProps.Step>;\n}\n\nfunction WizardStepListItem({\n index,\n step,\n activeStepIndex,\n farthestStepIndex,\n allowSkipTo,\n i18nStrings,\n isLoadingNextStep,\n onStepClick,\n onSkipToClick,\n steps,\n}: WizardStepListItemProps) {\n const status = getStepStatus(index, activeStepIndex, farthestStepIndex, isLoadingNextStep, allowSkipTo, steps);\n const isClickable = status === StepStatusValues.Visited || status === StepStatusValues.Next;\n const stepLabel = i18nStrings.stepNumberLabel?.(index + 1);\n const fullStepLabel = `${stepLabel}: ${step.title}`;\n const optionalDescriptionId = useUniqueId('wizard-step-optional-');\n const state = {\n active: 'active',\n unvisited: 'disabled',\n visited: 'enabled',\n next: 'enabled',\n }[status];\n\n const handleInteraction = () => handleStepNavigation(index, status, onStepClick, onSkipToClick);\n\n return (\n <li className={clsx(styles[`${state}`], styles['navigation-link-item'])}>\n <hr />\n\n <span className={clsx(styles.number, styles['navigation-link-label'])}>\n {i18nStrings.stepNumberLabel?.(index + 1)}\n {step.isOptional && <i id={optionalDescriptionId}>{` - ${i18nStrings.optional}`}</i>}\n </span>\n\n <a\n className={clsx(styles['navigation-link'], {\n [styles['navigation-link-active']]: status === StepStatusValues.Active,\n [styles['navigation-link-disabled']]: status === StepStatusValues.Unvisited,\n })}\n aria-current={status === StepStatusValues.Active ? 'step' : undefined}\n aria-disabled={status === StepStatusValues.Unvisited ? 'true' : undefined}\n onClick={event => {\n event.preventDefault();\n handleInteraction();\n }}\n onKeyDown={event => {\n if (event.key === ' ' || event.key === 'Enter') {\n event.preventDefault();\n }\n // Enter activates the button on key down instead of key up.\n if (event.key === 'Enter') {\n handleInteraction();\n }\n }}\n onKeyUp={event => {\n // Emulate button behavior, which also fires on space.\n if (event.key === ' ') {\n handleInteraction();\n }\n }}\n role=\"button\"\n tabIndex={isClickable ? 0 : undefined}\n aria-label={fullStepLabel}\n aria-describedby={step.isOptional ? optionalDescriptionId : undefined}\n {...(status === StepStatusValues.Unvisited\n ? {}\n : getNavigationActionDetail(index, 'step', true, `.${analyticsSelectors['step-title']}`))}\n >\n <div className={styles.circle} />\n\n <span className={clsx(styles.title, analyticsSelectors['step-title'])}>{step.title}</span>\n </a>\n </li>\n );\n}\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { WizardProps } from './interfaces';
|
|
2
|
+
interface WizardStepNavigationExpandableProps {
|
|
3
|
+
activeStepIndex: number;
|
|
4
|
+
farthestStepIndex: number;
|
|
5
|
+
allowSkipTo: boolean;
|
|
6
|
+
i18nStrings: WizardProps.I18nStrings;
|
|
7
|
+
isLoadingNextStep: boolean;
|
|
8
|
+
onStepClick: (stepIndex: number) => void;
|
|
9
|
+
onSkipToClick: (stepIndex: number) => void;
|
|
10
|
+
steps: ReadonlyArray<WizardProps.Step>;
|
|
11
|
+
expanded: boolean;
|
|
12
|
+
onExpandChange: (expanded: boolean) => void;
|
|
13
|
+
}
|
|
14
|
+
export default function WizardStepNavigationExpandable({ activeStepIndex, farthestStepIndex, allowSkipTo, i18nStrings, isLoadingNextStep, onStepClick, onSkipToClick, steps, expanded, onExpandChange, }: WizardStepNavigationExpandableProps): JSX.Element;
|
|
15
|
+
export {};
|
|
16
|
+
//# sourceMappingURL=wizard-step-navigation-expandable.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wizard-step-navigation-expandable.d.ts","sourceRoot":"","sources":["../../../src/wizard/wizard-step-navigation-expandable.tsx"],"names":[],"mappings":"AAMA,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAK3C,UAAU,mCAAmC;IAC3C,eAAe,EAAE,MAAM,CAAC;IACxB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,WAAW,EAAE,OAAO,CAAC;IACrB,WAAW,EAAE,WAAW,CAAC,WAAW,CAAC;IACrC,iBAAiB,EAAE,OAAO,CAAC;IAC3B,WAAW,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IACzC,aAAa,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IAC3C,KAAK,EAAE,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IACvC,QAAQ,EAAE,OAAO,CAAC;IAClB,cAAc,EAAE,CAAC,QAAQ,EAAE,OAAO,KAAK,IAAI,CAAC;CAC7C;AAED,MAAM,CAAC,OAAO,UAAU,8BAA8B,CAAC,EACrD,eAAe,EACf,iBAAiB,EACjB,WAAW,EACX,WAAW,EACX,iBAAiB,EACjB,WAAW,EACX,aAAa,EACb,KAAK,EACL,QAAQ,EACR,cAAc,GACf,EAAE,mCAAmC,eA+BrC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import clsx from 'clsx';
|
|
5
|
+
import InternalExpandableSection from '../expandable-section/internal';
|
|
6
|
+
import WizardStepList from './wizard-step-list';
|
|
7
|
+
import styles from './styles.css.js';
|
|
8
|
+
export default function WizardStepNavigationExpandable({ activeStepIndex, farthestStepIndex, allowSkipTo, i18nStrings, isLoadingNextStep, onStepClick, onSkipToClick, steps, expanded, onExpandChange, }) {
|
|
9
|
+
var _a, _b;
|
|
10
|
+
const collapsedStepsLabel = (_a = i18nStrings.collapsedStepsLabel) === null || _a === void 0 ? void 0 : _a.call(i18nStrings, activeStepIndex + 1, steps.length);
|
|
11
|
+
const headerAriaLabel = collapsedStepsLabel
|
|
12
|
+
? `${collapsedStepsLabel} - ${(_b = i18nStrings.navigationAriaLabel) !== null && _b !== void 0 ? _b : 'Steps'}`
|
|
13
|
+
: undefined;
|
|
14
|
+
return (React.createElement(InternalExpandableSection, { variant: "footer", headerText: collapsedStepsLabel, headerAriaLabel: headerAriaLabel, expanded: expanded, onChange: ({ detail }) => onExpandChange(detail.expanded) },
|
|
15
|
+
React.createElement("nav", { className: clsx(styles.navigation, styles.refresh, styles['collapsed-steps-navigation']), "aria-label": i18nStrings.navigationAriaLabel },
|
|
16
|
+
React.createElement(WizardStepList, { activeStepIndex: activeStepIndex, farthestStepIndex: farthestStepIndex, allowSkipTo: allowSkipTo, i18nStrings: i18nStrings, isLoadingNextStep: isLoadingNextStep, onStepClick: onStepClick, onSkipToClick: onSkipToClick, steps: steps }))));
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=wizard-step-navigation-expandable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wizard-step-navigation-expandable.js","sourceRoot":"","sources":["../../../src/wizard/wizard-step-navigation-expandable.tsx"],"names":[],"mappings":"AAAA,qEAAqE;AACrE,sCAAsC;AACtC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,IAAI,MAAM,MAAM,CAAC;AAExB,OAAO,yBAAyB,MAAM,gCAAgC,CAAC;AAEvE,OAAO,cAAc,MAAM,oBAAoB,CAAC;AAEhD,OAAO,MAAM,MAAM,iBAAiB,CAAC;AAerC,MAAM,CAAC,OAAO,UAAU,8BAA8B,CAAC,EACrD,eAAe,EACf,iBAAiB,EACjB,WAAW,EACX,WAAW,EACX,iBAAiB,EACjB,WAAW,EACX,aAAa,EACb,KAAK,EACL,QAAQ,EACR,cAAc,GACsB;;IACpC,MAAM,mBAAmB,GAAG,MAAA,WAAW,CAAC,mBAAmB,4DAAG,eAAe,GAAG,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IACjG,MAAM,eAAe,GAAG,mBAAmB;QACzC,CAAC,CAAC,GAAG,mBAAmB,MAAM,MAAA,WAAW,CAAC,mBAAmB,mCAAI,OAAO,EAAE;QAC1E,CAAC,CAAC,SAAS,CAAC;IAEd,OAAO,CACL,oBAAC,yBAAyB,IACxB,OAAO,EAAC,QAAQ,EAChB,UAAU,EAAE,mBAAmB,EAC/B,eAAe,EAAE,eAAe,EAChC,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,cAAc,CAAC,MAAM,CAAC,QAAQ,CAAC;QAEzD,6BACE,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,4BAA4B,CAAC,CAAC,gBAC5E,WAAW,CAAC,mBAAmB;YAE3C,oBAAC,cAAc,IACb,eAAe,EAAE,eAAe,EAChC,iBAAiB,EAAE,iBAAiB,EACpC,WAAW,EAAE,WAAW,EACxB,WAAW,EAAE,WAAW,EACxB,iBAAiB,EAAE,iBAAiB,EACpC,WAAW,EAAE,WAAW,EACxB,aAAa,EAAE,aAAa,EAC5B,KAAK,EAAE,KAAK,GACZ,CACE,CACoB,CAC7B,CAAC;AACJ,CAAC","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport React from 'react';\nimport clsx from 'clsx';\n\nimport InternalExpandableSection from '../expandable-section/internal';\nimport { WizardProps } from './interfaces';\nimport WizardStepList from './wizard-step-list';\n\nimport styles from './styles.css.js';\n\ninterface WizardStepNavigationExpandableProps {\n activeStepIndex: number;\n farthestStepIndex: number;\n allowSkipTo: boolean;\n i18nStrings: WizardProps.I18nStrings;\n isLoadingNextStep: boolean;\n onStepClick: (stepIndex: number) => void;\n onSkipToClick: (stepIndex: number) => void;\n steps: ReadonlyArray<WizardProps.Step>;\n expanded: boolean;\n onExpandChange: (expanded: boolean) => void;\n}\n\nexport default function WizardStepNavigationExpandable({\n activeStepIndex,\n farthestStepIndex,\n allowSkipTo,\n i18nStrings,\n isLoadingNextStep,\n onStepClick,\n onSkipToClick,\n steps,\n expanded,\n onExpandChange,\n}: WizardStepNavigationExpandableProps) {\n const collapsedStepsLabel = i18nStrings.collapsedStepsLabel?.(activeStepIndex + 1, steps.length);\n const headerAriaLabel = collapsedStepsLabel\n ? `${collapsedStepsLabel} - ${i18nStrings.navigationAriaLabel ?? 'Steps'}`\n : undefined;\n\n return (\n <InternalExpandableSection\n variant=\"footer\"\n headerText={collapsedStepsLabel}\n headerAriaLabel={headerAriaLabel}\n expanded={expanded}\n onChange={({ detail }) => onExpandChange(detail.expanded)}\n >\n <nav\n className={clsx(styles.navigation, styles.refresh, styles['collapsed-steps-navigation'])}\n aria-label={i18nStrings.navigationAriaLabel}\n >\n <WizardStepList\n activeStepIndex={activeStepIndex}\n farthestStepIndex={farthestStepIndex}\n allowSkipTo={allowSkipTo}\n i18nStrings={i18nStrings}\n isLoadingNextStep={isLoadingNextStep}\n onStepClick={onStepClick}\n onSkipToClick={onSkipToClick}\n steps={steps}\n />\n </nav>\n </InternalExpandableSection>\n );\n}\n"]}
|