@purpur/library 9.4.1 → 9.5.0

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 (89) hide show
  1. package/CHANGELOG.json +39 -0
  2. package/CHANGELOG.md +23 -1
  3. package/dist/LICENSE.txt +8 -1
  4. package/dist/calendar-BXQ3v62X.js +2 -0
  5. package/dist/{calendar-CBBV8n3x.js.map → calendar-BXQ3v62X.js.map} +1 -1
  6. package/dist/{calendar-DEXw83mu.mjs → calendar-d53vgYqR.mjs} +481 -465
  7. package/dist/{calendar-DEXw83mu.mjs.map → calendar-d53vgYqR.mjs.map} +1 -1
  8. package/dist/calendar.cjs.js +1 -1
  9. package/dist/calendar.es.js +3 -3
  10. package/dist/comparison-table-C74IAVqz.js +2 -0
  11. package/dist/comparison-table-C74IAVqz.js.map +1 -0
  12. package/dist/comparison-table-DctKxmX9.mjs +267 -0
  13. package/dist/comparison-table-DctKxmX9.mjs.map +1 -0
  14. package/dist/comparison-table.cjs.js +1 -1
  15. package/dist/comparison-table.es.js +1 -1
  16. package/dist/components/calendar/src/calendar.d.ts +4 -11
  17. package/dist/components/calendar/src/calendar.d.ts.map +1 -1
  18. package/dist/components/comparison-table/src/comparison-table.d.ts.map +1 -1
  19. package/dist/components/comparison-table/src/components/OptionCard/option-card.d.ts +2 -1
  20. package/dist/components/comparison-table/src/components/OptionCard/option-card.d.ts.map +1 -1
  21. package/dist/components/comparison-table/src/components/ScrollProgress/scroll-progress.d.ts +1 -2
  22. package/dist/components/comparison-table/src/components/ScrollProgress/scroll-progress.d.ts.map +1 -1
  23. package/dist/components/date-field/src/date-field.d.ts.map +1 -1
  24. package/dist/components/date-picker/src/date-picker.d.ts +11 -2
  25. package/dist/components/date-picker/src/date-picker.d.ts.map +1 -1
  26. package/dist/components/date-range-field/src/date-range-field.d.ts +27 -0
  27. package/dist/components/date-range-field/src/date-range-field.d.ts.map +1 -0
  28. package/dist/components-metadata.js +10 -0
  29. package/dist/date-field-BKKty89_.js +2 -0
  30. package/dist/{date-field-BJaomFjs.js.map → date-field-BKKty89_.js.map} +1 -1
  31. package/dist/{date-field-D3rTtf9Y.mjs → date-field-Cv5CKR1y.mjs} +276 -268
  32. package/dist/{date-field-D3rTtf9Y.mjs.map → date-field-Cv5CKR1y.mjs.map} +1 -1
  33. package/dist/date-field.cjs.js +1 -1
  34. package/dist/date-field.es.js +1 -1
  35. package/dist/date-picker-CzxhZxsw.mjs +1611 -0
  36. package/dist/date-picker-CzxhZxsw.mjs.map +1 -0
  37. package/dist/date-picker-uyPKJulK.js +2 -0
  38. package/dist/date-picker-uyPKJulK.js.map +1 -0
  39. package/dist/date-picker.cjs.js +1 -1
  40. package/dist/date-picker.es.js +1 -1
  41. package/dist/date-range-field-CFcjprIl.mjs +142 -0
  42. package/dist/date-range-field-CFcjprIl.mjs.map +1 -0
  43. package/dist/date-range-field-D8vLeSwp.js +2 -0
  44. package/dist/date-range-field-D8vLeSwp.js.map +1 -0
  45. package/dist/date-range-field.cjs.js +2 -0
  46. package/dist/date-range-field.cjs.js.map +1 -0
  47. package/dist/date-range-field.es.js +5 -0
  48. package/dist/date-range-field.es.js.map +1 -0
  49. package/dist/{floating-ui.react-dom-gsHLgcoR.mjs → floating-ui.react-dom-EredA301.mjs} +3 -3
  50. package/dist/{floating-ui.react-dom-gsHLgcoR.mjs.map → floating-ui.react-dom-EredA301.mjs.map} +1 -1
  51. package/dist/{format-DpkYPs7O.mjs → format-CWOXI-dC.mjs} +8 -8
  52. package/dist/{format-DpkYPs7O.mjs.map → format-CWOXI-dC.mjs.map} +1 -1
  53. package/dist/libraries/library/src/date-range-field.d.ts +6 -0
  54. package/dist/libraries/library/src/date-range-field.d.ts.map +1 -0
  55. package/dist/libraries/library/src/library.d.ts +1 -0
  56. package/dist/libraries/library/src/library.d.ts.map +1 -1
  57. package/dist/library.cjs.js +1 -1
  58. package/dist/library.es.js +636 -633
  59. package/dist/library.es.js.map +1 -1
  60. package/dist/{popover-_xJATlhN.mjs → popover-I26xNbTz.mjs} +2 -2
  61. package/dist/{popover-_xJATlhN.mjs.map → popover-I26xNbTz.mjs.map} +1 -1
  62. package/dist/popover.es.js +1 -1
  63. package/dist/purpur.css +1 -1
  64. package/dist/{stepper-CNnx_NiR.mjs → stepper-CWR2vGPj.mjs} +2 -2
  65. package/dist/{stepper-CNnx_NiR.mjs.map → stepper-CWR2vGPj.mjs.map} +1 -1
  66. package/dist/stepper.es.js +1 -1
  67. package/dist/{table-D_sdSJyr.mjs → table-g_n68i4s.mjs} +2 -2
  68. package/dist/{table-D_sdSJyr.mjs.map → table-g_n68i4s.mjs.map} +1 -1
  69. package/dist/table.es.js +1 -1
  70. package/dist/{tooltip-VlURN8H3.mjs → tooltip-LU2Cy-QC.mjs} +2 -2
  71. package/dist/{tooltip-VlURN8H3.mjs.map → tooltip-LU2Cy-QC.mjs.map} +1 -1
  72. package/dist/tooltip.es.js +1 -1
  73. package/dist/{zh-TW-oiRD71xW.mjs → zh-TW-DrQ6h7hA.mjs} +2 -2
  74. package/dist/{zh-TW-oiRD71xW.mjs.map → zh-TW-DrQ6h7hA.mjs.map} +1 -1
  75. package/package.json +22 -21
  76. package/src/aliases.ts +7 -0
  77. package/src/date-range-field.ts +6 -0
  78. package/src/entries.js +1 -0
  79. package/src/library.ts +2 -0
  80. package/dist/calendar-CBBV8n3x.js +0 -2
  81. package/dist/comparison-table-8bOJmz-L.mjs +0 -275
  82. package/dist/comparison-table-8bOJmz-L.mjs.map +0 -1
  83. package/dist/comparison-table-mKL2IHXW.js +0 -2
  84. package/dist/comparison-table-mKL2IHXW.js.map +0 -1
  85. package/dist/date-field-BJaomFjs.js +0 -2
  86. package/dist/date-picker-CbUNbOhn.mjs +0 -1415
  87. package/dist/date-picker-CbUNbOhn.mjs.map +0 -1
  88. package/dist/date-picker-DYXNB5aU.js +0 -2
  89. package/dist/date-picker-DYXNB5aU.js.map +0 -1
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("./calendar-CBBV8n3x.js"),e=require("./zh-TW-CAp7WWVq.js"),a=require("./format-CFKKBdIQ.js");exports.Calendar=r.Calendar;exports.af=e.af;exports.ar=e.ar;exports.arDZ=e.arDZ;exports.arEG=e.arEG;exports.arMA=e.arMA;exports.arSA=e.arSA;exports.arTN=e.arTN;exports.az=e.az;exports.be=e.be;exports.beTarask=e.beTarask;exports.bg=e.bg;exports.bn=e.bn;exports.bs=e.bs;exports.ca=e.ca;exports.ckb=e.ckb;exports.cs=e.cs;exports.cy=e.cy;exports.da=e.da;exports.de=e.de;exports.deAT=e.deAT;exports.el=e.el;exports.enAU=e.enAU;exports.enCA=e.enCA;exports.enGB=e.enGB;exports.enIE=e.enIE;exports.enIN=e.enIN;exports.enNZ=e.enNZ;exports.enZA=e.enZA;exports.eo=e.eo;exports.es=e.es;exports.et=e.et;exports.eu=e.eu;exports.faIR=e.faIR;exports.fi=e.fi;exports.fr=e.fr;exports.frCA=e.frCA;exports.frCH=e.frCH;exports.fy=e.fy;exports.gd=e.gd;exports.gl=e.gl;exports.gu=e.gu;exports.he=e.he;exports.hi=e.hi;exports.hr=e.hr;exports.ht=e.ht;exports.hu=e.hu;exports.hy=e.hy;exports.id=e.id;exports.is=e.is;exports.it=e.it;exports.itCH=e.itCH;exports.ja=e.ja;exports.jaHira=e.jaHira;exports.ka=e.ka;exports.kk=e.kk;exports.km=e.km;exports.kn=e.kn;exports.ko=e.ko;exports.lb=e.lb;exports.lt=e.lt;exports.lv=e.lv;exports.mk=e.mk;exports.mn=e.mn;exports.ms=e.ms;exports.mt=e.mt;exports.nb=e.nb;exports.nl=e.nl;exports.nlBE=e.nlBE;exports.nn=e.nn;exports.oc=e.oc;exports.pl=e.pl;exports.pt=e.pt;exports.ptBR=e.ptBR;exports.ro=e.ro;exports.ru=e.ru;exports.se=e.se;exports.sk=e.sk;exports.sl=e.sl;exports.sq=e.sq;exports.sr=e.sr;exports.srLatn=e.srLatn;exports.sv=e.sv;exports.ta=e.ta;exports.te=e.te;exports.th=e.th;exports.tr=e.tr;exports.ug=e.ug;exports.uk=e.uk;exports.uz=e.uz;exports.uzCyrl=e.uzCyrl;exports.vi=e.vi;exports.zhCN=e.zhCN;exports.zhHK=e.zhHK;exports.zhTW=e.zhTW;exports.enUS=a.enUS;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("./calendar-BXQ3v62X.js"),e=require("./zh-TW-CAp7WWVq.js"),a=require("./format-CFKKBdIQ.js");exports.Calendar=r.Calendar;exports.af=e.af;exports.ar=e.ar;exports.arDZ=e.arDZ;exports.arEG=e.arEG;exports.arMA=e.arMA;exports.arSA=e.arSA;exports.arTN=e.arTN;exports.az=e.az;exports.be=e.be;exports.beTarask=e.beTarask;exports.bg=e.bg;exports.bn=e.bn;exports.bs=e.bs;exports.ca=e.ca;exports.ckb=e.ckb;exports.cs=e.cs;exports.cy=e.cy;exports.da=e.da;exports.de=e.de;exports.deAT=e.deAT;exports.el=e.el;exports.enAU=e.enAU;exports.enCA=e.enCA;exports.enGB=e.enGB;exports.enIE=e.enIE;exports.enIN=e.enIN;exports.enNZ=e.enNZ;exports.enZA=e.enZA;exports.eo=e.eo;exports.es=e.es;exports.et=e.et;exports.eu=e.eu;exports.faIR=e.faIR;exports.fi=e.fi;exports.fr=e.fr;exports.frCA=e.frCA;exports.frCH=e.frCH;exports.fy=e.fy;exports.gd=e.gd;exports.gl=e.gl;exports.gu=e.gu;exports.he=e.he;exports.hi=e.hi;exports.hr=e.hr;exports.ht=e.ht;exports.hu=e.hu;exports.hy=e.hy;exports.id=e.id;exports.is=e.is;exports.it=e.it;exports.itCH=e.itCH;exports.ja=e.ja;exports.jaHira=e.jaHira;exports.ka=e.ka;exports.kk=e.kk;exports.km=e.km;exports.kn=e.kn;exports.ko=e.ko;exports.lb=e.lb;exports.lt=e.lt;exports.lv=e.lv;exports.mk=e.mk;exports.mn=e.mn;exports.ms=e.ms;exports.mt=e.mt;exports.nb=e.nb;exports.nl=e.nl;exports.nlBE=e.nlBE;exports.nn=e.nn;exports.oc=e.oc;exports.pl=e.pl;exports.pt=e.pt;exports.ptBR=e.ptBR;exports.ro=e.ro;exports.ru=e.ru;exports.se=e.se;exports.sk=e.sk;exports.sl=e.sl;exports.sq=e.sq;exports.sr=e.sr;exports.srLatn=e.srLatn;exports.sv=e.sv;exports.ta=e.ta;exports.te=e.te;exports.th=e.th;exports.tr=e.tr;exports.ug=e.ug;exports.uk=e.uk;exports.uz=e.uz;exports.uzCyrl=e.uzCyrl;exports.vi=e.vi;exports.zhCN=e.zhCN;exports.zhHK=e.zhHK;exports.zhTW=e.zhTW;exports.enUS=a.enUS;
2
2
  //# sourceMappingURL=calendar.cjs.js.map
