@spscommerce/ds-shared 0.0.0-20260319-8230915ce

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md ADDED
@@ -0,0 +1,48 @@
1
+ [//]: # "START_AUTOGENERATED"
2
+
3
+ ## [@spscommerce/ds-shared](https://github.com/spscommerce/design-system/tree/main/packages/@spscommerce/ds-shared#readme)
4
+
5
+ ![release: 1.1.0](https://img.shields.io/badge/release-1.1.0-blue.svg?style=flat-square)
6
+ ![build: passing](https://img.shields.io/badge/build-passing-green.svg?style=flat-square)
7
+ ![tests: failing](https://img.shields.io/badge/tests-failing-red.svg?style=flat-square)
8
+
9
+ Package for sharing code and types between DS Angular and DS React.
10
+
11
+ ### Installation
12
+
13
+ ```shell
14
+ npm install --save @spscommerce/ds-shared
15
+ ```
16
+
17
+ #### Peer Dependencies
18
+
19
+ <div class="row">
20
+ <div class="col-5">
21
+ <table class="sps-table">
22
+ <thead class="sps-table__head">
23
+ <tr class="sps-table__row">
24
+ <th class="sps-table__header">
25
+ <span class="sps-table__header-cell-body">
26
+ Package
27
+ </span>
28
+ </th>
29
+ <th class="sps-table__header text-right">
30
+ <span class="sps-table__header-cell-body">
31
+ Version
32
+ </span>
33
+ </th>
34
+ </tr>
35
+ </thead>
36
+ <tbody class="sps-table__body">
37
+ <tr class="sps-table__row"><td class="sps-table__cell"><a href="https://github.com/spscommerce/design-system/tree/main/packages/@spscommerce/utils#readme">@spscommerce/utils</a></td><td class="sps-table__cell text-right">^1.1.0</td></tr>
38
+ <tr class="sps-table__row"><td class="sps-table__cell"><a href="https://momentjs.com">moment</a></td><td class="sps-table__cell text-right">^2.25.3</td></tr>
39
+ <tr class="sps-table__row"><td class="sps-table__cell"><a href="http://momentjs.com/timezone/">moment-timezone</a></td><td class="sps-table__cell text-right">^0.5.28</td></tr>
40
+ </tbody>
41
+ </table>
42
+ </div>
43
+ <div class="col-7">
44
+ &nbsp;
45
+ </div>
46
+ </div>
47
+
48
+ [//]: # "END_AUTOGENERATED"
@@ -0,0 +1,12 @@
1
+ export interface ChartDataObject {
2
+ label: string;
3
+ value: number;
4
+ }
5
+ /**
6
+ * Used for the Y and X axis for bar charts.
7
+ * The Y axis uses tickCount but the X axis does not
8
+ */
9
+ export interface ChartAxis {
10
+ tickValues: any;
11
+ tickCount?: number;
12
+ }
@@ -0,0 +1,34 @@
1
+ export declare enum StdButtonKind {
2
+ DEFAULT = "default",
3
+ CONFIRM = "confirm",
4
+ DELETE = "delete",
5
+ KEY = "key"
6
+ }
7
+ declare enum ButtonKindIcon {
8
+ ICON = "icon"
9
+ }
10
+ declare enum ButtonKindLink {
11
+ LINK = "link"
12
+ }
13
+ export type DropdownKind = StdButtonKind | ButtonKindIcon;
14
+ export declare const DropdownKind: Readonly<{
15
+ ICON: ButtonKindIcon.ICON;
16
+ DEFAULT: StdButtonKind.DEFAULT;
17
+ CONFIRM: StdButtonKind.CONFIRM;
18
+ DELETE: StdButtonKind.DELETE;
19
+ KEY: StdButtonKind.KEY;
20
+ }>;
21
+ export type ButtonKind = StdButtonKind | ButtonKindIcon | ButtonKindLink;
22
+ export declare const ButtonKind: Readonly<{
23
+ LINK: ButtonKindLink.LINK;
24
+ ICON: ButtonKindIcon.ICON;
25
+ DEFAULT: StdButtonKind.DEFAULT;
26
+ CONFIRM: StdButtonKind.CONFIRM;
27
+ DELETE: StdButtonKind.DELETE;
28
+ KEY: StdButtonKind.KEY;
29
+ }>;
30
+ export declare enum ButtonType {
31
+ BUTTON = "button",
32
+ SUBMIT = "submit"
33
+ }
34
+ export {};
@@ -0,0 +1,4 @@
1
+ export declare enum ClickableTagKind {
2
+ BLUE = "blue",
3
+ GRAY = "gray"
4
+ }
@@ -0,0 +1,41 @@
1
+ import type { Duration, Moment } from "moment-timezone";
2
+ export interface MomentRange {
3
+ start: Moment;
4
+ end: Moment;
5
+ preset?: Duration;
6
+ }
7
+ export interface SimpleDate {
8
+ year: number;
9
+ month: number;
10
+ date: number;
11
+ }
12
+ export type SimpleDateRange = [SimpleDate, SimpleDate];
13
+ export type SimpleMomentRange = [Moment | null, Moment | null];
14
+ export declare enum SelectMode {
15
+ START = 0,
16
+ END = 1
17
+ }
18
+ export interface DateSelectionEvent<T = Moment | MomentRange> {
19
+ value: T;
20
+ mode: SelectMode;
21
+ }
22
+ /**
23
+ * A list of lists representing the weeks and
24
+ * days of a month, e.g.
25
+ * [ [ , , 1, 2, 3, 4, 5 ],
26
+ * [ 6, 7, 8, 9, 10, 11, 12 ],
27
+ * [ 13, 14, 15, 16, 17, 18, 19 ],
28
+ * [ 20, 21, 22, 23, 24, 25, 26 ],
29
+ * [ 27, 28, 29, 30, , , ] ]
30
+ * but where each number is a SimpleDate object
31
+ */
32
+ export type CalendarArray = ReadonlyArray<readonly SimpleDate[]>;
33
+ export type ISO8601String = string;
34
+ export interface DatePreset {
35
+ label: string;
36
+ definition: ISO8601String | (() => SimpleDateRange);
37
+ }
38
+ export interface DateTimePreset {
39
+ label: string;
40
+ definition: ISO8601String | (() => SimpleMomentRange);
41
+ }
@@ -0,0 +1,43 @@
1
+ import type { ReactElement, FC } from "react";
2
+ export interface ExtraExampleRendererArgs {
3
+ naviagateTo: (selection: string) => void;
4
+ NavigateTo: (props: {
5
+ to: string;
6
+ children: ReactElement | string;
7
+ slugPrefix?: string;
8
+ }) => ReactElement;
9
+ Link: (props: {
10
+ to: string;
11
+ children: ReactElement | string;
12
+ }) => ReactElement;
13
+ }
14
+ type ReactChildOrRenderer = ReactElement | string | ((args: ExtraExampleRendererArgs) => ReactElement | string);
15
+ export interface DSExampleBase {
16
+ description?: ReactChildOrRenderer;
17
+ }
18
+ export interface DSReactExampleJSX {
19
+ jsx: string;
20
+ imports?: string;
21
+ }
22
+ export interface DSReactExampleComponent {
23
+ react: string;
24
+ }
25
+ export type DSReactExample = DSExampleBase & (DSReactExampleComponent | DSReactExampleJSX);
26
+ export type DSExample = DSReactExample;
27
+ export declare function exampleIsReactComponentExample(example: DSExample): example is DSReactExampleComponent;
28
+ export declare function exampleIsReactJSXExample(example: DSExample): example is DSReactExampleJSX;
29
+ export interface DSExamplesTab<T extends DSExample = DSExample> {
30
+ label?: ReactChildOrRenderer;
31
+ description?: ReactChildOrRenderer;
32
+ customSection?: ReactChildOrRenderer;
33
+ examples?: Record<string, T>;
34
+ }
35
+ export type DSExamples<T extends DSExample = DSExample> = Record<string, DSExamplesTab<T>>;
36
+ export type DSReactExamples = DSExamples<DSReactExample>;
37
+ export type ComponentManifest = Record<string, {
38
+ description?: ReactChildOrRenderer;
39
+ components: unknown[];
40
+ examples: DSReactExamples;
41
+ notices?: FC[];
42
+ }>;
43
+ export {};
@@ -0,0 +1,15 @@
1
+ import { SpsIcon } from "./icon";
2
+ export declare enum FeedbackBlockKind {
3
+ TIP = "tip",
4
+ SUCCESS = "success",
5
+ WARNING = "warning",
6
+ ERROR = "error",
7
+ INFO = "info"
8
+ }
9
+ export declare const FeedbackBlockIcons: Readonly<{
10
+ tip: SpsIcon.LIGHTBULB;
11
+ error: SpsIcon.EXCLAMATION_CIRCLE;
12
+ info: SpsIcon.INFO_CIRCLE;
13
+ success: SpsIcon.CHECKMARK;
14
+ warning: SpsIcon.EXCLAMATION_TRIANGLE;
15
+ }>;
@@ -0,0 +1,7 @@
1
+ export declare enum SpsFilterTileKind {
2
+ GENERAL = "general",
3
+ SUCCESS = "success",
4
+ ERROR = "error",
5
+ WARNING = "warning",
6
+ PROCESSING = "processing"
7
+ }
package/lib/grid.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ /** Allowable values for the width of an element in our 12-column layout grid. */
2
+ export type GridWidth = 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12;
@@ -0,0 +1,12 @@
1
+ import { SpsIcon } from "./icon";
2
+ export declare const GROWLER_VISIBLE_DURATION_MS = 7000;
3
+ export declare const GROWLER_FADEOUT_DURATION_MS = 2000;
4
+ export declare enum GrowlerKind {
5
+ ACTIVITY = "activity",
6
+ ERROR = "error",
7
+ INFO = "info",
8
+ PROGRESS = "progress",
9
+ SUCCESS = "success",
10
+ WARNING = "warning"
11
+ }
12
+ export declare const GrowlerIcon: Map<GrowlerKind, SpsIcon>;
package/lib/icon.d.ts ADDED
@@ -0,0 +1,215 @@
1
+ export declare enum SpsIconSize {
2
+ EXTRA_SMALL = "xs",
3
+ SMALL = "sm",
4
+ MEDIUM = "md",
5
+ LARGE = "lg",
6
+ EXTRA_LARGE = "xl"
7
+ }
8
+ export declare enum SpsIcon {
9
+ AI = "ai",
10
+ ANGLE_LEFT = "angle-left",
11
+ ANGLE_RIGHT = "angle-right",
12
+ ARCHIVE = "archive",
13
+ ARCHIVE_CIRCLE = "archive-circle",
14
+ ARROW_DOWN = "arrow-down",
15
+ ARROW_LEFT = "arrow-left",
16
+ ARROW_LEFT_CIRCLE = "arrow-left-circle",
17
+ ARROW_RIGHT = "arrow-right",
18
+ ARROW_RIGHT_CIRCLE = "arrow-right-circle",
19
+ ARROW_UP = "arrow-up",
20
+ ASTERISK = "asterisk",
21
+ ASTERISK_CIRCLE = "asterisk-circle",
22
+ BAN = "ban",
23
+ BAN_CIRCLE = "ban-circle",
24
+ BARCODE = "barcode",
25
+ BELL = "bell",
26
+ BELL_FILLED = "bell-filled",
27
+ BOLD = "bold",
28
+ BOLT = "bolt",
29
+ BOOK = "book",
30
+ BUILDING = "building",
31
+ BURST = "burst",
32
+ BURST_BOLT = "burst-bolt",
33
+ CALENDAR = "calendar",
34
+ CALENDAR_BLANK = "calendar-blank",
35
+ CALENDAR_BLANK_CIRCLE = "calendar-blank-circle",
36
+ CALENDAR_SELECT = "calendar-select",
37
+ CAMERA = "camera",
38
+ CHART_AREA = "chart-area",
39
+ CHART_BAR = "chart-bar",
40
+ CHART_LINE = "chart-line",
41
+ CHART_PIE = "chart-pie",
42
+ CHECKMARK = "checkmark",
43
+ CHECKMARK_CIRCLE = "checkmark-circle",
44
+ CHEVRON_DOWN = "chevron-down",
45
+ CHEVRON_LEFT = "chevron-left",
46
+ CHEVRON_RIGHT = "chevron-right",
47
+ CHEVRON_UP = "chevron-up",
48
+ CIRCLE_OUTLINE = "circle-outline",
49
+ CLEAR_FORMATTING = "clear-formatting",
50
+ CLOCK = "clock",
51
+ CLOCK_CIRCLE = "clock-circle",
52
+ CODE_FORK = "code-fork",
53
+ COLUMN_SWITCHER = "column-switcher",
54
+ COMMENT_BUBBLE = "comment-bubble",
55
+ COMMENT_BUBBLE_EXCLAMATION = "comment-bubble-exclamation",
56
+ COMMENT_BUBBLE_QUESTION = "comment-bubble-question",
57
+ COMPLETE_FILE = "complete-file",
58
+ CONVERSATION = "conversation",
59
+ CREDIT_CARD = "credit-card",
60
+ DASHBOARD = "dashboard",
61
+ DATABASE = "database",
62
+ DESCENDING_ELLIPSES_CIRCLE = "descending-ellipses-circle",
63
+ DISK = "disk",
64
+ DISK_CIRCLE = "disk-circle",
65
+ DOLLAR_SIGN = "dollar-sign",
66
+ DOUBLE_ANGLE_LEFT = "double-angle-left",
67
+ DOUBLE_ANGLE_RIGHT = "double-angle-right",
68
+ DOWNLOAD_CLOUD = "download-cloud",
69
+ DRILL = "drill",
70
+ DUPLICATE = "duplicate",
71
+ ELLIPSES = "ellipses",
72
+ ENVELOPE = "envelope",
73
+ EXCHANGE = "exchange",
74
+ EXCLAMATION_CIRCLE = "exclamation-circle",
75
+ EXCLAMATION_TRIANGLE = "exclamation-triangle",
76
+ EXPAND_COLLAPSE = "expand-collapse",
77
+ EYE = "eye",
78
+ EYE_SLASH = "eye-slash",
79
+ FILE = "file",
80
+ FILE_DUPLICATE = "file-duplicate",
81
+ FILE_PDF = "file-pdf",
82
+ FILE_PRESENTATION = "file-presentation",
83
+ FILE_SIZE = "file-size",
84
+ FILE_SOLID = "file-solid",
85
+ FILE_SOLID_TEXT = "file-solid-text",
86
+ FILE_SPREADSHEET = "file-spreadsheet",
87
+ FILE_TEXT = "file-text",
88
+ FILTER = "filter",
89
+ FLAG = "flag",
90
+ FLAG_OUTLINE = "flag-outline",
91
+ FOLDER = "folder",
92
+ FOLDER_OPEN = "folder-open",
93
+ FOLDER_SOLID = "folder-solid",
94
+ FOLDER_SOLID_OPEN = "folder-solid-open",
95
+ GEAR = "gear",
96
+ GLOBE = "globe",
97
+ GRID = "grid",
98
+ GROUP = "group",
99
+ HAND_STOP = "hand-stop",
100
+ HANDSHAKE = "handshake",
101
+ HAT = "hat",
102
+ HEART = "heart",
103
+ HEART_OUTLINE = "heart-outline",
104
+ HISTORY = "history",
105
+ I_MADE_THIS = "i-made-this",
106
+ INBOX = "inbox",
107
+ INCOMING = "incoming",
108
+ INFO_CIRCLE = "info-circle",
109
+ ITALICS = "italics",
110
+ INTERCOM = "intercom",
111
+ ITEM_TAG = "item-tag",
112
+ KEY = "key",
113
+ LIFE_PRESERVER = "life-preserver",
114
+ LIGHTBULB = "lightbulb",
115
+ LINK = "link",
116
+ LINKEDIN = "linkedin",
117
+ LIST = "list",
118
+ LIST_CARDS = "list-cards",
119
+ LIST_COLUMNS = "list-columns",
120
+ LIST_INDENT = "list-indent",
121
+ LIST_ORDERED = "list-ordered",
122
+ LIST_OUTDENT = "list-outdent",
123
+ LIST_UNORDERED = "list-unordered",
124
+ LIST_SUMMARY = "list-summary",
125
+ LIST_TABLE = "list-table",
126
+ LOCATION = "location",
127
+ LOCKED = "locked",
128
+ LOCKED_CIRCLE = "locked-circle",
129
+ MAP = "map",
130
+ MAP_MARKER = "map-marker",
131
+ MAXIMIZE = "maximize",
132
+ MICROPHONE_ON = "microphone-on",
133
+ MICROPHONE_OFF = "microphone-off",
134
+ MINIMIZE = "minimize",
135
+ MINUS = "minus",
136
+ MINUS_CIRCLE = "minus-circle",
137
+ NESTED_LIST = "nested-list",
138
+ NEW_FILE = "new-file",
139
+ NEW_SCREEN = "new-screen",
140
+ OUTGOING = "outgoing",
141
+ PAPER_PLANE = "paper-plane",
142
+ PENCIL = "pencil",
143
+ PHOTO = "photo",
144
+ PIN = "pin",
145
+ PIN_OUTLINE = "pin-outline",
146
+ PINTEREST = "pinterest",
147
+ PLAY = "play",
148
+ PLUS_CIRCLE = "plus-circle",
149
+ PLUS_SIGN = "plus-sign",
150
+ PRESENTATION = "presentation",
151
+ PRINTER = "printer",
152
+ QR_CODE = "qr-code",
153
+ QUESTION_CIRCLE = "question-circle",
154
+ QUOTE_LEFT = "quote-left",
155
+ QUOTE_RIGHT = "quote-right",
156
+ RANDOM = "random",
157
+ REDO = "redo",
158
+ REFRESH = "refresh",
159
+ RIGHT_CIRCLE = "right-circle",
160
+ ROCKET = "rocket",
161
+ SAVED_CIRCLE = "saved-circle",
162
+ SEARCH = "search",
163
+ SEARCH_PLUS = "search-plus",
164
+ SHARE = "share",
165
+ SHOPPING_CART = "shopping-cart",
166
+ SORT_ALPHA_ASC = "sort-alpha-asc",
167
+ SORT_ALPHA_DESC = "sort-alpha-desc",
168
+ SORT_NUM_ASC = "sort-num-asc",
169
+ SORT_NUM_DESC = "sort-num-desc",
170
+ STAR = "star",
171
+ STAR_OUTLINE = "star-outline",
172
+ STATUS_ARCHIVED = "status-archived",
173
+ STATUS_CANCELLED = "status-cancelled",
174
+ STATUS_ERROR = "status-error",
175
+ STATUS_IN_PROCESS = "status-in-process",
176
+ STATUS_IN_TRANSIT = "status-in-transit",
177
+ STATUS_LOCKED = "status-locked",
178
+ STATUS_NEW = "status-new",
179
+ STATUS_OK = "status-ok",
180
+ STATUS_ON_HOLD = "status-on-hold",
181
+ STATUS_OUTDATED = "status-outdated",
182
+ STATUS_PREVIEW = "status-preview",
183
+ STATUS_REJECTED = "status-rejected",
184
+ STATUS_SAVED = "status-saved",
185
+ STATUS_SAVING = "status-saving",
186
+ STATUS_TEMPLATE = "status-template",
187
+ STATUS_WARNING = "status-warning",
188
+ TABLE = "table",
189
+ TABS = "tabs",
190
+ TAG = "tag",
191
+ TEMPLATE_CIRCLE = "template-circle",
192
+ THUMBS_DOWN = "thumbs-down",
193
+ THUMBS_DOWN_OUTLINE = "thumbs-down-outline",
194
+ THUMBS_UP = "thumbs-up",
195
+ THUMBS_UP_OUTLINE = "thumbs-up-outline",
196
+ TRASH = "trash",
197
+ TRUCK_SHIPPING = "truck-shipping",
198
+ TWITTER = "twitter",
199
+ UNARCHIVE = "unarchive",
200
+ UNDO = "undo",
201
+ UNLINK = "unlink",
202
+ UNLOCKED = "unlocked",
203
+ UPLOAD_CLOUD = "upload-cloud",
204
+ USER = "user",
205
+ USER_IMPERSONATION = "user-impersonation",
206
+ VOLUME_OFF = "volume-off",
207
+ VOLUME_LOW = "volume-low",
208
+ VOLUME_MEDIUM = "volume-medium",
209
+ VOLUME_FULL = "volume-full",
210
+ WRENCH = "wrench",
211
+ WORKFLOW = "workflow",
212
+ WORKFLOW_COMPLETE = "workflow-complete",
213
+ X = "x",
214
+ X_CIRCLE = "x-circle"
215
+ }
package/lib/index.d.ts ADDED
@@ -0,0 +1,30 @@
1
+ export * from "./bar-chart";
2
+ export * from "./button";
3
+ export * from "./datetime";
4
+ export * from "./clickable-tag";
5
+ export * from "./examples";
6
+ export * from "./feedback";
7
+ export * from "./filter-tile";
8
+ export * from "./growler";
9
+ export * from "./grid";
10
+ export * from "./icon";
11
+ export * from "./insight-card";
12
+ export * from "./insight-tile";
13
+ export * from "./key-value-list-item";
14
+ export * from "./line-chart";
15
+ export * from "./modal";
16
+ export * from "./option-list";
17
+ export * from "./pagination";
18
+ export * from "./positioning";
19
+ export * from "./ring-size";
20
+ export * from "./spinner";
21
+ export * from "./stacked-horizontal-bar-chart";
22
+ export * from "./stepped-progress-bar";
23
+ export * from "./table";
24
+ export * from "./tabs";
25
+ export * from "./tag";
26
+ export * from "./tooltip";
27
+ export * from "./sps-action";
28
+ export * from "./task-queue";
29
+ export * from "./wizard-substep-condition";
30
+ export * from "./z-strata";
package/lib/index.js ADDED
@@ -0,0 +1,155 @@
1
+ import { simpleMetadataDecoratorApplicator as O } from "@spscommerce/utils";
2
+ var R = /* @__PURE__ */ ((e) => (e.DEFAULT = "default", e.CONFIRM = "confirm", e.DELETE = "delete", e.KEY = "key", e))(R || {}), A = /* @__PURE__ */ ((e) => (e.ICON = "icon", e))(A || {}), L = /* @__PURE__ */ ((e) => (e.LINK = "link", e))(L || {});
3
+ const V = Object.freeze({ ...R, ...A }), y = Object.freeze({ ...R, ...A, ...L });
4
+ var a = /* @__PURE__ */ ((e) => (e.BUTTON = "button", e.SUBMIT = "submit", e))(a || {}), l = /* @__PURE__ */ ((e) => (e[e.START = 0] = "START", e[e.END = 1] = "END", e))(l || {}), _ = /* @__PURE__ */ ((e) => (e.BLUE = "blue", e.GRAY = "gray", e))(_ || {});
5
+ function X(e) {
6
+ return e.hasOwnProperty("react");
7
+ }
8
+ function Y(e) {
9
+ return e.hasOwnProperty("jsx");
10
+ }
11
+ var N = /* @__PURE__ */ ((e) => (e.EXTRA_SMALL = "xs", e.SMALL = "sm", e.MEDIUM = "md", e.LARGE = "lg", e.EXTRA_LARGE = "xl", e))(N || {}), E = /* @__PURE__ */ ((e) => (e.AI = "ai", e.ANGLE_LEFT = "angle-left", e.ANGLE_RIGHT = "angle-right", e.ARCHIVE = "archive", e.ARCHIVE_CIRCLE = "archive-circle", e.ARROW_DOWN = "arrow-down", e.ARROW_LEFT = "arrow-left", e.ARROW_LEFT_CIRCLE = "arrow-left-circle", e.ARROW_RIGHT = "arrow-right", e.ARROW_RIGHT_CIRCLE = "arrow-right-circle", e.ARROW_UP = "arrow-up", e.ASTERISK = "asterisk", e.ASTERISK_CIRCLE = "asterisk-circle", e.BAN = "ban", e.BAN_CIRCLE = "ban-circle", e.BARCODE = "barcode", e.BELL = "bell", e.BELL_FILLED = "bell-filled", e.BOLD = "bold", e.BOLT = "bolt", e.BOOK = "book", e.BUILDING = "building", e.BURST = "burst", e.BURST_BOLT = "burst-bolt", e.CALENDAR = "calendar", e.CALENDAR_BLANK = "calendar-blank", e.CALENDAR_BLANK_CIRCLE = "calendar-blank-circle", e.CALENDAR_SELECT = "calendar-select", e.CAMERA = "camera", e.CHART_AREA = "chart-area", e.CHART_BAR = "chart-bar", e.CHART_LINE = "chart-line", e.CHART_PIE = "chart-pie", e.CHECKMARK = "checkmark", e.CHECKMARK_CIRCLE = "checkmark-circle", e.CHEVRON_DOWN = "chevron-down", e.CHEVRON_LEFT = "chevron-left", e.CHEVRON_RIGHT = "chevron-right", e.CHEVRON_UP = "chevron-up", e.CIRCLE_OUTLINE = "circle-outline", e.CLEAR_FORMATTING = "clear-formatting", e.CLOCK = "clock", e.CLOCK_CIRCLE = "clock-circle", e.CODE_FORK = "code-fork", e.COLUMN_SWITCHER = "column-switcher", e.COMMENT_BUBBLE = "comment-bubble", e.COMMENT_BUBBLE_EXCLAMATION = "comment-bubble-exclamation", e.COMMENT_BUBBLE_QUESTION = "comment-bubble-question", e.COMPLETE_FILE = "complete-file", e.CONVERSATION = "conversation", e.CREDIT_CARD = "credit-card", e.DASHBOARD = "dashboard", e.DATABASE = "database", e.DESCENDING_ELLIPSES_CIRCLE = "descending-ellipses-circle", e.DISK = "disk", e.DISK_CIRCLE = "disk-circle", e.DOLLAR_SIGN = "dollar-sign", e.DOUBLE_ANGLE_LEFT = "double-angle-left", e.DOUBLE_ANGLE_RIGHT = "double-angle-right", e.DOWNLOAD_CLOUD = "download-cloud", e.DRILL = "drill", e.DUPLICATE = "duplicate", e.ELLIPSES = "ellipses", e.ENVELOPE = "envelope", e.EXCHANGE = "exchange", e.EXCLAMATION_CIRCLE = "exclamation-circle", e.EXCLAMATION_TRIANGLE = "exclamation-triangle", e.EXPAND_COLLAPSE = "expand-collapse", e.EYE = "eye", e.EYE_SLASH = "eye-slash", e.FILE = "file", e.FILE_DUPLICATE = "file-duplicate", e.FILE_PDF = "file-pdf", e.FILE_PRESENTATION = "file-presentation", e.FILE_SIZE = "file-size", e.FILE_SOLID = "file-solid", e.FILE_SOLID_TEXT = "file-solid-text", e.FILE_SPREADSHEET = "file-spreadsheet", e.FILE_TEXT = "file-text", e.FILTER = "filter", e.FLAG = "flag", e.FLAG_OUTLINE = "flag-outline", e.FOLDER = "folder", e.FOLDER_OPEN = "folder-open", e.FOLDER_SOLID = "folder-solid", e.FOLDER_SOLID_OPEN = "folder-solid-open", e.GEAR = "gear", e.GLOBE = "globe", e.GRID = "grid", e.GROUP = "group", e.HAND_STOP = "hand-stop", e.HANDSHAKE = "handshake", e.HAT = "hat", e.HEART = "heart", e.HEART_OUTLINE = "heart-outline", e.HISTORY = "history", e.I_MADE_THIS = "i-made-this", e.INBOX = "inbox", e.INCOMING = "incoming", e.INFO_CIRCLE = "info-circle", e.ITALICS = "italics", e.INTERCOM = "intercom", e.ITEM_TAG = "item-tag", e.KEY = "key", e.LIFE_PRESERVER = "life-preserver", e.LIGHTBULB = "lightbulb", e.LINK = "link", e.LINKEDIN = "linkedin", e.LIST = "list", e.LIST_CARDS = "list-cards", e.LIST_COLUMNS = "list-columns", e.LIST_INDENT = "list-indent", e.LIST_ORDERED = "list-ordered", e.LIST_OUTDENT = "list-outdent", e.LIST_UNORDERED = "list-unordered", e.LIST_SUMMARY = "list-summary", e.LIST_TABLE = "list-table", e.LOCATION = "location", e.LOCKED = "locked", e.LOCKED_CIRCLE = "locked-circle", e.MAP = "map", e.MAP_MARKER = "map-marker", e.MAXIMIZE = "maximize", e.MICROPHONE_ON = "microphone-on", e.MICROPHONE_OFF = "microphone-off", e.MINIMIZE = "minimize", e.MINUS = "minus", e.MINUS_CIRCLE = "minus-circle", e.NESTED_LIST = "nested-list", e.NEW_FILE = "new-file", e.NEW_SCREEN = "new-screen", e.OUTGOING = "outgoing", e.PAPER_PLANE = "paper-plane", e.PENCIL = "pencil", e.PHOTO = "photo", e.PIN = "pin", e.PIN_OUTLINE = "pin-outline", e.PINTEREST = "pinterest", e.PLAY = "play", e.PLUS_CIRCLE = "plus-circle", e.PLUS_SIGN = "plus-sign", e.PRESENTATION = "presentation", e.PRINTER = "printer", e.QR_CODE = "qr-code", e.QUESTION_CIRCLE = "question-circle", e.QUOTE_LEFT = "quote-left", e.QUOTE_RIGHT = "quote-right", e.RANDOM = "random", e.REDO = "redo", e.REFRESH = "refresh", e.RIGHT_CIRCLE = "right-circle", e.ROCKET = "rocket", e.SAVED_CIRCLE = "saved-circle", e.SEARCH = "search", e.SEARCH_PLUS = "search-plus", e.SHARE = "share", e.SHOPPING_CART = "shopping-cart", e.SORT_ALPHA_ASC = "sort-alpha-asc", e.SORT_ALPHA_DESC = "sort-alpha-desc", e.SORT_NUM_ASC = "sort-num-asc", e.SORT_NUM_DESC = "sort-num-desc", e.STAR = "star", e.STAR_OUTLINE = "star-outline", e.STATUS_ARCHIVED = "status-archived", e.STATUS_CANCELLED = "status-cancelled", e.STATUS_ERROR = "status-error", e.STATUS_IN_PROCESS = "status-in-process", e.STATUS_IN_TRANSIT = "status-in-transit", e.STATUS_LOCKED = "status-locked", e.STATUS_NEW = "status-new", e.STATUS_OK = "status-ok", e.STATUS_ON_HOLD = "status-on-hold", e.STATUS_OUTDATED = "status-outdated", e.STATUS_PREVIEW = "status-preview", e.STATUS_REJECTED = "status-rejected", e.STATUS_SAVED = "status-saved", e.STATUS_SAVING = "status-saving", e.STATUS_TEMPLATE = "status-template", e.STATUS_WARNING = "status-warning", e.TABLE = "table", e.TABS = "tabs", e.TAG = "tag", e.TEMPLATE_CIRCLE = "template-circle", e.THUMBS_DOWN = "thumbs-down", e.THUMBS_DOWN_OUTLINE = "thumbs-down-outline", e.THUMBS_UP = "thumbs-up", e.THUMBS_UP_OUTLINE = "thumbs-up-outline", e.TRASH = "trash", e.TRUCK_SHIPPING = "truck-shipping", e.TWITTER = "twitter", e.UNARCHIVE = "unarchive", e.UNDO = "undo", e.UNLINK = "unlink", e.UNLOCKED = "unlocked", e.UPLOAD_CLOUD = "upload-cloud", e.USER = "user", e.USER_IMPERSONATION = "user-impersonation", e.VOLUME_OFF = "volume-off", e.VOLUME_LOW = "volume-low", e.VOLUME_MEDIUM = "volume-medium", e.VOLUME_FULL = "volume-full", e.WRENCH = "wrench", e.WORKFLOW = "workflow", e.WORKFLOW_COMPLETE = "workflow-complete", e.X = "x", e.X_CIRCLE = "x-circle", e))(E || {}), u = /* @__PURE__ */ ((e) => (e.TIP = "tip", e.SUCCESS = "success", e.WARNING = "warning", e.ERROR = "error", e.INFO = "info", e))(u || {});
12
+ const j = Object.freeze({
13
+ tip: E.LIGHTBULB,
14
+ error: E.EXCLAMATION_CIRCLE,
15
+ info: E.INFO_CIRCLE,
16
+ success: E.CHECKMARK,
17
+ warning: E.EXCLAMATION_TRIANGLE
18
+ });
19
+ var i = /* @__PURE__ */ ((e) => (e.GENERAL = "general", e.SUCCESS = "success", e.ERROR = "error", e.WARNING = "warning", e.PROCESSING = "processing", e))(i || {});
20
+ const n = 7e3, K = 2e3;
21
+ var C = /* @__PURE__ */ ((e) => (e.ACTIVITY = "activity", e.ERROR = "error", e.INFO = "info", e.PROGRESS = "progress", e.SUCCESS = "success", e.WARNING = "warning", e))(C || {});
22
+ const Q = /* @__PURE__ */ new Map([
23
+ ["info", E.INFO_CIRCLE],
24
+ ["warning", E.EXCLAMATION_TRIANGLE],
25
+ ["error", E.EXCLAMATION_CIRCLE],
26
+ ["success", E.CHECKMARK]
27
+ ]);
28
+ var U = /* @__PURE__ */ ((e) => (e.GENERAL = "general", e.SUCCESS = "success", e.ERROR = "error", e.WARNING = "warning", e.PROCESSING = "processing", e))(U || {});
29
+ const q = Object.freeze({
30
+ general: E.STATUS_NEW,
31
+ success: E.STATUS_OK,
32
+ error: E.STATUS_ERROR,
33
+ warning: E.STATUS_WARNING,
34
+ processing: E.STATUS_IN_PROCESS
35
+ });
36
+ var D = /* @__PURE__ */ ((e) => (e.GENERAL = "general", e.SUCCESS = "success", e.ERROR = "error", e.WARNING = "warning", e.PROCESSING = "processing", e))(D || {});
37
+ const s = Object.freeze({
38
+ general: E.STATUS_NEW,
39
+ success: E.STATUS_OK,
40
+ error: E.STATUS_ERROR,
41
+ warning: E.STATUS_WARNING,
42
+ processing: E.STATUS_IN_PROCESS
43
+ });
44
+ var G = /* @__PURE__ */ ((e) => (e.LIGHT = "light", e.DARK = "dark", e))(G || {}), f = /* @__PURE__ */ ((e) => (e.BLUE = "blue200", e.GRAY = "gray600", e.GREEN = "green200", e.ORANGE = "orange200", e.PURPLE = "purple200", e.RED = "red200", e))(f || {}), h = /* @__PURE__ */ ((e) => (e.GENERAL = "general", e.INFO = "info", e.SUCCESS = "success", e.WARNING = "warning", e.SERIOUS_WARNING = "serious-warning", e))(h || {}), M = /* @__PURE__ */ ((e) => (e.SMALL = "small", e.MEDIUM = "medium", e.LARGE = "large", e.X_LARGE = "xlarge", e))(M || {});
45
+ class J {
46
+ constructor(r, t = {}) {
47
+ this.value = r, Object.assign(this, t);
48
+ }
49
+ get text() {
50
+ return this.textInternal ? this.textInternal : this.value ? this.textKey ? this.value[this.textKey] ?? "" : String(this.value) : "";
51
+ }
52
+ set text(r) {
53
+ this.textInternal = r;
54
+ }
55
+ get caption() {
56
+ return this.captionInternal ? this.captionInternal : this.value && this.captionKey ? this.value[this.captionKey] : "";
57
+ }
58
+ set caption(r) {
59
+ this.captionInternal = r;
60
+ }
61
+ get href() {
62
+ return this.value ? this.value.isLink && typeof this.value == "function" ? this.value() : this.value.href : null;
63
+ }
64
+ get disabled() {
65
+ return typeof this.disabledInternal < "u" ? this.disabledInternal : this.value ? this.value.disabled : !1;
66
+ }
67
+ set disabled(r) {
68
+ this.disabledInternal = r;
69
+ }
70
+ get bold() {
71
+ return typeof this.boldInternal < "u" ? this.boldInternal : this.value ? this.value.bold && this.value.bold === !0 : !1;
72
+ }
73
+ getHtml(r) {
74
+ return r ? this.text.replace(r, "<u>$&</u>") : this.text;
75
+ }
76
+ }
77
+ const $ = [
78
+ 10,
79
+ 25,
80
+ 50,
81
+ 100
82
+ ];
83
+ var m = /* @__PURE__ */ ((e) => (e.TOP_LEFT = "top left", e.TOP_MIDDLE = "top middle", e.TOP_RIGHT = "top right", e.RIGHT_TOP = "right top", e.RIGHT_MIDDLE = "right middle", e.RIGHT_BOTTOM = "right bottom", e.BOTTOM_RIGHT = "bottom right", e.BOTTOM_MIDDLE = "bottom middle", e.BOTTOM_LEFT = "bottom left", e.LEFT_BOTTOM = "left bottom", e.LEFT_MIDDLE = "left middle", e.LEFT_TOP = "left top", e))(m || {}), P = /* @__PURE__ */ ((e) => (e[e.SMALL = 14] = "SMALL", e[e.MEDIUM = 26] = "MEDIUM", e[e.LARGE = 38] = "LARGE", e))(P || {}), g = /* @__PURE__ */ ((e) => (e.SMALL = "small", e.MEDIUM = "medium", e.LARGE = "large", e))(g || {}), v = /* @__PURE__ */ ((e) => (e.BLUE = "blue200", e.GRAY = "gray600", e.GREEN = "green200", e.ORANGE = "orange200", e.PURPLE = "purple200", e.RED = "red200", e))(v || {}), H = /* @__PURE__ */ ((e) => (e.PURPLE = "purple", e.RED = "red", e.BLUE = "blue", e.ORANGE = "orange", e.GRAY = "gray", e))(H || {}), b = /* @__PURE__ */ ((e) => (e.ASCENDING = "ascending", e.DESCENDING = "descending", e))(b || {}), d = /* @__PURE__ */ ((e) => (e.DEFAULT = "default", e.KEY = "key", e.WARNING = "warning", e.ERROR = "error", e.PENDING = "pending", e.SUCCESS = "success", e.INFO = "info", e))(d || {});
84
+ const Z = 1e3;
85
+ var F = /* @__PURE__ */ ((e) => (e.MANUAL = "manual", e.MOUSEOVER = "mouseover", e.CLICK = "click", e))(F || {}), B = /* @__PURE__ */ ((e) => (e.DEFAULT = "default", e.HELP = "help", e.ERROR = "error", e.WARNING = "warning", e.CONTAINER = "container", e))(B || {});
86
+ const W = {
87
+ icon: "",
88
+ label: "",
89
+ caption: "",
90
+ disabled: !1,
91
+ isLink: !1
92
+ };
93
+ function z(e) {
94
+ return (r, t, T) => O(
95
+ e,
96
+ W,
97
+ r,
98
+ t,
99
+ T
100
+ );
101
+ }
102
+ var w = /* @__PURE__ */ ((e) => (e.COMPLETED = "completed", e.ERRORED = "errored", e.WARNING = "warning", e.IN_PROGRESS = "in_progress", e))(w || {});
103
+ const c = Object.freeze({
104
+ completed: E.STATUS_OK,
105
+ errored: E.STATUS_ERROR,
106
+ warning: E.STATUS_WARNING,
107
+ in_progress: "sps-spinner sps-spinner--small"
108
+ }), S = 5e3;
109
+ var I = /* @__PURE__ */ ((e) => (e.BASIC = "basic", e.COMPLETED = "completed", e.COMPLETE = "completed", e.ACTIVE = "active", e))(I || {}), x = /* @__PURE__ */ ((e) => (e[e.BASE = 0] = "BASE", e[e.TIP = 10] = "TIP", e[e.DROPDOWN = 100] = "DROPDOWN", e[e.BAR = 1e3] = "BAR", e[e.DIALOG = 1e4] = "DIALOG", e))(x || {});
110
+ export {
111
+ y as ButtonKind,
112
+ a as ButtonType,
113
+ _ as ClickableTagKind,
114
+ $ as DEFAULT_PAGE_SIZE_OPTIONS,
115
+ V as DropdownKind,
116
+ j as FeedbackBlockIcons,
117
+ u as FeedbackBlockKind,
118
+ K as GROWLER_FADEOUT_DURATION_MS,
119
+ n as GROWLER_VISIBLE_DURATION_MS,
120
+ Q as GrowlerIcon,
121
+ C as GrowlerKind,
122
+ G as KeyValueListTitleColor,
123
+ f as LineChartColors,
124
+ h as ModalKind,
125
+ M as ModalSize,
126
+ m as Position,
127
+ P as RingSize,
128
+ W as SPS_ACTION_DEFAULTS,
129
+ l as SelectMode,
130
+ b as SortDirection,
131
+ g as SpinnerSize,
132
+ z as SpsAction,
133
+ i as SpsFilterTileKind,
134
+ E as SpsIcon,
135
+ N as SpsIconSize,
136
+ q as SpsInsightCardIcons,
137
+ U as SpsInsightCardKind,
138
+ s as SpsInsightTileIcons,
139
+ D as SpsInsightTileKind,
140
+ J as SpsOptionListOption,
141
+ w as SpsTaskStatus,
142
+ c as SpsTaskStatusIcons,
143
+ v as StackedBarChartMilestone,
144
+ R as StdButtonKind,
145
+ H as SteppedProgressBarColor,
146
+ S as TASK_QUEUE_NOTIFICATION_DURATION_MS,
147
+ Z as TOOLTIP_HIDE_DELAY_MS_DEFAULT,
148
+ d as TagKind,
149
+ B as TooltipKind,
150
+ F as TooltipShowTrigger,
151
+ I as WizardSubstepConditions,
152
+ x as ZStratum,
153
+ X as exampleIsReactComponentExample,
154
+ Y as exampleIsReactJSXExample
155
+ };
@@ -0,0 +1 @@
1
+ (function(E,R){typeof exports=="object"&&typeof module<"u"?R(exports,require("@spscommerce/utils")):typeof define=="function"&&define.amd?define(["exports","@spscommerce/utils"],R):(E=typeof globalThis<"u"?globalThis:E||self,R(E.DSShared={},E.utils))})(this,function(E,R){"use strict";var T=(e=>(e.DEFAULT="default",e.CONFIRM="confirm",e.DELETE="delete",e.KEY="key",e))(T||{}),A=(e=>(e.ICON="icon",e))(A||{}),a=(e=>(e.LINK="link",e))(a||{});const k=Object.freeze({...T,...A}),y=Object.freeze({...T,...A,...a});var l=(e=>(e.BUTTON="button",e.SUBMIT="submit",e))(l||{}),O=(e=>(e[e.START=0]="START",e[e.END=1]="END",e))(O||{}),_=(e=>(e.BLUE="blue",e.GRAY="gray",e))(_||{});function V(e){return e.hasOwnProperty("react")}function K(e){return e.hasOwnProperty("jsx")}var i=(e=>(e.EXTRA_SMALL="xs",e.SMALL="sm",e.MEDIUM="md",e.LARGE="lg",e.EXTRA_LARGE="xl",e))(i||{}),r=(e=>(e.AI="ai",e.ANGLE_LEFT="angle-left",e.ANGLE_RIGHT="angle-right",e.ARCHIVE="archive",e.ARCHIVE_CIRCLE="archive-circle",e.ARROW_DOWN="arrow-down",e.ARROW_LEFT="arrow-left",e.ARROW_LEFT_CIRCLE="arrow-left-circle",e.ARROW_RIGHT="arrow-right",e.ARROW_RIGHT_CIRCLE="arrow-right-circle",e.ARROW_UP="arrow-up",e.ASTERISK="asterisk",e.ASTERISK_CIRCLE="asterisk-circle",e.BAN="ban",e.BAN_CIRCLE="ban-circle",e.BARCODE="barcode",e.BELL="bell",e.BELL_FILLED="bell-filled",e.BOLD="bold",e.BOLT="bolt",e.BOOK="book",e.BUILDING="building",e.BURST="burst",e.BURST_BOLT="burst-bolt",e.CALENDAR="calendar",e.CALENDAR_BLANK="calendar-blank",e.CALENDAR_BLANK_CIRCLE="calendar-blank-circle",e.CALENDAR_SELECT="calendar-select",e.CAMERA="camera",e.CHART_AREA="chart-area",e.CHART_BAR="chart-bar",e.CHART_LINE="chart-line",e.CHART_PIE="chart-pie",e.CHECKMARK="checkmark",e.CHECKMARK_CIRCLE="checkmark-circle",e.CHEVRON_DOWN="chevron-down",e.CHEVRON_LEFT="chevron-left",e.CHEVRON_RIGHT="chevron-right",e.CHEVRON_UP="chevron-up",e.CIRCLE_OUTLINE="circle-outline",e.CLEAR_FORMATTING="clear-formatting",e.CLOCK="clock",e.CLOCK_CIRCLE="clock-circle",e.CODE_FORK="code-fork",e.COLUMN_SWITCHER="column-switcher",e.COMMENT_BUBBLE="comment-bubble",e.COMMENT_BUBBLE_EXCLAMATION="comment-bubble-exclamation",e.COMMENT_BUBBLE_QUESTION="comment-bubble-question",e.COMPLETE_FILE="complete-file",e.CONVERSATION="conversation",e.CREDIT_CARD="credit-card",e.DASHBOARD="dashboard",e.DATABASE="database",e.DESCENDING_ELLIPSES_CIRCLE="descending-ellipses-circle",e.DISK="disk",e.DISK_CIRCLE="disk-circle",e.DOLLAR_SIGN="dollar-sign",e.DOUBLE_ANGLE_LEFT="double-angle-left",e.DOUBLE_ANGLE_RIGHT="double-angle-right",e.DOWNLOAD_CLOUD="download-cloud",e.DRILL="drill",e.DUPLICATE="duplicate",e.ELLIPSES="ellipses",e.ENVELOPE="envelope",e.EXCHANGE="exchange",e.EXCLAMATION_CIRCLE="exclamation-circle",e.EXCLAMATION_TRIANGLE="exclamation-triangle",e.EXPAND_COLLAPSE="expand-collapse",e.EYE="eye",e.EYE_SLASH="eye-slash",e.FILE="file",e.FILE_DUPLICATE="file-duplicate",e.FILE_PDF="file-pdf",e.FILE_PRESENTATION="file-presentation",e.FILE_SIZE="file-size",e.FILE_SOLID="file-solid",e.FILE_SOLID_TEXT="file-solid-text",e.FILE_SPREADSHEET="file-spreadsheet",e.FILE_TEXT="file-text",e.FILTER="filter",e.FLAG="flag",e.FLAG_OUTLINE="flag-outline",e.FOLDER="folder",e.FOLDER_OPEN="folder-open",e.FOLDER_SOLID="folder-solid",e.FOLDER_SOLID_OPEN="folder-solid-open",e.GEAR="gear",e.GLOBE="globe",e.GRID="grid",e.GROUP="group",e.HAND_STOP="hand-stop",e.HANDSHAKE="handshake",e.HAT="hat",e.HEART="heart",e.HEART_OUTLINE="heart-outline",e.HISTORY="history",e.I_MADE_THIS="i-made-this",e.INBOX="inbox",e.INCOMING="incoming",e.INFO_CIRCLE="info-circle",e.ITALICS="italics",e.INTERCOM="intercom",e.ITEM_TAG="item-tag",e.KEY="key",e.LIFE_PRESERVER="life-preserver",e.LIGHTBULB="lightbulb",e.LINK="link",e.LINKEDIN="linkedin",e.LIST="list",e.LIST_CARDS="list-cards",e.LIST_COLUMNS="list-columns",e.LIST_INDENT="list-indent",e.LIST_ORDERED="list-ordered",e.LIST_OUTDENT="list-outdent",e.LIST_UNORDERED="list-unordered",e.LIST_SUMMARY="list-summary",e.LIST_TABLE="list-table",e.LOCATION="location",e.LOCKED="locked",e.LOCKED_CIRCLE="locked-circle",e.MAP="map",e.MAP_MARKER="map-marker",e.MAXIMIZE="maximize",e.MICROPHONE_ON="microphone-on",e.MICROPHONE_OFF="microphone-off",e.MINIMIZE="minimize",e.MINUS="minus",e.MINUS_CIRCLE="minus-circle",e.NESTED_LIST="nested-list",e.NEW_FILE="new-file",e.NEW_SCREEN="new-screen",e.OUTGOING="outgoing",e.PAPER_PLANE="paper-plane",e.PENCIL="pencil",e.PHOTO="photo",e.PIN="pin",e.PIN_OUTLINE="pin-outline",e.PINTEREST="pinterest",e.PLAY="play",e.PLUS_CIRCLE="plus-circle",e.PLUS_SIGN="plus-sign",e.PRESENTATION="presentation",e.PRINTER="printer",e.QR_CODE="qr-code",e.QUESTION_CIRCLE="question-circle",e.QUOTE_LEFT="quote-left",e.QUOTE_RIGHT="quote-right",e.RANDOM="random",e.REDO="redo",e.REFRESH="refresh",e.RIGHT_CIRCLE="right-circle",e.ROCKET="rocket",e.SAVED_CIRCLE="saved-circle",e.SEARCH="search",e.SEARCH_PLUS="search-plus",e.SHARE="share",e.SHOPPING_CART="shopping-cart",e.SORT_ALPHA_ASC="sort-alpha-asc",e.SORT_ALPHA_DESC="sort-alpha-desc",e.SORT_NUM_ASC="sort-num-asc",e.SORT_NUM_DESC="sort-num-desc",e.STAR="star",e.STAR_OUTLINE="star-outline",e.STATUS_ARCHIVED="status-archived",e.STATUS_CANCELLED="status-cancelled",e.STATUS_ERROR="status-error",e.STATUS_IN_PROCESS="status-in-process",e.STATUS_IN_TRANSIT="status-in-transit",e.STATUS_LOCKED="status-locked",e.STATUS_NEW="status-new",e.STATUS_OK="status-ok",e.STATUS_ON_HOLD="status-on-hold",e.STATUS_OUTDATED="status-outdated",e.STATUS_PREVIEW="status-preview",e.STATUS_REJECTED="status-rejected",e.STATUS_SAVED="status-saved",e.STATUS_SAVING="status-saving",e.STATUS_TEMPLATE="status-template",e.STATUS_WARNING="status-warning",e.TABLE="table",e.TABS="tabs",e.TAG="tag",e.TEMPLATE_CIRCLE="template-circle",e.THUMBS_DOWN="thumbs-down",e.THUMBS_DOWN_OUTLINE="thumbs-down-outline",e.THUMBS_UP="thumbs-up",e.THUMBS_UP_OUTLINE="thumbs-up-outline",e.TRASH="trash",e.TRUCK_SHIPPING="truck-shipping",e.TWITTER="twitter",e.UNARCHIVE="unarchive",e.UNDO="undo",e.UNLINK="unlink",e.UNLOCKED="unlocked",e.UPLOAD_CLOUD="upload-cloud",e.USER="user",e.USER_IMPERSONATION="user-impersonation",e.VOLUME_OFF="volume-off",e.VOLUME_LOW="volume-low",e.VOLUME_MEDIUM="volume-medium",e.VOLUME_FULL="volume-full",e.WRENCH="wrench",e.WORKFLOW="workflow",e.WORKFLOW_COMPLETE="workflow-complete",e.X="x",e.X_CIRCLE="x-circle",e))(r||{}),N=(e=>(e.TIP="tip",e.SUCCESS="success",e.WARNING="warning",e.ERROR="error",e.INFO="info",e))(N||{});const X=Object.freeze({tip:r.LIGHTBULB,error:r.EXCLAMATION_CIRCLE,info:r.INFO_CIRCLE,success:r.CHECKMARK,warning:r.EXCLAMATION_TRIANGLE});var u=(e=>(e.GENERAL="general",e.SUCCESS="success",e.ERROR="error",e.WARNING="warning",e.PROCESSING="processing",e))(u||{});const Y=7e3,j=2e3;var C=(e=>(e.ACTIVITY="activity",e.ERROR="error",e.INFO="info",e.PROGRESS="progress",e.SUCCESS="success",e.WARNING="warning",e))(C||{});const s=new Map([["info",r.INFO_CIRCLE],["warning",r.EXCLAMATION_TRIANGLE],["error",r.EXCLAMATION_CIRCLE],["success",r.CHECKMARK]]);var U=(e=>(e.GENERAL="general",e.SUCCESS="success",e.ERROR="error",e.WARNING="warning",e.PROCESSING="processing",e))(U||{});const c=Object.freeze({general:r.STATUS_NEW,success:r.STATUS_OK,error:r.STATUS_ERROR,warning:r.STATUS_WARNING,processing:r.STATUS_IN_PROCESS});var D=(e=>(e.GENERAL="general",e.SUCCESS="success",e.ERROR="error",e.WARNING="warning",e.PROCESSING="processing",e))(D||{});const Q=Object.freeze({general:r.STATUS_NEW,success:r.STATUS_OK,error:r.STATUS_ERROR,warning:r.STATUS_WARNING,processing:r.STATUS_IN_PROCESS});var d=(e=>(e.LIGHT="light",e.DARK="dark",e))(d||{}),f=(e=>(e.BLUE="blue200",e.GRAY="gray600",e.GREEN="green200",e.ORANGE="orange200",e.PURPLE="purple200",e.RED="red200",e))(f||{}),h=(e=>(e.GENERAL="general",e.INFO="info",e.SUCCESS="success",e.WARNING="warning",e.SERIOUS_WARNING="serious-warning",e))(h||{}),G=(e=>(e.SMALL="small",e.MEDIUM="medium",e.LARGE="large",e.X_LARGE="xlarge",e))(G||{});class q{constructor(t,L={}){this.value=t,Object.assign(this,L)}get text(){return this.textInternal?this.textInternal:this.value?this.textKey?this.value[this.textKey]??"":String(this.value):""}set text(t){this.textInternal=t}get caption(){return this.captionInternal?this.captionInternal:this.value&&this.captionKey?this.value[this.captionKey]:""}set caption(t){this.captionInternal=t}get href(){return this.value?this.value.isLink&&typeof this.value=="function"?this.value():this.value.href:null}get disabled(){return typeof this.disabledInternal<"u"?this.disabledInternal:this.value?this.value.disabled:!1}set disabled(t){this.disabledInternal=t}get bold(){return typeof this.boldInternal<"u"?this.boldInternal:this.value?this.value.bold&&this.value.bold===!0:!1}getHtml(t){return t?this.text.replace(t,"<u>$&</u>"):this.text}}const J=[10,25,50,100];var M=(e=>(e.TOP_LEFT="top left",e.TOP_MIDDLE="top middle",e.TOP_RIGHT="top right",e.RIGHT_TOP="right top",e.RIGHT_MIDDLE="right middle",e.RIGHT_BOTTOM="right bottom",e.BOTTOM_RIGHT="bottom right",e.BOTTOM_MIDDLE="bottom middle",e.BOTTOM_LEFT="bottom left",e.LEFT_BOTTOM="left bottom",e.LEFT_MIDDLE="left middle",e.LEFT_TOP="left top",e))(M||{}),m=(e=>(e[e.SMALL=14]="SMALL",e[e.MEDIUM=26]="MEDIUM",e[e.LARGE=38]="LARGE",e))(m||{}),g=(e=>(e.SMALL="small",e.MEDIUM="medium",e.LARGE="large",e))(g||{}),P=(e=>(e.BLUE="blue200",e.GRAY="gray600",e.GREEN="green200",e.ORANGE="orange200",e.PURPLE="purple200",e.RED="red200",e))(P||{}),b=(e=>(e.PURPLE="purple",e.RED="red",e.BLUE="blue",e.ORANGE="orange",e.GRAY="gray",e))(b||{}),v=(e=>(e.ASCENDING="ascending",e.DESCENDING="descending",e))(v||{}),H=(e=>(e.DEFAULT="default",e.KEY="key",e.WARNING="warning",e.ERROR="error",e.PENDING="pending",e.SUCCESS="success",e.INFO="info",e))(H||{});const $=1e3;var n=(e=>(e.MANUAL="manual",e.MOUSEOVER="mouseover",e.CLICK="click",e))(n||{}),F=(e=>(e.DEFAULT="default",e.HELP="help",e.ERROR="error",e.WARNING="warning",e.CONTAINER="container",e))(F||{});const I={icon:"",label:"",caption:"",disabled:!1,isLink:!1};function z(e){return(t,L,S)=>R.simpleMetadataDecoratorApplicator(e,I,t,L,S)}var B=(e=>(e.COMPLETED="completed",e.ERRORED="errored",e.WARNING="warning",e.IN_PROGRESS="in_progress",e))(B||{});const Z=Object.freeze({completed:r.STATUS_OK,errored:r.STATUS_ERROR,warning:r.STATUS_WARNING,in_progress:"sps-spinner sps-spinner--small"}),x=5e3;var W=(e=>(e.BASIC="basic",e.COMPLETED="completed",e.COMPLETE="completed",e.ACTIVE="active",e))(W||{}),w=(e=>(e[e.BASE=0]="BASE",e[e.TIP=10]="TIP",e[e.DROPDOWN=100]="DROPDOWN",e[e.BAR=1e3]="BAR",e[e.DIALOG=1e4]="DIALOG",e))(w||{});E.ButtonKind=y,E.ButtonType=l,E.ClickableTagKind=_,E.DEFAULT_PAGE_SIZE_OPTIONS=J,E.DropdownKind=k,E.FeedbackBlockIcons=X,E.FeedbackBlockKind=N,E.GROWLER_FADEOUT_DURATION_MS=j,E.GROWLER_VISIBLE_DURATION_MS=Y,E.GrowlerIcon=s,E.GrowlerKind=C,E.KeyValueListTitleColor=d,E.LineChartColors=f,E.ModalKind=h,E.ModalSize=G,E.Position=M,E.RingSize=m,E.SPS_ACTION_DEFAULTS=I,E.SelectMode=O,E.SortDirection=v,E.SpinnerSize=g,E.SpsAction=z,E.SpsFilterTileKind=u,E.SpsIcon=r,E.SpsIconSize=i,E.SpsInsightCardIcons=c,E.SpsInsightCardKind=U,E.SpsInsightTileIcons=Q,E.SpsInsightTileKind=D,E.SpsOptionListOption=q,E.SpsTaskStatus=B,E.SpsTaskStatusIcons=Z,E.StackedBarChartMilestone=P,E.StdButtonKind=T,E.SteppedProgressBarColor=b,E.TASK_QUEUE_NOTIFICATION_DURATION_MS=x,E.TOOLTIP_HIDE_DELAY_MS_DEFAULT=$,E.TagKind=H,E.TooltipKind=F,E.TooltipShowTrigger=n,E.WizardSubstepConditions=W,E.ZStratum=w,E.exampleIsReactComponentExample=V,E.exampleIsReactJSXExample=K,Object.defineProperty(E,Symbol.toStringTag,{value:"Module"})});
@@ -0,0 +1,15 @@
1
+ import { SpsIcon } from "./icon";
2
+ export declare enum SpsInsightCardKind {
3
+ GENERAL = "general",
4
+ SUCCESS = "success",
5
+ ERROR = "error",
6
+ WARNING = "warning",
7
+ PROCESSING = "processing"
8
+ }
9
+ export declare const SpsInsightCardIcons: Readonly<{
10
+ general: SpsIcon.STATUS_NEW;
11
+ success: SpsIcon.STATUS_OK;
12
+ error: SpsIcon.STATUS_ERROR;
13
+ warning: SpsIcon.STATUS_WARNING;
14
+ processing: SpsIcon.STATUS_IN_PROCESS;
15
+ }>;
@@ -0,0 +1,15 @@
1
+ import { SpsIcon } from "./icon";
2
+ export declare enum SpsInsightTileKind {
3
+ GENERAL = "general",
4
+ SUCCESS = "success",
5
+ ERROR = "error",
6
+ WARNING = "warning",
7
+ PROCESSING = "processing"
8
+ }
9
+ export declare const SpsInsightTileIcons: Readonly<{
10
+ general: SpsIcon.STATUS_NEW;
11
+ success: SpsIcon.STATUS_OK;
12
+ error: SpsIcon.STATUS_ERROR;
13
+ warning: SpsIcon.STATUS_WARNING;
14
+ processing: SpsIcon.STATUS_IN_PROCESS;
15
+ }>;
@@ -0,0 +1,4 @@
1
+ export declare enum KeyValueListTitleColor {
2
+ LIGHT = "light",
3
+ DARK = "dark"
4
+ }
@@ -0,0 +1,8 @@
1
+ export declare enum LineChartColors {
2
+ BLUE = "blue200",
3
+ GRAY = "gray600",
4
+ GREEN = "green200",
5
+ ORANGE = "orange200",
6
+ PURPLE = "purple200",
7
+ RED = "red200"
8
+ }
package/lib/modal.d.ts ADDED
@@ -0,0 +1,13 @@
1
+ export declare enum ModalKind {
2
+ GENERAL = "general",
3
+ INFO = "info",
4
+ SUCCESS = "success",
5
+ WARNING = "warning",
6
+ SERIOUS_WARNING = "serious-warning"
7
+ }
8
+ export declare enum ModalSize {
9
+ SMALL = "small",
10
+ MEDIUM = "medium",
11
+ LARGE = "large",
12
+ X_LARGE = "xlarge"
13
+ }
@@ -0,0 +1,32 @@
1
+ /** Shape of the config param for the `SpsOptionListOption<T>` constructor. */
2
+ export interface SpsOptionListOptionConfig {
3
+ textKey?: string;
4
+ text?: string;
5
+ bold?: boolean;
6
+ captionKey?: string;
7
+ caption?: string;
8
+ disabled?: boolean;
9
+ }
10
+ /**
11
+ * All options passed in to components such as the select, the autocomplete, etc which
12
+ * use the Option List are normalized internally to this representation of an Option List option.
13
+ */
14
+ export declare class SpsOptionListOption<T> {
15
+ value: T;
16
+ get text(): string;
17
+ set text(value: string);
18
+ get caption(): string;
19
+ set caption(value: string);
20
+ get href(): any;
21
+ get disabled(): boolean;
22
+ set disabled(value: boolean);
23
+ get bold(): any;
24
+ textKey: string;
25
+ captionKey: string;
26
+ private textInternal;
27
+ private captionInternal;
28
+ private disabledInternal;
29
+ private boldInternal;
30
+ constructor(value: T, config?: SpsOptionListOptionConfig);
31
+ getHtml(patternToUnderline?: RegExp | null): string;
32
+ }
@@ -0,0 +1,2 @@
1
+ /** The defaults for the page size selector in the Pagination component. */
2
+ export declare const DEFAULT_PAGE_SIZE_OPTIONS: number[];
@@ -0,0 +1,14 @@
1
+ export declare enum Position {
2
+ TOP_LEFT = "top left",
3
+ TOP_MIDDLE = "top middle",
4
+ TOP_RIGHT = "top right",
5
+ RIGHT_TOP = "right top",
6
+ RIGHT_MIDDLE = "right middle",
7
+ RIGHT_BOTTOM = "right bottom",
8
+ BOTTOM_RIGHT = "bottom right",
9
+ BOTTOM_MIDDLE = "bottom middle",
10
+ BOTTOM_LEFT = "bottom left",
11
+ LEFT_BOTTOM = "left bottom",
12
+ LEFT_MIDDLE = "left middle",
13
+ LEFT_TOP = "left top"
14
+ }
@@ -0,0 +1,5 @@
1
+ export declare enum RingSize {
2
+ SMALL = 14,
3
+ MEDIUM = 26,
4
+ LARGE = 38
5
+ }
@@ -0,0 +1,5 @@
1
+ export declare enum SpinnerSize {
2
+ SMALL = "small",
3
+ MEDIUM = "medium",
4
+ LARGE = "large"
5
+ }
@@ -0,0 +1,27 @@
1
+ import type { MetadataProperty } from "@spscommerce/utils";
2
+ /**
3
+ * Metadata describing an "action" that can be passed in
4
+ * to components such as modal and select.
5
+ */
6
+ export interface SpsActionDescriptor {
7
+ label?: MetadataProperty<string>;
8
+ icon?: MetadataProperty<string>;
9
+ caption?: MetadataProperty<string>;
10
+ disabled?: MetadataProperty<boolean>;
11
+ isLink?: MetadataProperty<boolean>;
12
+ href?: MetadataProperty<string>;
13
+ newTab?: MetadataProperty<boolean>;
14
+ [key: string]: MetadataProperty<any>;
15
+ }
16
+ export declare const SPS_ACTION_DEFAULTS: SpsActionDescriptor;
17
+ /** A method that has been decorated with `@SpsAction`. */
18
+ export interface SpsActionMethod extends SpsActionDescriptor {
19
+ (...args: any[]): any;
20
+ }
21
+ /**
22
+ * Attaches metadata to the decorated method, designating it as an "action"
23
+ * that can be passed in to components such as modal and select. For example,
24
+ * if passed in to the modal, a button will be rendered in the modal using the
25
+ * specified label, icon, etc, and clicking that button will call the method.
26
+ */
27
+ export declare function SpsAction(actionDescriptor: SpsActionDescriptor): MethodDecorator;
@@ -0,0 +1,8 @@
1
+ export declare enum StackedBarChartMilestone {
2
+ BLUE = "blue200",
3
+ GRAY = "gray600",
4
+ GREEN = "green200",
5
+ ORANGE = "orange200",
6
+ PURPLE = "purple200",
7
+ RED = "red200"
8
+ }
@@ -0,0 +1,7 @@
1
+ export declare enum SteppedProgressBarColor {
2
+ PURPLE = "purple",
3
+ RED = "red",
4
+ BLUE = "blue",
5
+ ORANGE = "orange",
6
+ GRAY = "gray"
7
+ }
package/lib/table.d.ts ADDED
@@ -0,0 +1,12 @@
1
+ export declare enum SortDirection {
2
+ ASCENDING = "ascending",
3
+ DESCENDING = "descending"
4
+ }
5
+ export interface SortedColumn {
6
+ key: string;
7
+ direction: SortDirection;
8
+ }
9
+ export type SortChangeHandler = (newSort: SortedColumn[]) => void;
10
+ export type ResizeState = Record<string, number>;
11
+ export type ResizeStateChangeHandler = (newResizeState: ResizeState) => void;
12
+ export type SpsTableCellWrapWidth = 200 | 300 | 400 | 500 | 600;
package/lib/tabs.d.ts ADDED
@@ -0,0 +1,13 @@
1
+ import type { SpsIcon } from "./icon";
2
+ export interface SpsTab {
3
+ /** id of the tab itself. */
4
+ id?: string;
5
+ /**
6
+ * id of the pane associated with the tab, which is
7
+ * displayed when the tab is active.
8
+ */
9
+ controlsId?: string;
10
+ icon?: SpsIcon;
11
+ label: string;
12
+ tag?: string;
13
+ }
package/lib/tag.d.ts ADDED
@@ -0,0 +1,9 @@
1
+ export declare enum TagKind {
2
+ DEFAULT = "default",
3
+ KEY = "key",
4
+ WARNING = "warning",
5
+ ERROR = "error",
6
+ PENDING = "pending",
7
+ SUCCESS = "success",
8
+ INFO = "info"
9
+ }
@@ -0,0 +1,24 @@
1
+ import { SpsIcon } from "./icon";
2
+ import type { SpsActionMethod } from "./sps-action";
3
+ /** The possible statuses for a task in the Task Queue. */
4
+ export declare enum SpsTaskStatus {
5
+ COMPLETED = "completed",
6
+ ERRORED = "errored",
7
+ WARNING = "warning",
8
+ IN_PROGRESS = "in_progress"
9
+ }
10
+ export declare const SpsTaskStatusIcons: Readonly<{
11
+ completed: SpsIcon.STATUS_OK;
12
+ errored: SpsIcon.STATUS_ERROR;
13
+ warning: SpsIcon.STATUS_WARNING;
14
+ in_progress: "sps-spinner sps-spinner--small";
15
+ }>;
16
+ /** Represents a task in the Task Queue. */
17
+ export interface SpsTask {
18
+ status: SpsTaskStatus;
19
+ unread: boolean;
20
+ heading: string;
21
+ subheading: any;
22
+ actions?: SpsActionMethod[];
23
+ }
24
+ export declare const TASK_QUEUE_NOTIFICATION_DURATION_MS = 5000;
@@ -0,0 +1,13 @@
1
+ export declare const TOOLTIP_HIDE_DELAY_MS_DEFAULT = 1000;
2
+ export declare enum TooltipShowTrigger {
3
+ MANUAL = "manual",
4
+ MOUSEOVER = "mouseover",
5
+ CLICK = "click"
6
+ }
7
+ export declare enum TooltipKind {
8
+ DEFAULT = "default",
9
+ HELP = "help",
10
+ ERROR = "error",
11
+ WARNING = "warning",
12
+ CONTAINER = "container"
13
+ }
@@ -0,0 +1,6 @@
1
+ export declare enum WizardSubstepConditions {
2
+ BASIC = "basic",
3
+ COMPLETED = "completed",
4
+ COMPLETE = "completed",
5
+ ACTIVE = "active"
6
+ }
@@ -0,0 +1,7 @@
1
+ export declare enum ZStratum {
2
+ BASE = 0,
3
+ TIP = 10,
4
+ DROPDOWN = 100,
5
+ BAR = 1000,
6
+ DIALOG = 10000
7
+ }
package/package.json ADDED
@@ -0,0 +1,40 @@
1
+ {
2
+ "name": "@spscommerce/ds-shared",
3
+ "description": "Package for sharing code and types between DS Angular and DS React.",
4
+ "version": "0.0.0-20260319-8230915ce",
5
+ "author": "SPS Commerce",
6
+ "license": "UNLICENSED",
7
+ "repository": "https://github.com/spscommerce/woodland/tree/main/packages/@spscommerce/ds-shared",
8
+ "homepage": "https://github.com/spscommerce/woodland/tree/main/packages/@spscommerce/ds-shared#readme",
9
+ "publishConfig": {
10
+ "access": "public"
11
+ },
12
+ "type": "module",
13
+ "module": "./lib/index.js",
14
+ "main": "./lib/index.umd.cjs",
15
+ "types": "./lib/index.d.ts",
16
+ "exports": {
17
+ "types": "./lib/index.d.ts",
18
+ "require": "./lib/index.umd.cjs",
19
+ "import": "./lib/index.js",
20
+ "default": "./lib/index.js"
21
+ },
22
+ "peerDependencies": {
23
+ "@spscommerce/utils": "^7.0.0 || ^8.0.0",
24
+ "moment": "^2.25.3",
25
+ "moment-timezone": "^0.5.48"
26
+ },
27
+ "devDependencies": {
28
+ "@spscommerce/utils": "^8.1.1",
29
+ "moment": "^2.25.3",
30
+ "moment-timezone": "^0.6.0"
31
+ },
32
+ "scripts": {
33
+ "build": "pnpm run build:js && pnpm run build:types",
34
+ "build:js": "vite build",
35
+ "build:types": "tsc --emitDeclarationOnly --declaration --declarationDir lib",
36
+ "watch": "vite build --watch",
37
+ "clean": "git clean -fdX",
38
+ "pub": "node ../../scripts/publish-package.mjs"
39
+ }
40
+ }
package/tsconfig.json ADDED
@@ -0,0 +1,13 @@
1
+ {
2
+ "extends": "../../tsconfig.base.json",
3
+ "compilerOptions": {
4
+ "baseUrl": "tsconfig",
5
+ "rootDir": "src/",
6
+ "outDir": "./lib",
7
+ "target": "es5",
8
+ "esModuleInterop": true,
9
+ "declaration": true
10
+ },
11
+ "include": ["src/**/*"],
12
+ "exclude": ["node_modules", "lib"]
13
+ }
@@ -0,0 +1,20 @@
1
+ import path from "node:path";
2
+
3
+ import { defineConfig } from "vite";
4
+
5
+ import pkg from "./package.json";
6
+
7
+ export default defineConfig({
8
+ build: {
9
+ lib: {
10
+ entry: path.resolve(__dirname, "src/index.ts"),
11
+ name: "DSShared",
12
+ fileName: "index",
13
+ },
14
+ outDir: path.resolve(__dirname, "./lib"),
15
+ emptyOutDir: false,
16
+ rollupOptions: {
17
+ external: pkg.peerDependencies ? Object.keys(pkg.peerDependencies) : [],
18
+ },
19
+ },
20
+ });