@ultraviolet/plus 3.0.0-beta.10 → 3.0.0-beta.11

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.
Files changed (32) hide show
  1. package/dist/components/Conversation/index.cjs +7 -97
  2. package/dist/components/Conversation/index.js +7 -95
  3. package/dist/components/Conversation/styles.css.cjs +17 -0
  4. package/dist/components/Conversation/styles.css.d.ts +7 -0
  5. package/dist/components/Conversation/styles.css.js +17 -0
  6. package/dist/components/InfoTable/InfoTable.cjs +5 -18
  7. package/dist/components/InfoTable/InfoTable.js +6 -17
  8. package/dist/components/InfoTable/components/Cell.cjs +3 -32
  9. package/dist/components/InfoTable/components/Cell.d.ts +0 -4
  10. package/dist/components/InfoTable/components/Cell.js +4 -31
  11. package/dist/components/InfoTable/components/Row.cjs +12 -17
  12. package/dist/components/InfoTable/components/Row.d.ts +0 -12
  13. package/dist/components/InfoTable/components/Row.js +13 -16
  14. package/dist/components/InfoTable/context.cjs +5 -0
  15. package/dist/components/InfoTable/context.d.ts +3 -0
  16. package/dist/components/InfoTable/context.js +5 -0
  17. package/dist/components/InfoTable/styles.css.cjs +15 -0
  18. package/dist/components/InfoTable/styles.css.d.ts +6 -0
  19. package/dist/components/InfoTable/styles.css.js +15 -0
  20. package/dist/components/OfferList/OfferList.cjs +2 -16
  21. package/dist/components/OfferList/OfferList.js +2 -14
  22. package/dist/components/OfferList/components/Banner.cjs +8 -95
  23. package/dist/components/OfferList/components/Banner.js +9 -94
  24. package/dist/components/OfferList/components/Cell.cjs +2 -33
  25. package/dist/components/OfferList/components/Cell.js +3 -32
  26. package/dist/components/OfferList/components/Row.cjs +12 -91
  27. package/dist/components/OfferList/components/Row.js +15 -92
  28. package/dist/components/OfferList/styles.css.cjs +34 -0
  29. package/dist/components/OfferList/styles.css.d.ts +40 -0
  30. package/dist/components/OfferList/styles.css.js +34 -0
  31. package/dist/plus.css +1 -1
  32. package/package.json +9 -8
@@ -1,98 +1,7 @@
1
1
  "use client";
2
2
  import { jsx } from "@emotion/react/jsx-runtime";
