@ultraviolet/plus 2.1.5 → 3.0.0-beta.2
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/dist/components/CodeEditor/CodeEditor.cjs +7 -5
- package/dist/components/CodeEditor/CodeEditor.d.ts +2 -1
- package/dist/components/CodeEditor/CodeEditor.js +7 -5
- package/dist/components/EstimateCost/componentStyle.d.ts +10 -8
- package/dist/components/InfoTable/InfoTable.cjs +5 -3
- package/dist/components/InfoTable/InfoTable.d.ts +3 -1
- package/dist/components/InfoTable/InfoTable.js +5 -3
- package/dist/components/InfoTable/components/Row.d.ts +5 -5
- package/dist/components/Navigation/Navigation.d.ts +1 -1
- package/dist/components/Navigation/NavigationContent.cjs +7 -6
- package/dist/components/Navigation/NavigationContent.d.ts +1 -1
- package/dist/components/Navigation/NavigationContent.js +7 -6
- package/dist/components/Navigation/components/Item.cjs +49 -82
- package/dist/components/Navigation/components/Item.d.ts +2 -2
- package/dist/components/Navigation/components/Item.js +62 -95
- package/dist/components/Navigation/types.d.ts +1 -0
- package/dist/components/OfferList/OfferList.cjs +5 -3
- package/dist/components/OfferList/OfferList.d.ts +4 -2
- package/dist/components/OfferList/OfferList.js +5 -3
- package/dist/components/OrderSummary/ScrollableContent.cjs +4 -4
- package/dist/components/OrderSummary/ScrollableContent.js +4 -4
- package/dist/components/OrderSummary/index.cjs +8 -6
- package/dist/components/OrderSummary/index.d.ts +1 -1
- package/dist/components/OrderSummary/index.js +8 -6
- package/dist/components/OrderSummary/types.d.ts +2 -0
- package/package.json +11 -10
|
@@ -21,7 +21,7 @@ const StyledList = /* @__PURE__ */ _styled__default.default(ui.List, process.env
|
|
|
21
21
|
theme
|
|
22
22
|
}) => theme.sizing[700], ";max-width:", ({
|
|
23
23
|
theme
|
|
24
|
-
}) => theme.sizing[700], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVStCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgUm93IH0gZnJvbSAnLi9jb21wb25lbnRzL1JvdydcbmltcG9ydCB7IE9mZmVyTGlzdFByb3ZpZGVyIH0gZnJvbSAnLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkTGlzdCA9IHN0eWxlZChMaXN0KWBcbiAgIHRkOmZpcnN0LWNoaWxkLFxuICAgdGg6Zmlyc3QtY2hpbGQge1xuICAgIHdpZHRoOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtaW4td2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtYXgtd2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+
|
|
24
|
+
}) => theme.sizing[700], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVStCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgUm93IH0gZnJvbSAnLi9jb21wb25lbnRzL1JvdydcbmltcG9ydCB7IE9mZmVyTGlzdFByb3ZpZGVyIH0gZnJvbSAnLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkTGlzdCA9IHN0eWxlZChMaXN0KWBcbiAgIHRkOmZpcnN0LWNoaWxkLFxuICAgdGg6Zmlyc3QtY2hpbGQge1xuICAgIHdpZHRoOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtaW4td2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtYXgtd2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgfVxuYFxuXG50eXBlIE9mZmVyTGlzdFByb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIExpc3Q+LFxuICAnc2VsZWN0YWJsZScgfCAnb25TZWxlY3RlZENoYW5nZSdcbj4gJiB7XG4gIC8qKlxuICAgKiBNYWtlIG9mZmVyTGlzdCBzZWxlY3RhYmxlIGJ5IGNob29zaW5nIGl0cyB0eXBlXG4gICAqL1xuICB0eXBlPzogJ3JhZGlvJyB8ICdjaGVja2JveCdcbiAgb25DaGFuZ2VTZWxlY3Q/OiAoc2VsZWN0ZWQ6IHN0cmluZyB8IHN0cmluZ1tdKSA9PiB2b2lkXG4gIC8qKlxuICAgKiBQcmUtc2VsZWN0ZWQgcm93cyAodXNpbmcgdGhlaXIgb2ZmZXJOYW1lKS4gTXVzdCBiZSBhbiBhcnJheSB3aGVuIGB0eXBlID0gXCJjaGVja2JveFwiYC5cbiAgICovXG4gIHNlbGVjdGVkPzogc3RyaW5nIHwgc3RyaW5nW11cbiAgWydkYXRhLXRlc3RpZCddPzogc3RyaW5nXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgT2ZmZXJMaXN0ID0gKHtcbiAgZXhwYW5kYWJsZSxcbiAgdHlwZSA9ICdyYWRpbycsXG4gIGNvbHVtbnMsXG4gIGNoaWxkcmVuLFxuICBsb2FkaW5nLFxuICBhdXRvQ29sbGFwc2UsXG4gIHNlbGVjdGVkLFxuICBvbkNoYW5nZVNlbGVjdCxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogT2ZmZXJMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgW3JhZGlvU2VsZWN0ZWRSb3csIHNldFJhZGlvU2VsZWN0ZWRSb3ddID0gdXNlU3RhdGU8c3RyaW5nIHwgdW5kZWZpbmVkPihcbiAgICB0eXBlb2Ygc2VsZWN0ZWQgPT09ICdzdHJpbmcnID8gc2VsZWN0ZWQgOiB1bmRlZmluZWQsXG4gIClcbiAgY29uc3QgW2NoZWNrYm94U2VsZWN0ZWRSb3dzLCBzZXRDaGVja2JveFNlbGVjdGVkUm93c10gPSB1c2VTdGF0ZTxzdHJpbmdbXT4oXG4gICAgQXJyYXkuaXNBcnJheShzZWxlY3RlZCkgPyBzZWxlY3RlZCA6IFtdLFxuICApXG5cbiAgY29uc3QgY29tcHV0ZWRDb2x1bW5zID0gW1xuICAgIHtcbiAgICAgIGxhYmVsOiAnJyxcbiAgICB9LFxuICAgIGV4cGFuZGFibGUgPyB7IGxhYmVsOiAnJyB9IDogbnVsbCxcbiAgICAuLi5jb2x1bW5zLFxuICBdLmZpbHRlcihlbGVtZW50ID0+ICEhZWxlbWVudClcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChzZWxlY3RlZCkge1xuICAgICAgaWYgKHR5cGVvZiBzZWxlY3RlZCA9PT0gJ3N0cmluZycgJiYgdHlwZSA9PT0gJ3JhZGlvJykge1xuICAgICAgICBzZXRSYWRpb1NlbGVjdGVkUm93KHNlbGVjdGVkKVxuICAgICAgfVxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkoc2VsZWN0ZWQpICYmIHR5cGUgPT09ICdjaGVja2JveCcpIHtcbiAgICAgICAgc2V0Q2hlY2tib3hTZWxlY3RlZFJvd3Moc2VsZWN0ZWQpXG4gICAgICB9XG4gICAgfVxuICB9LCBbdHlwZSwgc2VsZWN0ZWRdKVxuXG4gIHJldHVybiAoXG4gICAgPE9mZmVyTGlzdFByb3ZpZGVyXG4gICAgICBhdXRvQ29sbGFwc2U9e2F1dG9Db2xsYXBzZX1cbiAgICAgIGNoZWNrYm94U2VsZWN0ZWRSb3dzPXtjaGVja2JveFNlbGVjdGVkUm93c31cbiAgICAgIGV4cGFuZGFibGU9e2V4cGFuZGFibGV9XG4gICAgICBsb2FkaW5nPXtsb2FkaW5nfVxuICAgICAgb25DaGFuZ2VTZWxlY3Q9e29uQ2hhbmdlU2VsZWN0fVxuICAgICAgcmFkaW9TZWxlY3RlZFJvdz17cmFkaW9TZWxlY3RlZFJvd31cbiAgICAgIHNlbGVjdGFibGU9e3R5cGV9XG4gICAgICBzZXRDaGVja2JveFNlbGVjdGVkUm93cz17c2V0Q2hlY2tib3hTZWxlY3RlZFJvd3N9XG4gICAgICBzZXRSYWRpb1NlbGVjdGVkUm93PXtzZXRSYWRpb1NlbGVjdGVkUm93fVxuICAgID5cbiAgICAgIDxTdHlsZWRMaXN0XG4gICAgICAgIGF1dG9Db2xsYXBzZT17YXV0b0NvbGxhcHNlfVxuICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgY29sdW1ucz17Y29tcHV0ZWRDb2x1bW5zfVxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgICAgZXhwYW5kYWJsZT17ZmFsc2V9XG4gICAgICAgIHNlbGVjdGFibGU9e2ZhbHNlfVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L1N0eWxlZExpc3Q+XG4gICAgPC9PZmZlckxpc3RQcm92aWRlcj5cbiAgKVxufVxuXG5PZmZlckxpc3QuUm93ID0gUm93XG5PZmZlckxpc3QuQ2VsbCA9IENlbGxcbiJdfQ== */"));
|
|
25
25
|
const OfferList = ({
|
|
26
26
|
expandable,
|
|
27
27
|
type = "radio",
|
|
@@ -30,7 +30,9 @@ const OfferList = ({
|
|
|
30
30
|
loading,
|
|
31
31
|
autoCollapse,
|
|
32
32
|
selected,
|
|
33
|
-
onChangeSelect
|
|
33
|
+
onChangeSelect,
|
|
34
|
+
className,
|
|
35
|
+
"data-testid": dataTestId
|
|
34
36
|
}) => {
|
|
35
37
|
const [radioSelectedRow, setRadioSelectedRow] = react.useState(typeof selected === "string" ? selected : void 0);
|
|
36
38
|
const [checkboxSelectedRows, setCheckboxSelectedRows] = react.useState(Array.isArray(selected) ? selected : []);
|
|
@@ -49,7 +51,7 @@ const OfferList = ({
|
|
|
49
51
|
}
|
|
50
52
|
}
|
|
51
53
|
}, [type, selected]);
|
|
52
|
-
return /* @__PURE__ */ jsxRuntime.jsx(OfferListProvider.OfferListProvider, { autoCollapse, checkboxSelectedRows, expandable, loading, onChangeSelect, radioSelectedRow, selectable: type, setCheckboxSelectedRows, setRadioSelectedRow, children: /* @__PURE__ */ jsxRuntime.jsx(StyledList, { autoCollapse, columns: computedColumns, expandable: false, selectable: false, children }) });
|
|
54
|
+
return /* @__PURE__ */ jsxRuntime.jsx(OfferListProvider.OfferListProvider, { autoCollapse, checkboxSelectedRows, expandable, loading, onChangeSelect, radioSelectedRow, selectable: type, setCheckboxSelectedRows, setRadioSelectedRow, children: /* @__PURE__ */ jsxRuntime.jsx(StyledList, { autoCollapse, className, columns: computedColumns, "data-testid": dataTestId, expandable: false, selectable: false, children }) });
|
|
53
55
|
};
|
|
54
56
|
OfferList.Row = Row.Row;
|
|
55
57
|
OfferList.Cell = Cell.Cell;
|
|
@@ -10,16 +10,18 @@ type OfferListProps = Omit<ComponentProps<typeof List>, 'selectable' | 'onSelect
|
|
|
10
10
|
* Pre-selected rows (using their offerName). Must be an array when `type = "checkbox"`.
|
|
11
11
|
*/
|
|
12
12
|
selected?: string | string[];
|
|
13
|
+
['data-testid']?: string;
|
|
14
|
+
className?: string;
|
|
13
15
|
};
|
|
14
16
|
export declare const OfferList: {
|
|
15
|
-
({ expandable, type, columns, children, loading, autoCollapse, selected, onChangeSelect, }: OfferListProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
17
|
+
({ expandable, type, columns, children, loading, autoCollapse, selected, onChangeSelect, className, "data-testid": dataTestId, }: OfferListProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
16
18
|
Row: ({ children, disabled, id, banner, expandablePadding, offerName, expandable: expandableContent, selectDisabled, highlightAnimation, expanded, className, "data-dragging": dataDragging, "data-testid": dataTestId, style, badge, }: {
|
|
17
19
|
children: import("react").ReactNode;
|
|
18
20
|
id: string;
|
|
19
21
|
expandable?: import("react").ReactNode;
|
|
20
22
|
selectDisabled?: boolean | string;
|
|
21
23
|
disabled?: boolean;
|
|
22
|
-
sentiment?: "
|
|
24
|
+
sentiment?: "danger" | "info" | "neutral" | "success" | "primary" | "warning" | "secondary";
|
|
23
25
|
expanded?: boolean;
|
|
24
26
|
className?: string;
|
|
25
27
|
expandablePadding?: "0" | "1" | "0.5" | "0.25" | "1.5" | "2" | "3" | "4" | "5" | "6" | "7" | "8" | "9" | "10";
|
|
@@ -17,7 +17,7 @@ const StyledList = /* @__PURE__ */ _styled(List, process.env.NODE_ENV === "produ
|
|
|
17
17
|
theme
|
|
18
18
|
}) => theme.sizing[700], ";max-width:", ({
|
|
19
19
|
theme
|
|
20
|
-
}) => theme.sizing[700], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVStCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgUm93IH0gZnJvbSAnLi9jb21wb25lbnRzL1JvdydcbmltcG9ydCB7IE9mZmVyTGlzdFByb3ZpZGVyIH0gZnJvbSAnLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkTGlzdCA9IHN0eWxlZChMaXN0KWBcbiAgIHRkOmZpcnN0LWNoaWxkLFxuICAgdGg6Zmlyc3QtY2hpbGQge1xuICAgIHdpZHRoOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtaW4td2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtYXgtd2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+
|
|
20
|
+
}) => theme.sizing[700], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVStCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgUm93IH0gZnJvbSAnLi9jb21wb25lbnRzL1JvdydcbmltcG9ydCB7IE9mZmVyTGlzdFByb3ZpZGVyIH0gZnJvbSAnLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkTGlzdCA9IHN0eWxlZChMaXN0KWBcbiAgIHRkOmZpcnN0LWNoaWxkLFxuICAgdGg6Zmlyc3QtY2hpbGQge1xuICAgIHdpZHRoOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtaW4td2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtYXgtd2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgfVxuYFxuXG50eXBlIE9mZmVyTGlzdFByb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIExpc3Q+LFxuICAnc2VsZWN0YWJsZScgfCAnb25TZWxlY3RlZENoYW5nZSdcbj4gJiB7XG4gIC8qKlxuICAgKiBNYWtlIG9mZmVyTGlzdCBzZWxlY3RhYmxlIGJ5IGNob29zaW5nIGl0cyB0eXBlXG4gICAqL1xuICB0eXBlPzogJ3JhZGlvJyB8ICdjaGVja2JveCdcbiAgb25DaGFuZ2VTZWxlY3Q/OiAoc2VsZWN0ZWQ6IHN0cmluZyB8IHN0cmluZ1tdKSA9PiB2b2lkXG4gIC8qKlxuICAgKiBQcmUtc2VsZWN0ZWQgcm93cyAodXNpbmcgdGhlaXIgb2ZmZXJOYW1lKS4gTXVzdCBiZSBhbiBhcnJheSB3aGVuIGB0eXBlID0gXCJjaGVja2JveFwiYC5cbiAgICovXG4gIHNlbGVjdGVkPzogc3RyaW5nIHwgc3RyaW5nW11cbiAgWydkYXRhLXRlc3RpZCddPzogc3RyaW5nXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgT2ZmZXJMaXN0ID0gKHtcbiAgZXhwYW5kYWJsZSxcbiAgdHlwZSA9ICdyYWRpbycsXG4gIGNvbHVtbnMsXG4gIGNoaWxkcmVuLFxuICBsb2FkaW5nLFxuICBhdXRvQ29sbGFwc2UsXG4gIHNlbGVjdGVkLFxuICBvbkNoYW5nZVNlbGVjdCxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogT2ZmZXJMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgW3JhZGlvU2VsZWN0ZWRSb3csIHNldFJhZGlvU2VsZWN0ZWRSb3ddID0gdXNlU3RhdGU8c3RyaW5nIHwgdW5kZWZpbmVkPihcbiAgICB0eXBlb2Ygc2VsZWN0ZWQgPT09ICdzdHJpbmcnID8gc2VsZWN0ZWQgOiB1bmRlZmluZWQsXG4gIClcbiAgY29uc3QgW2NoZWNrYm94U2VsZWN0ZWRSb3dzLCBzZXRDaGVja2JveFNlbGVjdGVkUm93c10gPSB1c2VTdGF0ZTxzdHJpbmdbXT4oXG4gICAgQXJyYXkuaXNBcnJheShzZWxlY3RlZCkgPyBzZWxlY3RlZCA6IFtdLFxuICApXG5cbiAgY29uc3QgY29tcHV0ZWRDb2x1bW5zID0gW1xuICAgIHtcbiAgICAgIGxhYmVsOiAnJyxcbiAgICB9LFxuICAgIGV4cGFuZGFibGUgPyB7IGxhYmVsOiAnJyB9IDogbnVsbCxcbiAgICAuLi5jb2x1bW5zLFxuICBdLmZpbHRlcihlbGVtZW50ID0+ICEhZWxlbWVudClcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChzZWxlY3RlZCkge1xuICAgICAgaWYgKHR5cGVvZiBzZWxlY3RlZCA9PT0gJ3N0cmluZycgJiYgdHlwZSA9PT0gJ3JhZGlvJykge1xuICAgICAgICBzZXRSYWRpb1NlbGVjdGVkUm93KHNlbGVjdGVkKVxuICAgICAgfVxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkoc2VsZWN0ZWQpICYmIHR5cGUgPT09ICdjaGVja2JveCcpIHtcbiAgICAgICAgc2V0Q2hlY2tib3hTZWxlY3RlZFJvd3Moc2VsZWN0ZWQpXG4gICAgICB9XG4gICAgfVxuICB9LCBbdHlwZSwgc2VsZWN0ZWRdKVxuXG4gIHJldHVybiAoXG4gICAgPE9mZmVyTGlzdFByb3ZpZGVyXG4gICAgICBhdXRvQ29sbGFwc2U9e2F1dG9Db2xsYXBzZX1cbiAgICAgIGNoZWNrYm94U2VsZWN0ZWRSb3dzPXtjaGVja2JveFNlbGVjdGVkUm93c31cbiAgICAgIGV4cGFuZGFibGU9e2V4cGFuZGFibGV9XG4gICAgICBsb2FkaW5nPXtsb2FkaW5nfVxuICAgICAgb25DaGFuZ2VTZWxlY3Q9e29uQ2hhbmdlU2VsZWN0fVxuICAgICAgcmFkaW9TZWxlY3RlZFJvdz17cmFkaW9TZWxlY3RlZFJvd31cbiAgICAgIHNlbGVjdGFibGU9e3R5cGV9XG4gICAgICBzZXRDaGVja2JveFNlbGVjdGVkUm93cz17c2V0Q2hlY2tib3hTZWxlY3RlZFJvd3N9XG4gICAgICBzZXRSYWRpb1NlbGVjdGVkUm93PXtzZXRSYWRpb1NlbGVjdGVkUm93fVxuICAgID5cbiAgICAgIDxTdHlsZWRMaXN0XG4gICAgICAgIGF1dG9Db2xsYXBzZT17YXV0b0NvbGxhcHNlfVxuICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgY29sdW1ucz17Y29tcHV0ZWRDb2x1bW5zfVxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgICAgZXhwYW5kYWJsZT17ZmFsc2V9XG4gICAgICAgIHNlbGVjdGFibGU9e2ZhbHNlfVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L1N0eWxlZExpc3Q+XG4gICAgPC9PZmZlckxpc3RQcm92aWRlcj5cbiAgKVxufVxuXG5PZmZlckxpc3QuUm93ID0gUm93XG5PZmZlckxpc3QuQ2VsbCA9IENlbGxcbiJdfQ== */"));
|
|
21
21
|
const OfferList = ({
|
|
22
22
|
expandable,
|
|
23
23
|
type = "radio",
|
|
@@ -26,7 +26,9 @@ const OfferList = ({
|
|
|
26
26
|
loading,
|
|
27
27
|
autoCollapse,
|
|
28
28
|
selected,
|
|
29
|
-
onChangeSelect
|
|
29
|
+
onChangeSelect,
|
|
30
|
+
className,
|
|
31
|
+
"data-testid": dataTestId
|
|
30
32
|
}) => {
|
|
31
33
|
const [radioSelectedRow, setRadioSelectedRow] = useState(typeof selected === "string" ? selected : void 0);
|
|
32
34
|
const [checkboxSelectedRows, setCheckboxSelectedRows] = useState(Array.isArray(selected) ? selected : []);
|
|
@@ -45,7 +47,7 @@ const OfferList = ({
|
|
|
45
47
|
}
|
|
46
48
|
}
|
|
47
49
|
}, [type, selected]);
|
|
48
|
-
return /* @__PURE__ */ jsx(OfferListProvider, { autoCollapse, checkboxSelectedRows, expandable, loading, onChangeSelect, radioSelectedRow, selectable: type, setCheckboxSelectedRows, setRadioSelectedRow, children: /* @__PURE__ */ jsx(StyledList, { autoCollapse, columns: computedColumns, expandable: false, selectable: false, children }) });
|
|
50
|
+
return /* @__PURE__ */ jsx(OfferListProvider, { autoCollapse, checkboxSelectedRows, expandable, loading, onChangeSelect, radioSelectedRow, selectable: type, setCheckboxSelectedRows, setRadioSelectedRow, children: /* @__PURE__ */ jsx(StyledList, { autoCollapse, className, columns: computedColumns, "data-testid": dataTestId, expandable: false, selectable: false, children }) });
|
|
49
51
|
};
|
|
50
52
|
OfferList.Row = Row;
|
|
51
53
|
OfferList.Cell = Cell;
|
|
@@ -15,7 +15,7 @@ const StyledNumberInputV2 = /* @__PURE__ */ _styled__default.default(ui.NumberIn
|
|
|
15
15
|
label: "StyledNumberInputV2"
|
|
16
16
|
})("max-width:12.5rem;background-color:", ({
|
|
17
17
|
theme
|
|
18
|
-
}) => theme.colors.neutral.background, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAW+C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
18
|
+
}) => theme.colors.neutral.background, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAW+C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
19
19
|
const ContainerScrollable = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
|
|
20
20
|
target: "e3ux9t2"
|
|
21
21
|
} : {
|
|
@@ -23,7 +23,7 @@ const ContainerScrollable = /* @__PURE__ */ _styled__default.default(ui.Stack, p
|
|
|
23
23
|
label: "ContainerScrollable"
|
|
24
24
|
})("overflow-y:scroll;padding:", ({
|
|
25
25
|
theme
|
|
26
|
-
}) => theme.space[3], ";height:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAeyC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
26
|
+
}) => theme.space[3], ";min-height:10rem;height:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAeyC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
27
27
|
const DetailsStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
|
|
28
28
|
target: "e3ux9t1"
|
|
29
29
|
} : {
|
|
@@ -31,7 +31,7 @@ const DetailsStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.
|
|
|
31
31
|
label: "DetailsStack"
|
|
32
32
|
})("padding-left:", ({
|
|
33
33
|
theme
|
|
34
|
-
}) => theme.space[1], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAqBkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
34
|
+
}) => theme.space[1], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAsBkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
35
35
|
const CategoryStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
|
|
36
36
|
target: "e3ux9t0"
|
|
37
37
|
} : {
|
|
@@ -41,7 +41,7 @@ const CategoryStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process
|
|
|
41
41
|
theme
|
|
42
42
|
}) => theme.colors.neutral.border, ";padding-bottom:", ({
|
|
43
43
|
theme
|
|
44
|
-
}) => theme.space[3], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAwBmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
44
|
+
}) => theme.space[3], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAyBmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
45
45
|
const CategoryName = ({
|
|
46
46
|
category
|
|
47
47
|
}) => {
|
|
@@ -11,7 +11,7 @@ const StyledNumberInputV2 = /* @__PURE__ */ _styled(NumberInput, process.env.NOD
|
|
|
11
11
|
label: "StyledNumberInputV2"
|
|
12
12
|
})("max-width:12.5rem;background-color:", ({
|
|
13
13
|
theme
|
|
14
|
-
}) => theme.colors.neutral.background, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAW+C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
14
|
+
}) => theme.colors.neutral.background, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAW+C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
15
15
|
const ContainerScrollable = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
|
|
16
16
|
target: "e3ux9t2"
|
|
17
17
|
} : {
|
|
@@ -19,7 +19,7 @@ const ContainerScrollable = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV
|
|
|
19
19
|
label: "ContainerScrollable"
|
|
20
20
|
})("overflow-y:scroll;padding:", ({
|
|
21
21
|
theme
|
|
22
|
-
}) => theme.space[3], ";height:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAeyC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
22
|
+
}) => theme.space[3], ";min-height:10rem;height:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAeyC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
23
23
|
const DetailsStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
|
|
24
24
|
target: "e3ux9t1"
|
|
25
25
|
} : {
|
|
@@ -27,7 +27,7 @@ const DetailsStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "pr
|
|
|
27
27
|
label: "DetailsStack"
|
|
28
28
|
})("padding-left:", ({
|
|
29
29
|
theme
|
|
30
|
-
}) => theme.space[1], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAqBkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
30
|
+
}) => theme.space[1], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAsBkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
31
31
|
const CategoryStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
|
|
32
32
|
target: "e3ux9t0"
|
|
33
33
|
} : {
|
|
@@ -37,7 +37,7 @@ const CategoryStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "p
|
|
|
37
37
|
theme
|
|
38
38
|
}) => theme.colors.neutral.border, ";padding-bottom:", ({
|
|
39
39
|
theme
|
|
40
|
-
}) => theme.space[3], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAwBmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
40
|
+
}) => theme.space[3], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx"],"names":[],"mappings":"AAyBmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
|
|
41
41
|
const CategoryName = ({
|
|
42
42
|
category
|
|
43
43
|
}) => {
|