@@ -1,6 +1,6 @@
1
- import { C as e } from "./calendar-DEXw83mu.mjs";
2
- import { a as n, b as t, c as k, d as l, e as f, f as h, g as o, h as b, i, j as m, k as u, l as C, m as A, n as d, o as p, p as z, q as c, r as g, s as y, t as v, u as x, v as B, w as H, x as N, y as T, z as j, A as E, B as I, C as Z, D as q, E as D, F as G, G as R, H as S, I as U, J as w, K, L, M, N as W, O as F, P as J, Q as O, R as P, S as Q, T as V, U as X, V as Y, W as _, X as $, Y as aa, Z as sa, _ as ea, $ as ra, a0 as na, a1 as ta, a2 as ka, a3 as la, a4 as fa, a5 as ha, a6 as oa, a7 as ba, a8 as ia, a9 as ma, aa as ua, ab as Ca, ac as Aa, ad as da, ae as pa, af as za, ag as ca, ah as ga, ai as ya, aj as va, ak as xa, al as Ba, am as Ha, an as Na, ao as Ta, ap as ja, aq as Ea, ar as Ia, as as Za, at as qa, au as Da, av as Ga, aw as Ra, ax as Sa, ay as Ua, az as wa, aA as Ka, aB as La, aC as Ma, aD as Wa } from "./zh-TW-oiRD71xW.mjs";
3
- import { e as Ja } from "./format-DpkYPs7O.mjs";
1
+ import { C as e } from "./calendar-d53vgYqR.mjs";
2
+ import { a as n, b as t, c as k, d as l, e as f, f as h, g as o, h as b, i, j as m, k as u, l as C, m as A, n as d, o as p, p as z, q as c, r as g, s as y, t as v, u as x, v as B, w as H, x as N, y as T, z as j, A as E, B as I, C as Z, D as q, E as D, F as G, G as R, H as S, I as U, J as w, K, L, M, N as W, O as F, P as J, Q as O, R as P, S as Q, T as V, U as X, V as Y, W as _, X as $, Y as aa, Z as sa, _ as ea, $ as ra, a0 as na, a1 as ta, a2 as ka, a3 as la, a4 as fa, a5 as ha, a6 as oa, a7 as ba, a8 as ia, a9 as ma, aa as ua, ab as Ca, ac as Aa, ad as da, ae as pa, af as za, ag as ca, ah as ga, ai as ya, aj as va, ak as xa, al as Ba, am as Ha, an as Na, ao as Ta, ap as ja, aq as Ea, ar as Ia, as as Za, at as qa, au as Da, av as Ga, aw as Ra, ax as Sa, ay as Ua, az as wa, aA as Ka, aB as La, aC as Ma, aD as Wa } from "./zh-TW-DrQ6h7hA.mjs";
3
+ import { e as Ja } from "./format-CWOXI-dC.mjs";
4
4
  export {
5
5
  e as Calendar,
6
6
  n as af,
@@ -0,0 +1,2 @@
1
+ "use strict";const r=require("react/jsx-runtime"),p=require("react"),I=require("./bind-DeUYJ6m9.js"),L=require("./checkmark.es-lYntWFA3.js"),F=require("./minus.es-DtXArdKK.js"),A=require("./chevron-down.es-BMjgiS3F.js"),S=require("./paragraph-By4jMjnH.js"),O=require("./badge-CQ0SS_t8.js"),D=require("./button-DmybVApa.js"),B=require("./heading-drD5ugCC.js"),V=require("./arrow-left.es-CCWJyrcQ.js"),H=require("./arrow-right.es-eH-IgGi9.js"),K={"purpur-comparison-table__wrapper":"_purpur-comparison-table__wrapper_1udkj_1","purpur-comparison-table":"_purpur-comparison-table_1udkj_1","purpur-comparison-table--primary":"_purpur-comparison-table--primary_1udkj_11","purpur-comparison-table--secondary":"_purpur-comparison-table--secondary_1udkj_15","purpur-comparison-table__feature-row":"_purpur-comparison-table__feature-row_1udkj_32","purpur-comparison-table__cards":"_purpur-comparison-table__cards_1udkj_32","purpur-comparison-table__separator":"_purpur-comparison-table__separator_1udkj_49"},W={"purpur-comparison-table-cell":"_purpur-comparison-table-cell_117pb_1","purpur-comparison-table-cell--check":"_purpur-comparison-table-cell--check_117pb_16","purpur-comparison-table-cell--minus":"_purpur-comparison-table-cell--minus_117pb_19","purpur-comparison-table-cell__icon":"_purpur-comparison-table-cell__icon_117pb_22"},T=I.c.bind(W),z="purpur-comparison-table-cell",G=({value:s})=>{const t=p.isValidElement(s)||["string","number"].includes(typeof s),o=T(z,[t?"":`${z}--${s?"check":"minus"}`]),$=s?L.a:F.e;return r.jsx("span",{className:T(o),children:t?s:r.jsx($,{size:"xs",className:T(`${z}__icon`)})})},J={"purpur-comparison-table-lead-cell":"_purpur-comparison-table-lead-cell_1vild_1","purpur-comparison-table-lead-cell__description":"_purpur-comparison-table-lead-cell__description_1vild_5","purpur-comparison-table-lead-cell__summary":"_purpur-comparison-table-lead-cell__summary_1vild_40","purpur-comparison-table-lead-cell__summary-title":"_purpur-comparison-table-lead-cell__summary-title_1vild_48","purpur-comparison-table-lead-cell__summary-icon":"_purpur-comparison-table-lead-cell__summary-icon_1vild_51"},w=I.c.bind(J),k="purpur-comparison-table-lead-cell",Q=({title:s,description:t})=>{const i=typeof t=="string",o=w(k);return r.jsxs("details",{className:o,"data-is-expandable":i,children:[r.jsxs("summary",{className:w(`${k}__summary`),tabIndex:i?0:-1,children:[r.jsx(S.Paragraph,{className:w(`${k}__summary-title`),variant:"paragraph-100-bold",children:s}),r.jsx(A.l,{className:w(`${k}__summary-icon`),size:"sm"})]}),t&&r.jsx(S.Paragraph,{variant:"paragraph-100",className:w(`${k}__description`),children:t})]})},U={"purpur-comparison-table-option-card":"_purpur-comparison-table-option-card_15113_1","purpur-comparison-table-option-card--highlighted":"_purpur-comparison-table-option-card--highlighted_15113_11","purpur-comparison-table-option-card__badge":"_purpur-comparison-table-option-card__badge_15113_14","purpur-comparison-table-option-card__main-content":"_purpur-comparison-table-option-card__main-content_15113_19","purpur-comparison-table-option-card__image":"_purpur-comparison-table-option-card__image_15113_25","purpur-comparison-table-option-card__body":"_purpur-comparison-table-option-card__body_15113_31","purpur-comparison-table-option-card__description":"_purpur-comparison-table-option-card__description_15113_36","purpur-comparison-table-option-card__description-text":"_purpur-comparison-table-option-card__description-text_15113_41","purpur-comparison-table-option-card__read-more":"_purpur-comparison-table-option-card__read-more_15113_50","purpur-comparison-table-option-card__read-more-icon":"_purpur-comparison-table-option-card__read-more-icon_15113_54","purpur-comparison-table-option-card__footer":"_purpur-comparison-table-option-card__footer_15113_62","purpur-comparison-table-option-card__price":"_purpur-comparison-table-option-card__price_15113_67","purpur-comparison-table-option-card--show-full-descriptions":"_purpur-comparison-table-option-card--show-full-descriptions_15113_74","purpur-comparison-table-option-card--first-card":"_purpur-comparison-table-option-card--first-card_15113_107"},d=I.c.bind(U),l="purpur-comparison-table-option-card",X=({id:s,cardIndex:t,description:i,variablePriceText:o,price:$,isHighlighted:b,ariaLabels:x,badge:h,actions:j,isFirstCard:v,image:e,title:n,showFullDescriptions:m,toggleShowFullDescriptions:u})=>{const _=d(l,{[`${l}--highlighted`]:b,[`${l}--first-card`]:v,[`${l}--show-full-descriptions`]:m}),c=()=>{if(!i)return null;const g=i.length>50;return r.jsxs("div",{className:d(`${l}__description`),children:[r.jsx(S.Paragraph,{variant:"paragraph-100",className:d(`${l}__description-text`),children:i}),g&&r.jsxs(D.Button,{variant:"text",size:"xs",className:d(`${l}__read-more`),onClick:u,children:[r.jsx("span",{className:d(`${l}__read-more-text`),children:m?x.readLess:x.readMore}),r.jsx(A.l,{className:d(`${l}__read-more-icon`),size:"xs"})]})]})};return r.jsxs("article",{className:_,"data-card-id":s,"data-card-index":t,children:[h&&r.jsx(O.Badge,{...h,className:d(`${l}__badge`)}),r.jsxs("section",{className:d(`${l}__main-content`),children:[r.jsx("img",{src:e.src,alt:e.alt,className:d(`${l}__image`)}),r.jsxs("div",{className:d(`${l}__body`),children:[r.jsx(B.Heading,{tag:"h3",variant:"title-200",className:d(`${l}__title`),children:n}),c()]})]}),r.jsxs("footer",{className:d(`${l}__footer`),children:[r.jsxs("span",{className:d(`${l}__price`),id:s,children:[r.jsx(S.Paragraph,{variant:"paragraph-100",children:o}),r.jsx(S.Paragraph,{variant:"paragraph-100-bold",children:$})]}),j]})]})},Y="_active_ybbe8_44",Z={"purpur-comparison-table-scroll-progress":"_purpur-comparison-table-scroll-progress_ybbe8_1","purpur-comparison-table-scroll-progress__indicators":"_purpur-comparison-table-scroll-progress__indicators_ybbe8_15","purpur-comparison-table-scroll-progress__indicator":"_purpur-comparison-table-scroll-progress__indicator_ybbe8_15",active:Y,"purpur-comparison-table-scroll-progress__buttons":"_purpur-comparison-table-scroll-progress__buttons_ybbe8_48","purpur-comparison-table-scroll-progress__button":"_purpur-comparison-table-scroll-progress__button_ybbe8_48","purpur-comparison-table-scroll-progress__button-icon":"_purpur-comparison-table-scroll-progress__button-icon_ybbe8_57"},f=I.c.bind(Z),y="purpur-comparison-table-scroll-progress",rr=({items:s,container:t,ariaLabels:i})=>{const[o,$]=p.useState(new Set),b=p.useCallback(e=>{const n=window.matchMedia("(prefers-reduced-motion: reduce)").matches;t.current?.querySelector(`[data-card-index="${e}"]`)?.scrollIntoView({behavior:n?"instant":"smooth",block:"nearest"})},[t]),x=p.useCallback(()=>{if(o.size===0)return;const n=Math.min(...Array.from(o))-1;n<0||b(n)},[o,b]),h=p.useCallback(()=>{if(o.size===0)return;const n=Math.max(...Array.from(o))+1;n>=s.length||b(n)},[o,s.length,b]),j=p.useCallback(e=>{(e.key==="ArrowRight"||e.key==="ArrowLeft")&&(e.preventDefault(),e.key==="ArrowRight"?h():e.key==="ArrowLeft"&&x())},[h,x]);p.useEffect(()=>{const e=t.current;if(!e)return;const n=new IntersectionObserver(m=>{$(u=>{const _=new Set(u);return m.forEach(c=>{const a=Number(c.target.getAttribute("data-card-index"));Number.isNaN(a)||(c.isIntersecting?_.add(a):_.delete(a))}),_})},{root:e,threshold:.5});return s.forEach((m,u)=>{const _=e.querySelector(`[data-card-index="${u}"]`);_&&n.observe(_)}),()=>n.disconnect()},[t,s]),p.useEffect(()=>{const e=t.current;if(e)return e.addEventListener("keydown",j),()=>e.removeEventListener("keydown",j)},[t,j]);const v=()=>{if(o.size===0)return;const e=[],n=o.size,m=Math.min(...Array.from(o)),u=s.slice(0,m).length,_=s.slice(m+n).length;let c=0;for(let a=0;a<s.length;a++){if(u+1!==a&&u<=a&&a<s.length-_)continue;let g="active";(a<u||a>s.length-1-_)&&(g=""),e.push(r.jsx("li",{className:f(`${y}__indicator`,g)},`indicator-${c++}`))}return e.length<2?null:e};return r.jsxs("li",{className:f(y),children:[r.jsx("ul",{className:f(`${y}__indicators`),children:v()}),r.jsxs("div",{className:f(`${y}__buttons`),children:[r.jsx(D.Button,{"aria-label":i.previous,variant:"secondary",iconOnly:!0,className:f(`${y}__button`),disabled:o.has(0),onClick:x,children:r.jsx(V.l,{className:f(`${y}__button-icon`),size:"xs"})}),r.jsx(D.Button,{"aria-label":i.next,variant:"secondary",iconOnly:!0,className:f(`${y}__button`),disabled:o.has(s.length-1),onClick:h,children:r.jsx(H.i,{className:f(`${y}__button-icon`),size:"xs"})})]})]})},C=I.c.bind(K),N="purpur-comparison-table",R=({classname:s,features:t,items:i,ariaLabels:o,variant:$="primary"})=>{const b=p.useId(),x=C(s,N,`${N}--${$}`),h=p.useRef(null),[j,v]=p.useState(!1),e=p.useCallback(()=>{v(c=>!c)},[]),n=()=>r.jsxs("li",{className:C(`${N}__cards`),children:[r.jsx("div",{className:C(`${N}__separator`)}),i.map((c,a)=>p.createElement(X,{...c,showFullDescriptions:j,toggleShowFullDescriptions:e,key:a,isFirstCard:a===0,ariaLabels:o,cardIndex:a,id:`${a}-${b}`}))]}),m=()=>Object.entries(t).map(([c,a],g)=>r.jsxs("li",{className:C(`${N}__feature-row`),children:[r.jsx(Q,{title:c,description:a}),i.map((q,E)=>r.jsx(G,{value:q.features[c]??!1},E))]},g)),u=p.useRef(0),_=c=>{const a=c.currentTarget,g=a.querySelector("[data-card-id]")?.clientWidth??0,q=Math.round(a.scrollLeft/g),E=q*g+q,M=c.timeStamp-u.current,P=Math.abs(a.scrollLeft-E);u.current&&M<200||P<10||(u.current=c.timeStamp,a.scrollTo({left:E,behavior:"smooth"}))};return r.jsx("div",{className:C(N+"__wrapper"),children:r.jsxs("ul",{id:N+`-${b}`,ref:h,className:x,onScrollEnd:_,style:{"--initial-columns":i.length+1},children:[r.jsx(rr,{items:i,container:h,ariaLabels:o}),n(),m()]})})};R.displayName="ComparisonTable";exports.ComparisonTable=R;
2
+ //# sourceMappingURL=comparison-table-C74IAVqz.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"comparison-table-C74IAVqz.js","sources":["../../../components/comparison-table/src/components/Cell/cell.tsx","../../../components/comparison-table/src/components/LeadCell/lead-cell.tsx","../../../components/comparison-table/src/components/OptionCard/option-card.tsx","../../../components/comparison-table/src/components/ScrollProgress/scroll-progress.tsx","../../../components/comparison-table/src/comparison-table.tsx"],"sourcesContent":["import React, { isValidElement, type ReactNode } from \"react\";\nimport { IconCheckmark } from \"@purpur/icon/checkmark\";\nimport { IconMinus } from \"@purpur/icon/minus\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./cell.module.scss\";\n\ntype CellProps = {\n value: boolean | ReactNode;\n};\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-comparison-table-cell\";\n\nexport const Cell = ({ value }: CellProps) => {\n const isReactNode = isValidElement(value) || [\"string\", \"number\"].includes(typeof value);\n\n const getClassName = () => {\n if (isReactNode) return \"\";\n return `${rootClassName}--${value ? \"check\" : \"minus\"}`;\n };\n\n const classes = cx(rootClassName, [getClassName()]);\n\n const Icon = value ? IconCheckmark : IconMinus;\n\n return (\n <span className={cx(classes)}>\n {isReactNode ? value : <Icon size=\"xs\" className={cx(`${rootClassName}__icon`)} />}\n </span>\n );\n};\n","import React, { type ReactNode } from \"react\";\nimport { IconChevronDown } from \"@purpur/icon/chevron-down\";\nimport { Paragraph } from \"@purpur/paragraph\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./lead-cell.module.scss\";\n\ntype LeadCellProps = {\n title: string;\n description?: ReactNode;\n};\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-comparison-table-lead-cell\";\n\nexport const LeadCell = ({ title, description }: LeadCellProps) => {\n const isExpandable = typeof description === \"string\";\n const classes = cx(rootClassName);\n\n return (\n <details className={classes} data-is-expandable={isExpandable}>\n <summary className={cx(`${rootClassName}__summary`)} tabIndex={isExpandable ? 0 : -1}>\n <Paragraph className={cx(`${rootClassName}__summary-title`)} variant=\"paragraph-100-bold\">\n {title}\n </Paragraph>\n <IconChevronDown className={cx(`${rootClassName}__summary-icon`)} size=\"sm\" />\n </summary>\n {description && (\n <Paragraph variant=\"paragraph-100\" className={cx(`${rootClassName}__description`)}>\n {description}\n </Paragraph>\n )}\n </details>\n );\n};\n","import React, { type ReactNode } from \"react\";\nimport { Badge, type BadgeProps } from \"@purpur/badge\";\nimport { Button } from \"@purpur/button\";\nimport { Heading } from \"@purpur/heading\";\nimport { IconChevronDown } from \"@purpur/icon/chevron-down\";\nimport { Paragraph } from \"@purpur/paragraph\";\nimport c from \"classnames/bind\";\n\nimport { type ComparisonTableProps } from \"../../comparison-table\";\nimport styles from \"./option-card.module.scss\";\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-comparison-table-option-card\";\n\nexport type OptionCardProps = {\n image: {\n src: string;\n alt: string;\n };\n\n title: string;\n description: string;\n variablePriceText: string;\n price: string;\n\n actions: ReactNode;\n\n badge?: BadgeProps;\n isHighlighted?: boolean;\n};\n\ntype OptionCardPropsAdditions = {\n id: string;\n cardIndex: number;\n isFirstCard: boolean;\n ariaLabels: ComparisonTableProps[\"ariaLabels\"];\n\n showFullDescriptions: boolean;\n toggleShowFullDescriptions: () => void;\n};\n\nexport const OptionCard = ({\n id,\n cardIndex,\n description,\n variablePriceText,\n price,\n isHighlighted,\n ariaLabels,\n badge,\n actions,\n isFirstCard,\n image,\n title,\n showFullDescriptions,\n toggleShowFullDescriptions,\n}: OptionCardProps & OptionCardPropsAdditions) => {\n const classes = cx(rootClassName, {\n [`${rootClassName}--highlighted`]: isHighlighted,\n [`${rootClassName}--first-card`]: isFirstCard,\n [`${rootClassName}--show-full-descriptions`]: showFullDescriptions,\n });\n\n const renderDescription = () => {\n if (!description) return null;\n\n const longThreshold = 50;\n const longDescription = description.length > longThreshold;\n\n return (\n <div className={cx(`${rootClassName}__description`)}>\n <Paragraph variant=\"paragraph-100\" className={cx(`${rootClassName}__description-text`)}>\n {description}\n </Paragraph>\n {longDescription && (\n <Button\n variant=\"text\"\n size=\"xs\"\n className={cx(`${rootClassName}__read-more`)}\n onClick={toggleShowFullDescriptions}\n >\n <span className={cx(`${rootClassName}__read-more-text`)}>\n {showFullDescriptions ? ariaLabels.readLess : ariaLabels.readMore}\n </span>\n <IconChevronDown className={cx(`${rootClassName}__read-more-icon`)} size=\"xs\" />\n </Button>\n )}\n </div>\n );\n };\n\n return (\n <article className={classes} data-card-id={id} data-card-index={cardIndex}>\n {badge && <Badge {...badge} className={cx(`${rootClassName}__badge`)} />}\n\n <section className={cx(`${rootClassName}__main-content`)}>\n <img src={image.src} alt={image.alt} className={cx(`${rootClassName}__image`)} />\n\n <div className={cx(`${rootClassName}__body`)}>\n <Heading tag=\"h3\" variant=\"title-200\" className={cx(`${rootClassName}__title`)}>\n {title}\n </Heading>\n {renderDescription()}\n </div>\n </section>\n\n <footer className={cx(`${rootClassName}__footer`)}>\n <span className={cx(`${rootClassName}__price`)} id={id}>\n <Paragraph variant=\"paragraph-100\">{variablePriceText}</Paragraph>\n <Paragraph variant=\"paragraph-100-bold\">{price}</Paragraph>\n </span>\n\n {actions}\n </footer>\n </article>\n );\n};\n","import React, { type RefObject, useCallback, useEffect, useState } from \"react\";\nimport { Button } from \"@purpur/button\";\nimport { IconArrowLeft } from \"@purpur/icon/arrow-left\";\nimport { IconArrowRight } from \"@purpur/icon/arrow-right\";\nimport c from \"classnames/bind\";\n\nimport { type ComparisonTableProps, type Features, type Item } from \"../../comparison-table\";\nimport styles from \"./scroll-progress.module.scss\";\n\nconst cx = c.bind(styles);\nconst rootClassName = \"purpur-comparison-table-scroll-progress\";\n\ntype ScrollProgressProps = {\n items: Array<Item<Features>>;\n container: RefObject<HTMLUListElement | null>;\n ariaLabels: ComparisonTableProps[\"ariaLabels\"];\n};\n\nexport const ScrollProgress = ({ items, container, ariaLabels }: ScrollProgressProps) => {\n const [inViewSet, setInViewSet] = useState<Set<number>>(new Set());\n\n const scrollToCard = useCallback(\n (index: number) => {\n const reduceMotion = window.matchMedia(\"(prefers-reduced-motion: reduce)\").matches;\n\n const card = container.current?.querySelector(\n `[data-card-index=\"${index}\"]`\n ) as HTMLElement | null;\n card?.scrollIntoView({ behavior: reduceMotion ? \"instant\" : \"smooth\", block: \"nearest\" });\n },\n [container]\n );\n\n const previousCard = useCallback(() => {\n if (inViewSet.size === 0) return;\n\n const leftmostactiveIndex = Math.min(...Array.from(inViewSet));\n const targetIndex = leftmostactiveIndex - 1;\n\n if (targetIndex < 0) return;\n\n scrollToCard(targetIndex);\n }, [inViewSet, scrollToCard]);\n\n const nextCard = useCallback(() => {\n if (inViewSet.size === 0) return;\n\n const rightmostactiveIndex = Math.max(...Array.from(inViewSet));\n const targetIndex = rightmostactiveIndex + 1;\n\n if (targetIndex >= items.length) return;\n\n scrollToCard(targetIndex);\n }, [inViewSet, items.length, scrollToCard]);\n\n const handleKeyDown = useCallback(\n (e: KeyboardEvent) => {\n if (e.key === \"ArrowRight\" || e.key === \"ArrowLeft\") {\n e.preventDefault();\n\n if (e.key === \"ArrowRight\") nextCard();\n else if (e.key === \"ArrowLeft\") previousCard();\n }\n },\n [nextCard, previousCard]\n );\n\n useEffect(() => {\n const root = container.current;\n\n if (!root) return;\n\n const observer = new IntersectionObserver(\n (entries) => {\n setInViewSet((prev) => {\n const next = new Set(prev);\n\n entries.forEach((entry) => {\n const index = Number(entry.target.getAttribute(\"data-card-index\"));\n\n if (Number.isNaN(index)) return;\n\n if (entry.isIntersecting) {\n next.add(index);\n } else {\n next.delete(index);\n }\n });\n return next;\n });\n },\n { root, threshold: 0.5 }\n );\n\n items.forEach((_, index) => {\n const card = root.querySelector(`[data-card-index=\"${index}\"]`) as HTMLElement | null;\n\n if (card) observer.observe(card);\n });\n\n return () => observer.disconnect();\n }, [container, items]);\n\n useEffect(() => {\n const root = container.current;\n\n if (!root) return;\n\n root.addEventListener(\"keydown\", handleKeyDown);\n\n return () => root.removeEventListener(\"keydown\", handleKeyDown);\n }, [container, handleKeyDown]);\n\n const renderIndicators = () => {\n if (inViewSet.size === 0) return;\n\n const indicators = [];\n const viewCapacity = inViewSet.size;\n const leftmostActiveIndex = Math.min(...Array.from(inViewSet));\n const head = items.slice(0, leftmostActiveIndex).length;\n const trail = items.slice(leftmostActiveIndex + viewCapacity).length;\n\n let key = 0;\n\n for (let i = 0; i < items.length; i++) {\n if (head + 1 !== i && head <= i && i < items.length - trail) continue;\n\n let status = \"active\";\n\n if (i < head || i > items.length - 1 - trail) status = \"\";\n\n indicators.push(\n <li key={`indicator-${key++}`} className={cx(`${rootClassName}__indicator`, status)} />\n );\n }\n\n if (indicators.length < 2) return null;\n\n return indicators;\n };\n\n return (\n <li className={cx(rootClassName)}>\n <ul className={cx(`${rootClassName}__indicators`)}>{renderIndicators()}</ul>\n\n <div className={cx(`${rootClassName}__buttons`)}>\n <Button\n aria-label={ariaLabels.previous}\n variant=\"secondary\"\n iconOnly\n className={cx(`${rootClassName}__button`)}\n disabled={inViewSet.has(0)}\n onClick={previousCard}\n >\n <IconArrowLeft className={cx(`${rootClassName}__button-icon`)} size=\"xs\" />\n </Button>\n <Button\n aria-label={ariaLabels.next}\n variant=\"secondary\"\n iconOnly\n className={cx(`${rootClassName}__button`)}\n disabled={inViewSet.has(items.length - 1)}\n onClick={nextCard}\n >\n <IconArrowRight className={cx(`${rootClassName}__button-icon`)} size=\"xs\" />\n </Button>\n </div>\n </li>\n );\n};\n","import React, { type ReactNode, type UIEvent, useCallback, useId, useRef, useState } from \"react\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./comparison-table.module.scss\";\nimport { Cell } from \"./components/Cell/cell\";\nimport { LeadCell } from \"./components/LeadCell/lead-cell\";\nimport { OptionCard, type OptionCardProps } from \"./components/OptionCard/option-card\";\nimport { ScrollProgress } from \"./components/ScrollProgress/scroll-progress\";\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-comparison-table\";\n\nexport type Features = Record<string, ReactNode | null>;\n\nexport type Item<TFeatures extends Features = Features> = OptionCardProps & {\n features: Partial<Record<keyof TFeatures, ReactNode | string | boolean>>;\n};\n\nexport type ComparisonTableProps<TFeatures extends Features = Features> = {\n /** List of features that can be supported by the comparison table\n *\n * string = description of the feature that can be viewed by expanding cell.\n *\n * null = no description\n *\n {\n [featureName]: ReactNode | null\n }\n */\n features: TFeatures;\n\n /** List of items to be displayed in the comparison table\n *\n *\n Item = {\n image: {\n src: string;\n alt: string;\n };\n\n title: string;\n description: string;\n variablePriceText: string;\n price: string;\n actions: ReactNode;\n badge?: BadgeProps;\n isHighlighted?: boolean;\n\n features: {\n [featureName in keyof Features]?: string | boolean;\n };\n }\n */\n items: Array<Item<TFeatures>>;\n\n /** Aria labels for the comparison table and various components\n *\n {\n previous: string;\n next: string;\n readMore: string;\n readLess: string;\n }\n */\n ariaLabels: {\n previous: string;\n next: string;\n readMore: string;\n readLess: string;\n };\n variant?: \"primary\" | \"secondary\";\n classname?: string;\n};\n\nexport const ComparisonTable = <TFeatures extends Features>({\n classname,\n features,\n items,\n ariaLabels,\n variant = \"primary\",\n}: ComparisonTableProps<TFeatures>) => {\n const id = useId();\n const classes = cx(classname, rootClassName, `${rootClassName}--${variant}`);\n const containerRef = useRef<HTMLUListElement>(null);\n const [showFullDescriptions, setShowFullDescriptions] = useState(false);\n\n const handleToggleShowFullDescriptions = useCallback(() => {\n setShowFullDescriptions((prev) => !prev);\n }, []);\n\n const renderCards = () => {\n return (\n <li className={cx(`${rootClassName}__cards`)}>\n <div className={cx(`${rootClassName}__separator`)} />\n {items.map((item, index) => (\n <OptionCard\n {...item}\n showFullDescriptions={showFullDescriptions}\n toggleShowFullDescriptions={handleToggleShowFullDescriptions}\n key={index}\n isFirstCard={index === 0}\n ariaLabels={ariaLabels}\n cardIndex={index}\n id={`${index}-${id}`}\n />\n ))}\n </li>\n );\n };\n\n const renderFeatures = () => {\n return Object.entries(features).map(([title, description], i) => (\n <li key={i} className={cx(`${rootClassName}__feature-row`)}>\n <LeadCell title={title} description={description} />\n {items.map((item, index) => (\n <Cell key={index} value={item.features[title as keyof TFeatures] ?? false} />\n ))}\n </li>\n ));\n };\n\n const deltaTime = useRef(0);\n\n const handleScrollEnd = (e: UIEvent<HTMLUListElement>) => {\n /**\n * This function makes sure that the scroll position is never stuck between two cards, since scroll snap is not fully reliable.\n */\n\n const target = e.currentTarget;\n const cardwidth = target.querySelector(\"[data-card-id]\")?.clientWidth ?? 0;\n const cardPos = Math.round(target.scrollLeft / cardwidth);\n const scrollTarget = cardPos * cardwidth + cardPos;\n const timeDiff = e.timeStamp - deltaTime.current;\n const scrollDiff = Math.abs(target.scrollLeft - scrollTarget);\n\n if (deltaTime.current && timeDiff < 200) return;\n if (scrollDiff < 10) return;\n\n deltaTime.current = e.timeStamp;\n\n target.scrollTo({ left: scrollTarget, behavior: \"smooth\" });\n };\n\n return (\n <div className={cx(rootClassName + \"__wrapper\")}>\n <ul\n id={rootClassName + `-${id}`}\n ref={containerRef}\n className={classes}\n // eslint-disable-next-line react/no-unknown-property\n onScrollEnd={handleScrollEnd}\n style={{\n // @ts-expect-error | Typescript doesn't recognize the CSS variable, but it works as intended\n [\"--initial-columns\"]: items.length + 1,\n }}\n >\n <ScrollProgress items={items} container={containerRef} ariaLabels={ariaLabels} />\n {renderCards()}\n {renderFeatures()}\n </ul>\n </div>\n );\n};\n\nComparisonTable.displayName = \"ComparisonTable\";\n"],"names":["cx","c","styles","rootClassName","Cell","value","isReactNode","isValidElement","classes","Icon","IconCheckmark","IconMinus","jsx","LeadCell","title","description","isExpandable","jsxs","Paragraph","IconChevronDown","OptionCard","id","cardIndex","variablePriceText","price","isHighlighted","ariaLabels","badge","actions","isFirstCard","image","showFullDescriptions","toggleShowFullDescriptions","renderDescription","longDescription","Button","Badge","Heading","ScrollProgress","items","container","inViewSet","setInViewSet","useState","scrollToCard","useCallback","index","reduceMotion","previousCard","targetIndex","nextCard","handleKeyDown","useEffect","root","observer","entries","prev","next","entry","_","card","renderIndicators","indicators","viewCapacity","leftmostActiveIndex","head","trail","key","i","status","IconArrowLeft","IconArrowRight","ComparisonTable","classname","features","variant","useId","containerRef","useRef","setShowFullDescriptions","handleToggleShowFullDescriptions","renderCards","item","createElement","renderFeatures","deltaTime","handleScrollEnd","e","target","cardwidth","cardPos","scrollTarget","timeDiff","scrollDiff"],"mappings":"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"}
@@ -0,0 +1,267 @@
1
+ import { jsx as e, jsxs as p } from "react/jsx-runtime";
2
+ import { isValidElement as q, useState as O, useCallback as S, useEffect as F, useId as B, useRef as L, createElement as H } from "react";
3
+ import { c as z } from "./bind-CU-R61T-.mjs";
4
+ import { a as K } from "./checkmark.es-DdgIZN2R.mjs";
5
+ import { e as W } from "./minus.es-BK9qA9iJ.mjs";
6
+ import { l as R } from "./chevron-down.es-PCIIj6oG.mjs";
7
+ import { P as j } from "./paragraph-DSxXmX_0.mjs";
8
+ import { a as G } from "./badge-DalD-yqG.mjs";
9
+ import { b as M } from "./button-4-yWOgtD.mjs";
10
+ import { H as J } from "./heading-xwBuT_-9.mjs";
11
+ import { l as Q } from "./arrow-left.es-DU-PX-Il.mjs";
12
+ import { i as U } from "./arrow-right.es-C7SkjAB6.mjs";
13
+ const X = {
14
+ "purpur-comparison-table__wrapper": "_purpur-comparison-table__wrapper_1udkj_1",
15
+ "purpur-comparison-table": "_purpur-comparison-table_1udkj_1",
16
+ "purpur-comparison-table--primary": "_purpur-comparison-table--primary_1udkj_11",
17
+ "purpur-comparison-table--secondary": "_purpur-comparison-table--secondary_1udkj_15",
18
+ "purpur-comparison-table__feature-row": "_purpur-comparison-table__feature-row_1udkj_32",
19
+ "purpur-comparison-table__cards": "_purpur-comparison-table__cards_1udkj_32",
20
+ "purpur-comparison-table__separator": "_purpur-comparison-table__separator_1udkj_49"
21
+ }, Y = {
22
+ "purpur-comparison-table-cell": "_purpur-comparison-table-cell_117pb_1",
23
+ "purpur-comparison-table-cell--check": "_purpur-comparison-table-cell--check_117pb_16",
24
+ "purpur-comparison-table-cell--minus": "_purpur-comparison-table-cell--minus_117pb_19",
25
+ "purpur-comparison-table-cell__icon": "_purpur-comparison-table-cell__icon_117pb_22"
26
+ }, A = z.bind(Y), D = "purpur-comparison-table-cell", Z = ({ value: a }) => {
27
+ const s = q(a) || ["string", "number"].includes(typeof a), t = A(D, [s ? "" : `${D}--${a ? "check" : "minus"}`]), N = a ? K : W;
28
+ return /* @__PURE__ */ e("span", { className: A(t), children: s ? a : /* @__PURE__ */ e(N, { size: "xs", className: A(`${D}__icon`) }) });
29
+ }, rr = {
30
+ "purpur-comparison-table-lead-cell": "_purpur-comparison-table-lead-cell_1vild_1",
31
+ "purpur-comparison-table-lead-cell__description": "_purpur-comparison-table-lead-cell__description_1vild_5",
32
+ "purpur-comparison-table-lead-cell__summary": "_purpur-comparison-table-lead-cell__summary_1vild_40",
33
+ "purpur-comparison-table-lead-cell__summary-title": "_purpur-comparison-table-lead-cell__summary-title_1vild_48",
34
+ "purpur-comparison-table-lead-cell__summary-icon": "_purpur-comparison-table-lead-cell__summary-icon_1vild_51"
35
+ }, k = z.bind(rr), C = "purpur-comparison-table-lead-cell", or = ({ title: a, description: s }) => {
36
+ const i = typeof s == "string", t = k(C);
37
+ return /* @__PURE__ */ p("details", { className: t, "data-is-expandable": i, children: [
38
+ /* @__PURE__ */ p("summary", { className: k(`${C}__summary`), tabIndex: i ? 0 : -1, children: [
39
+ /* @__PURE__ */ e(j, { className: k(`${C}__summary-title`), variant: "paragraph-100-bold", children: a }),
40
+ /* @__PURE__ */ e(R, { className: k(`${C}__summary-icon`), size: "sm" })
41
+ ] }),
42
+ s && /* @__PURE__ */ e(j, { variant: "paragraph-100", className: k(`${C}__description`), children: s })
43
+ ] });
44
+ }, er = {
45
+ "purpur-comparison-table-option-card": "_purpur-comparison-table-option-card_15113_1",
46
+ "purpur-comparison-table-option-card--highlighted": "_purpur-comparison-table-option-card--highlighted_15113_11",
47
+ "purpur-comparison-table-option-card__badge": "_purpur-comparison-table-option-card__badge_15113_14",
48
+ "purpur-comparison-table-option-card__main-content": "_purpur-comparison-table-option-card__main-content_15113_19",
49
+ "purpur-comparison-table-option-card__image": "_purpur-comparison-table-option-card__image_15113_25",
50
+ "purpur-comparison-table-option-card__body": "_purpur-comparison-table-option-card__body_15113_31",
51
+ "purpur-comparison-table-option-card__description": "_purpur-comparison-table-option-card__description_15113_36",
52
+ "purpur-comparison-table-option-card__description-text": "_purpur-comparison-table-option-card__description-text_15113_41",
53
+ "purpur-comparison-table-option-card__read-more": "_purpur-comparison-table-option-card__read-more_15113_50",
54
+ "purpur-comparison-table-option-card__read-more-icon": "_purpur-comparison-table-option-card__read-more-icon_15113_54",
55
+ "purpur-comparison-table-option-card__footer": "_purpur-comparison-table-option-card__footer_15113_62",
56
+ "purpur-comparison-table-option-card__price": "_purpur-comparison-table-option-card__price_15113_67",
57
+ "purpur-comparison-table-option-card--show-full-descriptions": "_purpur-comparison-table-option-card--show-full-descriptions_15113_74",
58
+ "purpur-comparison-table-option-card--first-card": "_purpur-comparison-table-option-card--first-card_15113_107"
59
+ }, d = z.bind(er), l = "purpur-comparison-table-option-card", ar = ({
60
+ id: a,
61
+ cardIndex: s,
62
+ description: i,
63
+ variablePriceText: t,
64
+ price: N,
65
+ isHighlighted: b,
66
+ ariaLabels: g,
67
+ badge: h,
68
+ actions: v,
69
+ isFirstCard: w,
70
+ image: r,
71
+ title: n,
72
+ showFullDescriptions: m,
73
+ toggleShowFullDescriptions: _
74
+ }) => {
75
+ const u = d(l, {
76
+ [`${l}--highlighted`]: b,
77
+ [`${l}--first-card`]: w,
78
+ [`${l}--show-full-descriptions`]: m
79
+ }), c = () => {
80
+ if (!i) return null;
81
+ const f = i.length > 50;
82
+ return /* @__PURE__ */ p("div", { className: d(`${l}__description`), children: [
83
+ /* @__PURE__ */ e(j, { variant: "paragraph-100", className: d(`${l}__description-text`), children: i }),
84
+ f && /* @__PURE__ */ p(
85
+ M,
86
+ {
87
+ variant: "text",
88
+ size: "xs",
89
+ className: d(`${l}__read-more`),
90
+ onClick: _,
91
+ children: [
92
+ /* @__PURE__ */ e("span", { className: d(`${l}__read-more-text`), children: m ? g.readLess : g.readMore }),
93
+ /* @__PURE__ */ e(R, { className: d(`${l}__read-more-icon`), size: "xs" })
94
+ ]
95
+ }
96
+ )
97
+ ] });
98
+ };
99
+ return /* @__PURE__ */ p("article", { className: u, "data-card-id": a, "data-card-index": s, children: [
100
+ h && /* @__PURE__ */ e(G, { ...h, className: d(`${l}__badge`) }),
101
+ /* @__PURE__ */ p("section", { className: d(`${l}__main-content`), children: [
102
+ /* @__PURE__ */ e("img", { src: r.src, alt: r.alt, className: d(`${l}__image`) }),
103
+ /* @__PURE__ */ p("div", { className: d(`${l}__body`), children: [
104
+ /* @__PURE__ */ e(J, { tag: "h3", variant: "title-200", className: d(`${l}__title`), children: n }),
105
+ c()
106
+ ] })
107
+ ] }),
108
+ /* @__PURE__ */ p("footer", { className: d(`${l}__footer`), children: [
109
+ /* @__PURE__ */ p("span", { className: d(`${l}__price`), id: a, children: [
110
+ /* @__PURE__ */ e(j, { variant: "paragraph-100", children: t }),
111
+ /* @__PURE__ */ e(j, { variant: "paragraph-100-bold", children: N })
112
+ ] }),
113
+ v
114
+ ] })
115
+ ] });
116
+ }, tr = "_active_ybbe8_44", sr = {
117
+ "purpur-comparison-table-scroll-progress": "_purpur-comparison-table-scroll-progress_ybbe8_1",
118
+ "purpur-comparison-table-scroll-progress__indicators": "_purpur-comparison-table-scroll-progress__indicators_ybbe8_15",
119
+ "purpur-comparison-table-scroll-progress__indicator": "_purpur-comparison-table-scroll-progress__indicator_ybbe8_15",
120
+ active: tr,
121
+ "purpur-comparison-table-scroll-progress__buttons": "_purpur-comparison-table-scroll-progress__buttons_ybbe8_48",
122
+ "purpur-comparison-table-scroll-progress__button": "_purpur-comparison-table-scroll-progress__button_ybbe8_48",
123
+ "purpur-comparison-table-scroll-progress__button-icon": "_purpur-comparison-table-scroll-progress__button-icon_ybbe8_57"
124
+ }, y = z.bind(sr), $ = "purpur-comparison-table-scroll-progress", cr = ({ items: a, container: s, ariaLabels: i }) => {
125
+ const [t, N] = O(/* @__PURE__ */ new Set()), b = S(
126
+ (r) => {
127
+ const n = window.matchMedia("(prefers-reduced-motion: reduce)").matches;
128
+ s.current?.querySelector(
129
+ `[data-card-index="${r}"]`
130
+ )?.scrollIntoView({ behavior: n ? "instant" : "smooth", block: "nearest" });
131
+ },
132
+ [s]
133
+ ), g = S(() => {
134
+ if (t.size === 0) return;
135
+ const n = Math.min(...Array.from(t)) - 1;
136
+ n < 0 || b(n);
137
+ }, [t, b]), h = S(() => {
138
+ if (t.size === 0) return;
139
+ const n = Math.max(...Array.from(t)) + 1;
140
+ n >= a.length || b(n);
141
+ }, [t, a.length, b]), v = S(
142
+ (r) => {
143
+ (r.key === "ArrowRight" || r.key === "ArrowLeft") && (r.preventDefault(), r.key === "ArrowRight" ? h() : r.key === "ArrowLeft" && g());
144
+ },
145
+ [h, g]
146
+ );
147
+ F(() => {
148
+ const r = s.current;
149
+ if (!r) return;
150
+ const n = new IntersectionObserver(
151
+ (m) => {
152
+ N((_) => {
153
+ const u = new Set(_);
154
+ return m.forEach((c) => {
155
+ const o = Number(c.target.getAttribute("data-card-index"));
156
+ Number.isNaN(o) || (c.isIntersecting ? u.add(o) : u.delete(o));
157
+ }), u;
158
+ });
159
+ },
160
+ { root: r, threshold: 0.5 }
161
+ );
162
+ return a.forEach((m, _) => {
163
+ const u = r.querySelector(`[data-card-index="${_}"]`);
164
+ u && n.observe(u);
165
+ }), () => n.disconnect();
166
+ }, [s, a]), F(() => {
167
+ const r = s.current;
168
+ if (r)
169
+ return r.addEventListener("keydown", v), () => r.removeEventListener("keydown", v);
170
+ }, [s, v]);
171
+ const w = () => {
172
+ if (t.size === 0) return;
173
+ const r = [], n = t.size, m = Math.min(...Array.from(t)), _ = a.slice(0, m).length, u = a.slice(m + n).length;
174
+ let c = 0;
175
+ for (let o = 0; o < a.length; o++) {
176
+ if (_ + 1 !== o && _ <= o && o < a.length - u) continue;
177
+ let f = "active";
178
+ (o < _ || o > a.length - 1 - u) && (f = ""), r.push(
179
+ /* @__PURE__ */ e("li", { className: y(`${$}__indicator`, f) }, `indicator-${c++}`)
180
+ );
181
+ }
182
+ return r.length < 2 ? null : r;
183
+ };
184
+ return /* @__PURE__ */ p("li", { className: y($), children: [
185
+ /* @__PURE__ */ e("ul", { className: y(`${$}__indicators`), children: w() }),
186
+ /* @__PURE__ */ p("div", { className: y(`${$}__buttons`), children: [
187
+ /* @__PURE__ */ e(
188
+ M,
189
+ {
190
+ "aria-label": i.previous,
191
+ variant: "secondary",
192
+ iconOnly: !0,
193
+ className: y(`${$}__button`),
194
+ disabled: t.has(0),
195
+ onClick: g,
196
+ children: /* @__PURE__ */ e(Q, { className: y(`${$}__button-icon`), size: "xs" })
197
+ }
198
+ ),
199
+ /* @__PURE__ */ e(
200
+ M,
201
+ {
202
+ "aria-label": i.next,
203
+ variant: "secondary",
204
+ iconOnly: !0,
205
+ className: y(`${$}__button`),
206
+ disabled: t.has(a.length - 1),
207
+ onClick: h,
208
+ children: /* @__PURE__ */ e(U, { className: y(`${$}__button-icon`), size: "xs" })
209
+ }
210
+ )
211
+ ] })
212
+ ] });
213
+ }, I = z.bind(X), x = "purpur-comparison-table", nr = ({
214
+ classname: a,
215
+ features: s,
216
+ items: i,
217
+ ariaLabels: t,
218
+ variant: N = "primary"
219
+ }) => {
220
+ const b = B(), g = I(a, x, `${x}--${N}`), h = L(null), [v, w] = O(!1), r = S(() => {
221
+ w((c) => !c);
222
+ }, []), n = () => /* @__PURE__ */ p("li", { className: I(`${x}__cards`), children: [
223
+ /* @__PURE__ */ e("div", { className: I(`${x}__separator`) }),
224
+ i.map((c, o) => /* @__PURE__ */ H(
225
+ ar,
226
+ {
227
+ ...c,
228
+ showFullDescriptions: v,
229
+ toggleShowFullDescriptions: r,
230
+ key: o,
231
+ isFirstCard: o === 0,
232
+ ariaLabels: t,
233
+ cardIndex: o,
234
+ id: `${o}-${b}`
235
+ }
236
+ ))
237
+ ] }), m = () => Object.entries(s).map(([c, o], f) => /* @__PURE__ */ p("li", { className: I(`${x}__feature-row`), children: [
238
+ /* @__PURE__ */ e(or, { title: c, description: o }),
239
+ i.map((E, T) => /* @__PURE__ */ e(Z, { value: E.features[c] ?? !1 }, T))
240
+ ] }, f)), _ = L(0), u = (c) => {
241
+ const o = c.currentTarget, f = o.querySelector("[data-card-id]")?.clientWidth ?? 0, E = Math.round(o.scrollLeft / f), T = E * f + E, P = c.timeStamp - _.current, V = Math.abs(o.scrollLeft - T);
242
+ _.current && P < 200 || V < 10 || (_.current = c.timeStamp, o.scrollTo({ left: T, behavior: "smooth" }));
243
+ };
244
+ return /* @__PURE__ */ e("div", { className: I(x + "__wrapper"), children: /* @__PURE__ */ p(
245
+ "ul",
246
+ {
247
+ id: x + `-${b}`,
248
+ ref: h,
249
+ className: g,
250
+ onScrollEnd: u,
251
+ style: {
252
+ // @ts-expect-error | Typescript doesn't recognize the CSS variable, but it works as intended
253
+ "--initial-columns": i.length + 1
254
+ },
255
+ children: [
256
+ /* @__PURE__ */ e(cr, { items: i, container: h, ariaLabels: t }),
257
+ n(),
258
+ m()
259
+ ]
260
+ }
261
+ ) });
262
+ };
263
+ nr.displayName = "ComparisonTable";
264
+ export {
265
+ nr as C
266
+ };
267
+ //# sourceMappingURL=comparison-table-DctKxmX9.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"comparison-table-DctKxmX9.mjs","sources":["../../../components/comparison-table/src/components/Cell/cell.tsx","../../../components/comparison-table/src/components/LeadCell/lead-cell.tsx","../../../components/comparison-table/src/components/OptionCard/option-card.tsx","../../../components/comparison-table/src/components/ScrollProgress/scroll-progress.tsx","../../../components/comparison-table/src/comparison-table.tsx"],"sourcesContent":["import React, { isValidElement, type ReactNode } from \"react\";\nimport { IconCheckmark } from \"@purpur/icon/checkmark\";\nimport { IconMinus } from \"@purpur/icon/minus\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./cell.module.scss\";\n\ntype CellProps = {\n value: boolean | ReactNode;\n};\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-comparison-table-cell\";\n\nexport const Cell = ({ value }: CellProps) => {\n const isReactNode = isValidElement(value) || [\"string\", \"number\"].includes(typeof value);\n\n const getClassName = () => {\n if (isReactNode) return \"\";\n return `${rootClassName}--${value ? \"check\" : \"minus\"}`;\n };\n\n const classes = cx(rootClassName, [getClassName()]);\n\n const Icon = value ? IconCheckmark : IconMinus;\n\n return (\n <span className={cx(classes)}>\n {isReactNode ? value : <Icon size=\"xs\" className={cx(`${rootClassName}__icon`)} />}\n </span>\n );\n};\n","import React, { type ReactNode } from \"react\";\nimport { IconChevronDown } from \"@purpur/icon/chevron-down\";\nimport { Paragraph } from \"@purpur/paragraph\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./lead-cell.module.scss\";\n\ntype LeadCellProps = {\n title: string;\n description?: ReactNode;\n};\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-comparison-table-lead-cell\";\n\nexport const LeadCell = ({ title, description }: LeadCellProps) => {\n const isExpandable = typeof description === \"string\";\n const classes = cx(rootClassName);\n\n return (\n <details className={classes} data-is-expandable={isExpandable}>\n <summary className={cx(`${rootClassName}__summary`)} tabIndex={isExpandable ? 0 : -1}>\n <Paragraph className={cx(`${rootClassName}__summary-title`)} variant=\"paragraph-100-bold\">\n {title}\n </Paragraph>\n <IconChevronDown className={cx(`${rootClassName}__summary-icon`)} size=\"sm\" />\n </summary>\n {description && (\n <Paragraph variant=\"paragraph-100\" className={cx(`${rootClassName}__description`)}>\n {description}\n </Paragraph>\n )}\n </details>\n );\n};\n","import React, { type ReactNode } from \"react\";\nimport { Badge, type BadgeProps } from \"@purpur/badge\";\nimport { Button } from \"@purpur/button\";\nimport { Heading } from \"@purpur/heading\";\nimport { IconChevronDown } from \"@purpur/icon/chevron-down\";\nimport { Paragraph } from \"@purpur/paragraph\";\nimport c from \"classnames/bind\";\n\nimport { type ComparisonTableProps } from \"../../comparison-table\";\nimport styles from \"./option-card.module.scss\";\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-comparison-table-option-card\";\n\nexport type OptionCardProps = {\n image: {\n src: string;\n alt: string;\n };\n\n title: string;\n description: string;\n variablePriceText: string;\n price: string;\n\n actions: ReactNode;\n\n badge?: BadgeProps;\n isHighlighted?: boolean;\n};\n\ntype OptionCardPropsAdditions = {\n id: string;\n cardIndex: number;\n isFirstCard: boolean;\n ariaLabels: ComparisonTableProps[\"ariaLabels\"];\n\n showFullDescriptions: boolean;\n toggleShowFullDescriptions: () => void;\n};\n\nexport const OptionCard = ({\n id,\n cardIndex,\n description,\n variablePriceText,\n price,\n isHighlighted,\n ariaLabels,\n badge,\n actions,\n isFirstCard,\n image,\n title,\n showFullDescriptions,\n toggleShowFullDescriptions,\n}: OptionCardProps & OptionCardPropsAdditions) => {\n const classes = cx(rootClassName, {\n [`${rootClassName}--highlighted`]: isHighlighted,\n [`${rootClassName}--first-card`]: isFirstCard,\n [`${rootClassName}--show-full-descriptions`]: showFullDescriptions,\n });\n\n const renderDescription = () => {\n if (!description) return null;\n\n const longThreshold = 50;\n const longDescription = description.length > longThreshold;\n\n return (\n <div className={cx(`${rootClassName}__description`)}>\n <Paragraph variant=\"paragraph-100\" className={cx(`${rootClassName}__description-text`)}>\n {description}\n </Paragraph>\n {longDescription && (\n <Button\n variant=\"text\"\n size=\"xs\"\n className={cx(`${rootClassName}__read-more`)}\n onClick={toggleShowFullDescriptions}\n >\n <span className={cx(`${rootClassName}__read-more-text`)}>\n {showFullDescriptions ? ariaLabels.readLess : ariaLabels.readMore}\n </span>\n <IconChevronDown className={cx(`${rootClassName}__read-more-icon`)} size=\"xs\" />\n </Button>\n )}\n </div>\n );\n };\n\n return (\n <article className={classes} data-card-id={id} data-card-index={cardIndex}>\n {badge && <Badge {...badge} className={cx(`${rootClassName}__badge`)} />}\n\n <section className={cx(`${rootClassName}__main-content`)}>\n <img src={image.src} alt={image.alt} className={cx(`${rootClassName}__image`)} />\n\n <div className={cx(`${rootClassName}__body`)}>\n <Heading tag=\"h3\" variant=\"title-200\" className={cx(`${rootClassName}__title`)}>\n {title}\n </Heading>\n {renderDescription()}\n </div>\n </section>\n\n <footer className={cx(`${rootClassName}__footer`)}>\n <span className={cx(`${rootClassName}__price`)} id={id}>\n <Paragraph variant=\"paragraph-100\">{variablePriceText}</Paragraph>\n <Paragraph variant=\"paragraph-100-bold\">{price}</Paragraph>\n </span>\n\n {actions}\n </footer>\n </article>\n );\n};\n","import React, { type RefObject, useCallback, useEffect, useState } from \"react\";\nimport { Button } from \"@purpur/button\";\nimport { IconArrowLeft } from \"@purpur/icon/arrow-left\";\nimport { IconArrowRight } from \"@purpur/icon/arrow-right\";\nimport c from \"classnames/bind\";\n\nimport { type ComparisonTableProps, type Features, type Item } from \"../../comparison-table\";\nimport styles from \"./scroll-progress.module.scss\";\n\nconst cx = c.bind(styles);\nconst rootClassName = \"purpur-comparison-table-scroll-progress\";\n\ntype ScrollProgressProps = {\n items: Array<Item<Features>>;\n container: RefObject<HTMLUListElement | null>;\n ariaLabels: ComparisonTableProps[\"ariaLabels\"];\n};\n\nexport const ScrollProgress = ({ items, container, ariaLabels }: ScrollProgressProps) => {\n const [inViewSet, setInViewSet] = useState<Set<number>>(new Set());\n\n const scrollToCard = useCallback(\n (index: number) => {\n const reduceMotion = window.matchMedia(\"(prefers-reduced-motion: reduce)\").matches;\n\n const card = container.current?.querySelector(\n `[data-card-index=\"${index}\"]`\n ) as HTMLElement | null;\n card?.scrollIntoView({ behavior: reduceMotion ? \"instant\" : \"smooth\", block: \"nearest\" });\n },\n [container]\n );\n\n const previousCard = useCallback(() => {\n if (inViewSet.size === 0) return;\n\n const leftmostactiveIndex = Math.min(...Array.from(inViewSet));\n const targetIndex = leftmostactiveIndex - 1;\n\n if (targetIndex < 0) return;\n\n scrollToCard(targetIndex);\n }, [inViewSet, scrollToCard]);\n\n const nextCard = useCallback(() => {\n if (inViewSet.size === 0) return;\n\n const rightmostactiveIndex = Math.max(...Array.from(inViewSet));\n const targetIndex = rightmostactiveIndex + 1;\n\n if (targetIndex >= items.length) return;\n\n scrollToCard(targetIndex);\n }, [inViewSet, items.length, scrollToCard]);\n\n const handleKeyDown = useCallback(\n (e: KeyboardEvent) => {\n if (e.key === \"ArrowRight\" || e.key === \"ArrowLeft\") {\n e.preventDefault();\n\n if (e.key === \"ArrowRight\") nextCard();\n else if (e.key === \"ArrowLeft\") previousCard();\n }\n },\n [nextCard, previousCard]\n );\n\n useEffect(() => {\n const root = container.current;\n\n if (!root) return;\n\n const observer = new IntersectionObserver(\n (entries) => {\n setInViewSet((prev) => {\n const next = new Set(prev);\n\n entries.forEach((entry) => {\n const index = Number(entry.target.getAttribute(\"data-card-index\"));\n\n if (Number.isNaN(index)) return;\n\n if (entry.isIntersecting) {\n next.add(index);\n } else {\n next.delete(index);\n }\n });\n return next;\n });\n },\n { root, threshold: 0.5 }\n );\n\n items.forEach((_, index) => {\n const card = root.querySelector(`[data-card-index=\"${index}\"]`) as HTMLElement | null;\n\n if (card) observer.observe(card);\n });\n\n return () => observer.disconnect();\n }, [container, items]);\n\n useEffect(() => {\n const root = container.current;\n\n if (!root) return;\n\n root.addEventListener(\"keydown\", handleKeyDown);\n\n return () => root.removeEventListener(\"keydown\", handleKeyDown);\n }, [container, handleKeyDown]);\n\n const renderIndicators = () => {\n if (inViewSet.size === 0) return;\n\n const indicators = [];\n const viewCapacity = inViewSet.size;\n const leftmostActiveIndex = Math.min(...Array.from(inViewSet));\n const head = items.slice(0, leftmostActiveIndex).length;\n const trail = items.slice(leftmostActiveIndex + viewCapacity).length;\n\n let key = 0;\n\n for (let i = 0; i < items.length; i++) {\n if (head + 1 !== i && head <= i && i < items.length - trail) continue;\n\n let status = \"active\";\n\n if (i < head || i > items.length - 1 - trail) status = \"\";\n\n indicators.push(\n <li key={`indicator-${key++}`} className={cx(`${rootClassName}__indicator`, status)} />\n );\n }\n\n if (indicators.length < 2) return null;\n\n return indicators;\n };\n\n return (\n <li className={cx(rootClassName)}>\n <ul className={cx(`${rootClassName}__indicators`)}>{renderIndicators()}</ul>\n\n <div className={cx(`${rootClassName}__buttons`)}>\n <Button\n aria-label={ariaLabels.previous}\n variant=\"secondary\"\n iconOnly\n className={cx(`${rootClassName}__button`)}\n disabled={inViewSet.has(0)}\n onClick={previousCard}\n >\n <IconArrowLeft className={cx(`${rootClassName}__button-icon`)} size=\"xs\" />\n </Button>\n <Button\n aria-label={ariaLabels.next}\n variant=\"secondary\"\n iconOnly\n className={cx(`${rootClassName}__button`)}\n disabled={inViewSet.has(items.length - 1)}\n onClick={nextCard}\n >\n <IconArrowRight className={cx(`${rootClassName}__button-icon`)} size=\"xs\" />\n </Button>\n </div>\n </li>\n );\n};\n","import React, { type ReactNode, type UIEvent, useCallback, useId, useRef, useState } from \"react\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./comparison-table.module.scss\";\nimport { Cell } from \"./components/Cell/cell\";\nimport { LeadCell } from \"./components/LeadCell/lead-cell\";\nimport { OptionCard, type OptionCardProps } from \"./components/OptionCard/option-card\";\nimport { ScrollProgress } from \"./components/ScrollProgress/scroll-progress\";\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-comparison-table\";\n\nexport type Features = Record<string, ReactNode | null>;\n\nexport type Item<TFeatures extends Features = Features> = OptionCardProps & {\n features: Partial<Record<keyof TFeatures, ReactNode | string | boolean>>;\n};\n\nexport type ComparisonTableProps<TFeatures extends Features = Features> = {\n /** List of features that can be supported by the comparison table\n *\n * string = description of the feature that can be viewed by expanding cell.\n *\n * null = no description\n *\n {\n [featureName]: ReactNode | null\n }\n */\n features: TFeatures;\n\n /** List of items to be displayed in the comparison table\n *\n *\n Item = {\n image: {\n src: string;\n alt: string;\n };\n\n title: string;\n description: string;\n variablePriceText: string;\n price: string;\n actions: ReactNode;\n badge?: BadgeProps;\n isHighlighted?: boolean;\n\n features: {\n [featureName in keyof Features]?: string | boolean;\n };\n }\n */\n items: Array<Item<TFeatures>>;\n\n /** Aria labels for the comparison table and various components\n *\n {\n previous: string;\n next: string;\n readMore: string;\n readLess: string;\n }\n */\n ariaLabels: {\n previous: string;\n next: string;\n readMore: string;\n readLess: string;\n };\n variant?: \"primary\" | \"secondary\";\n classname?: string;\n};\n\nexport const ComparisonTable = <TFeatures extends Features>({\n classname,\n features,\n items,\n ariaLabels,\n variant = \"primary\",\n}: ComparisonTableProps<TFeatures>) => {\n const id = useId();\n const classes = cx(classname, rootClassName, `${rootClassName}--${variant}`);\n const containerRef = useRef<HTMLUListElement>(null);\n const [showFullDescriptions, setShowFullDescriptions] = useState(false);\n\n const handleToggleShowFullDescriptions = useCallback(() => {\n setShowFullDescriptions((prev) => !prev);\n }, []);\n\n const renderCards = () => {\n return (\n <li className={cx(`${rootClassName}__cards`)}>\n <div className={cx(`${rootClassName}__separator`)} />\n {items.map((item, index) => (\n <OptionCard\n {...item}\n showFullDescriptions={showFullDescriptions}\n toggleShowFullDescriptions={handleToggleShowFullDescriptions}\n key={index}\n isFirstCard={index === 0}\n ariaLabels={ariaLabels}\n cardIndex={index}\n id={`${index}-${id}`}\n />\n ))}\n </li>\n );\n };\n\n const renderFeatures = () => {\n return Object.entries(features).map(([title, description], i) => (\n <li key={i} className={cx(`${rootClassName}__feature-row`)}>\n <LeadCell title={title} description={description} />\n {items.map((item, index) => (\n <Cell key={index} value={item.features[title as keyof TFeatures] ?? false} />\n ))}\n </li>\n ));\n };\n\n const deltaTime = useRef(0);\n\n const handleScrollEnd = (e: UIEvent<HTMLUListElement>) => {\n /**\n * This function makes sure that the scroll position is never stuck between two cards, since scroll snap is not fully reliable.\n */\n\n const target = e.currentTarget;\n const cardwidth = target.querySelector(\"[data-card-id]\")?.clientWidth ?? 0;\n const cardPos = Math.round(target.scrollLeft / cardwidth);\n const scrollTarget = cardPos * cardwidth + cardPos;\n const timeDiff = e.timeStamp - deltaTime.current;\n const scrollDiff = Math.abs(target.scrollLeft - scrollTarget);\n\n if (deltaTime.current && timeDiff < 200) return;\n if (scrollDiff < 10) return;\n\n deltaTime.current = e.timeStamp;\n\n target.scrollTo({ left: scrollTarget, behavior: \"smooth\" });\n };\n\n return (\n <div className={cx(rootClassName + \"__wrapper\")}>\n <ul\n id={rootClassName + `-${id}`}\n ref={containerRef}\n className={classes}\n // eslint-disable-next-line react/no-unknown-property\n onScrollEnd={handleScrollEnd}\n style={{\n // @ts-expect-error | Typescript doesn't recognize the CSS variable, but it works as intended\n [\"--initial-columns\"]: items.length + 1,\n }}\n >\n <ScrollProgress items={items} container={containerRef} ariaLabels={ariaLabels} />\n {renderCards()}\n {renderFeatures()}\n </ul>\n </div>\n );\n};\n\nComparisonTable.displayName = \"ComparisonTable\";\n"],"names":["cx","c","styles","rootClassName","Cell","value","isReactNode","isValidElement","classes","Icon","IconCheckmark","IconMinus","jsx","LeadCell","title","description","isExpandable","jsxs","Paragraph","IconChevronDown","OptionCard","id","cardIndex","variablePriceText","price","isHighlighted","ariaLabels","badge","actions","isFirstCard","image","showFullDescriptions","toggleShowFullDescriptions","renderDescription","longDescription","Button","Badge","Heading","ScrollProgress","items","container","inViewSet","setInViewSet","useState","scrollToCard","useCallback","index","reduceMotion","previousCard","targetIndex","nextCard","handleKeyDown","e","useEffect","root","observer","entries","prev","next","entry","_","card","renderIndicators","indicators","viewCapacity","leftmostActiveIndex","head","trail","key","i","status","IconArrowLeft","IconArrowRight","ComparisonTable","classname","features","variant","useId","containerRef","useRef","setShowFullDescriptions","handleToggleShowFullDescriptions","renderCards","item","createElement","renderFeatures","deltaTime","handleScrollEnd","target","cardwidth","cardPos","scrollTarget","timeDiff","scrollDiff"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./comparison-table-mKL2IHXW.js");exports.ComparisonTable=e.ComparisonTable;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./comparison-table-C74IAVqz.js");exports.ComparisonTable=e.ComparisonTable;
2
2
  //# sourceMappingURL=comparison-table.cjs.js.map
@@ -1,4 +1,4 @@
1
- import { C as r } from "./comparison-table-8bOJmz-L.mjs";
1
+ import { C as r } from "./comparison-table-DctKxmX9.mjs";
2
2
  export {
3
3
  r as ComparisonTable
4
4
  };
@@ -1,16 +1,9 @@
1
1
  import { default as React } from 'react';
2
- import { DateRange, DayPickerProps } from 'react-day-picker';
2
+ import { PropsBase, PropsRange, PropsRangeRequired, PropsSingle, PropsSingleRequired } from 'react-day-picker';
3
+ export type { DateRange } from 'react-day-picker';
3
4
  export * from 'react-day-picker/locale';
4
- type CalendarModeProps = {
5
- mode: "single";
6
- selected: Date | undefined;
7
- onSelect: (date: Date | undefined) => void;
8
- } | {
9
- mode: "range";
10
- selected: DateRange | undefined;
11
- onSelect: (dateRange: DateRange | undefined) => void;
12
- };
13
- export type CalendarProps = Omit<DayPickerProps, "mode" | "selected" | "onSelect"> & CalendarModeProps & {
5
+ type CalendarModeProps = PropsSingle | PropsSingleRequired | PropsRange | PropsRangeRequired;
6
+ export type CalendarProps = PropsBase & CalendarModeProps & {
14
7
  ["data-testid"]?: string;
15
8
  /**
16
9
  * Ref to first element - previous month button
@@ -1 +1 @@
1
- {"version":3,"file":"calendar.d.ts","sourceRoot":"","sources":["../../../../../../components/calendar/src/calendar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA8B,MAAM,OAAO,CAAC;AACnD,OAAO,EACL,KAAK,SAAS,EAEd,KAAK,cAAc,EAEpB,MAAM,kBAAkB,CAAC;AAK1B,cAAc,yBAAyB,CAAC;AAExC,OAAO,4BAA4B,CAAC;AACpC,OAAO,uBAAuB,CAAC;AAC/B,OAAO,qBAAqB,CAAC;AAG7B,KAAK,iBAAiB,GAClB;IACE,IAAI,EAAE,QAAQ,CAAC;IACf,QAAQ,EAAE,IAAI,GAAG,SAAS,CAAC;IAC3B,QAAQ,EAAE,CAAC,IAAI,EAAE,IAAI,GAAG,SAAS,KAAK,IAAI,CAAC;CAC5C,GACD;IACE,IAAI,EAAE,OAAO,CAAC;IACd,QAAQ,EAAE,SAAS,GAAG,SAAS,CAAC;IAChC,QAAQ,EAAE,CAAC,SAAS,EAAE,SAAS,GAAG,SAAS,KAAK,IAAI,CAAC;CACtD,CAAC;AAEN,MAAM,MAAM,aAAa,GAAG,IAAI,CAAC,cAAc,EAAE,MAAM,GAAG,UAAU,GAAG,UAAU,CAAC,GAChF,iBAAiB,GAAG;IAClB,CAAC,aAAa,CAAC,CAAC,EAAE,MAAM,CAAC;IACzB;;;SAGK;IACL,eAAe,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;CAChD,CAAC;AAEJ;;;;;;;GAOG;AACH,eAAO,MAAM,QAAQ;YAAW,aAAa;;CA2E5C,CAAC"}
1
+ {"version":3,"file":"calendar.d.ts","sourceRoot":"","sources":["../../../../../../components/calendar/src/calendar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAsC,MAAM,OAAO,CAAC;AAC3D,OAAO,EAGL,KAAK,SAAS,EACd,KAAK,UAAU,EACf,KAAK,kBAAkB,EACvB,KAAK,WAAW,EAChB,KAAK,mBAAmB,EACzB,MAAM,kBAAkB,CAAC;AAK1B,YAAY,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,cAAc,yBAAyB,CAAC;AAExC,OAAO,4BAA4B,CAAC;AACpC,OAAO,uBAAuB,CAAC;AAC/B,OAAO,qBAAqB,CAAC;AAG7B,KAAK,iBAAiB,GAAG,WAAW,GAAG,mBAAmB,GAAG,UAAU,GAAG,kBAAkB,CAAC;AAE7F,MAAM,MAAM,aAAa,GAAG,SAAS,GACnC,iBAAiB,GAAG;IAClB,CAAC,aAAa,CAAC,CAAC,EAAE,MAAM,CAAC;IACzB;;;SAGK;IACL,eAAe,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;CAChD,CAAC;AAEJ;;;;;;;GAOG;AACH,eAAO,MAAM,QAAQ;YAAW,aAAa;;CAmH5C,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"comparison-table.d.ts","sourceRoot":"","sources":["../../../../../../components/comparison-table/src/comparison-table.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,KAAK,SAAS,EAAsD,MAAM,OAAO,CAAC;AAMlG,OAAO,EAAc,KAAK,eAAe,EAAE,MAAM,qCAAqC,CAAC;AAOvF,MAAM,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAAC,CAAC;AAExD,MAAM,MAAM,IAAI,CAAC,SAAS,SAAS,QAAQ,GAAG,QAAQ,IAAI,eAAe,GAAG;IAC1E,QAAQ,EAAE,OAAO,CAAC,MAAM,CAAC,MAAM,SAAS,EAAE,SAAS,GAAG,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC;CAC1E,CAAC;AAEF,MAAM,MAAM,oBAAoB,CAAC,SAAS,SAAS,QAAQ,GAAG,QAAQ,IAAI;IACxE;;;;;;;;;MASE;IACF,QAAQ,EAAE,SAAS,CAAC;IAEpB;;;;;;;;;;;;;;;;;;;;;MAqBE;IACF,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IAE9B;;;;;;;;MAQE;IACF,UAAU,EAAE;QACV,QAAQ,EAAE,MAAM,CAAC;QACjB,IAAI,EAAE,MAAM,CAAC;QACb,QAAQ,EAAE,MAAM,CAAC;QACjB,QAAQ,EAAE,MAAM,CAAC;KAClB,CAAC;IACF,OAAO,CAAC,EAAE,SAAS,GAAG,WAAW,CAAC;IAClC,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,eAAO,MAAM,eAAe;KAAI,SAAS,SAAS,QAAQ,wDAMvD,oBAAoB,CAAC,SAAS,CAAC;;CAsFjC,CAAC"}
1
+ {"version":3,"file":"comparison-table.d.ts","sourceRoot":"","sources":["../../../../../../components/comparison-table/src/comparison-table.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,KAAK,SAAS,EAAsD,MAAM,OAAO,CAAC;AAMlG,OAAO,EAAc,KAAK,eAAe,EAAE,MAAM,qCAAqC,CAAC;AAOvF,MAAM,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CAAC,CAAC;AAExD,MAAM,MAAM,IAAI,CAAC,SAAS,SAAS,QAAQ,GAAG,QAAQ,IAAI,eAAe,GAAG;IAC1E,QAAQ,EAAE,OAAO,CAAC,MAAM,CAAC,MAAM,SAAS,EAAE,SAAS,GAAG,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC;CAC1E,CAAC;AAEF,MAAM,MAAM,oBAAoB,CAAC,SAAS,SAAS,QAAQ,GAAG,QAAQ,IAAI;IACxE;;;;;;;;;MASE;IACF,QAAQ,EAAE,SAAS,CAAC;IAEpB;;;;;;;;;;;;;;;;;;;;;MAqBE;IACF,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IAE9B;;;;;;;;MAQE;IACF,UAAU,EAAE;QACV,QAAQ,EAAE,MAAM,CAAC;QACjB,IAAI,EAAE,MAAM,CAAC;QACb,QAAQ,EAAE,MAAM,CAAC;QACjB,QAAQ,EAAE,MAAM,CAAC;KAClB,CAAC;IACF,OAAO,CAAC,EAAE,SAAS,GAAG,WAAW,CAAC;IAClC,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,eAAO,MAAM,eAAe;KAAI,SAAS,SAAS,QAAQ,wDAMvD,oBAAoB,CAAC,SAAS,CAAC;;CAkFjC,CAAC"}
@@ -16,11 +16,12 @@ export type OptionCardProps = {
16
16
  };
17
17
  type OptionCardPropsAdditions = {
18
18
  id: string;
19
+ cardIndex: number;
19
20
  isFirstCard: boolean;
20
21
  ariaLabels: ComparisonTableProps["ariaLabels"];
21
22
  showFullDescriptions: boolean;
22
23
  toggleShowFullDescriptions: () => void;
23
24
  };
24
- export declare const OptionCard: ({ id, description, variablePriceText, price, isHighlighted, ariaLabels, badge, actions, isFirstCard, image, title, showFullDescriptions, toggleShowFullDescriptions, }: OptionCardProps & OptionCardPropsAdditions) => React.JSX.Element;
25
+ export declare const OptionCard: ({ id, cardIndex, description, variablePriceText, price, isHighlighted, ariaLabels, badge, actions, isFirstCard, image, title, showFullDescriptions, toggleShowFullDescriptions, }: OptionCardProps & OptionCardPropsAdditions) => React.JSX.Element;
25
26
  export {};
26
27
  //# sourceMappingURL=option-card.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"option-card.d.ts","sourceRoot":"","sources":["../../../../../../../../components/comparison-table/src/components/OptionCard/option-card.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAC9C,OAAO,EAAS,KAAK,UAAU,EAAE,MAAM,eAAe,CAAC;AAOvD,OAAO,EAAE,KAAK,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAOnE,MAAM,MAAM,eAAe,GAAG;IAC5B,KAAK,EAAE;QACL,GAAG,EAAE,MAAM,CAAC;QACZ,GAAG,EAAE,MAAM,CAAC;KACb,CAAC;IAEF,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,KAAK,EAAE,MAAM,CAAC;IAEd,OAAO,EAAE,SAAS,CAAC;IAEnB,KAAK,CAAC,EAAE,UAAU,CAAC;IACnB,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB,CAAC;AAEF,KAAK,wBAAwB,GAAG;IAC9B,EAAE,EAAE,MAAM,CAAC;IACX,WAAW,EAAE,OAAO,CAAC;IACrB,UAAU,EAAE,oBAAoB,CAAC,YAAY,CAAC,CAAC;IAE/C,oBAAoB,EAAE,OAAO,CAAC;IAC9B,0BAA0B,EAAE,MAAM,IAAI,CAAC;CACxC,CAAC;AAEF,eAAO,MAAM,UAAU,GAAI,wKAcxB,eAAe,GAAG,wBAAwB,sBA4D5C,CAAC"}
1
+ {"version":3,"file":"option-card.d.ts","sourceRoot":"","sources":["../../../../../../../../components/comparison-table/src/components/OptionCard/option-card.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAC9C,OAAO,EAAS,KAAK,UAAU,EAAE,MAAM,eAAe,CAAC;AAOvD,OAAO,EAAE,KAAK,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAOnE,MAAM,MAAM,eAAe,GAAG;IAC5B,KAAK,EAAE;QACL,GAAG,EAAE,MAAM,CAAC;QACZ,GAAG,EAAE,MAAM,CAAC;KACb,CAAC;IAEF,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,KAAK,EAAE,MAAM,CAAC;IAEd,OAAO,EAAE,SAAS,CAAC;IAEnB,KAAK,CAAC,EAAE,UAAU,CAAC;IACnB,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB,CAAC;AAEF,KAAK,wBAAwB,GAAG;IAC9B,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,OAAO,CAAC;IACrB,UAAU,EAAE,oBAAoB,CAAC,YAAY,CAAC,CAAC;IAE/C,oBAAoB,EAAE,OAAO,CAAC;IAC9B,0BAA0B,EAAE,MAAM,IAAI,CAAC;CACxC,CAAC;AAEF,eAAO,MAAM,UAAU,GAAI,mLAexB,eAAe,GAAG,wBAAwB,sBA4D5C,CAAC"}
@@ -3,9 +3,8 @@ import { ComparisonTableProps, Features, Item } from '../../comparison-table';
3
3
  type ScrollProgressProps = {
4
4
  items: Array<Item<Features>>;
5
5
  container: RefObject<HTMLUListElement | null>;
6
- parentId: string;
7
6
  ariaLabels: ComparisonTableProps["ariaLabels"];
8
7
  };
9
- export declare const ScrollProgress: ({ items, container, parentId, ariaLabels }: ScrollProgressProps) => React.JSX.Element;
8
+ export declare const ScrollProgress: ({ items, container, ariaLabels }: ScrollProgressProps) => React.JSX.Element;
10
9
  export {};
11
10
  //# sourceMappingURL=scroll-progress.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"scroll-progress.d.ts","sourceRoot":"","sources":["../../../../../../../../components/comparison-table/src/components/ScrollProgress/scroll-progress.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,KAAK,SAAS,EAAoC,MAAM,OAAO,CAAC;AAMhF,OAAO,EAAE,KAAK,oBAAoB,EAAE,KAAK,QAAQ,EAAE,KAAK,IAAI,EAAE,MAAM,wBAAwB,CAAC;AAM7F,KAAK,mBAAmB,GAAG;IACzB,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;IAC7B,SAAS,EAAE,SAAS,CAAC,gBAAgB,GAAG,IAAI,CAAC,CAAC;IAC9C,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,oBAAoB,CAAC,YAAY,CAAC,CAAC;CAChD,CAAC;AAEF,eAAO,MAAM,cAAc,GAAI,4CAA4C,mBAAmB,sBA6J7F,CAAC"}
1
+ {"version":3,"file":"scroll-progress.d.ts","sourceRoot":"","sources":["../../../../../../../../components/comparison-table/src/components/ScrollProgress/scroll-progress.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,KAAK,SAAS,EAAoC,MAAM,OAAO,CAAC;AAMhF,OAAO,EAAE,KAAK,oBAAoB,EAAE,KAAK,QAAQ,EAAE,KAAK,IAAI,EAAE,MAAM,wBAAwB,CAAC;AAM7F,KAAK,mBAAmB,GAAG;IACzB,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;IAC7B,SAAS,EAAE,SAAS,CAAC,gBAAgB,GAAG,IAAI,CAAC,CAAC;IAC9C,UAAU,EAAE,oBAAoB,CAAC,YAAY,CAAC,CAAC;CAChD,CAAC;AAEF,eAAO,MAAM,cAAc,GAAI,kCAAkC,mBAAmB,sBAuJnF,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"date-field.d.ts","sourceRoot":"","sources":["../../../../../../components/date-field/src/date-field.tsx"],"names":[],"mappings":"AAAA,OAAO,KAON,MAAM,OAAO,CAAC;AACf,OAAO,EAAa,KAAK,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAIpE,OAAO,2BAA2B,CAAC;AAMnC,KAAK,kBAAkB,GAAG,IAAI,CAC5B,cAAc,EACd,MAAM,GAAG,OAAO,GAAG,UAAU,GAAG,sBAAsB,GAAG,kBAAkB,GAAG,SAAS,CACxF,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,kBAAkB,GAAG;IAChD,CAAC,aAAa,CAAC,CAAC,EAAE,MAAM,CAAC;IACzB,KAAK,CAAC,EAAE,IAAI,GAAG,SAAS,CAAC;IACzB,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,GAAG,SAAS,KAAK,IAAI,CAAC;CAC7C,CAAC;AAaF,eAAO,MAAM,SAAS,sGAkJrB,CAAC"}
1
+ {"version":3,"file":"date-field.d.ts","sourceRoot":"","sources":["../../../../../../components/date-field/src/date-field.tsx"],"names":[],"mappings":"AAAA,OAAO,KAON,MAAM,OAAO,CAAC;AACf,OAAO,EAAa,KAAK,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAIpE,OAAO,2BAA2B,CAAC;AAMnC,KAAK,kBAAkB,GAAG,IAAI,CAC5B,cAAc,EACd,MAAM,GAAG,OAAO,GAAG,UAAU,GAAG,sBAAsB,GAAG,kBAAkB,GAAG,SAAS,CACxF,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,kBAAkB,GAAG;IAChD,CAAC,aAAa,CAAC,CAAC,EAAE,MAAM,CAAC;IACzB,KAAK,CAAC,EAAE,IAAI,GAAG,SAAS,CAAC;IACzB,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,GAAG,SAAS,KAAK,IAAI,CAAC;CAC7C,CAAC;AAaF,eAAO,MAAM,SAAS,sGA+JrB,CAAC"}
@@ -1,11 +1,20 @@
1
1
  import { default as React, ComponentProps } from 'react';
2
2
  import { CalendarProps } from '../../calendar/src/calendar';
3
3
  import { DateFieldProps } from '../../date-field/src/date-field';
4
+ import { DateRangeFieldProps } from '../../date-range-field/src/date-range-field';
4
5
  import { Drawer } from '../../drawer/src/drawer';
5
- export type DatePickerProps = DateFieldProps & {
6
+ type CommonDatePickerProps = {
6
7
  calendarProps?: CalendarProps;
7
8
  drawerContentProps: Omit<ComponentProps<typeof Drawer.Content>, "children" | "backButton" | "backButtonText" | "backButtonOnlyIcon" | "onBackButtonClick" | "zIndex">;
8
9
  overlayZIndex?: number;
9
10
  };
10
- export declare const DatePicker: React.ForwardRefExoticComponent<Omit<DatePickerProps, "ref"> & React.RefAttributes<HTMLDivElement>>;
11
+ type SingleDatePickerProps = CommonDatePickerProps & DateFieldProps & {
12
+ mode?: "single";
13
+ };
14
+ type RangeDatePickerProps = CommonDatePickerProps & DateRangeFieldProps & {
15
+ mode: "range";
16
+ };
17
+ export type DatePickerProps = SingleDatePickerProps | RangeDatePickerProps;
18
+ export type { RangeDatePickerProps, SingleDatePickerProps };
19
+ export declare const DatePicker: React.ForwardRefExoticComponent<(RangeDatePickerProps | Omit<SingleDatePickerProps, "ref">) & React.RefAttributes<HTMLDivElement>>;
11
20
  //# sourceMappingURL=date-picker.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"date-picker.d.ts","sourceRoot":"","sources":["../../../../../../components/date-picker/src/date-picker.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EACZ,KAAK,cAAc,EAQpB,MAAM,OAAO,CAAC;AAYf,OAAO,EAAY,KAAK,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAChE,OAAO,EAAa,KAAK,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpE,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAIxC,OAAO,2BAA2B,CAAC;AACnC,OAAO,yBAAyB,CAAC;AACjC,OAAO,uBAAuB,CAAC;AAC/B,OAAO,qBAAqB,CAAC;AAK7B,MAAM,MAAM,eAAe,GAAG,cAAc,GAAG;IAC7C,aAAa,CAAC,EAAE,aAAa,CAAC;IAC9B,kBAAkB,EAAE,IAAI,CACtB,cAAc,CAAC,OAAO,MAAM,CAAC,OAAO,CAAC,EACnC,UAAU,GACV,YAAY,GACZ,gBAAgB,GAChB,oBAAoB,GACpB,mBAAmB,GACnB,QAAQ,CACX,CAAC;IACF,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,eAAO,MAAM,UAAU,qGAmJtB,CAAC"}
1
+ {"version":3,"file":"date-picker.d.ts","sourceRoot":"","sources":["../../../../../../components/date-picker/src/date-picker.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EACZ,KAAK,cAAc,EASpB,MAAM,OAAO,CAAC;AAYf,OAAO,EAAY,KAAK,aAAa,EAAkB,MAAM,kBAAkB,CAAC;AAChF,OAAO,EAAa,KAAK,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpE,OAAO,EAAkB,KAAK,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AACpF,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAKxC,OAAO,2BAA2B,CAAC;AACnC,OAAO,iCAAiC,CAAC;AACzC,OAAO,yBAAyB,CAAC;AACjC,OAAO,uBAAuB,CAAC;AAC/B,OAAO,qBAAqB,CAAC;AAK7B,KAAK,qBAAqB,GAAG;IAC3B,aAAa,CAAC,EAAE,aAAa,CAAC;IAC9B,kBAAkB,EAAE,IAAI,CACtB,cAAc,CAAC,OAAO,MAAM,CAAC,OAAO,CAAC,EACnC,UAAU,GACV,YAAY,GACZ,gBAAgB,GAChB,oBAAoB,GACpB,mBAAmB,GACnB,QAAQ,CACX,CAAC;IACF,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,KAAK,qBAAqB,GAAG,qBAAqB,GAChD,cAAc,GAAG;IACf,IAAI,CAAC,EAAE,QAAQ,CAAC;CACjB,CAAC;AAEJ,KAAK,oBAAoB,GAAG,qBAAqB,GAC/C,mBAAmB,GAAG;IACpB,IAAI,EAAE,OAAO,CAAC;CACf,CAAC;AAEJ,MAAM,MAAM,eAAe,GAAG,qBAAqB,GAAG,oBAAoB,CAAC;AAC3E,YAAY,EAAE,oBAAoB,EAAE,qBAAqB,EAAE,CAAC;AAE5D,eAAO,MAAM,UAAU,oIAQtB,CAAC"}
@@ -0,0 +1,27 @@
1
+ import { default as React } from 'react';
2
+ import { DateFieldProps } from '../../date-field/src/date-field';
3
+ type IndividualFieldProps = Omit<DateFieldProps, "value" | "onChange" | "disabled" | "readOnly" | "required" | "negative" | "aria-labelledby" | "aria-describedby" | "data-testid" | "startAdornment" | "className" | "ref">;
4
+ export type DateRangeFieldProps = {
5
+ label?: string;
6
+ fromLabel: string;
7
+ toLabel: string;
8
+ helperText?: string;
9
+ errorText?: string;
10
+ disabled?: boolean;
11
+ readOnly?: boolean;
12
+ required?: boolean;
13
+ hideRequiredAsterisk?: boolean;
14
+ fromValue?: Date;
15
+ toValue?: Date;
16
+ onFromChange?: (date: Date | undefined) => void;
17
+ onToChange?: (date: Date | undefined) => void;
18
+ fromFieldProps?: IndividualFieldProps;
19
+ toFieldProps?: IndividualFieldProps;
20
+ fromInputRef?: React.Ref<HTMLInputElement>;
21
+ toInputRef?: React.Ref<HTMLInputElement>;
22
+ className?: string;
23
+ ["data-testid"]?: string;
24
+ };
25
+ export declare const DateRangeField: React.ForwardRefExoticComponent<DateRangeFieldProps & React.RefAttributes<HTMLFieldSetElement>>;
26
+ export {};
27
+ //# sourceMappingURL=date-range-field.d.ts.map