3
- import _styled from "@emotion/styled/base";
4
- import { Text, Stack, List } from "@ultraviolet/ui";
5
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
6
- return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
7
- }
8
- const BannerWrapper = /* @__PURE__ */ _styled("tr", process.env.NODE_ENV === "production" ? {
9
- target: "edd5t9g3"
10
- } : {
11
- target: "edd5t9g3",
12
- label: "BannerWrapper"
13
- })("width:100%;display:table-row;vertical-align:middle;cursor:auto;background:", ({
14
- theme
15
- }) => theme.colors.neutral.backgroundWeak, ";border-radius:0 0 ", ({
16
- theme
17
- }) => theme.radii.default, " ", ({
18
- theme
19
- }) => theme.radii.default, ";position:relative;td,td:first-child,td:last-child{transition:box-shadow 200ms ease,border-color 200ms ease;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L2NvbXBvbmVudHMvQmFubmVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNK0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9PZmZlckxpc3QvY29tcG9uZW50cy9CYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgTGlzdCwgU3RhY2ssIFRleHQgfSBmcm9tICdAdWx0cmF2aW9sZXQvdWknXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcblxuY29uc3QgQmFubmVyV3JhcHBlciA9IHN0eWxlZC50cmBcbiAgd2lkdGg6IDEwMCU7XG4gIGRpc3BsYXk6IHRhYmxlLXJvdztcbiAgdmVydGljYWwtYWxpZ246IG1pZGRsZTtcbiAgY3Vyc29yOiBhdXRvO1xuICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmRXZWFrfTtcbiAgYm9yZGVyLXJhZGl1czogMCAwICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH0gJHsoeyB0aGVtZSB9KSA9PlxuICAgIHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG5cbiAgdGQsIHRkOmZpcnN0LWNoaWxkLCB0ZDpsYXN0LWNoaWxkIHtcbiAgICB0cmFuc2l0aW9uOlxuICAgICAgYm94LXNoYWRvdyAyMDBtcyBlYXNlLFxuICAgICAgYm9yZGVyLWNvbG9yIDIwMG1zIGVhc2U7XG4gIH1cbmBcblxuY29uc3QgU3R5bGVkVGV4dCA9IHN0eWxlZChUZXh0LCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NlbnRpbWVudCcsICdwcmltYXJ5Qm9yZGVyJ10uaW5jbHVkZXMocHJvcCksXG59KTx7XG4gIHNlbnRpbWVudDogQ29tcG9uZW50UHJvcHM8dHlwZW9mIExpc3QuUm93Plsnc2VudGltZW50J11cbiAgcHJpbWFyeUJvcmRlcj86IGJvb2xlYW5cbn0+YFxuICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgMjAwbXMgZWFzZTtcbiAgbWFyZ2luLXRvcDogLSR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbMl19O1xuICBwYWRkaW5nLWJsb2NrOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycwLjUnXX07XG4gIHBhZGRpbmctaW5saW5lOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICBib3JkZXI6IDFweCBzb2xpZCAkeyh7IHRoZW1lLCBwcmltYXJ5Qm9yZGVyLCBkaXNhYmxlZCB9KSA9PiAocHJpbWFyeUJvcmRlciAmJiAhZGlzYWJsZWQgPyB0aGVtZS5jb2xvcnMucHJpbWFyeS5ib3JkZXIgOiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXIpfTtcbiAgYm9yZGVyLXRvcDogbm9uZTtcbiAgYm9yZGVyLXJhZGl1czogMCAwICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH0gJHsoeyB0aGVtZSB9KSA9PlxuICAgIHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuXG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUsIHNlbnRpbWVudCwgZGlzYWJsZWQgfSkgPT4ge1xuICAgIGlmIChzZW50aW1lbnQgJiYgc2VudGltZW50ICE9PSAnbmV1dHJhbCcpIHtcbiAgICAgIHJldHVybiB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtcbiAgICAgICAgZGlzYWJsZWQgPyAnYmFja2dyb3VuZERpc2FibGVkJyA6ICdiYWNrZ3JvdW5kJ1xuICAgICAgXVxuICAgIH1cblxuICAgIHJldHVybiB0aGVtZS5jb2xvcnMubmV1dHJhbFtcbiAgICAgIGRpc2FibGVkID8gJ2JhY2tncm91bmRXZWFrJyA6ICdiYWNrZ3JvdW5kV2Vha0Rpc2FibGVkJ1xuICAgIF1cbiAgfX07XG5cbiAgY29sb3I6ICR7KHsgdGhlbWUsIHNlbnRpbWVudCwgZGlzYWJsZWQgfSkgPT4gdGhlbWUuY29sb3JzW3NlbnRpbWVudCA/PyAnbmV1dHJhbCddW2Rpc2FibGVkID8gJ3RleHREaXNhYmxlZCcgOiAndGV4dCddfTtcbmBcblxuY29uc3QgU3R5bGVkQ2VsbCA9IHN0eWxlZChMaXN0LkNlbGwpYFxuICBoZWlnaHQ6IGZpdC1jb250ZW50O1xuICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuICBib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogMDtcbiAgd2lkdGg6IDEwMCU7XG4gIHBhZGRpbmc6IDA7XG5gXG5cbmNvbnN0IFN0eWxlZFN0YWNrID0gc3R5bGVkKFN0YWNrLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8eyBzZW50aW1lbnQ6IENvbXBvbmVudFByb3BzPHR5cGVvZiBMaXN0LlJvdz5bJ3NlbnRpbWVudCddIH0+YFxuICBoZWlnaHQ6IGZpdC1jb250ZW50O1xuICBib3JkZXItdG9wOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuXG4gIGJvcmRlci1yYWRpdXM6IDAgMCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9ICR7KHsgdGhlbWUgfSkgPT5cbiAgICB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSwgc2VudGltZW50IH0pID0+IHtcbiAgICBpZiAoc2VudGltZW50ICYmIHNlbnRpbWVudCAhPT0gJ25ldXRyYWwnKSB7XG4gICAgICByZXR1cm4gdGhlbWUuY29sb3JzW3NlbnRpbWVudF0uYmFja2dyb3VuZFxuICAgIH1cblxuICAgIHJldHVybiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kV2Vha1xuICB9fTtcbiAgd2lkdGg6IDEwMCU7XG4gIHBhZGRpbmctYmxvY2s6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzAuNSddfTtcbiAgcGFkZGluZy1pbmxpbmU6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5cbiAgJlthcmlhLWRpc2FibGVkPVwidHJ1ZVwiXSB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kRGlzYWJsZWR9O1xuICB9XG5gXG5cbnR5cGUgQmFubmVyUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgc2VudGltZW50PzogQ29tcG9uZW50UHJvcHM8dHlwZW9mIExpc3QuUm93Plsnc2VudGltZW50J11cbiAgZGlzYWJsZWQ/OiBib29sZWFuXG4gIGNvbFNwYW4/OiBudW1iZXJcbiAgdHlwZT86ICdjZWxsJyB8ICdkaXYnXG4gIHNob3VsZEhhdmVQcmltYXJ5Qm9yZGVyPzogYm9vbGVhblxufVxuXG5leHBvcnQgY29uc3QgQmFubmVyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHNlbnRpbWVudCA9ICduZXV0cmFsJyxcbiAgZGlzYWJsZWQsXG4gIGNvbFNwYW4gPSAxMDAwLFxuICB0eXBlID0gJ2RpdicsXG4gIHNob3VsZEhhdmVQcmltYXJ5Qm9yZGVyLFxufTogQmFubmVyUHJvcHMpID0+XG4gIHR5cGUgPT09ICdkaXYnID8gKFxuICAgIDxTdHlsZWRTdGFjayBhcmlhLWRpc2FibGVkPXtkaXNhYmxlZH0gc2VudGltZW50PXtzZW50aW1lbnR9PlxuICAgICAgPFRleHQgYXM9XCJwXCIgZGlzYWJsZWQ9e2Rpc2FibGVkfSBzZW50aW1lbnQ9e3NlbnRpbWVudH0gdmFyaWFudD1cImNhcHRpb25cIj5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9UZXh0PlxuICAgIDwvU3R5bGVkU3RhY2s+XG4gICkgOiAoXG4gICAgPEJhbm5lcldyYXBwZXI+XG4gICAgICA8U3R5bGVkQ2VsbCBhcmlhLWRpc2FibGVkPXtkaXNhYmxlZH0gY29sU3Bhbj17Y29sU3Bhbn0+XG4gICAgICAgIDxTdHlsZWRUZXh0XG4gICAgICAgICAgYXM9XCJwXCJcbiAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgcHJpbWFyeUJvcmRlcj17c2hvdWxkSGF2ZVByaW1hcnlCb3JkZXJ9XG4gICAgICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICAgICAgdmFyaWFudD1cImNhcHRpb25cIlxuICAgICAgICA+XG4gICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICA8L1N0eWxlZFRleHQ+XG4gICAgICA8L1N0eWxlZENlbGw+XG4gICAgPC9CYW5uZXJXcmFwcGVyPlxuICApXG4iXX0= */"));
20
- const StyledText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
21
- shouldForwardProp: (prop) => !["sentiment", "primaryBorder"].includes(prop),
22
- target: "edd5t9g2"
23
- } : {
24
- shouldForwardProp: (prop) => !["sentiment", "primaryBorder"].includes(prop),
25
- target: "edd5t9g2",
26
- label: "StyledText"
27
- })("transition:border-color 200ms ease;margin-top:-", ({
28
- theme
29
- }) => theme.space[2], ";padding-block:", ({
30
- theme
31
- }) => theme.space["0.5"], ";padding-inline:", ({
32
- theme
33
- }) => theme.space["1"], ";border:1px solid ", ({
34
- theme,
35
- primaryBorder,
36
- disabled
37
- }) => primaryBorder && !disabled ? theme.colors.primary.border : theme.colors.neutral.border, ";border-top:none;border-radius:0 0 ", ({
38
- theme
39
- }) => theme.radii.default, " ", ({
40
- theme
41
- }) => theme.radii.default, ";background-color:", ({
42
- theme,
43
- sentiment,
44
- disabled
45
- }) => {
46
- if (sentiment && sentiment !== "neutral") {
47
- return theme.colors[sentiment][disabled ? "backgroundDisabled" : "background"];
48
- }
49
- return theme.colors.neutral[disabled ? "backgroundWeak" : "backgroundWeakDisabled"];
50
- }, ";color:", ({
51
- theme,
52
- sentiment,
53
- disabled
54
- }) => theme.colors[sentiment ?? "neutral"][disabled ? "textDisabled" : "text"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L2NvbXBvbmVudHMvQmFubmVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0QkUiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9PZmZlckxpc3QvY29tcG9uZW50cy9CYW5uZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgTGlzdCwgU3RhY2ssIFRleHQgfSBmcm9tICdAdWx0cmF2aW9sZXQvdWknXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudFByb3BzLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcblxuY29uc3QgQmFubmVyV3JhcHBlciA9IHN0eWxlZC50cmBcbiAgd2lkdGg6IDEwMCU7XG4gIGRpc3BsYXk6IHRhYmxlLXJvdztcbiAgdmVydGljYWwtYWxpZ246IG1pZGRsZTtcbiAgY3Vyc29yOiBhdXRvO1xuICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmRXZWFrfTtcbiAgYm9yZGVyLXJhZGl1czogMCAwICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH0gJHsoeyB0aGVtZSB9KSA9PlxuICAgIHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG5cbiAgdGQsIHRkOmZpcnN0LWNoaWxkLCB0ZDpsYXN0LWNoaWxkIHtcbiAgICB0cmFuc2l0aW9uOlxuICAgICAgYm94LXNoYWRvdyAyMDBtcyBlYXNlLFxuICAgICAgYm9yZGVyLWNvbG9yIDIwMG1zIGVhc2U7XG4gIH1cbmBcblxuY29uc3QgU3R5bGVkVGV4dCA9IHN0eWxlZChUZXh0LCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NlbnRpbWVudCcsICdwcmltYXJ5Qm9yZGVyJ10uaW5jbHVkZXMocHJvcCksXG59KTx7XG4gIHNlbnRpbWVudDogQ29tcG9uZW50UHJvcHM8dHlwZW9mIExpc3QuUm93Plsnc2VudGltZW50J11cbiAgcHJpbWFyeUJvcmRlcj86IGJvb2xlYW5cbn0+YFxuICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgMjAwbXMgZWFzZTtcbiAgbWFyZ2luLXRvcDogLSR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbMl19O1xuICBwYWRkaW5nLWJsb2NrOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycwLjUnXX07XG4gIHBhZGRpbmctaW5saW5lOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuICBib3JkZXI6IDFweCBzb2xpZCAkeyh7IHRoZW1lLCBwcmltYXJ5Qm9yZGVyLCBkaXNhYmxlZCB9KSA9PiAocHJpbWFyeUJvcmRlciAmJiAhZGlzYWJsZWQgPyB0aGVtZS5jb2xvcnMucHJpbWFyeS5ib3JkZXIgOiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXIpfTtcbiAgYm9yZGVyLXRvcDogbm9uZTtcbiAgYm9yZGVyLXJhZGl1czogMCAwICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH0gJHsoeyB0aGVtZSB9KSA9PlxuICAgIHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuXG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUsIHNlbnRpbWVudCwgZGlzYWJsZWQgfSkgPT4ge1xuICAgIGlmIChzZW50aW1lbnQgJiYgc2VudGltZW50ICE9PSAnbmV1dHJhbCcpIHtcbiAgICAgIHJldHVybiB0aGVtZS5jb2xvcnNbc2VudGltZW50XVtcbiAgICAgICAgZGlzYWJsZWQgPyAnYmFja2dyb3VuZERpc2FibGVkJyA6ICdiYWNrZ3JvdW5kJ1xuICAgICAgXVxuICAgIH1cblxuICAgIHJldHVybiB0aGVtZS5jb2xvcnMubmV1dHJhbFtcbiAgICAgIGRpc2FibGVkID8gJ2JhY2tncm91bmRXZWFrJyA6ICdiYWNrZ3JvdW5kV2Vha0Rpc2FibGVkJ1xuICAgIF1cbiAgfX07XG5cbiAgY29sb3I6ICR7KHsgdGhlbWUsIHNlbnRpbWVudCwgZGlzYWJsZWQgfSkgPT4gdGhlbWUuY29sb3JzW3NlbnRpbWVudCA/PyAnbmV1dHJhbCddW2Rpc2FibGVkID8gJ3RleHREaXNhYmxlZCcgOiAndGV4dCddfTtcbmBcblxuY29uc3QgU3R5bGVkQ2VsbCA9IHN0eWxlZChMaXN0LkNlbGwpYFxuICBoZWlnaHQ6IGZpdC1jb250ZW50O1xuICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuICBib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogMDtcbiAgd2lkdGg6IDEwMCU7XG4gIHBhZGRpbmc6IDA7XG5gXG5cbmNvbnN0IFN0eWxlZFN0YWNrID0gc3R5bGVkKFN0YWNrLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8eyBzZW50aW1lbnQ6IENvbXBvbmVudFByb3BzPHR5cGVvZiBMaXN0LlJvdz5bJ3NlbnRpbWVudCddIH0+YFxuICBoZWlnaHQ6IGZpdC1jb250ZW50O1xuICBib3JkZXItdG9wOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuXG4gIGJvcmRlci1yYWRpdXM6IDAgMCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9ICR7KHsgdGhlbWUgfSkgPT5cbiAgICB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSwgc2VudGltZW50IH0pID0+IHtcbiAgICBpZiAoc2VudGltZW50ICYmIHNlbnRpbWVudCAhPT0gJ25ldXRyYWwnKSB7XG4gICAgICByZXR1cm4gdGhlbWUuY29sb3JzW3NlbnRpbWVudF0uYmFja2dyb3VuZFxuICAgIH1cblxuICAgIHJldHVybiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kV2Vha1xuICB9fTtcbiAgd2lkdGg6IDEwMCU7XG4gIHBhZGRpbmctYmxvY2s6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzAuNSddfTtcbiAgcGFkZGluZy1pbmxpbmU6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5cbiAgJlthcmlhLWRpc2FibGVkPVwidHJ1ZVwiXSB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kRGlzYWJsZWR9O1xuICB9XG5gXG5cbnR5cGUgQmFubmVyUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgc2VudGltZW50PzogQ29tcG9uZW50UHJvcHM8dHlwZW9mIExpc3QuUm93Plsnc2VudGltZW50J11cbiAgZGlzYWJsZWQ/OiBib29sZWFuXG4gIGNvbFNwYW4/OiBudW1iZXJcbiAgdHlwZT86ICdjZWxsJyB8ICdkaXYnXG4gIHNob3VsZEhhdmVQcmltYXJ5Qm9yZGVyPzogYm9vbGVhblxufVxuXG5leHBvcnQgY29uc3QgQmFubmVyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHNlbnRpbWVudCA9ICduZXV0cmFsJyxcbiAgZGlzYWJsZWQsXG4gIGNvbFNwYW4gPSAxMDAwLFxuICB0eXBlID0gJ2RpdicsXG4gIHNob3VsZEhhdmVQcmltYXJ5Qm9yZGVyLFxufTogQmFubmVyUHJvcHMpID0+XG4gIHR5cGUgPT09ICdkaXYnID8gKFxuICAgIDxTdHlsZWRTdGFjayBhcmlhLWRpc2FibGVkPXtkaXNhYmxlZH0gc2VudGltZW50PXtzZW50aW1lbnR9PlxuICAgICAgPFRleHQgYXM9XCJwXCIgZGlzYWJsZWQ9e2Rpc2FibGVkfSBzZW50aW1lbnQ9e3NlbnRpbWVudH0gdmFyaWFudD1cImNhcHRpb25cIj5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9UZXh0PlxuICAgIDwvU3R5bGVkU3RhY2s+XG4gICkgOiAoXG4gICAgPEJhbm5lcldyYXBwZXI+XG4gICAgICA8U3R5bGVkQ2VsbCBhcmlhLWRpc2FibGVkPXtkaXNhYmxlZH0gY29sU3Bhbj17Y29sU3Bhbn0+XG4gICAgICAgIDxTdHlsZWRUZXh0XG4gICAgICAgICAgYXM9XCJwXCJcbiAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgcHJpbWFyeUJvcmRlcj17c2hvdWxkSGF2ZVByaW1hcnlCb3JkZXJ9XG4gICAgICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICAgICAgdmFyaWFudD1cImNhcHRpb25cIlxuICAgICAgICA+XG4gICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICA8L1N0eWxlZFRleHQ+XG4gICAgICA8L1N0eWxlZENlbGw+XG4gICAgPC9CYW5uZXJXcmFwcGVyPlxuICApXG4iXX0= */"));
55
- const StyledCell = /* @__PURE__ */ _styled(List.Cell, process.env.NODE_ENV === "production" ? {
56
- target: "edd5t9g1"
57
- } : {
58
- target: "edd5t9g1",
59
- label: "StyledCell"
60
- })(process.env.NODE_ENV === "production" ? {
61
- name: "epcr5t",
62
- styles: "height:fit-content;border-top-left-radius:0;border-top-right-radius:0;width:100%;padding:0"
63
- } : {
64
- name: "epcr5t",
65
- styles: "height:fit-content;border-top-left-radius:0;border-top-right-radius:0;width:100%;padding:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L2NvbXBvbmVudHMvQmFubmVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxRG9DIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L2NvbXBvbmVudHMvQmFubmVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IExpc3QsIFN0YWNrLCBUZXh0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcywgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5cbmNvbnN0IEJhbm5lcldyYXBwZXIgPSBzdHlsZWQudHJgXG4gIHdpZHRoOiAxMDAlO1xuICBkaXNwbGF5OiB0YWJsZS1yb3c7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG4gIGN1cnNvcjogYXV0bztcbiAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kV2Vha307XG4gIGJvcmRlci1yYWRpdXM6IDAgMCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9ICR7KHsgdGhlbWUgfSkgPT5cbiAgICB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuXG4gIHRkLCB0ZDpmaXJzdC1jaGlsZCwgdGQ6bGFzdC1jaGlsZCB7XG4gICAgdHJhbnNpdGlvbjpcbiAgICAgIGJveC1zaGFkb3cgMjAwbXMgZWFzZSxcbiAgICAgIGJvcmRlci1jb2xvciAyMDBtcyBlYXNlO1xuICB9XG5gXG5cbmNvbnN0IFN0eWxlZFRleHQgPSBzdHlsZWQoVGV4dCwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydzZW50aW1lbnQnLCAncHJpbWFyeUJvcmRlciddLmluY2x1ZGVzKHByb3ApLFxufSk8e1xuICBzZW50aW1lbnQ6IENvbXBvbmVudFByb3BzPHR5cGVvZiBMaXN0LlJvdz5bJ3NlbnRpbWVudCddXG4gIHByaW1hcnlCb3JkZXI/OiBib29sZWFuXG59PmBcbiAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yIDIwMG1zIGVhc2U7XG4gIG1hcmdpbi10b3A6IC0keyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWzJdfTtcbiAgcGFkZGluZy1ibG9jazogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMC41J119O1xuICBwYWRkaW5nLWlubGluZTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcbiAgYm9yZGVyOiAxcHggc29saWQgJHsoeyB0aGVtZSwgcHJpbWFyeUJvcmRlciwgZGlzYWJsZWQgfSkgPT4gKHByaW1hcnlCb3JkZXIgJiYgIWRpc2FibGVkID8gdGhlbWUuY29sb3JzLnByaW1hcnkuYm9yZGVyIDogdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyKX07XG4gIGJvcmRlci10b3A6IG5vbmU7XG4gIGJvcmRlci1yYWRpdXM6IDAgMCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9ICR7KHsgdGhlbWUgfSkgPT5cbiAgICB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcblxuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lLCBzZW50aW1lbnQsIGRpc2FibGVkIH0pID0+IHtcbiAgICBpZiAoc2VudGltZW50ICYmIHNlbnRpbWVudCAhPT0gJ25ldXRyYWwnKSB7XG4gICAgICByZXR1cm4gdGhlbWUuY29sb3JzW3NlbnRpbWVudF1bXG4gICAgICAgIGRpc2FibGVkID8gJ2JhY2tncm91bmREaXNhYmxlZCcgOiAnYmFja2dyb3VuZCdcbiAgICAgIF1cbiAgICB9XG5cbiAgICByZXR1cm4gdGhlbWUuY29sb3JzLm5ldXRyYWxbXG4gICAgICBkaXNhYmxlZCA/ICdiYWNrZ3JvdW5kV2VhaycgOiAnYmFja2dyb3VuZFdlYWtEaXNhYmxlZCdcbiAgICBdXG4gIH19O1xuXG4gIGNvbG9yOiAkeyh7IHRoZW1lLCBzZW50aW1lbnQsIGRpc2FibGVkIH0pID0+IHRoZW1lLmNvbG9yc1tzZW50aW1lbnQgPz8gJ25ldXRyYWwnXVtkaXNhYmxlZCA/ICd0ZXh0RGlzYWJsZWQnIDogJ3RleHQnXX07XG5gXG5cbmNvbnN0IFN0eWxlZENlbGwgPSBzdHlsZWQoTGlzdC5DZWxsKWBcbiAgaGVpZ2h0OiBmaXQtY29udGVudDtcbiAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMDtcbiAgYm9yZGVyLXRvcC1yaWdodC1yYWRpdXM6IDA7XG4gIHdpZHRoOiAxMDAlO1xuICBwYWRkaW5nOiAwO1xuYFxuXG5jb25zdCBTdHlsZWRTdGFjayA9IHN0eWxlZChTdGFjaywge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydzZW50aW1lbnQnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2VudGltZW50OiBDb21wb25lbnRQcm9wczx0eXBlb2YgTGlzdC5Sb3c+WydzZW50aW1lbnQnXSB9PmBcbiAgaGVpZ2h0OiBmaXQtY29udGVudDtcbiAgYm9yZGVyLXRvcDogMXB4IHNvbGlkICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyfTtcblxuICBib3JkZXItcmFkaXVzOiAwIDAgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fSAkeyh7IHRoZW1lIH0pID0+XG4gICAgdGhlbWUucmFkaWkuZGVmYXVsdH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUsIHNlbnRpbWVudCB9KSA9PiB7XG4gICAgaWYgKHNlbnRpbWVudCAmJiBzZW50aW1lbnQgIT09ICduZXV0cmFsJykge1xuICAgICAgcmV0dXJuIHRoZW1lLmNvbG9yc1tzZW50aW1lbnRdLmJhY2tncm91bmRcbiAgICB9XG5cbiAgICByZXR1cm4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFdlYWtcbiAgfX07XG4gIHdpZHRoOiAxMDAlO1xuICBwYWRkaW5nLWJsb2NrOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycwLjUnXX07XG4gIHBhZGRpbmctaW5saW5lOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuXG4gICZbYXJpYS1kaXNhYmxlZD1cInRydWVcIl0ge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZERpc2FibGVkfTtcbiAgfVxuYFxuXG50eXBlIEJhbm5lclByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHNlbnRpbWVudD86IENvbXBvbmVudFByb3BzPHR5cGVvZiBMaXN0LlJvdz5bJ3NlbnRpbWVudCddXG4gIGRpc2FibGVkPzogYm9vbGVhblxuICBjb2xTcGFuPzogbnVtYmVyXG4gIHR5cGU/OiAnY2VsbCcgfCAnZGl2J1xuICBzaG91bGRIYXZlUHJpbWFyeUJvcmRlcj86IGJvb2xlYW5cbn1cblxuZXhwb3J0IGNvbnN0IEJhbm5lciA9ICh7XG4gIGNoaWxkcmVuLFxuICBzZW50aW1lbnQgPSAnbmV1dHJhbCcsXG4gIGRpc2FibGVkLFxuICBjb2xTcGFuID0gMTAwMCxcbiAgdHlwZSA9ICdkaXYnLFxuICBzaG91bGRIYXZlUHJpbWFyeUJvcmRlcixcbn06IEJhbm5lclByb3BzKSA9PlxuICB0eXBlID09PSAnZGl2JyA/IChcbiAgICA8U3R5bGVkU3RhY2sgYXJpYS1kaXNhYmxlZD17ZGlzYWJsZWR9IHNlbnRpbWVudD17c2VudGltZW50fT5cbiAgICAgIDxUZXh0IGFzPVwicFwiIGRpc2FibGVkPXtkaXNhYmxlZH0gc2VudGltZW50PXtzZW50aW1lbnR9IHZhcmlhbnQ9XCJjYXB0aW9uXCI+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvVGV4dD5cbiAgICA8L1N0eWxlZFN0YWNrPlxuICApIDogKFxuICAgIDxCYW5uZXJXcmFwcGVyPlxuICAgICAgPFN0eWxlZENlbGwgYXJpYS1kaXNhYmxlZD17ZGlzYWJsZWR9IGNvbFNwYW49e2NvbFNwYW59PlxuICAgICAgICA8U3R5bGVkVGV4dFxuICAgICAgICAgIGFzPVwicFwiXG4gICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgIHByaW1hcnlCb3JkZXI9e3Nob3VsZEhhdmVQcmltYXJ5Qm9yZGVyfVxuICAgICAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgICAgIHZhcmlhbnQ9XCJjYXB0aW9uXCJcbiAgICAgICAgPlxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRUZXh0PlxuICAgICAgPC9TdHlsZWRDZWxsPlxuICAgIDwvQmFubmVyV3JhcHBlcj5cbiAgKVxuIl19 */",
66
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
67
- });
68
- const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
69
- shouldForwardProp: (prop) => !["sentiment"].includes(prop),
70
- target: "edd5t9g0"
71
- } : {
72
- shouldForwardProp: (prop) => !["sentiment"].includes(prop),
73
- target: "edd5t9g0",
74
- label: "StyledStack"
75
- })("height:fit-content;border-top:1px solid ", ({
76
- theme
77
- }) => theme.colors.neutral.border, ";border-radius:0 0 ", ({
78
- theme
79
- }) => theme.radii.default, " ", ({
80
- theme
81
- }) => theme.radii.default, ";background-color:", ({
82
- theme,
83
- sentiment
84
- }) => {
85
- if (sentiment && sentiment !== "neutral") {
86
- return theme.colors[sentiment].background;
87
- }
88
- return theme.colors.neutral.backgroundWeak;
89
- }, ";width:100%;padding-block:", ({
90
- theme
91
- }) => theme.space["0.5"], ";padding-inline:", ({
92
- theme
93
- }) => theme.space["1"], ';&[aria-disabled="true"]{background-color:', ({
94
- theme
95
- }) => theme.colors.neutral.backgroundDisabled, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L2NvbXBvbmVudHMvQmFubmVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRCtEIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L2NvbXBvbmVudHMvQmFubmVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IExpc3QsIFN0YWNrLCBUZXh0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcywgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5cbmNvbnN0IEJhbm5lcldyYXBwZXIgPSBzdHlsZWQudHJgXG4gIHdpZHRoOiAxMDAlO1xuICBkaXNwbGF5OiB0YWJsZS1yb3c7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG4gIGN1cnNvcjogYXV0bztcbiAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kV2Vha307XG4gIGJvcmRlci1yYWRpdXM6IDAgMCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9ICR7KHsgdGhlbWUgfSkgPT5cbiAgICB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuXG4gIHRkLCB0ZDpmaXJzdC1jaGlsZCwgdGQ6bGFzdC1jaGlsZCB7XG4gICAgdHJhbnNpdGlvbjpcbiAgICAgIGJveC1zaGFkb3cgMjAwbXMgZWFzZSxcbiAgICAgIGJvcmRlci1jb2xvciAyMDBtcyBlYXNlO1xuICB9XG5gXG5cbmNvbnN0IFN0eWxlZFRleHQgPSBzdHlsZWQoVGV4dCwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydzZW50aW1lbnQnLCAncHJpbWFyeUJvcmRlciddLmluY2x1ZGVzKHByb3ApLFxufSk8e1xuICBzZW50aW1lbnQ6IENvbXBvbmVudFByb3BzPHR5cGVvZiBMaXN0LlJvdz5bJ3NlbnRpbWVudCddXG4gIHByaW1hcnlCb3JkZXI/OiBib29sZWFuXG59PmBcbiAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yIDIwMG1zIGVhc2U7XG4gIG1hcmdpbi10b3A6IC0keyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWzJdfTtcbiAgcGFkZGluZy1ibG9jazogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMC41J119O1xuICBwYWRkaW5nLWlubGluZTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcbiAgYm9yZGVyOiAxcHggc29saWQgJHsoeyB0aGVtZSwgcHJpbWFyeUJvcmRlciwgZGlzYWJsZWQgfSkgPT4gKHByaW1hcnlCb3JkZXIgJiYgIWRpc2FibGVkID8gdGhlbWUuY29sb3JzLnByaW1hcnkuYm9yZGVyIDogdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyKX07XG4gIGJvcmRlci10b3A6IG5vbmU7XG4gIGJvcmRlci1yYWRpdXM6IDAgMCAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9ICR7KHsgdGhlbWUgfSkgPT5cbiAgICB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcblxuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lLCBzZW50aW1lbnQsIGRpc2FibGVkIH0pID0+IHtcbiAgICBpZiAoc2VudGltZW50ICYmIHNlbnRpbWVudCAhPT0gJ25ldXRyYWwnKSB7XG4gICAgICByZXR1cm4gdGhlbWUuY29sb3JzW3NlbnRpbWVudF1bXG4gICAgICAgIGRpc2FibGVkID8gJ2JhY2tncm91bmREaXNhYmxlZCcgOiAnYmFja2dyb3VuZCdcbiAgICAgIF1cbiAgICB9XG5cbiAgICByZXR1cm4gdGhlbWUuY29sb3JzLm5ldXRyYWxbXG4gICAgICBkaXNhYmxlZCA/ICdiYWNrZ3JvdW5kV2VhaycgOiAnYmFja2dyb3VuZFdlYWtEaXNhYmxlZCdcbiAgICBdXG4gIH19O1xuXG4gIGNvbG9yOiAkeyh7IHRoZW1lLCBzZW50aW1lbnQsIGRpc2FibGVkIH0pID0+IHRoZW1lLmNvbG9yc1tzZW50aW1lbnQgPz8gJ25ldXRyYWwnXVtkaXNhYmxlZCA/ICd0ZXh0RGlzYWJsZWQnIDogJ3RleHQnXX07XG5gXG5cbmNvbnN0IFN0eWxlZENlbGwgPSBzdHlsZWQoTGlzdC5DZWxsKWBcbiAgaGVpZ2h0OiBmaXQtY29udGVudDtcbiAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMDtcbiAgYm9yZGVyLXRvcC1yaWdodC1yYWRpdXM6IDA7XG4gIHdpZHRoOiAxMDAlO1xuICBwYWRkaW5nOiAwO1xuYFxuXG5jb25zdCBTdHlsZWRTdGFjayA9IHN0eWxlZChTdGFjaywge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydzZW50aW1lbnQnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgc2VudGltZW50OiBDb21wb25lbnRQcm9wczx0eXBlb2YgTGlzdC5Sb3c+WydzZW50aW1lbnQnXSB9PmBcbiAgaGVpZ2h0OiBmaXQtY29udGVudDtcbiAgYm9yZGVyLXRvcDogMXB4IHNvbGlkICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyfTtcblxuICBib3JkZXItcmFkaXVzOiAwIDAgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fSAkeyh7IHRoZW1lIH0pID0+XG4gICAgdGhlbWUucmFkaWkuZGVmYXVsdH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUsIHNlbnRpbWVudCB9KSA9PiB7XG4gICAgaWYgKHNlbnRpbWVudCAmJiBzZW50aW1lbnQgIT09ICduZXV0cmFsJykge1xuICAgICAgcmV0dXJuIHRoZW1lLmNvbG9yc1tzZW50aW1lbnRdLmJhY2tncm91bmRcbiAgICB9XG5cbiAgICByZXR1cm4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZFdlYWtcbiAgfX07XG4gIHdpZHRoOiAxMDAlO1xuICBwYWRkaW5nLWJsb2NrOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycwLjUnXX07XG4gIHBhZGRpbmctaW5saW5lOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuXG4gICZbYXJpYS1kaXNhYmxlZD1cInRydWVcIl0ge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZERpc2FibGVkfTtcbiAgfVxuYFxuXG50eXBlIEJhbm5lclByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHNlbnRpbWVudD86IENvbXBvbmVudFByb3BzPHR5cGVvZiBMaXN0LlJvdz5bJ3NlbnRpbWVudCddXG4gIGRpc2FibGVkPzogYm9vbGVhblxuICBjb2xTcGFuPzogbnVtYmVyXG4gIHR5cGU/OiAnY2VsbCcgfCAnZGl2J1xuICBzaG91bGRIYXZlUHJpbWFyeUJvcmRlcj86IGJvb2xlYW5cbn1cblxuZXhwb3J0IGNvbnN0IEJhbm5lciA9ICh7XG4gIGNoaWxkcmVuLFxuICBzZW50aW1lbnQgPSAnbmV1dHJhbCcsXG4gIGRpc2FibGVkLFxuICBjb2xTcGFuID0gMTAwMCxcbiAgdHlwZSA9ICdkaXYnLFxuICBzaG91bGRIYXZlUHJpbWFyeUJvcmRlcixcbn06IEJhbm5lclByb3BzKSA9PlxuICB0eXBlID09PSAnZGl2JyA/IChcbiAgICA8U3R5bGVkU3RhY2sgYXJpYS1kaXNhYmxlZD17ZGlzYWJsZWR9IHNlbnRpbWVudD17c2VudGltZW50fT5cbiAgICAgIDxUZXh0IGFzPVwicFwiIGRpc2FibGVkPXtkaXNhYmxlZH0gc2VudGltZW50PXtzZW50aW1lbnR9IHZhcmlhbnQ9XCJjYXB0aW9uXCI+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvVGV4dD5cbiAgICA8L1N0eWxlZFN0YWNrPlxuICApIDogKFxuICAgIDxCYW5uZXJXcmFwcGVyPlxuICAgICAgPFN0eWxlZENlbGwgYXJpYS1kaXNhYmxlZD17ZGlzYWJsZWR9IGNvbFNwYW49e2NvbFNwYW59PlxuICAgICAgICA8U3R5bGVkVGV4dFxuICAgICAgICAgIGFzPVwicFwiXG4gICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgIHByaW1hcnlCb3JkZXI9e3Nob3VsZEhhdmVQcmltYXJ5Qm9yZGVyfVxuICAgICAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgICAgIHZhcmlhbnQ9XCJjYXB0aW9uXCJcbiAgICAgICAgPlxuICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgPC9TdHlsZWRUZXh0PlxuICAgICAgPC9TdHlsZWRDZWxsPlxuICAgIDwvQmFubmVyV3JhcHBlcj5cbiAgKVxuIl19 */"));
3
+ import { Stack, Text, List } from "@ultraviolet/ui";
4
+ import { offerListBannerStack, offerListBanner, offerListBannerCell, offerListBannerText } from "../styles.css.js";
96
5
  const Banner = ({
97
6
  children,
98
7
  sentiment = "neutral",
@@ -100,7 +9,13 @@ const Banner = ({
100
9
  colSpan = 1e3,
101
10
  type = "div",
102
11
  shouldHavePrimaryBorder
103
- }) => type === "div" ? /* @__PURE__ */ jsx(StyledStack, { "aria-disabled": disabled, sentiment, children: /* @__PURE__ */ jsx(Text, { as: "p", disabled, sentiment, variant: "caption", children }) }) : /* @__PURE__ */ jsx(BannerWrapper, { children: /* @__PURE__ */ jsx(StyledCell, { "aria-disabled": disabled, colSpan, children: /* @__PURE__ */ jsx(StyledText, { as: "p", disabled, primaryBorder: shouldHavePrimaryBorder, sentiment, variant: "caption", children }) }) });
12
+ }) => type === "div" ? /* @__PURE__ */ jsx(Stack, { "aria-disabled": disabled, className: offerListBannerStack({
13
+ sentiment
14
+ }), children: /* @__PURE__ */ jsx(Text, { as: "p", disabled, sentiment, variant: "caption", children }) }) : /* @__PURE__ */ jsx("tr", { className: offerListBanner, children: /* @__PURE__ */ jsx(List.Cell, { "aria-disabled": disabled, className: offerListBannerCell, colSpan, children: /* @__PURE__ */ jsx(Text, { as: "p", className: offerListBannerText({
15
+ disabled,
16
+ primaryBorder: shouldHavePrimaryBorder,
17
+ sentiment
18
+ }), disabled, variant: "caption", children }) }) });
104
19
  export {
105
20
  Banner
106
21
  };
@@ -2,40 +2,9 @@
2
2
  "use strict";
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
4
  const jsxRuntime = require("@emotion/react/jsx-runtime");
5
- const _styled = require("@emotion/styled/base");
6
5
  const ui = require("@ultraviolet/ui");
7
6
  const OfferListProvider = require("../OfferListProvider.cjs");
8
- const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
9
- const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
10
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
11
- return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
12
- }
13
- const StyledCell = /* @__PURE__ */ _styled__default.default(ui.List.Cell, process.env.NODE_ENV === "production" ? {
14
- target: "e1m0nrr1"
15
- } : {
16
- target: "e1m0nrr1",
17
- label: "StyledCell"
18
- })(process.env.NODE_ENV === "production" ? {
19
- name: "1l0p3iw",
20
- styles: "white-space:pre-line"
21
- } : {
22
- name: "1l0p3iw",
23
- styles: "white-space:pre-line/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L2NvbXBvbmVudHMvQ2VsbC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT29DIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L2NvbXBvbmVudHMvQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0LCBTa2VsZXRvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZU9mZmVyTGlzdENvbnRleHQgfSBmcm9tICcuLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkQ2VsbCA9IHN0eWxlZChMaXN0LkNlbGwpYFxuICB3aGl0ZS1zcGFjZTogcHJlLWxpbmU7XG5gXG5cbmNvbnN0IExvYWRpbmdDZWxsID0gc3R5bGVkKExpc3QuQ2VsbClgXG4gIGhlaWdodDogMTAwJTtcbmBcbmV4cG9ydCBjb25zdCBDZWxsID0gKHtcbiAgY2hpbGRyZW4sXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgY29sU3Bhbixcbn06IENvbXBvbmVudFByb3BzPHR5cGVvZiBMaXN0LkNlbGw+KSA9PiB7XG4gIGNvbnN0IHsgbG9hZGluZyB9ID0gdXNlT2ZmZXJMaXN0Q29udGV4dCgpXG5cbiAgcmV0dXJuIGxvYWRpbmcgPyAoXG4gICAgPExvYWRpbmdDZWxsPlxuICAgICAgPFNrZWxldG9uIGRhdGEtc3RhdGU9e2xvYWRpbmd9IHZhcmlhbnQ9XCJsaW5lXCIgLz5cbiAgICA8L0xvYWRpbmdDZWxsPlxuICApIDogKFxuICAgIDxTdHlsZWRDZWxsXG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGNvbFNwYW49e2NvbFNwYW59XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRDZWxsPlxuICApXG59XG4iXX0= */",
24
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
25
- });
26
- const LoadingCell = /* @__PURE__ */ _styled__default.default(ui.List.Cell, process.env.NODE_ENV === "production" ? {
27
- target: "e1m0nrr0"
28
- } : {
29
- target: "e1m0nrr0",
30
- label: "LoadingCell"
31
- })(process.env.NODE_ENV === "production" ? {
32
- name: "13udsys",
33
- styles: "height:100%"
34
- } : {
35
- name: "13udsys",
36
- styles: "height:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L2NvbXBvbmVudHMvQ2VsbC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBV3FDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L2NvbXBvbmVudHMvQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0LCBTa2VsZXRvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZU9mZmVyTGlzdENvbnRleHQgfSBmcm9tICcuLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkQ2VsbCA9IHN0eWxlZChMaXN0LkNlbGwpYFxuICB3aGl0ZS1zcGFjZTogcHJlLWxpbmU7XG5gXG5cbmNvbnN0IExvYWRpbmdDZWxsID0gc3R5bGVkKExpc3QuQ2VsbClgXG4gIGhlaWdodDogMTAwJTtcbmBcbmV4cG9ydCBjb25zdCBDZWxsID0gKHtcbiAgY2hpbGRyZW4sXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgY29sU3Bhbixcbn06IENvbXBvbmVudFByb3BzPHR5cGVvZiBMaXN0LkNlbGw+KSA9PiB7XG4gIGNvbnN0IHsgbG9hZGluZyB9ID0gdXNlT2ZmZXJMaXN0Q29udGV4dCgpXG5cbiAgcmV0dXJuIGxvYWRpbmcgPyAoXG4gICAgPExvYWRpbmdDZWxsPlxuICAgICAgPFNrZWxldG9uIGRhdGEtc3RhdGU9e2xvYWRpbmd9IHZhcmlhbnQ9XCJsaW5lXCIgLz5cbiAgICA8L0xvYWRpbmdDZWxsPlxuICApIDogKFxuICAgIDxTdHlsZWRDZWxsXG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGNvbFNwYW49e2NvbFNwYW59XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRDZWxsPlxuICApXG59XG4iXX0= */",
37
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
38
- });
7
+ const styles_css = require("../styles.css.cjs");
39
8
  const Cell = ({
40
9
  children,
41
10
  className,
@@ -45,6 +14,6 @@ const Cell = ({
45
14
  const {
46
15
  loading
47
16
  } = OfferListProvider.useOfferListContext();
48
- return loading ? /* @__PURE__ */ jsxRuntime.jsx(LoadingCell, { children: /* @__PURE__ */ jsxRuntime.jsx(ui.Skeleton, { "data-state": loading, variant: "line" }) }) : /* @__PURE__ */ jsxRuntime.jsx(StyledCell, { className, colSpan, "data-testid": dataTestId, children });
17
+ return loading ? /* @__PURE__ */ jsxRuntime.jsx(ui.List.Cell, { className: styles_css.offerListLoadingCell, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Skeleton, { "data-state": loading, variant: "line" }) }) : /* @__PURE__ */ jsxRuntime.jsx(ui.List.Cell, { className: `${className ? `${className} ` : ""}${styles_css.offerListCell}`, colSpan, "data-testid": dataTestId, children });
49
18
  };
50
19
  exports.Cell = Cell;
@@ -1,37 +1,8 @@
1
1
  "use client";
2
2
  import { jsx } from "@emotion/react/jsx-runtime";
3
- import _styled from "@emotion/styled/base";
4
- import { Skeleton, List } from "@ultraviolet/ui";
3
+ import { List, Skeleton } from "@ultraviolet/ui";
5
4
  import { useOfferListContext } from "../OfferListProvider.js";
6
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
7
- return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
8
- }
9
- const StyledCell = /* @__PURE__ */ _styled(List.Cell, process.env.NODE_ENV === "production" ? {
10
- target: "e1m0nrr1"
11
- } : {
12
- target: "e1m0nrr1",
13
- label: "StyledCell"
14
- })(process.env.NODE_ENV === "production" ? {
15
- name: "1l0p3iw",
16
- styles: "white-space:pre-line"
17
- } : {
18
- name: "1l0p3iw",
19
- styles: "white-space:pre-line/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L2NvbXBvbmVudHMvQ2VsbC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT29DIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L2NvbXBvbmVudHMvQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0LCBTa2VsZXRvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZU9mZmVyTGlzdENvbnRleHQgfSBmcm9tICcuLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkQ2VsbCA9IHN0eWxlZChMaXN0LkNlbGwpYFxuICB3aGl0ZS1zcGFjZTogcHJlLWxpbmU7XG5gXG5cbmNvbnN0IExvYWRpbmdDZWxsID0gc3R5bGVkKExpc3QuQ2VsbClgXG4gIGhlaWdodDogMTAwJTtcbmBcbmV4cG9ydCBjb25zdCBDZWxsID0gKHtcbiAgY2hpbGRyZW4sXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgY29sU3Bhbixcbn06IENvbXBvbmVudFByb3BzPHR5cGVvZiBMaXN0LkNlbGw+KSA9PiB7XG4gIGNvbnN0IHsgbG9hZGluZyB9ID0gdXNlT2ZmZXJMaXN0Q29udGV4dCgpXG5cbiAgcmV0dXJuIGxvYWRpbmcgPyAoXG4gICAgPExvYWRpbmdDZWxsPlxuICAgICAgPFNrZWxldG9uIGRhdGEtc3RhdGU9e2xvYWRpbmd9IHZhcmlhbnQ9XCJsaW5lXCIgLz5cbiAgICA8L0xvYWRpbmdDZWxsPlxuICApIDogKFxuICAgIDxTdHlsZWRDZWxsXG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGNvbFNwYW49e2NvbFNwYW59XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRDZWxsPlxuICApXG59XG4iXX0= */",
20
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
21
- });
22
- const LoadingCell = /* @__PURE__ */ _styled(List.Cell, process.env.NODE_ENV === "production" ? {
23
- target: "e1m0nrr0"
24
- } : {
25
- target: "e1m0nrr0",
26
- label: "LoadingCell"
27
- })(process.env.NODE_ENV === "production" ? {
28
- name: "13udsys",
29
- styles: "height:100%"
30
- } : {
31
- name: "13udsys",
32
- styles: "height:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L2NvbXBvbmVudHMvQ2VsbC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBV3FDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L2NvbXBvbmVudHMvQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0LCBTa2VsZXRvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZU9mZmVyTGlzdENvbnRleHQgfSBmcm9tICcuLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkQ2VsbCA9IHN0eWxlZChMaXN0LkNlbGwpYFxuICB3aGl0ZS1zcGFjZTogcHJlLWxpbmU7XG5gXG5cbmNvbnN0IExvYWRpbmdDZWxsID0gc3R5bGVkKExpc3QuQ2VsbClgXG4gIGhlaWdodDogMTAwJTtcbmBcbmV4cG9ydCBjb25zdCBDZWxsID0gKHtcbiAgY2hpbGRyZW4sXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbiAgY29sU3Bhbixcbn06IENvbXBvbmVudFByb3BzPHR5cGVvZiBMaXN0LkNlbGw+KSA9PiB7XG4gIGNvbnN0IHsgbG9hZGluZyB9ID0gdXNlT2ZmZXJMaXN0Q29udGV4dCgpXG5cbiAgcmV0dXJuIGxvYWRpbmcgPyAoXG4gICAgPExvYWRpbmdDZWxsPlxuICAgICAgPFNrZWxldG9uIGRhdGEtc3RhdGU9e2xvYWRpbmd9IHZhcmlhbnQ9XCJsaW5lXCIgLz5cbiAgICA8L0xvYWRpbmdDZWxsPlxuICApIDogKFxuICAgIDxTdHlsZWRDZWxsXG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGNvbFNwYW49e2NvbFNwYW59XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRDZWxsPlxuICApXG59XG4iXX0= */",
33
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
34
- });
5
+ import { offerListLoadingCell, offerListCell } from "../styles.css.js";
35
6
  const Cell = ({
36
7
  children,
37
8
  className,
@@ -41,7 +12,7 @@ const Cell = ({
41
12
  const {
42
13
  loading
43
14
  } = useOfferListContext();
44
- return loading ? /* @__PURE__ */ jsx(LoadingCell, { children: /* @__PURE__ */ jsx(Skeleton, { "data-state": loading, variant: "line" }) }) : /* @__PURE__ */ jsx(StyledCell, { className, colSpan, "data-testid": dataTestId, children });
15
+ return loading ? /* @__PURE__ */ jsx(List.Cell, { className: offerListLoadingCell, children: /* @__PURE__ */ jsx(Skeleton, { "data-state": loading, variant: "line" }) }) : /* @__PURE__ */ jsx(List.Cell, { className: `${className ? `${className} ` : ""}${offerListCell}`, colSpan, "data-testid": dataTestId, children });
45
16
  };
46
17
  export {
47
18
  Cell
@@ -2,96 +2,14 @@
2
2
  "use strict";
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
4
  const jsxRuntime = require("@emotion/react/jsx-runtime");
5
- const _styled = require("@emotion/styled/base");
6
5
  const icons = require("@ultraviolet/icons");
6
+ const themes = require("@ultraviolet/themes");
7
7
  const ui = require("@ultraviolet/ui");
8
+ const dynamic = require("@vanilla-extract/dynamic");
8
9
  const react = require("react");
9
10
  const OfferListProvider = require("../OfferListProvider.cjs");
11
+ const styles_css = require("../styles.css.cjs");
10
12
  const Banner = require("./Banner.cjs");
11
- const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
12
- const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
13
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
14
- return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
15
- }
16
- const StyledBadge = /* @__PURE__ */ _styled__default.default(ui.Badge, process.env.NODE_ENV === "production" ? {
17
- target: "e1x1uxsp5"
18
- } : {
19
- target: "e1x1uxsp5",
20
- label: "StyledBadge"
21
- })("position:absolute;left:", ({
22
- theme
23
- }) => theme.space[1], ";transform:translateY(-150%);top:0;left:", ({
24
- theme
25
- }) => 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/OfferList/components/Row.tsx"],"names":[],"mappings":"AAiBmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OfferList/components/Row.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, ArrowUpIcon } from '@ultraviolet/icons'\nimport {\n  Badge as BadgeUV,\n  Button,\n  Checkbox,\n  List,\n  Radio,\n  Tooltip,\n} from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { Children, useCallback, useMemo, useState } from 'react'\nimport { useOfferListContext } from '../OfferListProvider'\nimport { Banner } from './Banner'\n\nconst StyledBadge = styled(BadgeUV)`\n  position: absolute;\n  left: ${({ theme }) => theme.space[1]};\n  transform: translateY(-150%);\n  top: 0;\n  left: ${({ theme }) => theme.space[3]};\n`\n\nconst BadgeContainer = styled.div`\nposition: absolute;\ntop: ${({ theme }) => theme.space[2]};\n`\n\nconst NoPaddingCell = styled(List.Cell)`\n  padding: 0;\n  width: 32px;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n`\nconst StyledRow = styled(List.Row, {\n  shouldForwardProp: prop => !['selected', 'hasBanner'].includes(prop),\n})<{ selected: boolean; hasBanner: boolean }>`\n    ${({ theme, selected }) =>\n      selected\n        ? `td, td:first-child, td:last-child {\n      border-color: ${theme.colors.primary.border};\n    }`\n        : null}\n\n    &[aria-expanded='true'] {\n      ${({ theme, selected }) =>\n        selected\n          ? `\n          td, td:first-child, td:last-child, & + tr td {\n            border-color: ${theme.colors.primary.border};\n          }\n    `\n          : null}\n    }\n\n    ${({ hasBanner }) =>\n      hasBanner\n        ? `td, td:first-child {\n        border-bottom-left-radius: 0;\n        }\n\n        td, td:last-child {\n          border-bottom-right-radius: 0;\n        }\n    `\n        : null}\n`\n\nconst SelectableContainer = styled.div`\n  display: flex;\n`\n\nconst CustomExpandable = styled('div', {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: ComponentProps<typeof List.Row>['expandablePadding'] }>`\n    padding: ${({ theme, padding }) =>\n      padding ? theme.space[padding] : theme.space['2']};\n`\n\ntype RowProps = ComponentProps<typeof List.Row> & {\n  banner?: {\n    text: ReactNode\n    sentiment?: 'neutral' | 'primary' | 'warning' | 'danger'\n  }\n  offerName: string\n  badge?: {\n    text: string\n    sentiment?: ComponentProps<typeof BadgeUV>['sentiment']\n  }\n}\nexport const Row = ({\n  children,\n  disabled,\n  id,\n  banner,\n  expandablePadding,\n  offerName,\n  expandable: expandableContent,\n  selectDisabled,\n  highlightAnimation,\n  expanded,\n  className,\n  'data-dragging': dataDragging,\n  'data-testid': dataTestId,\n  style,\n  badge,\n}: RowProps) => {\n  const {\n    selectable,\n    radioSelectedRow,\n    setRadioSelectedRow,\n    checkboxSelectedRows,\n    setCheckboxSelectedRows,\n    expandable,\n    loading,\n    onChangeSelect,\n    autoCollapse,\n  } = useOfferListContext()\n  const { expandedRowIds, collapseRow, expandRow } = List.useListContext()\n\n  const [isHovered, setHovered] = useState(false)\n  const childrenNumber =\n    Children.count(children) + (selectable ? 1 : 0) + (expandable ? 1 : 0)\n\n  const toggleRowExpand = useCallback(() => {\n    if (!loading) {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id, loading])\n\n  const computedExpandableContent = useMemo(() => {\n    if (expandable && !loading && expandedRowIds[id] && banner) {\n      return (\n        <>\n          <CustomExpandable padding={expandablePadding}>\n            {expandableContent}\n          </CustomExpandable>\n          <Banner disabled={disabled} sentiment={banner.sentiment}>\n            {banner.text}\n          </Banner>\n        </>\n      )\n    }\n    if (expandable && !loading) {\n      return expandableContent\n    }\n\n    return undefined\n  }, [\n    expandable,\n    loading,\n    expandedRowIds,\n    banner,\n    expandablePadding,\n    id,\n    expandableContent,\n    disabled,\n  ])\n\n  const isRowSelected = useMemo(() => {\n    if (selectable === 'radio') {\n      return radioSelectedRow === offerName\n    }\n\n    return checkboxSelectedRows.includes(offerName)\n  }, [offerName, checkboxSelectedRows, radioSelectedRow, selectable])\n\n  return (\n    <>\n      <StyledRow\n        className={className}\n        data-dragging={dataDragging}\n        data-testid={dataTestId}\n        disabled={disabled}\n        expandable={computedExpandableContent}\n        expandablePadding={banner ? '0' : undefined}\n        expanded={expanded ?? expandedRowIds[id]}\n        hasBanner={!!banner}\n        highlightAnimation={highlightAnimation}\n        id={id}\n        onMouseEnter={() => setHovered(true)}\n        onMouseLeave={() => setHovered(false)}\n        selected={\n          selectable === 'radio'\n            ? radioSelectedRow === offerName\n            : checkboxSelectedRows.includes(offerName)\n        }\n        style={style}\n      >\n        <NoPaddingCell>\n          {badge ? (\n            <BadgeContainer>\n              <StyledBadge\n                disabled={disabled}\n                sentiment={badge.sentiment}\n                size=\"small\"\n              >\n                {badge.text}\n              </StyledBadge>\n            </BadgeContainer>\n          ) : null}\n          <SelectableContainer>\n            <Tooltip\n              text={\n                typeof selectDisabled === 'string' ? selectDisabled : undefined\n              }\n            >\n              {selectable === 'radio' ? (\n                <Radio\n                  checked={isRowSelected}\n                  disabled={disabled || loading || !!selectDisabled}\n                  id={id}\n                  name={`radio-offer-list-${id}`}\n                  onChange={() => {\n                    setRadioSelectedRow(offerName)\n                    onChangeSelect?.(offerName)\n                    if (expandedRowIds[id]) {\n                      expandRow(id)\n                    } else if (!autoCollapse) {\n                      collapseRow(id)\n                    }\n                  }}\n                  value={id}\n                />\n              ) : (\n                <Checkbox\n                  aria-label=\"select\"\n                  checked={isRowSelected}\n                  disabled={disabled || loading || !!selectDisabled}\n                  id={id}\n                  name={`checkbox-offer-list-${id}`}\n                  onChange={() => {\n                    if (isRowSelected) {\n                      const newSelectedList = checkboxSelectedRows.filter(\n                        element => element !== offerName,\n                      )\n                      setCheckboxSelectedRows(newSelectedList)\n                      onChangeSelect?.(newSelectedList)\n                    } else {\n                      const newSelectedList = [\n                        ...checkboxSelectedRows,\n                        offerName,\n                      ]\n                      setCheckboxSelectedRows(newSelectedList)\n                      onChangeSelect?.(newSelectedList)\n                    }\n\n                    if (expandedRowIds[id]) {\n                      expandRow(id)\n                    } else if (!autoCollapse) {\n                      collapseRow(id)\n                    }\n                  }}\n                  value={id}\n                />\n              )}\n            </Tooltip>\n          </SelectableContainer>\n        </NoPaddingCell>\n        {expandable ? (\n          <NoPaddingCell>\n            <Button\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n              disabled={disabled || !expandable || loading}\n              onClick={toggleRowExpand}\n              sentiment=\"neutral\"\n              size=\"small\"\n              variant=\"ghost\"\n            >\n              {expandedRowIds[id] ? <ArrowUpIcon /> : <ArrowDownIcon />}\n            </Button>\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledRow>\n      {banner && !expandedRowIds[id] ? (\n        <Banner\n          colSpan={childrenNumber}\n          disabled={disabled}\n          sentiment={banner.sentiment}\n          shouldHavePrimaryBorder={isHovered || isRowSelected}\n          type=\"cell\"\n        >\n          {banner.text}\n        </Banner>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
26
- const BadgeContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
27
- target: "e1x1uxsp4"
28
- } : {
29
- target: "e1x1uxsp4",
30
- label: "BadgeContainer"
31
- })("position:absolute;top:", ({
32
- theme
33
- }) => theme.space[2], ";" + (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/OfferList/components/Row.tsx"],"names":[],"mappings":"AAyBiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OfferList/components/Row.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, ArrowUpIcon } from '@ultraviolet/icons'\nimport {\n  Badge as BadgeUV,\n  Button,\n  Checkbox,\n  List,\n  Radio,\n  Tooltip,\n} from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { Children, useCallback, useMemo, useState } from 'react'\nimport { useOfferListContext } from '../OfferListProvider'\nimport { Banner } from './Banner'\n\nconst StyledBadge = styled(BadgeUV)`\n  position: absolute;\n  left: ${({ theme }) => theme.space[1]};\n  transform: translateY(-150%);\n  top: 0;\n  left: ${({ theme }) => theme.space[3]};\n`\n\nconst BadgeContainer = styled.div`\nposition: absolute;\ntop: ${({ theme }) => theme.space[2]};\n`\n\nconst NoPaddingCell = styled(List.Cell)`\n  padding: 0;\n  width: 32px;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n`\nconst StyledRow = styled(List.Row, {\n  shouldForwardProp: prop => !['selected', 'hasBanner'].includes(prop),\n})<{ selected: boolean; hasBanner: boolean }>`\n    ${({ theme, selected }) =>\n      selected\n        ? `td, td:first-child, td:last-child {\n      border-color: ${theme.colors.primary.border};\n    }`\n        : null}\n\n    &[aria-expanded='true'] {\n      ${({ theme, selected }) =>\n        selected\n          ? `\n          td, td:first-child, td:last-child, & + tr td {\n            border-color: ${theme.colors.primary.border};\n          }\n    `\n          : null}\n    }\n\n    ${({ hasBanner }) =>\n      hasBanner\n        ? `td, td:first-child {\n        border-bottom-left-radius: 0;\n        }\n\n        td, td:last-child {\n          border-bottom-right-radius: 0;\n        }\n    `\n        : null}\n`\n\nconst SelectableContainer = styled.div`\n  display: flex;\n`\n\nconst CustomExpandable = styled('div', {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: ComponentProps<typeof List.Row>['expandablePadding'] }>`\n    padding: ${({ theme, padding }) =>\n      padding ? theme.space[padding] : theme.space['2']};\n`\n\ntype RowProps = ComponentProps<typeof List.Row> & {\n  banner?: {\n    text: ReactNode\n    sentiment?: 'neutral' | 'primary' | 'warning' | 'danger'\n  }\n  offerName: string\n  badge?: {\n    text: string\n    sentiment?: ComponentProps<typeof BadgeUV>['sentiment']\n  }\n}\nexport const Row = ({\n  children,\n  disabled,\n  id,\n  banner,\n  expandablePadding,\n  offerName,\n  expandable: expandableContent,\n  selectDisabled,\n  highlightAnimation,\n  expanded,\n  className,\n  'data-dragging': dataDragging,\n  'data-testid': dataTestId,\n  style,\n  badge,\n}: RowProps) => {\n  const {\n    selectable,\n    radioSelectedRow,\n    setRadioSelectedRow,\n    checkboxSelectedRows,\n    setCheckboxSelectedRows,\n    expandable,\n    loading,\n    onChangeSelect,\n    autoCollapse,\n  } = useOfferListContext()\n  const { expandedRowIds, collapseRow, expandRow } = List.useListContext()\n\n  const [isHovered, setHovered] = useState(false)\n  const childrenNumber =\n    Children.count(children) + (selectable ? 1 : 0) + (expandable ? 1 : 0)\n\n  const toggleRowExpand = useCallback(() => {\n    if (!loading) {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id, loading])\n\n  const computedExpandableContent = useMemo(() => {\n    if (expandable && !loading && expandedRowIds[id] && banner) {\n      return (\n        <>\n          <CustomExpandable padding={expandablePadding}>\n            {expandableContent}\n          </CustomExpandable>\n          <Banner disabled={disabled} sentiment={banner.sentiment}>\n            {banner.text}\n          </Banner>\n        </>\n      )\n    }\n    if (expandable && !loading) {\n      return expandableContent\n    }\n\n    return undefined\n  }, [\n    expandable,\n    loading,\n    expandedRowIds,\n    banner,\n    expandablePadding,\n    id,\n    expandableContent,\n    disabled,\n  ])\n\n  const isRowSelected = useMemo(() => {\n    if (selectable === 'radio') {\n      return radioSelectedRow === offerName\n    }\n\n    return checkboxSelectedRows.includes(offerName)\n  }, [offerName, checkboxSelectedRows, radioSelectedRow, selectable])\n\n  return (\n    <>\n      <StyledRow\n        className={className}\n        data-dragging={dataDragging}\n        data-testid={dataTestId}\n        disabled={disabled}\n        expandable={computedExpandableContent}\n        expandablePadding={banner ? '0' : undefined}\n        expanded={expanded ?? expandedRowIds[id]}\n        hasBanner={!!banner}\n        highlightAnimation={highlightAnimation}\n        id={id}\n        onMouseEnter={() => setHovered(true)}\n        onMouseLeave={() => setHovered(false)}\n        selected={\n          selectable === 'radio'\n            ? radioSelectedRow === offerName\n            : checkboxSelectedRows.includes(offerName)\n        }\n        style={style}\n      >\n        <NoPaddingCell>\n          {badge ? (\n            <BadgeContainer>\n              <StyledBadge\n                disabled={disabled}\n                sentiment={badge.sentiment}\n                size=\"small\"\n              >\n                {badge.text}\n              </StyledBadge>\n            </BadgeContainer>\n          ) : null}\n          <SelectableContainer>\n            <Tooltip\n              text={\n                typeof selectDisabled === 'string' ? selectDisabled : undefined\n              }\n            >\n              {selectable === 'radio' ? (\n                <Radio\n                  checked={isRowSelected}\n                  disabled={disabled || loading || !!selectDisabled}\n                  id={id}\n                  name={`radio-offer-list-${id}`}\n                  onChange={() => {\n                    setRadioSelectedRow(offerName)\n                    onChangeSelect?.(offerName)\n                    if (expandedRowIds[id]) {\n                      expandRow(id)\n                    } else if (!autoCollapse) {\n                      collapseRow(id)\n                    }\n                  }}\n                  value={id}\n                />\n              ) : (\n                <Checkbox\n                  aria-label=\"select\"\n                  checked={isRowSelected}\n                  disabled={disabled || loading || !!selectDisabled}\n                  id={id}\n                  name={`checkbox-offer-list-${id}`}\n                  onChange={() => {\n                    if (isRowSelected) {\n                      const newSelectedList = checkboxSelectedRows.filter(\n                        element => element !== offerName,\n                      )\n                      setCheckboxSelectedRows(newSelectedList)\n                      onChangeSelect?.(newSelectedList)\n                    } else {\n                      const newSelectedList = [\n                        ...checkboxSelectedRows,\n                        offerName,\n                      ]\n                      setCheckboxSelectedRows(newSelectedList)\n                      onChangeSelect?.(newSelectedList)\n                    }\n\n                    if (expandedRowIds[id]) {\n                      expandRow(id)\n                    } else if (!autoCollapse) {\n                      collapseRow(id)\n                    }\n                  }}\n                  value={id}\n                />\n              )}\n            </Tooltip>\n          </SelectableContainer>\n        </NoPaddingCell>\n        {expandable ? (\n          <NoPaddingCell>\n            <Button\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n              disabled={disabled || !expandable || loading}\n              onClick={toggleRowExpand}\n              sentiment=\"neutral\"\n              size=\"small\"\n              variant=\"ghost\"\n            >\n              {expandedRowIds[id] ? <ArrowUpIcon /> : <ArrowDownIcon />}\n            </Button>\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledRow>\n      {banner && !expandedRowIds[id] ? (\n        <Banner\n          colSpan={childrenNumber}\n          disabled={disabled}\n          sentiment={banner.sentiment}\n          shouldHavePrimaryBorder={isHovered || isRowSelected}\n          type=\"cell\"\n        >\n          {banner.text}\n        </Banner>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
34
- const NoPaddingCell = /* @__PURE__ */ _styled__default.default(ui.List.Cell, process.env.NODE_ENV === "production" ? {
35
- target: "e1x1uxsp3"
36
- } : {
37
- target: "e1x1uxsp3",
38
- label: "NoPaddingCell"
39
- })("padding:0;width:32px;&:first-of-type{padding-left:", ({
40
- theme
41
- }) => theme.space["2"], ";}" + (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/OfferList/components/Row.tsx"],"names":[],"mappings":"AA8BuC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OfferList/components/Row.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, ArrowUpIcon } from '@ultraviolet/icons'\nimport {\n  Badge as BadgeUV,\n  Button,\n  Checkbox,\n  List,\n  Radio,\n  Tooltip,\n} from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { Children, useCallback, useMemo, useState } from 'react'\nimport { useOfferListContext } from '../OfferListProvider'\nimport { Banner } from './Banner'\n\nconst StyledBadge = styled(BadgeUV)`\n  position: absolute;\n  left: ${({ theme }) => theme.space[1]};\n  transform: translateY(-150%);\n  top: 0;\n  left: ${({ theme }) => theme.space[3]};\n`\n\nconst BadgeContainer = styled.div`\nposition: absolute;\ntop: ${({ theme }) => theme.space[2]};\n`\n\nconst NoPaddingCell = styled(List.Cell)`\n  padding: 0;\n  width: 32px;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n`\nconst StyledRow = styled(List.Row, {\n  shouldForwardProp: prop => !['selected', 'hasBanner'].includes(prop),\n})<{ selected: boolean; hasBanner: boolean }>`\n    ${({ theme, selected }) =>\n      selected\n        ? `td, td:first-child, td:last-child {\n      border-color: ${theme.colors.primary.border};\n    }`\n        : null}\n\n    &[aria-expanded='true'] {\n      ${({ theme, selected }) =>\n        selected\n          ? `\n          td, td:first-child, td:last-child, & + tr td {\n            border-color: ${theme.colors.primary.border};\n          }\n    `\n          : null}\n    }\n\n    ${({ hasBanner }) =>\n      hasBanner\n        ? `td, td:first-child {\n        border-bottom-left-radius: 0;\n        }\n\n        td, td:last-child {\n          border-bottom-right-radius: 0;\n        }\n    `\n        : null}\n`\n\nconst SelectableContainer = styled.div`\n  display: flex;\n`\n\nconst CustomExpandable = styled('div', {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: ComponentProps<typeof List.Row>['expandablePadding'] }>`\n    padding: ${({ theme, padding }) =>\n      padding ? theme.space[padding] : theme.space['2']};\n`\n\ntype RowProps = ComponentProps<typeof List.Row> & {\n  banner?: {\n    text: ReactNode\n    sentiment?: 'neutral' | 'primary' | 'warning' | 'danger'\n  }\n  offerName: string\n  badge?: {\n    text: string\n    sentiment?: ComponentProps<typeof BadgeUV>['sentiment']\n  }\n}\nexport const Row = ({\n  children,\n  disabled,\n  id,\n  banner,\n  expandablePadding,\n  offerName,\n  expandable: expandableContent,\n  selectDisabled,\n  highlightAnimation,\n  expanded,\n  className,\n  'data-dragging': dataDragging,\n  'data-testid': dataTestId,\n  style,\n  badge,\n}: RowProps) => {\n  const {\n    selectable,\n    radioSelectedRow,\n    setRadioSelectedRow,\n    checkboxSelectedRows,\n    setCheckboxSelectedRows,\n    expandable,\n    loading,\n    onChangeSelect,\n    autoCollapse,\n  } = useOfferListContext()\n  const { expandedRowIds, collapseRow, expandRow } = List.useListContext()\n\n  const [isHovered, setHovered] = useState(false)\n  const childrenNumber =\n    Children.count(children) + (selectable ? 1 : 0) + (expandable ? 1 : 0)\n\n  const toggleRowExpand = useCallback(() => {\n    if (!loading) {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id, loading])\n\n  const computedExpandableContent = useMemo(() => {\n    if (expandable && !loading && expandedRowIds[id] && banner) {\n      return (\n        <>\n          <CustomExpandable padding={expandablePadding}>\n            {expandableContent}\n          </CustomExpandable>\n          <Banner disabled={disabled} sentiment={banner.sentiment}>\n            {banner.text}\n          </Banner>\n        </>\n      )\n    }\n    if (expandable && !loading) {\n      return expandableContent\n    }\n\n    return undefined\n  }, [\n    expandable,\n    loading,\n    expandedRowIds,\n    banner,\n    expandablePadding,\n    id,\n    expandableContent,\n    disabled,\n  ])\n\n  const isRowSelected = useMemo(() => {\n    if (selectable === 'radio') {\n      return radioSelectedRow === offerName\n    }\n\n    return checkboxSelectedRows.includes(offerName)\n  }, [offerName, checkboxSelectedRows, radioSelectedRow, selectable])\n\n  return (\n    <>\n      <StyledRow\n        className={className}\n        data-dragging={dataDragging}\n        data-testid={dataTestId}\n        disabled={disabled}\n        expandable={computedExpandableContent}\n        expandablePadding={banner ? '0' : undefined}\n        expanded={expanded ?? expandedRowIds[id]}\n        hasBanner={!!banner}\n        highlightAnimation={highlightAnimation}\n        id={id}\n        onMouseEnter={() => setHovered(true)}\n        onMouseLeave={() => setHovered(false)}\n        selected={\n          selectable === 'radio'\n            ? radioSelectedRow === offerName\n            : checkboxSelectedRows.includes(offerName)\n        }\n        style={style}\n      >\n        <NoPaddingCell>\n          {badge ? (\n            <BadgeContainer>\n              <StyledBadge\n                disabled={disabled}\n                sentiment={badge.sentiment}\n                size=\"small\"\n              >\n                {badge.text}\n              </StyledBadge>\n            </BadgeContainer>\n          ) : null}\n          <SelectableContainer>\n            <Tooltip\n              text={\n                typeof selectDisabled === 'string' ? selectDisabled : undefined\n              }\n            >\n              {selectable === 'radio' ? (\n                <Radio\n                  checked={isRowSelected}\n                  disabled={disabled || loading || !!selectDisabled}\n                  id={id}\n                  name={`radio-offer-list-${id}`}\n                  onChange={() => {\n                    setRadioSelectedRow(offerName)\n                    onChangeSelect?.(offerName)\n                    if (expandedRowIds[id]) {\n                      expandRow(id)\n                    } else if (!autoCollapse) {\n                      collapseRow(id)\n                    }\n                  }}\n                  value={id}\n                />\n              ) : (\n                <Checkbox\n                  aria-label=\"select\"\n                  checked={isRowSelected}\n                  disabled={disabled || loading || !!selectDisabled}\n                  id={id}\n                  name={`checkbox-offer-list-${id}`}\n                  onChange={() => {\n                    if (isRowSelected) {\n                      const newSelectedList = checkboxSelectedRows.filter(\n                        element => element !== offerName,\n                      )\n                      setCheckboxSelectedRows(newSelectedList)\n                      onChangeSelect?.(newSelectedList)\n                    } else {\n                      const newSelectedList = [\n                        ...checkboxSelectedRows,\n                        offerName,\n                      ]\n                      setCheckboxSelectedRows(newSelectedList)\n                      onChangeSelect?.(newSelectedList)\n                    }\n\n                    if (expandedRowIds[id]) {\n                      expandRow(id)\n                    } else if (!autoCollapse) {\n                      collapseRow(id)\n                    }\n                  }}\n                  value={id}\n                />\n              )}\n            </Tooltip>\n          </SelectableContainer>\n        </NoPaddingCell>\n        {expandable ? (\n          <NoPaddingCell>\n            <Button\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n              disabled={disabled || !expandable || loading}\n              onClick={toggleRowExpand}\n              sentiment=\"neutral\"\n              size=\"small\"\n              variant=\"ghost\"\n            >\n              {expandedRowIds[id] ? <ArrowUpIcon /> : <ArrowDownIcon />}\n            </Button>\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledRow>\n      {banner && !expandedRowIds[id] ? (\n        <Banner\n          colSpan={childrenNumber}\n          disabled={disabled}\n          sentiment={banner.sentiment}\n          shouldHavePrimaryBorder={isHovered || isRowSelected}\n          type=\"cell\"\n        >\n          {banner.text}\n        </Banner>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
42
- const StyledRow = /* @__PURE__ */ _styled__default.default(ui.List.Row, process.env.NODE_ENV === "production" ? {
43
- shouldForwardProp: (prop) => !["selected", "hasBanner"].includes(prop),
44
- target: "e1x1uxsp2"
45
- } : {
46
- shouldForwardProp: (prop) => !["selected", "hasBanner"].includes(prop),
47
- target: "e1x1uxsp2",
48
- label: "StyledRow"
49
- })(({
50
- theme,
51
- selected
52
- }) => selected ? `td, td:first-child, td:last-child {
53
- border-color: ${theme.colors.primary.border};
54
- }` : null, " &[aria-expanded='true']{", ({
55
- theme,
56
- selected
57
- }) => selected ? `
58
- td, td:first-child, td:last-child, & + tr td {
59
- border-color: ${theme.colors.primary.border};
60
- }
61
- ` : null, ";}", ({
62
- hasBanner
63
- }) => hasBanner ? `td, td:first-child {
64
- border-bottom-left-radius: 0;
65
- }
66
-
67
- td, td:last-child {
68
- border-bottom-right-radius: 0;
69
- }
70
- ` : null, ";" + (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/OfferList/components/Row.tsx"],"names":[],"mappings":"AAyC6C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OfferList/components/Row.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, ArrowUpIcon } from '@ultraviolet/icons'\nimport {\n  Badge as BadgeUV,\n  Button,\n  Checkbox,\n  List,\n  Radio,\n  Tooltip,\n} from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { Children, useCallback, useMemo, useState } from 'react'\nimport { useOfferListContext } from '../OfferListProvider'\nimport { Banner } from './Banner'\n\nconst StyledBadge = styled(BadgeUV)`\n  position: absolute;\n  left: ${({ theme }) => theme.space[1]};\n  transform: translateY(-150%);\n  top: 0;\n  left: ${({ theme }) => theme.space[3]};\n`\n\nconst BadgeContainer = styled.div`\nposition: absolute;\ntop: ${({ theme }) => theme.space[2]};\n`\n\nconst NoPaddingCell = styled(List.Cell)`\n  padding: 0;\n  width: 32px;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n`\nconst StyledRow = styled(List.Row, {\n  shouldForwardProp: prop => !['selected', 'hasBanner'].includes(prop),\n})<{ selected: boolean; hasBanner: boolean }>`\n    ${({ theme, selected }) =>\n      selected\n        ? `td, td:first-child, td:last-child {\n      border-color: ${theme.colors.primary.border};\n    }`\n        : null}\n\n    &[aria-expanded='true'] {\n      ${({ theme, selected }) =>\n        selected\n          ? `\n          td, td:first-child, td:last-child, & + tr td {\n            border-color: ${theme.colors.primary.border};\n          }\n    `\n          : null}\n    }\n\n    ${({ hasBanner }) =>\n      hasBanner\n        ? `td, td:first-child {\n        border-bottom-left-radius: 0;\n        }\n\n        td, td:last-child {\n          border-bottom-right-radius: 0;\n        }\n    `\n        : null}\n`\n\nconst SelectableContainer = styled.div`\n  display: flex;\n`\n\nconst CustomExpandable = styled('div', {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: ComponentProps<typeof List.Row>['expandablePadding'] }>`\n    padding: ${({ theme, padding }) =>\n      padding ? theme.space[padding] : theme.space['2']};\n`\n\ntype RowProps = ComponentProps<typeof List.Row> & {\n  banner?: {\n    text: ReactNode\n    sentiment?: 'neutral' | 'primary' | 'warning' | 'danger'\n  }\n  offerName: string\n  badge?: {\n    text: string\n    sentiment?: ComponentProps<typeof BadgeUV>['sentiment']\n  }\n}\nexport const Row = ({\n  children,\n  disabled,\n  id,\n  banner,\n  expandablePadding,\n  offerName,\n  expandable: expandableContent,\n  selectDisabled,\n  highlightAnimation,\n  expanded,\n  className,\n  'data-dragging': dataDragging,\n  'data-testid': dataTestId,\n  style,\n  badge,\n}: RowProps) => {\n  const {\n    selectable,\n    radioSelectedRow,\n    setRadioSelectedRow,\n    checkboxSelectedRows,\n    setCheckboxSelectedRows,\n    expandable,\n    loading,\n    onChangeSelect,\n    autoCollapse,\n  } = useOfferListContext()\n  const { expandedRowIds, collapseRow, expandRow } = List.useListContext()\n\n  const [isHovered, setHovered] = useState(false)\n  const childrenNumber =\n    Children.count(children) + (selectable ? 1 : 0) + (expandable ? 1 : 0)\n\n  const toggleRowExpand = useCallback(() => {\n    if (!loading) {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id, loading])\n\n  const computedExpandableContent = useMemo(() => {\n    if (expandable && !loading && expandedRowIds[id] && banner) {\n      return (\n        <>\n          <CustomExpandable padding={expandablePadding}>\n            {expandableContent}\n          </CustomExpandable>\n          <Banner disabled={disabled} sentiment={banner.sentiment}>\n            {banner.text}\n          </Banner>\n        </>\n      )\n    }\n    if (expandable && !loading) {\n      return expandableContent\n    }\n\n    return undefined\n  }, [\n    expandable,\n    loading,\n    expandedRowIds,\n    banner,\n    expandablePadding,\n    id,\n    expandableContent,\n    disabled,\n  ])\n\n  const isRowSelected = useMemo(() => {\n    if (selectable === 'radio') {\n      return radioSelectedRow === offerName\n    }\n\n    return checkboxSelectedRows.includes(offerName)\n  }, [offerName, checkboxSelectedRows, radioSelectedRow, selectable])\n\n  return (\n    <>\n      <StyledRow\n        className={className}\n        data-dragging={dataDragging}\n        data-testid={dataTestId}\n        disabled={disabled}\n        expandable={computedExpandableContent}\n        expandablePadding={banner ? '0' : undefined}\n        expanded={expanded ?? expandedRowIds[id]}\n        hasBanner={!!banner}\n        highlightAnimation={highlightAnimation}\n        id={id}\n        onMouseEnter={() => setHovered(true)}\n        onMouseLeave={() => setHovered(false)}\n        selected={\n          selectable === 'radio'\n            ? radioSelectedRow === offerName\n            : checkboxSelectedRows.includes(offerName)\n        }\n        style={style}\n      >\n        <NoPaddingCell>\n          {badge ? (\n            <BadgeContainer>\n              <StyledBadge\n                disabled={disabled}\n                sentiment={badge.sentiment}\n                size=\"small\"\n              >\n                {badge.text}\n              </StyledBadge>\n            </BadgeContainer>\n          ) : null}\n          <SelectableContainer>\n            <Tooltip\n              text={\n                typeof selectDisabled === 'string' ? selectDisabled : undefined\n              }\n            >\n              {selectable === 'radio' ? (\n                <Radio\n                  checked={isRowSelected}\n                  disabled={disabled || loading || !!selectDisabled}\n                  id={id}\n                  name={`radio-offer-list-${id}`}\n                  onChange={() => {\n                    setRadioSelectedRow(offerName)\n                    onChangeSelect?.(offerName)\n                    if (expandedRowIds[id]) {\n                      expandRow(id)\n                    } else if (!autoCollapse) {\n                      collapseRow(id)\n                    }\n                  }}\n                  value={id}\n                />\n              ) : (\n                <Checkbox\n                  aria-label=\"select\"\n                  checked={isRowSelected}\n                  disabled={disabled || loading || !!selectDisabled}\n                  id={id}\n                  name={`checkbox-offer-list-${id}`}\n                  onChange={() => {\n                    if (isRowSelected) {\n                      const newSelectedList = checkboxSelectedRows.filter(\n                        element => element !== offerName,\n                      )\n                      setCheckboxSelectedRows(newSelectedList)\n                      onChangeSelect?.(newSelectedList)\n                    } else {\n                      const newSelectedList = [\n                        ...checkboxSelectedRows,\n                        offerName,\n                      ]\n                      setCheckboxSelectedRows(newSelectedList)\n                      onChangeSelect?.(newSelectedList)\n                    }\n\n                    if (expandedRowIds[id]) {\n                      expandRow(id)\n                    } else if (!autoCollapse) {\n                      collapseRow(id)\n                    }\n                  }}\n                  value={id}\n                />\n              )}\n            </Tooltip>\n          </SelectableContainer>\n        </NoPaddingCell>\n        {expandable ? (\n          <NoPaddingCell>\n            <Button\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n              disabled={disabled || !expandable || loading}\n              onClick={toggleRowExpand}\n              sentiment=\"neutral\"\n              size=\"small\"\n              variant=\"ghost\"\n            >\n              {expandedRowIds[id] ? <ArrowUpIcon /> : <ArrowDownIcon />}\n            </Button>\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledRow>\n      {banner && !expandedRowIds[id] ? (\n        <Banner\n          colSpan={childrenNumber}\n          disabled={disabled}\n          sentiment={banner.sentiment}\n          shouldHavePrimaryBorder={isHovered || isRowSelected}\n          type=\"cell\"\n        >\n          {banner.text}\n        </Banner>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
71
- const SelectableContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
72
- target: "e1x1uxsp1"
73
- } : {
74
- target: "e1x1uxsp1",
75
- label: "SelectableContainer"
76
- })(process.env.NODE_ENV === "production" ? {
77
- name: "zjik7",
78
- styles: "display:flex"
79
- } : {
80
- name: "zjik7",
81
- styles: "display:flex/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OfferList/components/Row.tsx"],"names":[],"mappings":"AAyEsC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OfferList/components/Row.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, ArrowUpIcon } from '@ultraviolet/icons'\nimport {\n  Badge as BadgeUV,\n  Button,\n  Checkbox,\n  List,\n  Radio,\n  Tooltip,\n} from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { Children, useCallback, useMemo, useState } from 'react'\nimport { useOfferListContext } from '../OfferListProvider'\nimport { Banner } from './Banner'\n\nconst StyledBadge = styled(BadgeUV)`\n  position: absolute;\n  left: ${({ theme }) => theme.space[1]};\n  transform: translateY(-150%);\n  top: 0;\n  left: ${({ theme }) => theme.space[3]};\n`\n\nconst BadgeContainer = styled.div`\nposition: absolute;\ntop: ${({ theme }) => theme.space[2]};\n`\n\nconst NoPaddingCell = styled(List.Cell)`\n  padding: 0;\n  width: 32px;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n`\nconst StyledRow = styled(List.Row, {\n  shouldForwardProp: prop => !['selected', 'hasBanner'].includes(prop),\n})<{ selected: boolean; hasBanner: boolean }>`\n    ${({ theme, selected }) =>\n      selected\n        ? `td, td:first-child, td:last-child {\n      border-color: ${theme.colors.primary.border};\n    }`\n        : null}\n\n    &[aria-expanded='true'] {\n      ${({ theme, selected }) =>\n        selected\n          ? `\n          td, td:first-child, td:last-child, & + tr td {\n            border-color: ${theme.colors.primary.border};\n          }\n    `\n          : null}\n    }\n\n    ${({ hasBanner }) =>\n      hasBanner\n        ? `td, td:first-child {\n        border-bottom-left-radius: 0;\n        }\n\n        td, td:last-child {\n          border-bottom-right-radius: 0;\n        }\n    `\n        : null}\n`\n\nconst SelectableContainer = styled.div`\n  display: flex;\n`\n\nconst CustomExpandable = styled('div', {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: ComponentProps<typeof List.Row>['expandablePadding'] }>`\n    padding: ${({ theme, padding }) =>\n      padding ? theme.space[padding] : theme.space['2']};\n`\n\ntype RowProps = ComponentProps<typeof List.Row> & {\n  banner?: {\n    text: ReactNode\n    sentiment?: 'neutral' | 'primary' | 'warning' | 'danger'\n  }\n  offerName: string\n  badge?: {\n    text: string\n    sentiment?: ComponentProps<typeof BadgeUV>['sentiment']\n  }\n}\nexport const Row = ({\n  children,\n  disabled,\n  id,\n  banner,\n  expandablePadding,\n  offerName,\n  expandable: expandableContent,\n  selectDisabled,\n  highlightAnimation,\n  expanded,\n  className,\n  'data-dragging': dataDragging,\n  'data-testid': dataTestId,\n  style,\n  badge,\n}: RowProps) => {\n  const {\n    selectable,\n    radioSelectedRow,\n    setRadioSelectedRow,\n    checkboxSelectedRows,\n    setCheckboxSelectedRows,\n    expandable,\n    loading,\n    onChangeSelect,\n    autoCollapse,\n  } = useOfferListContext()\n  const { expandedRowIds, collapseRow, expandRow } = List.useListContext()\n\n  const [isHovered, setHovered] = useState(false)\n  const childrenNumber =\n    Children.count(children) + (selectable ? 1 : 0) + (expandable ? 1 : 0)\n\n  const toggleRowExpand = useCallback(() => {\n    if (!loading) {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id, loading])\n\n  const computedExpandableContent = useMemo(() => {\n    if (expandable && !loading && expandedRowIds[id] && banner) {\n      return (\n        <>\n          <CustomExpandable padding={expandablePadding}>\n            {expandableContent}\n          </CustomExpandable>\n          <Banner disabled={disabled} sentiment={banner.sentiment}>\n            {banner.text}\n          </Banner>\n        </>\n      )\n    }\n    if (expandable && !loading) {\n      return expandableContent\n    }\n\n    return undefined\n  }, [\n    expandable,\n    loading,\n    expandedRowIds,\n    banner,\n    expandablePadding,\n    id,\n    expandableContent,\n    disabled,\n  ])\n\n  const isRowSelected = useMemo(() => {\n    if (selectable === 'radio') {\n      return radioSelectedRow === offerName\n    }\n\n    return checkboxSelectedRows.includes(offerName)\n  }, [offerName, checkboxSelectedRows, radioSelectedRow, selectable])\n\n  return (\n    <>\n      <StyledRow\n        className={className}\n        data-dragging={dataDragging}\n        data-testid={dataTestId}\n        disabled={disabled}\n        expandable={computedExpandableContent}\n        expandablePadding={banner ? '0' : undefined}\n        expanded={expanded ?? expandedRowIds[id]}\n        hasBanner={!!banner}\n        highlightAnimation={highlightAnimation}\n        id={id}\n        onMouseEnter={() => setHovered(true)}\n        onMouseLeave={() => setHovered(false)}\n        selected={\n          selectable === 'radio'\n            ? radioSelectedRow === offerName\n            : checkboxSelectedRows.includes(offerName)\n        }\n        style={style}\n      >\n        <NoPaddingCell>\n          {badge ? (\n            <BadgeContainer>\n              <StyledBadge\n                disabled={disabled}\n                sentiment={badge.sentiment}\n                size=\"small\"\n              >\n                {badge.text}\n              </StyledBadge>\n            </BadgeContainer>\n          ) : null}\n          <SelectableContainer>\n            <Tooltip\n              text={\n                typeof selectDisabled === 'string' ? selectDisabled : undefined\n              }\n            >\n              {selectable === 'radio' ? (\n                <Radio\n                  checked={isRowSelected}\n                  disabled={disabled || loading || !!selectDisabled}\n                  id={id}\n                  name={`radio-offer-list-${id}`}\n                  onChange={() => {\n                    setRadioSelectedRow(offerName)\n                    onChangeSelect?.(offerName)\n                    if (expandedRowIds[id]) {\n                      expandRow(id)\n                    } else if (!autoCollapse) {\n                      collapseRow(id)\n                    }\n                  }}\n                  value={id}\n                />\n              ) : (\n                <Checkbox\n                  aria-label=\"select\"\n                  checked={isRowSelected}\n                  disabled={disabled || loading || !!selectDisabled}\n                  id={id}\n                  name={`checkbox-offer-list-${id}`}\n                  onChange={() => {\n                    if (isRowSelected) {\n                      const newSelectedList = checkboxSelectedRows.filter(\n                        element => element !== offerName,\n                      )\n                      setCheckboxSelectedRows(newSelectedList)\n                      onChangeSelect?.(newSelectedList)\n                    } else {\n                      const newSelectedList = [\n                        ...checkboxSelectedRows,\n                        offerName,\n                      ]\n                      setCheckboxSelectedRows(newSelectedList)\n                      onChangeSelect?.(newSelectedList)\n                    }\n\n                    if (expandedRowIds[id]) {\n                      expandRow(id)\n                    } else if (!autoCollapse) {\n                      collapseRow(id)\n                    }\n                  }}\n                  value={id}\n                />\n              )}\n            </Tooltip>\n          </SelectableContainer>\n        </NoPaddingCell>\n        {expandable ? (\n          <NoPaddingCell>\n            <Button\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n              disabled={disabled || !expandable || loading}\n              onClick={toggleRowExpand}\n              sentiment=\"neutral\"\n              size=\"small\"\n              variant=\"ghost\"\n            >\n              {expandedRowIds[id] ? <ArrowUpIcon /> : <ArrowDownIcon />}\n            </Button>\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledRow>\n      {banner && !expandedRowIds[id] ? (\n        <Banner\n          colSpan={childrenNumber}\n          disabled={disabled}\n          sentiment={banner.sentiment}\n          shouldHavePrimaryBorder={isHovered || isRowSelected}\n          type=\"cell\"\n        >\n          {banner.text}\n        </Banner>\n      ) : null}\n    </>\n  )\n}\n"]} */",
82
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
83
- });
84
- const CustomExpandable = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
85
- shouldForwardProp: (prop) => !["padding"].includes(prop),
86
- target: "e1x1uxsp0"
87
- } : {
88
- shouldForwardProp: (prop) => !["padding"].includes(prop),
89
- target: "e1x1uxsp0",
90
- label: "CustomExpandable"
91
- })("padding:", ({
92
- theme,
93
- padding
94
- }) => padding ? theme.space[padding] : theme.space["2"], ";" + (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/OfferList/components/Row.tsx"],"names":[],"mappings":"AA+EsE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OfferList/components/Row.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon, ArrowUpIcon } from '@ultraviolet/icons'\nimport {\n  Badge as BadgeUV,\n  Button,\n  Checkbox,\n  List,\n  Radio,\n  Tooltip,\n} from '@ultraviolet/ui'\nimport type { ComponentProps, ReactNode } from 'react'\nimport { Children, useCallback, useMemo, useState } from 'react'\nimport { useOfferListContext } from '../OfferListProvider'\nimport { Banner } from './Banner'\n\nconst StyledBadge = styled(BadgeUV)`\n  position: absolute;\n  left: ${({ theme }) => theme.space[1]};\n  transform: translateY(-150%);\n  top: 0;\n  left: ${({ theme }) => theme.space[3]};\n`\n\nconst BadgeContainer = styled.div`\nposition: absolute;\ntop: ${({ theme }) => theme.space[2]};\n`\n\nconst NoPaddingCell = styled(List.Cell)`\n  padding: 0;\n  width: 32px;\n\n  &:first-of-type {\n    padding-left: ${({ theme }) => theme.space['2']};\n  }\n\n`\nconst StyledRow = styled(List.Row, {\n  shouldForwardProp: prop => !['selected', 'hasBanner'].includes(prop),\n})<{ selected: boolean; hasBanner: boolean }>`\n    ${({ theme, selected }) =>\n      selected\n        ? `td, td:first-child, td:last-child {\n      border-color: ${theme.colors.primary.border};\n    }`\n        : null}\n\n    &[aria-expanded='true'] {\n      ${({ theme, selected }) =>\n        selected\n          ? `\n          td, td:first-child, td:last-child, & + tr td {\n            border-color: ${theme.colors.primary.border};\n          }\n    `\n          : null}\n    }\n\n    ${({ hasBanner }) =>\n      hasBanner\n        ? `td, td:first-child {\n        border-bottom-left-radius: 0;\n        }\n\n        td, td:last-child {\n          border-bottom-right-radius: 0;\n        }\n    `\n        : null}\n`\n\nconst SelectableContainer = styled.div`\n  display: flex;\n`\n\nconst CustomExpandable = styled('div', {\n  shouldForwardProp: prop => !['padding'].includes(prop),\n})<{ padding?: ComponentProps<typeof List.Row>['expandablePadding'] }>`\n    padding: ${({ theme, padding }) =>\n      padding ? theme.space[padding] : theme.space['2']};\n`\n\ntype RowProps = ComponentProps<typeof List.Row> & {\n  banner?: {\n    text: ReactNode\n    sentiment?: 'neutral' | 'primary' | 'warning' | 'danger'\n  }\n  offerName: string\n  badge?: {\n    text: string\n    sentiment?: ComponentProps<typeof BadgeUV>['sentiment']\n  }\n}\nexport const Row = ({\n  children,\n  disabled,\n  id,\n  banner,\n  expandablePadding,\n  offerName,\n  expandable: expandableContent,\n  selectDisabled,\n  highlightAnimation,\n  expanded,\n  className,\n  'data-dragging': dataDragging,\n  'data-testid': dataTestId,\n  style,\n  badge,\n}: RowProps) => {\n  const {\n    selectable,\n    radioSelectedRow,\n    setRadioSelectedRow,\n    checkboxSelectedRows,\n    setCheckboxSelectedRows,\n    expandable,\n    loading,\n    onChangeSelect,\n    autoCollapse,\n  } = useOfferListContext()\n  const { expandedRowIds, collapseRow, expandRow } = List.useListContext()\n\n  const [isHovered, setHovered] = useState(false)\n  const childrenNumber =\n    Children.count(children) + (selectable ? 1 : 0) + (expandable ? 1 : 0)\n\n  const toggleRowExpand = useCallback(() => {\n    if (!loading) {\n      if (expandedRowIds[id]) {\n        collapseRow(id)\n      } else {\n        expandRow(id)\n      }\n    }\n  }, [collapseRow, expandRow, expandedRowIds, id, loading])\n\n  const computedExpandableContent = useMemo(() => {\n    if (expandable && !loading && expandedRowIds[id] && banner) {\n      return (\n        <>\n          <CustomExpandable padding={expandablePadding}>\n            {expandableContent}\n          </CustomExpandable>\n          <Banner disabled={disabled} sentiment={banner.sentiment}>\n            {banner.text}\n          </Banner>\n        </>\n      )\n    }\n    if (expandable && !loading) {\n      return expandableContent\n    }\n\n    return undefined\n  }, [\n    expandable,\n    loading,\n    expandedRowIds,\n    banner,\n    expandablePadding,\n    id,\n    expandableContent,\n    disabled,\n  ])\n\n  const isRowSelected = useMemo(() => {\n    if (selectable === 'radio') {\n      return radioSelectedRow === offerName\n    }\n\n    return checkboxSelectedRows.includes(offerName)\n  }, [offerName, checkboxSelectedRows, radioSelectedRow, selectable])\n\n  return (\n    <>\n      <StyledRow\n        className={className}\n        data-dragging={dataDragging}\n        data-testid={dataTestId}\n        disabled={disabled}\n        expandable={computedExpandableContent}\n        expandablePadding={banner ? '0' : undefined}\n        expanded={expanded ?? expandedRowIds[id]}\n        hasBanner={!!banner}\n        highlightAnimation={highlightAnimation}\n        id={id}\n        onMouseEnter={() => setHovered(true)}\n        onMouseLeave={() => setHovered(false)}\n        selected={\n          selectable === 'radio'\n            ? radioSelectedRow === offerName\n            : checkboxSelectedRows.includes(offerName)\n        }\n        style={style}\n      >\n        <NoPaddingCell>\n          {badge ? (\n            <BadgeContainer>\n              <StyledBadge\n                disabled={disabled}\n                sentiment={badge.sentiment}\n                size=\"small\"\n              >\n                {badge.text}\n              </StyledBadge>\n            </BadgeContainer>\n          ) : null}\n          <SelectableContainer>\n            <Tooltip\n              text={\n                typeof selectDisabled === 'string' ? selectDisabled : undefined\n              }\n            >\n              {selectable === 'radio' ? (\n                <Radio\n                  checked={isRowSelected}\n                  disabled={disabled || loading || !!selectDisabled}\n                  id={id}\n                  name={`radio-offer-list-${id}`}\n                  onChange={() => {\n                    setRadioSelectedRow(offerName)\n                    onChangeSelect?.(offerName)\n                    if (expandedRowIds[id]) {\n                      expandRow(id)\n                    } else if (!autoCollapse) {\n                      collapseRow(id)\n                    }\n                  }}\n                  value={id}\n                />\n              ) : (\n                <Checkbox\n                  aria-label=\"select\"\n                  checked={isRowSelected}\n                  disabled={disabled || loading || !!selectDisabled}\n                  id={id}\n                  name={`checkbox-offer-list-${id}`}\n                  onChange={() => {\n                    if (isRowSelected) {\n                      const newSelectedList = checkboxSelectedRows.filter(\n                        element => element !== offerName,\n                      )\n                      setCheckboxSelectedRows(newSelectedList)\n                      onChangeSelect?.(newSelectedList)\n                    } else {\n                      const newSelectedList = [\n                        ...checkboxSelectedRows,\n                        offerName,\n                      ]\n                      setCheckboxSelectedRows(newSelectedList)\n                      onChangeSelect?.(newSelectedList)\n                    }\n\n                    if (expandedRowIds[id]) {\n                      expandRow(id)\n                    } else if (!autoCollapse) {\n                      collapseRow(id)\n                    }\n                  }}\n                  value={id}\n                />\n              )}\n            </Tooltip>\n          </SelectableContainer>\n        </NoPaddingCell>\n        {expandable ? (\n          <NoPaddingCell>\n            <Button\n              aria-label=\"expand\"\n              data-testid=\"list-expand-button\"\n              disabled={disabled || !expandable || loading}\n              onClick={toggleRowExpand}\n              sentiment=\"neutral\"\n              size=\"small\"\n              variant=\"ghost\"\n            >\n              {expandedRowIds[id] ? <ArrowUpIcon /> : <ArrowDownIcon />}\n            </Button>\n          </NoPaddingCell>\n        ) : null}\n        {children}\n      </StyledRow>\n      {banner && !expandedRowIds[id] ? (\n        <Banner\n          colSpan={childrenNumber}\n          disabled={disabled}\n          sentiment={banner.sentiment}\n          shouldHavePrimaryBorder={isHovered || isRowSelected}\n          type=\"cell\"\n        >\n          {banner.text}\n        </Banner>\n      ) : null}\n    </>\n  )\n}\n"]} */"));
95
13
  const Row = ({
96
14
  children,
97
15
  disabled,
@@ -139,7 +57,9 @@ const Row = ({
139
57
  const computedExpandableContent = react.useMemo(() => {
140
58
  if (expandable && !loading && expandedRowIds[id] && banner) {
141
59
  return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
142
- /* @__PURE__ */ jsxRuntime.jsx(CustomExpandable, { padding: expandablePadding, children: expandableContent }),
60
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles_css.offerListRowExpandable, style: dynamic.assignInlineVars({
61
+ [styles_css.expandablePadding]: themes.theme.space[expandablePadding ?? 2]
62
+ }), children: expandableContent }),
143
63
  /* @__PURE__ */ jsxRuntime.jsx(Banner.Banner, { disabled, sentiment: banner.sentiment, children: banner.text })
144
64
  ] });
145
65
  }
@@ -154,11 +74,12 @@ const Row = ({
154
74
  }
155
75
  return checkboxSelectedRows.includes(offerName);
156
76
  }, [offerName, checkboxSelectedRows, radioSelectedRow, selectable]);
77
+ const isSelected = selectable === "radio" ? radioSelectedRow === offerName : checkboxSelectedRows.includes(offerName);
157
78
  return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
158
- /* @__PURE__ */ jsxRuntime.jsxs(StyledRow, { className, "data-dragging": dataDragging, "data-testid": dataTestId, disabled, expandable: computedExpandableContent, expandablePadding: banner ? "0" : void 0, expanded: expanded ?? expandedRowIds[id], hasBanner: !!banner, highlightAnimation, id, onMouseEnter: () => setHovered(true), onMouseLeave: () => setHovered(false), selected: selectable === "radio" ? radioSelectedRow === offerName : checkboxSelectedRows.includes(offerName), style, children: [
159
- /* @__PURE__ */ jsxRuntime.jsxs(NoPaddingCell, { children: [
160
- badge ? /* @__PURE__ */ jsxRuntime.jsx(BadgeContainer, { children: /* @__PURE__ */ jsxRuntime.jsx(StyledBadge, { disabled, sentiment: badge.sentiment, size: "small", children: badge.text }) }) : null,
161
- /* @__PURE__ */ jsxRuntime.jsx(SelectableContainer, { children: /* @__PURE__ */ jsxRuntime.jsx(ui.Tooltip, { text: typeof selectDisabled === "string" ? selectDisabled : void 0, children: selectable === "radio" ? /* @__PURE__ */ jsxRuntime.jsx(ui.Radio, { checked: isRowSelected, disabled: disabled || loading || !!selectDisabled, id, name: `radio-offer-list-${id}`, onChange: () => {
79
+ /* @__PURE__ */ jsxRuntime.jsxs(ui.List.Row, { className: `${className ? `${className} ` : ""}${banner ? styles_css.offerListRowBanner : ""}${isSelected ? `${" "}${styles_css.offerListRowSelected}` : ""}`, "data-dragging": dataDragging, "data-testid": dataTestId, disabled, expandable: computedExpandableContent, expandablePadding: banner ? "0" : void 0, expanded: expanded ?? expandedRowIds[id], highlightAnimation, id, onMouseEnter: () => setHovered(true), onMouseLeave: () => setHovered(false), style, children: [
80
+ /* @__PURE__ */ jsxRuntime.jsxs(ui.List.Cell, { className: styles_css.offerListNoPaddingCell, children: [
81
+ badge ? /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles_css.offerListBadgeContainer, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Badge, { className: styles_css.offerListBadge, disabled, sentiment: badge.sentiment, size: "small", children: badge.text }) }) : null,
82
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles_css.offerListRowSelectableContainer, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Tooltip, { text: typeof selectDisabled === "string" ? selectDisabled : void 0, children: selectable === "radio" ? /* @__PURE__ */ jsxRuntime.jsx(ui.Radio, { checked: isRowSelected, disabled: disabled || loading || !!selectDisabled, id, name: `radio-offer-list-${id}`, onChange: () => {
162
83
  setRadioSelectedRow(offerName);
163
84
  onChangeSelect?.(offerName);
164
85
  if (expandedRowIds[id]) {
@@ -183,7 +104,7 @@ const Row = ({
183
104
  }
184
105
  }, value: id }) }) })
185
106
  ] }),
186
- expandable ? /* @__PURE__ */ jsxRuntime.jsx(NoPaddingCell, { children: /* @__PURE__ */ jsxRuntime.jsx(ui.Button, { "aria-label": "expand", "data-testid": "list-expand-button", disabled: disabled || !expandable || loading, onClick: toggleRowExpand, sentiment: "neutral", size: "small", variant: "ghost", children: expandedRowIds[id] ? /* @__PURE__ */ jsxRuntime.jsx(icons.ArrowUpIcon, {}) : /* @__PURE__ */ jsxRuntime.jsx(icons.ArrowDownIcon, {}) }) }) : null,
107
+ expandable ? /* @__PURE__ */ jsxRuntime.jsx(ui.List.Cell, { className: styles_css.offerListNoPaddingCell, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Button, { "aria-label": "expand", "data-testid": "list-expand-button", disabled: disabled || !expandable || loading, onClick: toggleRowExpand, sentiment: "neutral", size: "small", variant: "ghost", children: expandedRowIds[id] ? /* @__PURE__ */ jsxRuntime.jsx(icons.ArrowUpIcon, {}) : /* @__PURE__ */ jsxRuntime.jsx(icons.ArrowDownIcon, {}) }) }) : null,
187
108
  children
188
109
  ] }),
189
110
  banner && !expandedRowIds[id] ? /* @__PURE__ */ jsxRuntime.jsx(Banner.Banner, { colSpan: childrenNumber, disabled, sentiment: banner.sentiment, shouldHavePrimaryBorder: isHovered || isRowSelected, type: "cell", children: banner.text }) : null