@cambly/syntax-core 10.13.0 → 10.14.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 (117) hide show
  1. package/dist/Button/Button.cjs +4 -4
  2. package/dist/Button/Button.d.ts +7 -1
  3. package/dist/Button/Button.js +3 -3
  4. package/dist/Chip/Chip.cjs +2 -2
  5. package/dist/Chip/Chip.css +20 -14
  6. package/dist/Chip/Chip.css.map +1 -1
  7. package/dist/Chip/Chip.d.ts +6 -0
  8. package/dist/Chip/Chip.js +1 -1
  9. package/dist/Dialog/ModalDialog.cjs +5 -5
  10. package/dist/Dialog/ModalDialog.css +18 -22
  11. package/dist/Dialog/ModalDialog.css.map +1 -1
  12. package/dist/Dialog/ModalDialog.js +4 -4
  13. package/dist/IconButton/IconButton.cjs +4 -4
  14. package/dist/IconButton/IconButton.css +18 -22
  15. package/dist/IconButton/IconButton.css.map +1 -1
  16. package/dist/IconButton/IconButton.d.ts +6 -0
  17. package/dist/IconButton/IconButton.js +3 -3
  18. package/dist/LinkButton/LinkButton.cjs +4 -4
  19. package/dist/LinkButton/LinkButton.d.ts +6 -0
  20. package/dist/LinkButton/LinkButton.js +3 -3
  21. package/dist/Popover/Popover.cjs +6 -6
  22. package/dist/Popover/Popover.css +18 -22
  23. package/dist/Popover/Popover.css.map +1 -1
  24. package/dist/Popover/Popover.js +5 -5
  25. package/dist/RichSelect/RichSelectBox.cjs +7 -7
  26. package/dist/RichSelect/RichSelectBox.css +20 -14
  27. package/dist/RichSelect/RichSelectBox.css.map +1 -1
  28. package/dist/RichSelect/RichSelectBox.js +6 -6
  29. package/dist/RichSelect/RichSelectChip.cjs +3 -3
  30. package/dist/RichSelect/RichSelectChip.css +20 -14
  31. package/dist/RichSelect/RichSelectChip.css.map +1 -1
  32. package/dist/RichSelect/RichSelectChip.js +2 -2
  33. package/dist/RichSelect/RichSelectList.cjs +12 -12
  34. package/dist/RichSelect/RichSelectList.css +38 -36
  35. package/dist/RichSelect/RichSelectList.css.map +1 -1
  36. package/dist/RichSelect/RichSelectList.js +11 -11
  37. package/dist/SelectList/SelectList.cjs +3 -3
  38. package/dist/SelectList/SelectList.js +2 -2
  39. package/dist/__chunks/{DSMWIJEY.cjs → 3P4HISCU.cjs} +3 -3
  40. package/dist/__chunks/{TIG3BSZG.js → 4FB7KTL3.js} +2 -2
  41. package/dist/__chunks/{OLWEXK5F.cjs → 4TWU6PQA.cjs} +6 -6
  42. package/dist/__chunks/{JGXQJLCD.js → 53RQSOUJ.js} +6 -5
  43. package/dist/__chunks/53RQSOUJ.js.map +1 -0
  44. package/dist/__chunks/{4JXNDR7B.cjs → 5T5R6ZMD.cjs} +6 -5
  45. package/dist/__chunks/5T5R6ZMD.cjs.map +1 -0
  46. package/dist/__chunks/{HZ7TRVX2.cjs → 5WZOSAYH.cjs} +12 -12
  47. package/dist/__chunks/{H6JCVQBU.cjs → DA3CET5G.cjs} +1 -1
  48. package/dist/__chunks/{H6JCVQBU.cjs.map → DA3CET5G.cjs.map} +1 -1
  49. package/dist/__chunks/{ZLBPIQ2I.js → E7G4CMBM.js} +2 -2
  50. package/dist/__chunks/{BXUTWPRU.cjs → EVDDEHP3.cjs} +3 -3
  51. package/dist/__chunks/{EE5VI7K5.js → F4PJ53QQ.js} +1 -1
  52. package/dist/__chunks/{EE5VI7K5.js.map → F4PJ53QQ.js.map} +1 -1
  53. package/dist/__chunks/{G7GMDR6I.js → FKHOGYZI.js} +2 -2
  54. package/dist/__chunks/{NUDTHTSM.js → FQMG5WUT.js} +5 -5
  55. package/dist/__chunks/{PRE7WZF5.js → GHPZTFQK.js} +2 -2
  56. package/dist/__chunks/HCM63U3J.cjs +64 -0
  57. package/dist/__chunks/HCM63U3J.cjs.map +1 -0
  58. package/dist/__chunks/{7P7YX4X2.cjs → IMYS42TL.cjs} +8 -8
  59. package/dist/__chunks/IMYS42TL.cjs.map +1 -0
  60. package/dist/__chunks/JGYZV3JA.js +64 -0
  61. package/dist/__chunks/JGYZV3JA.js.map +1 -0
  62. package/dist/__chunks/{L3CUWPPD.js → M2ABILBX.js} +8 -8
  63. package/dist/__chunks/M2ABILBX.js.map +1 -0
  64. package/dist/__chunks/{GRYQKIWR.cjs → MUNI4VXL.cjs} +31 -5
  65. package/dist/__chunks/MUNI4VXL.cjs.map +1 -0
  66. package/dist/__chunks/{YGM4Z46I.js → NKWR4CYF.js} +6 -5
  67. package/dist/__chunks/NKWR4CYF.js.map +1 -0
  68. package/dist/__chunks/OFW6A65B.js +82 -0
  69. package/dist/__chunks/OFW6A65B.js.map +1 -0
  70. package/dist/__chunks/{SFJT2TM2.cjs → OXXXLEUD.cjs} +6 -5
  71. package/dist/__chunks/OXXXLEUD.cjs.map +1 -0
  72. package/dist/__chunks/{L4RR2XJT.js → PX3OQSL4.js} +3 -3
  73. package/dist/__chunks/QWMAWIWI.cjs +82 -0
  74. package/dist/__chunks/QWMAWIWI.cjs.map +1 -0
  75. package/dist/__chunks/{2ZUWZKPV.js → YKGFFSWB.js} +32 -6
  76. package/dist/__chunks/YKGFFSWB.js.map +1 -0
  77. package/dist/__chunks/{XSHPEZBA.cjs → ZDDA4AKB.cjs} +3 -3
  78. package/dist/__chunks/{RZCA77DH.cjs → ZDSY6FEO.cjs} +3 -3
  79. package/dist/colors/backgroundColor.cjs +2 -2
  80. package/dist/colors/backgroundColor.d.ts +1 -1
  81. package/dist/colors/backgroundColor.js +1 -1
  82. package/dist/colors/foregroundColor.cjs +2 -2
  83. package/dist/colors/foregroundColor.d.ts +1 -1
  84. package/dist/colors/foregroundColor.js +1 -1
  85. package/dist/index.cjs +14 -14
  86. package/dist/index.css +38 -36
  87. package/dist/index.css.map +1 -1
  88. package/dist/index.js +13 -13
  89. package/package.json +2 -2
  90. package/dist/__chunks/2ZUWZKPV.js.map +0 -1
  91. package/dist/__chunks/4JXNDR7B.cjs.map +0 -1
  92. package/dist/__chunks/7P7YX4X2.cjs.map +0 -1
  93. package/dist/__chunks/A4O4F3KK.cjs +0 -57
  94. package/dist/__chunks/A4O4F3KK.cjs.map +0 -1
  95. package/dist/__chunks/GRYQKIWR.cjs.map +0 -1
  96. package/dist/__chunks/JGXQJLCD.js.map +0 -1
  97. package/dist/__chunks/JVOQF4CG.js +0 -44
  98. package/dist/__chunks/JVOQF4CG.js.map +0 -1
  99. package/dist/__chunks/L3CUWPPD.js.map +0 -1
  100. package/dist/__chunks/RKEF7WKZ.cjs +0 -44
  101. package/dist/__chunks/RKEF7WKZ.cjs.map +0 -1
  102. package/dist/__chunks/SFJT2TM2.cjs.map +0 -1
  103. package/dist/__chunks/Y2OAIOQE.js +0 -57
  104. package/dist/__chunks/Y2OAIOQE.js.map +0 -1
  105. package/dist/__chunks/YGM4Z46I.js.map +0 -1
  106. /package/dist/__chunks/{DSMWIJEY.cjs.map → 3P4HISCU.cjs.map} +0 -0
  107. /package/dist/__chunks/{TIG3BSZG.js.map → 4FB7KTL3.js.map} +0 -0
  108. /package/dist/__chunks/{OLWEXK5F.cjs.map → 4TWU6PQA.cjs.map} +0 -0
  109. /package/dist/__chunks/{HZ7TRVX2.cjs.map → 5WZOSAYH.cjs.map} +0 -0
  110. /package/dist/__chunks/{ZLBPIQ2I.js.map → E7G4CMBM.js.map} +0 -0
  111. /package/dist/__chunks/{BXUTWPRU.cjs.map → EVDDEHP3.cjs.map} +0 -0
  112. /package/dist/__chunks/{G7GMDR6I.js.map → FKHOGYZI.js.map} +0 -0
  113. /package/dist/__chunks/{NUDTHTSM.js.map → FQMG5WUT.js.map} +0 -0
  114. /package/dist/__chunks/{PRE7WZF5.js.map → GHPZTFQK.js.map} +0 -0
  115. /package/dist/__chunks/{L4RR2XJT.js.map → PX3OQSL4.js.map} +0 -0
  116. /package/dist/__chunks/{XSHPEZBA.cjs.map → ZDDA4AKB.cjs.map} +0 -0
  117. /package/dist/__chunks/{RZCA77DH.cjs.map → ZDSY6FEO.cjs.map} +0 -0
@@ -17,10 +17,29 @@ var _react = require('react');
17
17
  var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames);
18
18
 
19
19
  // css-module:./Chip.module.css#css-module
20
- var Chip_module_default = { "chip": "_chip_1jp9s_1", "chipClassic": "_chipClassic_1jp9s_10", "chipCambio": "_chipCambio_1jp9s_15", "disabled": "_disabled_1jp9s_20", "deselectedChip": "_deselectedChip_1jp9s_25", "selectedChip": "_selectedChip_1jp9s_29", "deselectedChipCambio": "_deselectedChipCambio_1jp9s_34", "selectedChipCambio": "_selectedChipCambio_1jp9s_38", "icon": "_icon_1jp9s_42", "selectedIcon": "_selectedIcon_1jp9s_50", "sm": "_sm_1jp9s_54", "lg": "_lg_1jp9s_60", "forceFocus": "_forceFocus_1jp9s_67" };
20
+ var Chip_module_default = { "chip": "_chip_1ndh3_1", "chipClassic": "_chipClassic_1ndh3_10", "chipCambio": "_chipCambio_1ndh3_15", "disabled": "_disabled_1ndh3_20", "deselectedChip": "_deselectedChip_1ndh3_25", "selectedChip": "_selectedChip_1ndh3_29", "deselectedChipCambio": "_deselectedChipCambio_1ndh3_34", "deselectedChipCambioOnDarkBackground": "_deselectedChipCambioOnDarkBackground_1ndh3_38", "selectedChipCambio": "_selectedChipCambio_1ndh3_42", "selectedChipCambioOnDarkBackground": "_selectedChipCambioOnDarkBackground_1ndh3_46", "icon": "_icon_1ndh3_50", "selectedIcon": "_selectedIcon_1ndh3_58", "sm": "_sm_1ndh3_62", "lg": "_lg_1ndh3_68", "forceFocus": "_forceFocus_1ndh3_75" };
21
21
 
22
22
  // src/Chip/Chip.tsx
23
23
  var _jsxruntime = require('react/jsx-runtime');
24
+ function typographyColor({
25
+ themeName,
26
+ selected,
27
+ on
28
+ }) {
29
+ if (themeName === "cambio" && on === "darkBackground") {
30
+ if (selected) {
31
+ return "gray900";
32
+ } else {
33
+ return "white";
34
+ }
35
+ } else {
36
+ if (selected) {
37
+ return "white";
38
+ } else {
39
+ return "gray900";
40
+ }
41
+ }
42
+ }
24
43
  var Chip = _react.forwardRef.call(void 0,
25
44
  ({
26
45
  disabled: disabledProp = false,
@@ -28,6 +47,7 @@ var Chip = _react.forwardRef.call(void 0,
28
47
  "data-testid": dataTestId,
29
48
  size = "sm",
30
49
  text,
50
+ on = "lightBackground",
31
51
  onChange,
32
52
  icon: Icon,
33
53
  dangerouslyForceFocusStyles
@@ -36,13 +56,15 @@ var Chip = _react.forwardRef.call(void 0,
36
56
  const transformedSize = themeName === "cambio" ? "sm" : size;
37
57
  const isHydrated = _K4AUV2VKcjs.useIsHydrated.call(void 0, );
38
58
  const disabled = !isHydrated || disabledProp;
59
+ const selectedChipCambioStyle = on === "lightBackground" ? Chip_module_default.selectedChipCambio : Chip_module_default.selectedChipCambioOnDarkBackground;
60
+ const deselectedChipCambioStyle = on === "lightBackground" ? Chip_module_default.deselectedChipCambio : Chip_module_default.deselectedChipCambioOnDarkBackground;
39
61
  const chipStyles = _classnames2.default.call(void 0,
40
62
  Chip_module_default.chip,
41
63
  themeName === "classic" ? Chip_module_default.chipClassic : Chip_module_default.chipCambio,
42
64
  Chip_module_default[transformedSize],
43
65
  {
44
- [themeName === "classic" ? Chip_module_default.selectedChip : Chip_module_default.selectedChipCambio]: selected,
45
- [themeName === "classic" ? Chip_module_default.deselectedChip : Chip_module_default.deselectedChipCambio]: !selected,
66
+ [themeName === "classic" ? Chip_module_default.selectedChip : selectedChipCambioStyle]: selected,
67
+ [themeName === "classic" ? Chip_module_default.deselectedChip : deselectedChipCambioStyle]: !selected,
46
68
  [Chip_module_default.disabled]: disabled,
47
69
  [Chip_module_default.forceFocus]: dangerouslyForceFocusStyles
48
70
  }
@@ -54,6 +76,10 @@ var Chip = _react.forwardRef.call(void 0,
54
76
  ["sm"]: 200,
55
77
  ["lg"]: 300
56
78
  };
79
+ const color = _react.useMemo.call(void 0,
80
+ () => typographyColor({ themeName, selected, on }),
81
+ [themeName, selected, on]
82
+ );
57
83
  return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
58
84
  "button",
59
85
  {
@@ -70,7 +96,7 @@ var Chip = _react.forwardRef.call(void 0,
70
96
  _WGRHH5TFcjs.Typography_default,
71
97
  {
72
98
  size: themeName === "classic" ? typographySize[transformedSize] : 100,
73
- color: selected ? "white" : "gray900",
99
+ color,
74
100
  children: text
75
101
  }
76
102
  ) })
@@ -85,4 +111,4 @@ var Chip_default = Chip;
85
111
 
86
112
 
87
113
  exports.Chip_default = Chip_default;
88
- //# sourceMappingURL=GRYQKIWR.cjs.map
114
+ //# sourceMappingURL=MUNI4VXL.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/Chip/Chip.tsx","css-module:./Chip.module.css#css-module"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,SAAgB,YAAY,eAAe;AAC3C,OAAO,gBAAgB;;;ACDiE,IAAO,sBAAQ,EAAC,QAAO,iBAAgB,eAAc,yBAAwB,cAAa,wBAAuB,YAAW,sBAAqB,kBAAiB,4BAA2B,gBAAe,0BAAyB,wBAAuB,kCAAiC,wCAAuC,kDAAiD,sBAAqB,gCAA+B,sCAAqC,gDAA+C,QAAO,kBAAiB,gBAAe,0BAAyB,MAAK,gBAAe,MAAK,gBAAe,cAAa,uBAAsB;;;ADiJ1tB,SASW,KATX;AAzIN,SAAS,gBAAgB;AAAA,EACvB;AAAA,EACA;AAAA,EACA;AACF,GAIwB;AACtB,MAAI,cAAc,YAAY,OAAO,kBAAkB;AACrD,QAAI,UAAU;AACZ,aAAO;AAAA,IACT,OAAO;AACL,aAAO;AAAA,IACT;AAAA,EACF,OAAO;AACL,QAAI,UAAU;AACZ,aAAO;AAAA,IACT,OAAO;AACL,aAAO;AAAA,IACT;AAAA,EACF;AACF;AAwDA,IAAM,OAAO;AAAA,EACX,CACE;AAAA,IACE,UAAU,eAAe;AAAA,IACzB,WAAW;AAAA,IACX,eAAe;AAAA,IACf,OAAO;AAAA,IACP;AAAA,IACA,KAAK;AAAA,IACL;AAAA,IACA,MAAM;AAAA,IACN;AAAA,EACF,GACA,QACG;AACH,UAAM,EAAE,UAAU,IAAI,SAAS;AAC/B,UAAM,kBAAkB,cAAc,WAAW,OAAO;AACxD,UAAM,aAAa,cAAc;AACjC,UAAM,WAAW,CAAC,cAAc;AAEhC,UAAM,0BACJ,OAAO,oBACH,oBAAO,qBACP,oBAAO;AAEb,UAAM,4BACJ,OAAO,oBACH,oBAAO,uBACP,oBAAO;AAEb,UAAM,aAAa;AAAA,MACjB,oBAAO;AAAA,MACP,cAAc,YAAY,oBAAO,cAAc,oBAAO;AAAA,MACtD,oBAAO,eAAe;AAAA,MACtB;AAAA,QACE,CAAC,cAAc,YACX,oBAAO,eACP,uBAAuB,GAAG;AAAA,QAC9B,CAAC,cAAc,YACX,oBAAO,iBACP,yBAAyB,GAAG,CAAC;AAAA,QACjC,CAAC,oBAAO,QAAQ,GAAG;AAAA,QACnB,CAAC,oBAAO,UAAU,GAAG;AAAA,MACvB;AAAA,IACF;AACA,UAAM,aAAa,WAAW,oBAAO,MAAM;AAAA,MACzC,CAAC,oBAAO,YAAY,GAAG;AAAA,IACzB,CAAC;AACD,UAAM,iBAAiB;AAAA,MACrB,CAAC,IAAI,GAAG;AAAA,MACR,CAAC,IAAI,GAAG;AAAA,IACV;AAEA,UAAM,QAAQ;AAAA,MACZ,MAAM,gBAAgB,EAAE,WAAW,UAAU,GAAG,CAAC;AAAA,MACjD,CAAC,WAAW,UAAU,EAAE;AAAA,IAC1B;AAEA,WACE;AAAA,MAAC;AAAA;AAAA,QACC,WAAW;AAAA,QACX;AAAA,QACA,eAAa;AAAA,QACb;AAAA,QACA,MAAK;AAAA,QACL,gBAAc;AAAA,QACd,SAAS;AAAA,QAER;AAAA,kBAAQ,oBAAC,QAAK,WAAW,YAAY;AAAA,UACtC,oBAAC,eAAI,UAAU,OAAO,IAAI,GACxB;AAAA,YAAC;AAAA;AAAA,cACC,MACE,cAAc,YAAY,eAAe,eAAe,IAAI;AAAA,cAE9D;AAAA,cAEC;AAAA;AAAA,UACH,GACF;AAAA;AAAA;AAAA,IACF;AAAA,EAEJ;AACF;AAEA,KAAK,cAAc;AAEnB,IAAO,eAAQ","sourcesContent":["import React, { forwardRef, useMemo } from \"react\";\nimport classnames from \"classnames\";\nimport Typography from \"../Typography/Typography\";\nimport Box from \"../Box/Box\";\nimport styles from \"./Chip.module.css\";\nimport useIsHydrated from \"../useIsHydrated\";\nimport { useTheme } from \"../ThemeProvider/ThemeProvider\";\n\nfunction typographyColor({\n themeName,\n selected,\n on,\n}: {\n themeName: \"cambio\" | \"classic\";\n selected: boolean;\n on: \"lightBackground\" | \"darkBackground\";\n}): \"white\" | \"gray900\" {\n if (themeName === \"cambio\" && on === \"darkBackground\") {\n if (selected) {\n return \"gray900\";\n } else {\n return \"white\";\n }\n } else {\n if (selected) {\n return \"white\";\n } else {\n return \"gray900\";\n }\n }\n}\n\ntype ChipProps = {\n /**\n * If true, the chip will be disabled.\n */\n disabled?: boolean;\n /**\n * Sets the initial status of this chip component.\n * * `true` will display a grey chip.\n * * `false` will display a premium800 color chip.\n *\n * @defaultValue \"false\"\n */\n selected?: boolean;\n /**\n * Test id for the button\n */\n \"data-testid\"?: string;\n /**\n * Size of the chip.\n *\n * Classic:\n * * `sm`: 32px\n * * `lg`: 48px\n *\n * Cambio:\n * * `sm`: 32px\n *\n * @defaultValue sm\n */\n size?: \"sm\" | \"lg\";\n /**\n * The text to be displayed on the chip\n */\n text: string;\n /**\n * Indicate whether the badge renders on a light or dark background. Changes the color of the chip (Cambio only)\n *\n * @defaulValue `lightBackground`\n */\n on?: \"lightBackground\" | \"darkBackground\";\n /**\n * The callback to be called when the chip is clicked\n */\n onChange: React.MouseEventHandler<HTMLButtonElement>;\n /**\n * The icon to be displayed.\n */\n icon?: React.ComponentType<{ className?: string }>;\n /** forces focus ring styling */\n dangerouslyForceFocusStyles?: boolean;\n};\n/**\n * [Chip](https://cambly-syntax.vercel.app/?path=/docs/components-chip--docs) is used to show status (selected/not selected) like a toggle button.\n */\nconst Chip = forwardRef<HTMLButtonElement, ChipProps>(\n (\n {\n disabled: disabledProp = false,\n selected = false,\n \"data-testid\": dataTestId,\n size = \"sm\",\n text,\n on = \"lightBackground\",\n onChange,\n icon: Icon,\n dangerouslyForceFocusStyles,\n }: ChipProps,\n ref,\n ) => {\n const { themeName } = useTheme();\n const transformedSize = themeName === \"cambio\" ? \"sm\" : size;\n const isHydrated = useIsHydrated();\n const disabled = !isHydrated || disabledProp;\n\n const selectedChipCambioStyle =\n on === \"lightBackground\"\n ? styles.selectedChipCambio\n : styles.selectedChipCambioOnDarkBackground;\n\n const deselectedChipCambioStyle =\n on === \"lightBackground\"\n ? styles.deselectedChipCambio\n : styles.deselectedChipCambioOnDarkBackground;\n\n const chipStyles = classnames(\n styles.chip,\n themeName === \"classic\" ? styles.chipClassic : styles.chipCambio,\n styles[transformedSize],\n {\n [themeName === \"classic\"\n ? styles.selectedChip\n : selectedChipCambioStyle]: selected,\n [themeName === \"classic\"\n ? styles.deselectedChip\n : deselectedChipCambioStyle]: !selected,\n [styles.disabled]: disabled,\n [styles.forceFocus]: dangerouslyForceFocusStyles,\n },\n );\n const iconStyles = classnames(styles.icon, {\n [styles.selectedIcon]: selected,\n });\n const typographySize = {\n [\"sm\"]: 200,\n [\"lg\"]: 300,\n } as const;\n\n const color = useMemo(\n () => typographyColor({ themeName, selected, on }),\n [themeName, selected, on],\n );\n\n return (\n <button\n className={chipStyles}\n disabled={disabled}\n data-testid={dataTestId}\n ref={ref}\n type=\"button\"\n aria-pressed={selected}\n onClick={onChange}\n >\n {Icon && <Icon className={iconStyles} />}\n <Box paddingX={Icon ? 1 : 0}>\n <Typography\n size={\n themeName === \"classic\" ? typographySize[transformedSize] : 100\n }\n color={color}\n >\n {text}\n </Typography>\n </Box>\n </button>\n );\n },\n);\n\nChip.displayName = \"Chip\";\n\nexport default Chip;\n","import \"/home/runner/work/syntax/syntax/packages/syntax-core/src/Chip/Chip.module.css\"; export default {\"chip\":\"_chip_1ndh3_1\",\"chipClassic\":\"_chipClassic_1ndh3_10\",\"chipCambio\":\"_chipCambio_1ndh3_15\",\"disabled\":\"_disabled_1ndh3_20\",\"deselectedChip\":\"_deselectedChip_1ndh3_25\",\"selectedChip\":\"_selectedChip_1ndh3_29\",\"deselectedChipCambio\":\"_deselectedChipCambio_1ndh3_34\",\"deselectedChipCambioOnDarkBackground\":\"_deselectedChipCambioOnDarkBackground_1ndh3_38\",\"selectedChipCambio\":\"_selectedChipCambio_1ndh3_42\",\"selectedChipCambioOnDarkBackground\":\"_selectedChipCambioOnDarkBackground_1ndh3_46\",\"icon\":\"_icon_1ndh3_50\",\"selectedIcon\":\"_selectedIcon_1ndh3_58\",\"sm\":\"_sm_1ndh3_62\",\"lg\":\"_lg_1ndh3_68\",\"forceFocus\":\"_forceFocus_1ndh3_75\"}"]}
@@ -15,11 +15,11 @@ import {
15
15
  import {
16
16
  cambioForegroundColor,
17
17
  classicForegroundColor
18
- } from "./JVOQF4CG.js";
18
+ } from "./JGYZV3JA.js";
19
19
  import {
20
20
  cambioBackgroundColor,
21
21
  classicBackgroundColor
22
- } from "./Y2OAIOQE.js";
22
+ } from "./OFW6A65B.js";
23
23
  import {
24
24
  Box_default
25
25
  } from "./YGKZCJF5.js";
@@ -55,14 +55,15 @@ var Button = forwardRef(
55
55
  fullWidth = false,
56
56
  startIcon: StartIcon,
57
57
  endIcon: EndIcon,
58
+ on = "lightBackground",
58
59
  onClick,
59
60
  tooltip,
60
61
  type = "button"
61
62
  }, ref) => {
62
63
  const isHydrated = useIsHydrated();
63
64
  const { themeName } = useTheme();
64
- const foregroundColorClass = themeName === "classic" ? classicForegroundColor(classicColor(color)) : cambioForegroundColor(cambioColor(color));
65
- const backgroundColorClass = themeName === "classic" ? classicBackgroundColor(classicColor(color)) : cambioBackgroundColor(cambioColor(color));
65
+ const foregroundColorClass = themeName === "classic" ? classicForegroundColor(classicColor(color)) : cambioForegroundColor(cambioColor(color), on);
66
+ const backgroundColorClass = themeName === "classic" ? classicBackgroundColor(classicColor(color)) : cambioBackgroundColor(cambioColor(color), on);
66
67
  return /* @__PURE__ */ jsxs(
67
68
  "button",
68
69
  {
@@ -133,4 +134,4 @@ var Button_default = Button;
133
134
  export {
134
135
  Button_default
135
136
  };
136
- //# sourceMappingURL=YGM4Z46I.js.map
137
+ //# sourceMappingURL=NKWR4CYF.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/Button/Button.tsx","css-module:./Button.module.css#css-module"],"sourcesContent":["import React, { forwardRef } from \"react\";\nimport classNames from \"classnames\";\nimport { type Size } from \"../constants\";\nimport Typography from \"../Typography/Typography\";\nimport Box from \"../Box/Box\";\nimport iconSize from \"./constants/iconSize\";\nimport textVariant from \"./constants/textVariant\";\nimport loadingIconSize from \"./constants/loadingIconSize\";\nimport styles from \"./Button.module.css\";\nimport useIsHydrated from \"../useIsHydrated\";\nimport { useTheme } from \"../ThemeProvider/ThemeProvider\";\nimport { classicColor, cambioColor } from \"./constants/color\";\nimport {\n classicBackgroundColor,\n cambioBackgroundColor,\n} from \"../colors/backgroundColor\";\nimport {\n classicForegroundColor,\n cambioForegroundColor,\n} from \"../colors/foregroundColor\";\n\ntype ButtonProps = {\n /**\n * Test id for the button\n */\n \"data-testid\"?: string;\n /**\n * The text to be displayed inside the button\n */\n text: string;\n /**\n * The text to be displayed inside the button when it is in a loading state\n */\n loadingText?: string;\n /**\n * The color of the button\n *\n * Classic only:\n * * `inverse`\n * * `success`\n *\n * Cambio only:\n * * `success-primary`\n * * `success-secondary`\n * * `success-tertiary`\n *\n * @defaultValue \"primary\"\n */\n color?:\n | \"primary\"\n | \"secondary\"\n | \"tertiary\"\n | \"destructive-primary\"\n | \"destructive-secondary\"\n | \"destructive-tertiary\"\n | \"branded\"\n | \"success\"\n | \"success-primary\"\n | \"success-secondary\"\n | \"success-tertiary\"\n | \"inverse\";\n /**\n * The size of the button\n *\n * Classic:\n * * `sm`: 32px\n * * `md`: 40px\n * * `lg`: 48px\n *\n * Cambio:\n * * `sm`: 32px\n * * `md`: 48px\n * * `lg`: 64px\n *\n * @defaultValue \"md\"\n */\n size?: (typeof Size)[number];\n /**\n * The label to be used for accessibility\n */\n accessibilityLabel?: string;\n /**\n * If `true`, the button will be disabled\n *\n * @defaultValue false\n */\n disabled?: boolean;\n /**\n * If `true`, the button will be in a loading state\n *\n * @defaultValue false\n */\n loading?: boolean;\n /**\n * If `true`, the button will take up the full width of its container\n *\n * @defaultValue false\n */\n fullWidth?: boolean;\n /**\n * The icon to be displayed at the start of the button. Please use a [Rounded Material Icon](https://material.io/resources/icons/?style=round)\n * Note: startIcon is not supported in the Cambio theme\n */\n startIcon?: React.ComponentType<{ className?: string }>;\n /**\n * The icon to be displayed at the end of the button. Please use a [Rounded Material Icon](https://material.io/resources/icons/?style=round)\n * Note: endIcon is not supported in the Cambio theme\n */\n endIcon?: React.ComponentType<{ className?: string }>;\n /**\n * Indicate whether the button renders on a light or dark background. Changes the color of the button (Cambio only)\n *\n * @defaulValue `lightBackground`\n */\n on?: \"lightBackground\" | \"darkBackground\";\n /**\n * The callback to be called when the button is clicked\n */\n onClick?: React.MouseEventHandler<HTMLButtonElement>;\n /**\n * The tooltip to be displayed when the user hovers over the button\n */\n tooltip?: string;\n /**\n * The type you want to set for the primitive `<button/>`\n */\n type?: \"button\" | \"submit\" | \"reset\";\n};\n\n/**\n * [Button](https://cambly-syntax.vercel.app/?path=/docs/components-button--docs) is used to trigger an action or event, such as submitting a form, opening a dialog, canceling an action, or performing a delete operation.\n */\nconst Button = forwardRef<HTMLButtonElement, ButtonProps>(\n (\n {\n \"data-testid\": dataTestId,\n text,\n loadingText,\n color = \"primary\",\n size = \"md\",\n accessibilityLabel,\n disabled = false,\n loading = false,\n fullWidth = false,\n startIcon: StartIcon,\n endIcon: EndIcon,\n on = \"lightBackground\",\n onClick,\n tooltip,\n type = \"button\",\n }: ButtonProps,\n ref,\n ) => {\n const isHydrated = useIsHydrated();\n const { themeName } = useTheme();\n\n const foregroundColorClass =\n themeName === \"classic\"\n ? classicForegroundColor(classicColor(color))\n : cambioForegroundColor(cambioColor(color), on);\n\n const backgroundColorClass =\n themeName === \"classic\"\n ? classicBackgroundColor(classicColor(color))\n : cambioBackgroundColor(cambioColor(color), on);\n\n return (\n <button\n data-testid={dataTestId}\n ref={ref}\n aria-label={accessibilityLabel}\n type={type}\n title={tooltip}\n disabled={!isHydrated || disabled || loading}\n onClick={onClick}\n className={classNames(\n styles.button,\n foregroundColorClass,\n backgroundColorClass,\n themeName === \"classic\" ? styles[size] : styles[`${size}Cambio`],\n {\n [styles.fullWidth]: fullWidth,\n [styles.buttonGap]:\n themeName === \"classic\" && (size === \"lg\" || size === \"md\"),\n [styles.secondaryBorder]:\n themeName === \"classic\" && color === \"secondary\",\n [styles.secondaryDestructiveBorder]:\n themeName === \"classic\" && color === \"destructive-secondary\",\n },\n )}\n >\n {!loading && StartIcon && themeName === \"classic\" && (\n <StartIcon className={classNames(styles.icon, iconSize[size])} />\n )}\n {((loading && loadingText) || (!loading && text)) && (\n <Box paddingX={1}>\n <Typography\n size={\n themeName === \"classic\" ? textVariant[size] : textVariant[size]\n }\n >\n <span\n // Temporary - until we have cambio colors on Typogrphay\n className={foregroundColorClass}\n style={{ fontWeight: 500 }}\n >\n {loading ? loadingText : text}\n </span>\n </Typography>\n </Box>\n )}\n {!loading && EndIcon && themeName === \"classic\" && (\n <EndIcon className={classNames(styles.icon, iconSize[size])} />\n )}\n {loading && (\n <svg\n className={classNames(styles.loading, foregroundColorClass)}\n viewBox=\"22 22 44 44\"\n width={loadingIconSize[size]}\n height={loadingIconSize[size]}\n >\n <circle\n className={styles.loadingCircle}\n cx=\"44\"\n cy=\"44\"\n r=\"20.2\"\n fill=\"none\"\n strokeWidth=\"3.6\"\n />\n </svg>\n )}\n </button>\n );\n },\n);\n\nButton.displayName = \"Button\";\n\nexport default Button;\n","import \"/home/runner/work/syntax/syntax/packages/syntax-core/src/Button/Button.module.css\"; export default {\"button\":\"_button_ddq3j_1\",\"buttonGap\":\"_buttonGap_ddq3j_9\",\"fullWidth\":\"_fullWidth_ddq3j_50\",\"sm\":\"_sm_ddq3j_54\",\"md\":\"_md_ddq3j_61\",\"lg\":\"_lg_ddq3j_68\",\"smCambio\":\"_smCambio_ddq3j_75\",\"mdCambio\":\"_mdCambio_ddq3j_82\",\"lgCambio\":\"_lgCambio_ddq3j_89\",\"icon\":\"_icon_ddq3j_96\",\"smIcon\":\"_smIcon_ddq3j_100\",\"mdIcon\":\"_mdIcon_ddq3j_107\",\"lgIcon\":\"_lgIcon_ddq3j_114\",\"secondaryBorder\":\"_secondaryBorder_ddq3j_121\",\"secondaryDestructiveBorder\":\"_secondaryDestructiveBorder_ddq3j_125\",\"loading\":\"_loading_ddq3j_139\",\"syntaxButtonLoadingRotate\":\"_syntaxButtonLoadingRotate_ddq3j_1\",\"loadingCircle\":\"_loadingCircle_ddq3j_143\"}"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,SAAgB,kBAAkB;AAClC,OAAO,gBAAgB;;;ACDqE,IAAO,wBAAQ,EAAC,UAAS,mBAAkB,aAAY,sBAAqB,aAAY,uBAAsB,MAAK,gBAAe,MAAK,gBAAe,MAAK,gBAAe,YAAW,sBAAqB,YAAW,sBAAqB,YAAW,sBAAqB,QAAO,kBAAiB,UAAS,qBAAoB,UAAS,qBAAoB,UAAS,qBAAoB,mBAAkB,8BAA6B,8BAA6B,yCAAwC,WAAU,sBAAqB,6BAA4B,sCAAqC,iBAAgB,2BAA0B;;;ADuK7sB,SAyBI,KAzBJ;AAnCN,IAAM,SAAS;AAAA,EACb,CACE;AAAA,IACE,eAAe;AAAA,IACf;AAAA,IACA;AAAA,IACA,QAAQ;AAAA,IACR,OAAO;AAAA,IACP;AAAA,IACA,WAAW;AAAA,IACX,UAAU;AAAA,IACV,YAAY;AAAA,IACZ,WAAW;AAAA,IACX,SAAS;AAAA,IACT,KAAK;AAAA,IACL;AAAA,IACA;AAAA,IACA,OAAO;AAAA,EACT,GACA,QACG;AACH,UAAM,aAAa,cAAc;AACjC,UAAM,EAAE,UAAU,IAAI,SAAS;AAE/B,UAAM,uBACJ,cAAc,YACV,uBAAuB,aAAa,KAAK,CAAC,IAC1C,sBAAsB,YAAY,KAAK,GAAG,EAAE;AAElD,UAAM,uBACJ,cAAc,YACV,uBAAuB,aAAa,KAAK,CAAC,IAC1C,sBAAsB,YAAY,KAAK,GAAG,EAAE;AAElD,WACE;AAAA,MAAC;AAAA;AAAA,QACC,eAAa;AAAA,QACb;AAAA,QACA,cAAY;AAAA,QACZ;AAAA,QACA,OAAO;AAAA,QACP,UAAU,CAAC,cAAc,YAAY;AAAA,QACrC;AAAA,QACA,WAAW;AAAA,UACT,sBAAO;AAAA,UACP;AAAA,UACA;AAAA,UACA,cAAc,YAAY,sBAAO,IAAI,IAAI,sBAAO,GAAG,YAAY;AAAA,UAC/D;AAAA,YACE,CAAC,sBAAO,SAAS,GAAG;AAAA,YACpB,CAAC,sBAAO,SAAS,GACf,cAAc,cAAc,SAAS,QAAQ,SAAS;AAAA,YACxD,CAAC,sBAAO,eAAe,GACrB,cAAc,aAAa,UAAU;AAAA,YACvC,CAAC,sBAAO,0BAA0B,GAChC,cAAc,aAAa,UAAU;AAAA,UACzC;AAAA,QACF;AAAA,QAEC;AAAA,WAAC,WAAW,aAAa,cAAc,aACtC,oBAAC,aAAU,WAAW,WAAW,sBAAO,MAAM,iBAAS,IAAI,CAAC,GAAG;AAAA,WAE9D,WAAW,eAAiB,CAAC,WAAW,SACzC,oBAAC,eAAI,UAAU,GACb;AAAA,YAAC;AAAA;AAAA,cACC,MACE,cAAc,YAAY,oBAAY,IAAI,IAAI,oBAAY,IAAI;AAAA,cAGhE;AAAA,gBAAC;AAAA;AAAA,kBAEC,WAAW;AAAA,kBACX,OAAO,EAAE,YAAY,IAAI;AAAA,kBAExB,oBAAU,cAAc;AAAA;AAAA,cAC3B;AAAA;AAAA,UACF,GACF;AAAA,UAED,CAAC,WAAW,WAAW,cAAc,aACpC,oBAAC,WAAQ,WAAW,WAAW,sBAAO,MAAM,iBAAS,IAAI,CAAC,GAAG;AAAA,UAE9D,WACC;AAAA,YAAC;AAAA;AAAA,cACC,WAAW,WAAW,sBAAO,SAAS,oBAAoB;AAAA,cAC1D,SAAQ;AAAA,cACR,OAAO,wBAAgB,IAAI;AAAA,cAC3B,QAAQ,wBAAgB,IAAI;AAAA,cAE5B;AAAA,gBAAC;AAAA;AAAA,kBACC,WAAW,sBAAO;AAAA,kBAClB,IAAG;AAAA,kBACH,IAAG;AAAA,kBACH,GAAE;AAAA,kBACF,MAAK;AAAA,kBACL,aAAY;AAAA;AAAA,cACd;AAAA;AAAA,UACF;AAAA;AAAA;AAAA,IAEJ;AAAA,EAEJ;AACF;AAEA,OAAO,cAAc;AAErB,IAAO,iBAAQ;","names":[]}
@@ -0,0 +1,82 @@
1
+ "use client"
2
+ import {
3
+ colors_module_default
4
+ } from "./FMQVMNVR.js";
5
+
6
+ // src/colors/backgroundColor.ts
7
+ function classicBackgroundColor(color) {
8
+ switch (color) {
9
+ case "secondary":
10
+ return colors_module_default.primary100BackgroundColor;
11
+ case "destructive-primary":
12
+ return colors_module_default.destructive700BackgroundColor;
13
+ case "destructive-secondary":
14
+ return colors_module_default.destructive100BackgroundColor;
15
+ case "success":
16
+ return colors_module_default.success700BackgroundColor;
17
+ case "tertiary":
18
+ case "destructive-tertiary":
19
+ return colors_module_default.whiteBackgroundColor;
20
+ case "branded":
21
+ return colors_module_default.yellow700BackgroundColor;
22
+ case "inverse":
23
+ return colors_module_default.gray60BackgroundColor;
24
+ default:
25
+ return colors_module_default.primary700BackgroundColor;
26
+ }
27
+ }
28
+ function cambioBackgroundColor(color, on) {
29
+ if (on === "lightBackground") {
30
+ switch (color) {
31
+ case "primary":
32
+ return colors_module_default.cambioBlackBackgroundColor;
33
+ case "secondary":
34
+ return colors_module_default.cambioGray370BackgroundColor;
35
+ case "tertiary":
36
+ case "success-tertiary":
37
+ case "destructive-tertiary":
38
+ return colors_module_default.cambioTransparentFullBackgroundColor;
39
+ case "success-primary":
40
+ return colors_module_default.cambioSuccess700BackgroundColor;
41
+ case "success-secondary":
42
+ return colors_module_default.cambioSuccess370BackgroundColor;
43
+ case "destructive-primary":
44
+ return colors_module_default.cambioDestructive700BackgroundColor;
45
+ case "destructive-secondary":
46
+ return colors_module_default.cambioDestructive370BackgroundColor;
47
+ case "branded":
48
+ return colors_module_default.cambioYellow700BackgroundColor;
49
+ default:
50
+ return colors_module_default.cambioBlackBackgroundColor;
51
+ }
52
+ } else {
53
+ switch (color) {
54
+ case "primary":
55
+ return colors_module_default.cambioGray200BackgroundColor;
56
+ case "secondary":
57
+ return colors_module_default.cambioGray870BackgroundColor;
58
+ case "tertiary":
59
+ case "success-tertiary":
60
+ case "destructive-tertiary":
61
+ return colors_module_default.cambioTransparentFullBackgroundColor;
62
+ case "success-primary":
63
+ return colors_module_default.cambioSuccess300BackgroundColor;
64
+ case "success-secondary":
65
+ return colors_module_default.cambioSuccess770BackgroundColor;
66
+ case "destructive-primary":
67
+ return colors_module_default.cambioDestructive300BackgroundColor;
68
+ case "destructive-secondary":
69
+ return colors_module_default.cambioDestructive770BackgroundColor;
70
+ case "branded":
71
+ return colors_module_default.cambioYellow700BackgroundColor;
72
+ default:
73
+ return colors_module_default.cambioWhiteBackgroundColor;
74
+ }
75
+ }
76
+ }
77
+
78
+ export {
79
+ classicBackgroundColor,
80
+ cambioBackgroundColor
81
+ };
82
+ //# sourceMappingURL=OFW6A65B.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/colors/backgroundColor.ts"],"sourcesContent":["import { type CambioColor, type Color } from \"../constants\";\nimport styles from \"./colors.module.css\";\n\nexport function classicBackgroundColor(color: (typeof Color)[number]): string {\n switch (color) {\n case \"secondary\":\n return styles.primary100BackgroundColor;\n case \"destructive-primary\":\n return styles.destructive700BackgroundColor;\n case \"destructive-secondary\":\n return styles.destructive100BackgroundColor;\n case \"success\":\n return styles.success700BackgroundColor;\n case \"tertiary\":\n case \"destructive-tertiary\":\n return styles.whiteBackgroundColor;\n case \"branded\":\n return styles.yellow700BackgroundColor;\n case \"inverse\":\n return styles.gray60BackgroundColor;\n default:\n return styles.primary700BackgroundColor;\n }\n}\n\nexport function cambioBackgroundColor(\n color: (typeof CambioColor)[number],\n on: \"lightBackground\" | \"darkBackground\",\n): string {\n if (on === \"lightBackground\") {\n switch (color) {\n case \"primary\":\n return styles.cambioBlackBackgroundColor;\n case \"secondary\":\n return styles.cambioGray370BackgroundColor;\n case \"tertiary\":\n case \"success-tertiary\":\n case \"destructive-tertiary\":\n return styles.cambioTransparentFullBackgroundColor;\n case \"success-primary\":\n return styles.cambioSuccess700BackgroundColor;\n case \"success-secondary\":\n return styles.cambioSuccess370BackgroundColor;\n case \"destructive-primary\":\n return styles.cambioDestructive700BackgroundColor;\n case \"destructive-secondary\":\n return styles.cambioDestructive370BackgroundColor;\n case \"branded\":\n return styles.cambioYellow700BackgroundColor;\n default:\n return styles.cambioBlackBackgroundColor;\n }\n } else {\n switch (color) {\n case \"primary\":\n return styles.cambioGray200BackgroundColor;\n case \"secondary\":\n return styles.cambioGray870BackgroundColor;\n case \"tertiary\":\n case \"success-tertiary\":\n case \"destructive-tertiary\":\n return styles.cambioTransparentFullBackgroundColor;\n case \"success-primary\":\n return styles.cambioSuccess300BackgroundColor;\n case \"success-secondary\":\n return styles.cambioSuccess770BackgroundColor;\n case \"destructive-primary\":\n return styles.cambioDestructive300BackgroundColor;\n case \"destructive-secondary\":\n return styles.cambioDestructive770BackgroundColor;\n case \"branded\":\n return styles.cambioYellow700BackgroundColor;\n default:\n return styles.cambioWhiteBackgroundColor;\n }\n }\n}\n"],"mappings":";;;;;;AAGO,SAAS,uBAAuB,OAAuC;AAC5E,UAAQ,OAAO;AAAA,IACb,KAAK;AACH,aAAO,sBAAO;AAAA,IAChB,KAAK;AACH,aAAO,sBAAO;AAAA,IAChB,KAAK;AACH,aAAO,sBAAO;AAAA,IAChB,KAAK;AACH,aAAO,sBAAO;AAAA,IAChB,KAAK;AAAA,IACL,KAAK;AACH,aAAO,sBAAO;AAAA,IAChB,KAAK;AACH,aAAO,sBAAO;AAAA,IAChB,KAAK;AACH,aAAO,sBAAO;AAAA,IAChB;AACE,aAAO,sBAAO;AAAA,EAClB;AACF;AAEO,SAAS,sBACd,OACA,IACQ;AACR,MAAI,OAAO,mBAAmB;AAC5B,YAAQ,OAAO;AAAA,MACb,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB;AACE,eAAO,sBAAO;AAAA,IAClB;AAAA,EACF,OAAO;AACL,YAAQ,OAAO;AAAA,MACb,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB;AACE,eAAO,sBAAO;AAAA,IAClB;AAAA,EACF;AACF;","names":[]}
@@ -15,11 +15,11 @@ var _HWQUS53Mcjs = require('./HWQUS53M.cjs');
15
15
 
16
16
 
17
17
 
18
- var _RKEF7WKZcjs = require('./RKEF7WKZ.cjs');
18
+ var _HCM63U3Jcjs = require('./HCM63U3J.cjs');
19
19
 
20
20
 
21
21
 
22
- var _A4O4F3KKcjs = require('./A4O4F3KK.cjs');
22
+ var _QWMAWIWIcjs = require('./QWMAWIWI.cjs');
23
23
 
24
24
 
25
25
  var _WGRHH5TFcjs = require('./WGRHH5TF.cjs');
@@ -48,11 +48,12 @@ var LinkButton = _react.forwardRef.call(void 0,
48
48
  fullWidth = false,
49
49
  startIcon: StartIcon,
50
50
  endIcon: EndIcon,
51
+ on = "lightBackground",
51
52
  onClick
52
53
  }, ref) => {
53
54
  const { themeName } = _6W5WRS53cjs.useTheme.call(void 0, );
54
- const foregroundColorClass = themeName === "classic" ? _RKEF7WKZcjs.classicForegroundColor.call(void 0, _HWQUS53Mcjs.classicColor.call(void 0, color)) : _RKEF7WKZcjs.cambioForegroundColor.call(void 0, _HWQUS53Mcjs.cambioColor.call(void 0, color));
55
- const backgroundColorClass = themeName === "classic" ? _A4O4F3KKcjs.classicBackgroundColor.call(void 0, _HWQUS53Mcjs.classicColor.call(void 0, color)) : _A4O4F3KKcjs.cambioBackgroundColor.call(void 0, _HWQUS53Mcjs.cambioColor.call(void 0, color));
55
+ const foregroundColorClass = themeName === "classic" ? _HCM63U3Jcjs.classicForegroundColor.call(void 0, _HWQUS53Mcjs.classicColor.call(void 0, color)) : _HCM63U3Jcjs.cambioForegroundColor.call(void 0, _HWQUS53Mcjs.cambioColor.call(void 0, color), on);
56
+ const backgroundColorClass = themeName === "classic" ? _QWMAWIWIcjs.classicBackgroundColor.call(void 0, _HWQUS53Mcjs.classicColor.call(void 0, color)) : _QWMAWIWIcjs.cambioBackgroundColor.call(void 0, _HWQUS53Mcjs.cambioColor.call(void 0, color), on);
56
57
  return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
57
58
  "a",
58
59
  {
@@ -122,4 +123,4 @@ var LinkButton_default = LinkButton;
122
123
 
123
124
 
124
125
  exports.LinkButton_default = LinkButton_default;
125
- //# sourceMappingURL=SFJT2TM2.cjs.map
126
+ //# sourceMappingURL=OXXXLEUD.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/LinkButton/LinkButton.tsx","css-module:./LinkButton.module.css#css-module"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,SAAS,kBAA2C;AACpD,OAAO,gBAAgB;;;ACD6E,IAAO,4BAAQ,EAAC,cAAa,uBAAsB,cAAa,uBAAsB;;;ADsJpL,SA4BI,KA5BJ;AA/BN,IAAM,aAAa;AAAA,EACjB,CACE;AAAA,IACE;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,eAAe;AAAA,IACf,QAAQ;AAAA,IACR,OAAO;AAAA,IACP,YAAY;AAAA,IACZ,WAAW;AAAA,IACX,SAAS;AAAA,IACT,KAAK;AAAA,IACL;AAAA,EACF,GACA,QACG;AACH,UAAM,EAAE,UAAU,IAAI,SAAS;AAE/B,UAAM,uBACJ,cAAc,YACV,uBAAuB,aAAa,KAAK,CAAC,IAC1C,sBAAsB,YAAY,KAAK,GAAG,EAAE;AAElD,UAAM,uBACJ,cAAc,YACV,uBAAuB,aAAa,KAAK,CAAC,IAC1C,sBAAsB,YAAY,KAAK,GAAG,EAAE;AAElD,WACE;AAAA,MAAC;AAAA;AAAA,QACC;AAAA,QACA,eAAa;AAAA,QACb;AAAA,QACA;AAAA,QACA;AAAA,QACA,WAAW;AAAA,UACT,0BAAO;AAAA,UACP,sBAAa;AAAA,UACb;AAAA,UACA;AAAA,UACA,cAAc,YACV,sBAAa,IAAI,IACjB,sBAAa,GAAG,YAAY;AAAA,UAChC;AAAA,YACE,CAAC,sBAAa,SAAS,GAAG;AAAA,YAC1B,CAAC,0BAAO,UAAU,GAAG,CAAC;AAAA,YACtB,CAAC,sBAAa,SAAS,GACrB,cAAc,cAAc,SAAS,QAAQ,SAAS;AAAA,YACxD,CAAC,sBAAa,eAAe,GAC3B,cAAc,aAAa,UAAU;AAAA,YACvC,CAAC,sBAAa,0BAA0B,GACtC,cAAc,aAAa,UAAU;AAAA,UACzC;AAAA,QACF;AAAA,QACA;AAAA,QAEC;AAAA,uBAAa,cAAc,aAC1B;AAAA,YAAC;AAAA;AAAA,cACC,WAAW;AAAA,gBACT,sBAAa;AAAA,gBACb,iBAAS,IAAI;AAAA,gBACb;AAAA,cACF;AAAA;AAAA,UACF;AAAA,UAEF;AAAA,YAAC;AAAA;AAAA,cACC,MAAM,cAAc,YAAY,oBAAY,IAAI,IAAI,oBAAY,IAAI;AAAA,cAEpE;AAAA,gBAAC;AAAA;AAAA,kBAEC,WAAW;AAAA,kBACX,OAAO,EAAE,YAAY,IAAI;AAAA,kBAExB;AAAA;AAAA,cACH;AAAA;AAAA,UACF;AAAA,UACC,WAAW,cAAc,aACxB;AAAA,YAAC;AAAA;AAAA,cACC,WAAW;AAAA,gBACT,sBAAa;AAAA,gBACb,iBAAS,IAAI;AAAA,gBACb;AAAA,cACF;AAAA;AAAA,UACF;AAAA;AAAA;AAAA,IAEJ;AAAA,EAEJ;AACF;AAEA,WAAW,cAAc;AAEzB,IAAO,qBAAQ","sourcesContent":["import { forwardRef, type HtmlHTMLAttributes } from \"react\";\nimport classNames from \"classnames\";\nimport React from \"react\";\nimport { type Size } from \"../constants\";\nimport Typography from \"../Typography/Typography\";\nimport buttonStyles from \"../Button/Button.module.css\";\nimport iconSize from \"../Button/constants/iconSize\";\nimport textVariant from \"../Button/constants/textVariant\";\nimport styles from \"./LinkButton.module.css\";\n\nimport { classicColor, cambioColor } from \"../Button/constants/color\";\nimport {\n classicBackgroundColor,\n cambioBackgroundColor,\n} from \"../colors//backgroundColor\";\nimport {\n classicForegroundColor,\n cambioForegroundColor,\n} from \"../colors/foregroundColor\";\nimport { useTheme } from \"../ThemeProvider/ThemeProvider\";\n\ntype LinkButtonProps = {\n /**\n * Test id for the button\n */\n \"data-testid\"?: string;\n /**\n * The text to be displayed inside the button\n */\n text: string;\n /**\n * The link that the LinkButton should route to.\n *\n */\n href?: string;\n /**\n * The target attribute specifies where to open the linked document.\n *\n */\n target?: \"_blank\" | \"_self\" | \"_parent\" | \"_top\";\n /**\n * The rel attribute specifies the relationship between the document and the link.\n *\n */\n rel?: HtmlHTMLAttributes<HTMLAnchorElement>[\"rel\"];\n /**\n * The color of the button\n *\n * Classic only:\n * * `inverse`\n * * `success`\n *\n * Cambio only:\n * * `success-primary`\n * * `success-secondary`\n * * `success-tertiary`\n *\n * @defaultValue \"primary\"\n */\n color?:\n | \"primary\"\n | \"secondary\"\n | \"tertiary\"\n | \"destructive-primary\"\n | \"destructive-secondary\"\n | \"destructive-tertiary\"\n | \"branded\"\n | \"success\"\n | \"success-primary\"\n | \"success-secondary\"\n | \"success-tertiary\"\n | \"inverse\";\n /**\n * The size of the button\n *\n * Classic:\n * * `sm`: 32px\n * * `md`: 40px\n * * `lg`: 48px\n *\n * Cambio:\n * * `sm`: 32px\n * * `md`: 48px\n * * `lg`: 64px\n *\n * @defaultValue \"md\"\n */\n size?: (typeof Size)[number];\n /**\n * If `true`, the button will take up the full width of its container\n *\n * @defaultValue false\n */\n fullWidth?: boolean;\n /**\n * The icon to be displayed at the start of the button. Please use a [Rounded Material Icon](https://material.io/resources/icons/?style=round)\n * Note: startIcon is not supported in the Cambio theme\n */\n startIcon?: React.ComponentType<{ className?: string }>;\n /**\n * The icon to be displayed at the end of the button. Please use a [Rounded Material Icon](https://material.io/resources/icons/?style=round)\n * Note: endIcon is not supported in the Cambio theme\n */\n endIcon?: React.ComponentType<{ className?: string }>;\n /**\n * Indicate whether the button renders on a light or dark background. Changes the color of the button (Cambio only)\n *\n * @defaulValue `lightBackground`\n */\n on?: \"lightBackground\" | \"darkBackground\";\n /**\n * An optional onClick event. This is used for certain wrapper's support (such as react-router-dom).\n */\n onClick?: React.MouseEventHandler<HTMLAnchorElement>;\n};\n\n/**\n * [LinkButton](https://cambly-syntax.vercel.app/?path=/docs/components-linkbutton--docs) is a \"variation\" of Button that should look identical to Button, but should be used to render links instead.\n */\nconst LinkButton = forwardRef<HTMLAnchorElement, LinkButtonProps>(\n (\n {\n text,\n href,\n target,\n rel,\n \"data-testid\": dataTestId,\n color = \"primary\",\n size = \"md\",\n fullWidth = false,\n startIcon: StartIcon,\n endIcon: EndIcon,\n on = \"lightBackground\",\n onClick,\n }: LinkButtonProps,\n ref,\n ) => {\n const { themeName } = useTheme();\n\n const foregroundColorClass =\n themeName === \"classic\"\n ? classicForegroundColor(classicColor(color))\n : cambioForegroundColor(cambioColor(color), on);\n\n const backgroundColorClass =\n themeName === \"classic\"\n ? classicBackgroundColor(classicColor(color))\n : cambioBackgroundColor(cambioColor(color), on);\n\n return (\n <a\n href={href}\n data-testid={dataTestId}\n target={target}\n ref={ref}\n rel={rel}\n className={classNames(\n styles.linkButton,\n buttonStyles.button,\n foregroundColorClass,\n backgroundColorClass,\n themeName === \"classic\"\n ? buttonStyles[size]\n : buttonStyles[`${size}Cambio`],\n {\n [buttonStyles.fullWidth]: fullWidth,\n [styles.fitContent]: !fullWidth,\n [buttonStyles.buttonGap]:\n themeName === \"classic\" && (size === \"lg\" || size === \"md\"),\n [buttonStyles.secondaryBorder]:\n themeName === \"classic\" && color === \"secondary\",\n [buttonStyles.secondaryDestructiveBorder]:\n themeName === \"classic\" && color === \"destructive-secondary\",\n },\n )}\n onClick={onClick}\n >\n {StartIcon && themeName === \"classic\" && (\n <StartIcon\n className={classNames(\n buttonStyles.icon,\n iconSize[size],\n foregroundColorClass,\n )}\n />\n )}\n <Typography\n size={themeName === \"classic\" ? textVariant[size] : textVariant[size]}\n >\n <span\n // Temporary - until we have cambio colors on Typogrphay\n className={foregroundColorClass}\n style={{ fontWeight: 500 }}\n >\n {text}\n </span>\n </Typography>\n {EndIcon && themeName === \"classic\" && (\n <EndIcon\n className={classNames(\n buttonStyles.icon,\n iconSize[size],\n foregroundColorClass,\n )}\n />\n )}\n </a>\n );\n },\n);\n\nLinkButton.displayName = \"LinkButton\";\n\nexport default LinkButton;\n","import \"/home/runner/work/syntax/syntax/packages/syntax-core/src/LinkButton/LinkButton.module.css\"; export default {\"linkButton\":\"_linkButton_1qjrb_1\",\"fitContent\":\"_fitContent_1qjrb_11\"}"]}
@@ -4,13 +4,13 @@ import {
4
4
  } from "./JZ2Q7R2R.js";
5
5
  import {
6
6
  Button_default
7
- } from "./YGM4Z46I.js";
7
+ } from "./NKWR4CYF.js";
8
8
  import {
9
9
  Divider
10
10
  } from "./FWQWL53Q.js";
11
11
  import {
12
12
  RichSelectChip_default
13
- } from "./TIG3BSZG.js";
13
+ } from "./4FB7KTL3.js";
14
14
  import {
15
15
  RichSelectSection_default
16
16
  } from "./53I23AHM.js";
@@ -208,4 +208,4 @@ export {
208
208
  RichSelectBoxContext,
209
209
  RichSelectBox_default
210
210
  };
211
- //# sourceMappingURL=L4RR2XJT.js.map
211
+ //# sourceMappingURL=PX3OQSL4.js.map
@@ -0,0 +1,82 @@
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});"use client"
2
+
3
+
4
+ var _VKB7KOAHcjs = require('./VKB7KOAH.cjs');
5
+
6
+ // src/colors/backgroundColor.ts
7
+ function classicBackgroundColor(color) {
8
+ switch (color) {
9
+ case "secondary":
10
+ return _VKB7KOAHcjs.colors_module_default.primary100BackgroundColor;
11
+ case "destructive-primary":
12
+ return _VKB7KOAHcjs.colors_module_default.destructive700BackgroundColor;
13
+ case "destructive-secondary":
14
+ return _VKB7KOAHcjs.colors_module_default.destructive100BackgroundColor;
15
+ case "success":
16
+ return _VKB7KOAHcjs.colors_module_default.success700BackgroundColor;
17
+ case "tertiary":
18
+ case "destructive-tertiary":
19
+ return _VKB7KOAHcjs.colors_module_default.whiteBackgroundColor;
20
+ case "branded":
21
+ return _VKB7KOAHcjs.colors_module_default.yellow700BackgroundColor;
22
+ case "inverse":
23
+ return _VKB7KOAHcjs.colors_module_default.gray60BackgroundColor;
24
+ default:
25
+ return _VKB7KOAHcjs.colors_module_default.primary700BackgroundColor;
26
+ }
27
+ }
28
+ function cambioBackgroundColor(color, on) {
29
+ if (on === "lightBackground") {
30
+ switch (color) {
31
+ case "primary":
32
+ return _VKB7KOAHcjs.colors_module_default.cambioBlackBackgroundColor;
33
+ case "secondary":
34
+ return _VKB7KOAHcjs.colors_module_default.cambioGray370BackgroundColor;
35
+ case "tertiary":
36
+ case "success-tertiary":
37
+ case "destructive-tertiary":
38
+ return _VKB7KOAHcjs.colors_module_default.cambioTransparentFullBackgroundColor;
39
+ case "success-primary":
40
+ return _VKB7KOAHcjs.colors_module_default.cambioSuccess700BackgroundColor;
41
+ case "success-secondary":
42
+ return _VKB7KOAHcjs.colors_module_default.cambioSuccess370BackgroundColor;
43
+ case "destructive-primary":
44
+ return _VKB7KOAHcjs.colors_module_default.cambioDestructive700BackgroundColor;
45
+ case "destructive-secondary":
46
+ return _VKB7KOAHcjs.colors_module_default.cambioDestructive370BackgroundColor;
47
+ case "branded":
48
+ return _VKB7KOAHcjs.colors_module_default.cambioYellow700BackgroundColor;
49
+ default:
50
+ return _VKB7KOAHcjs.colors_module_default.cambioBlackBackgroundColor;
51
+ }
52
+ } else {
53
+ switch (color) {
54
+ case "primary":
55
+ return _VKB7KOAHcjs.colors_module_default.cambioGray200BackgroundColor;
56
+ case "secondary":
57
+ return _VKB7KOAHcjs.colors_module_default.cambioGray870BackgroundColor;
58
+ case "tertiary":
59
+ case "success-tertiary":
60
+ case "destructive-tertiary":
61
+ return _VKB7KOAHcjs.colors_module_default.cambioTransparentFullBackgroundColor;
62
+ case "success-primary":
63
+ return _VKB7KOAHcjs.colors_module_default.cambioSuccess300BackgroundColor;
64
+ case "success-secondary":
65
+ return _VKB7KOAHcjs.colors_module_default.cambioSuccess770BackgroundColor;
66
+ case "destructive-primary":
67
+ return _VKB7KOAHcjs.colors_module_default.cambioDestructive300BackgroundColor;
68
+ case "destructive-secondary":
69
+ return _VKB7KOAHcjs.colors_module_default.cambioDestructive770BackgroundColor;
70
+ case "branded":
71
+ return _VKB7KOAHcjs.colors_module_default.cambioYellow700BackgroundColor;
72
+ default:
73
+ return _VKB7KOAHcjs.colors_module_default.cambioWhiteBackgroundColor;
74
+ }
75
+ }
76
+ }
77
+
78
+
79
+
80
+
81
+ exports.classicBackgroundColor = classicBackgroundColor; exports.cambioBackgroundColor = cambioBackgroundColor;
82
+ //# sourceMappingURL=QWMAWIWI.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/colors/backgroundColor.ts"],"names":[],"mappings":";;;;;;AAGO,SAAS,uBAAuB,OAAuC;AAC5E,UAAQ,OAAO;AAAA,IACb,KAAK;AACH,aAAO,sBAAO;AAAA,IAChB,KAAK;AACH,aAAO,sBAAO;AAAA,IAChB,KAAK;AACH,aAAO,sBAAO;AAAA,IAChB,KAAK;AACH,aAAO,sBAAO;AAAA,IAChB,KAAK;AAAA,IACL,KAAK;AACH,aAAO,sBAAO;AAAA,IAChB,KAAK;AACH,aAAO,sBAAO;AAAA,IAChB,KAAK;AACH,aAAO,sBAAO;AAAA,IAChB;AACE,aAAO,sBAAO;AAAA,EAClB;AACF;AAEO,SAAS,sBACd,OACA,IACQ;AACR,MAAI,OAAO,mBAAmB;AAC5B,YAAQ,OAAO;AAAA,MACb,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB;AACE,eAAO,sBAAO;AAAA,IAClB;AAAA,EACF,OAAO;AACL,YAAQ,OAAO;AAAA,MACb,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB,KAAK;AACH,eAAO,sBAAO;AAAA,MAChB;AACE,eAAO,sBAAO;AAAA,IAClB;AAAA,EACF;AACF","sourcesContent":["import { type CambioColor, type Color } from \"../constants\";\nimport styles from \"./colors.module.css\";\n\nexport function classicBackgroundColor(color: (typeof Color)[number]): string {\n switch (color) {\n case \"secondary\":\n return styles.primary100BackgroundColor;\n case \"destructive-primary\":\n return styles.destructive700BackgroundColor;\n case \"destructive-secondary\":\n return styles.destructive100BackgroundColor;\n case \"success\":\n return styles.success700BackgroundColor;\n case \"tertiary\":\n case \"destructive-tertiary\":\n return styles.whiteBackgroundColor;\n case \"branded\":\n return styles.yellow700BackgroundColor;\n case \"inverse\":\n return styles.gray60BackgroundColor;\n default:\n return styles.primary700BackgroundColor;\n }\n}\n\nexport function cambioBackgroundColor(\n color: (typeof CambioColor)[number],\n on: \"lightBackground\" | \"darkBackground\",\n): string {\n if (on === \"lightBackground\") {\n switch (color) {\n case \"primary\":\n return styles.cambioBlackBackgroundColor;\n case \"secondary\":\n return styles.cambioGray370BackgroundColor;\n case \"tertiary\":\n case \"success-tertiary\":\n case \"destructive-tertiary\":\n return styles.cambioTransparentFullBackgroundColor;\n case \"success-primary\":\n return styles.cambioSuccess700BackgroundColor;\n case \"success-secondary\":\n return styles.cambioSuccess370BackgroundColor;\n case \"destructive-primary\":\n return styles.cambioDestructive700BackgroundColor;\n case \"destructive-secondary\":\n return styles.cambioDestructive370BackgroundColor;\n case \"branded\":\n return styles.cambioYellow700BackgroundColor;\n default:\n return styles.cambioBlackBackgroundColor;\n }\n } else {\n switch (color) {\n case \"primary\":\n return styles.cambioGray200BackgroundColor;\n case \"secondary\":\n return styles.cambioGray870BackgroundColor;\n case \"tertiary\":\n case \"success-tertiary\":\n case \"destructive-tertiary\":\n return styles.cambioTransparentFullBackgroundColor;\n case \"success-primary\":\n return styles.cambioSuccess300BackgroundColor;\n case \"success-secondary\":\n return styles.cambioSuccess770BackgroundColor;\n case \"destructive-primary\":\n return styles.cambioDestructive300BackgroundColor;\n case \"destructive-secondary\":\n return styles.cambioDestructive770BackgroundColor;\n case \"branded\":\n return styles.cambioYellow700BackgroundColor;\n default:\n return styles.cambioWhiteBackgroundColor;\n }\n }\n}\n"]}
@@ -13,14 +13,33 @@ import {
13
13
  } from "./JB65NEXK.js";
14
14
 
15
15
  // src/Chip/Chip.tsx
16
- import { forwardRef } from "react";
16
+ import { forwardRef, useMemo } from "react";
17
17
  import classnames from "classnames";
18
18
 
19
19
  // css-module:./Chip.module.css#css-module
20
- var Chip_module_default = { "chip": "_chip_1jp9s_1", "chipClassic": "_chipClassic_1jp9s_10", "chipCambio": "_chipCambio_1jp9s_15", "disabled": "_disabled_1jp9s_20", "deselectedChip": "_deselectedChip_1jp9s_25", "selectedChip": "_selectedChip_1jp9s_29", "deselectedChipCambio": "_deselectedChipCambio_1jp9s_34", "selectedChipCambio": "_selectedChipCambio_1jp9s_38", "icon": "_icon_1jp9s_42", "selectedIcon": "_selectedIcon_1jp9s_50", "sm": "_sm_1jp9s_54", "lg": "_lg_1jp9s_60", "forceFocus": "_forceFocus_1jp9s_67" };
20
+ var Chip_module_default = { "chip": "_chip_1ndh3_1", "chipClassic": "_chipClassic_1ndh3_10", "chipCambio": "_chipCambio_1ndh3_15", "disabled": "_disabled_1ndh3_20", "deselectedChip": "_deselectedChip_1ndh3_25", "selectedChip": "_selectedChip_1ndh3_29", "deselectedChipCambio": "_deselectedChipCambio_1ndh3_34", "deselectedChipCambioOnDarkBackground": "_deselectedChipCambioOnDarkBackground_1ndh3_38", "selectedChipCambio": "_selectedChipCambio_1ndh3_42", "selectedChipCambioOnDarkBackground": "_selectedChipCambioOnDarkBackground_1ndh3_46", "icon": "_icon_1ndh3_50", "selectedIcon": "_selectedIcon_1ndh3_58", "sm": "_sm_1ndh3_62", "lg": "_lg_1ndh3_68", "forceFocus": "_forceFocus_1ndh3_75" };
21
21
 
22
22
  // src/Chip/Chip.tsx
23
23
  import { jsx, jsxs } from "react/jsx-runtime";
24
+ function typographyColor({
25
+ themeName,
26
+ selected,
27
+ on
28
+ }) {
29
+ if (themeName === "cambio" && on === "darkBackground") {
30
+ if (selected) {
31
+ return "gray900";
32
+ } else {
33
+ return "white";
34
+ }
35
+ } else {
36
+ if (selected) {
37
+ return "white";
38
+ } else {
39
+ return "gray900";
40
+ }
41
+ }
42
+ }
24
43
  var Chip = forwardRef(
25
44
  ({
26
45
  disabled: disabledProp = false,
@@ -28,6 +47,7 @@ var Chip = forwardRef(
28
47
  "data-testid": dataTestId,
29
48
  size = "sm",
30
49
  text,
50
+ on = "lightBackground",
31
51
  onChange,
32
52
  icon: Icon,
33
53
  dangerouslyForceFocusStyles
@@ -36,13 +56,15 @@ var Chip = forwardRef(
36
56
  const transformedSize = themeName === "cambio" ? "sm" : size;
37
57
  const isHydrated = useIsHydrated();
38
58
  const disabled = !isHydrated || disabledProp;
59
+ const selectedChipCambioStyle = on === "lightBackground" ? Chip_module_default.selectedChipCambio : Chip_module_default.selectedChipCambioOnDarkBackground;
60
+ const deselectedChipCambioStyle = on === "lightBackground" ? Chip_module_default.deselectedChipCambio : Chip_module_default.deselectedChipCambioOnDarkBackground;
39
61
  const chipStyles = classnames(
40
62
  Chip_module_default.chip,
41
63
  themeName === "classic" ? Chip_module_default.chipClassic : Chip_module_default.chipCambio,
42
64
  Chip_module_default[transformedSize],
43
65
  {
44
- [themeName === "classic" ? Chip_module_default.selectedChip : Chip_module_default.selectedChipCambio]: selected,
45
- [themeName === "classic" ? Chip_module_default.deselectedChip : Chip_module_default.deselectedChipCambio]: !selected,
66
+ [themeName === "classic" ? Chip_module_default.selectedChip : selectedChipCambioStyle]: selected,
67
+ [themeName === "classic" ? Chip_module_default.deselectedChip : deselectedChipCambioStyle]: !selected,
46
68
  [Chip_module_default.disabled]: disabled,
47
69
  [Chip_module_default.forceFocus]: dangerouslyForceFocusStyles
48
70
  }
@@ -54,6 +76,10 @@ var Chip = forwardRef(
54
76
  ["sm"]: 200,
55
77
  ["lg"]: 300
56
78
  };
79
+ const color = useMemo(
80
+ () => typographyColor({ themeName, selected, on }),
81
+ [themeName, selected, on]
82
+ );
57
83
  return /* @__PURE__ */ jsxs(
58
84
  "button",
59
85
  {
@@ -70,7 +96,7 @@ var Chip = forwardRef(
70
96
  Typography_default,
71
97
  {
72
98
  size: themeName === "classic" ? typographySize[transformedSize] : 100,
73
- color: selected ? "white" : "gray900",
99
+ color,
74
100
  children: text
75
101
  }
76
102
  ) })
@@ -85,4 +111,4 @@ var Chip_default = Chip;
85
111
  export {
86
112
  Chip_default
87
113
  };
88
- //# sourceMappingURL=2ZUWZKPV.js.map
114
+ //# sourceMappingURL=YKGFFSWB.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/Chip/Chip.tsx","css-module:./Chip.module.css#css-module"],"sourcesContent":["import React, { forwardRef, useMemo } from \"react\";\nimport classnames from \"classnames\";\nimport Typography from \"../Typography/Typography\";\nimport Box from \"../Box/Box\";\nimport styles from \"./Chip.module.css\";\nimport useIsHydrated from \"../useIsHydrated\";\nimport { useTheme } from \"../ThemeProvider/ThemeProvider\";\n\nfunction typographyColor({\n themeName,\n selected,\n on,\n}: {\n themeName: \"cambio\" | \"classic\";\n selected: boolean;\n on: \"lightBackground\" | \"darkBackground\";\n}): \"white\" | \"gray900\" {\n if (themeName === \"cambio\" && on === \"darkBackground\") {\n if (selected) {\n return \"gray900\";\n } else {\n return \"white\";\n }\n } else {\n if (selected) {\n return \"white\";\n } else {\n return \"gray900\";\n }\n }\n}\n\ntype ChipProps = {\n /**\n * If true, the chip will be disabled.\n */\n disabled?: boolean;\n /**\n * Sets the initial status of this chip component.\n * * `true` will display a grey chip.\n * * `false` will display a premium800 color chip.\n *\n * @defaultValue \"false\"\n */\n selected?: boolean;\n /**\n * Test id for the button\n */\n \"data-testid\"?: string;\n /**\n * Size of the chip.\n *\n * Classic:\n * * `sm`: 32px\n * * `lg`: 48px\n *\n * Cambio:\n * * `sm`: 32px\n *\n * @defaultValue sm\n */\n size?: \"sm\" | \"lg\";\n /**\n * The text to be displayed on the chip\n */\n text: string;\n /**\n * Indicate whether the badge renders on a light or dark background. Changes the color of the chip (Cambio only)\n *\n * @defaulValue `lightBackground`\n */\n on?: \"lightBackground\" | \"darkBackground\";\n /**\n * The callback to be called when the chip is clicked\n */\n onChange: React.MouseEventHandler<HTMLButtonElement>;\n /**\n * The icon to be displayed.\n */\n icon?: React.ComponentType<{ className?: string }>;\n /** forces focus ring styling */\n dangerouslyForceFocusStyles?: boolean;\n};\n/**\n * [Chip](https://cambly-syntax.vercel.app/?path=/docs/components-chip--docs) is used to show status (selected/not selected) like a toggle button.\n */\nconst Chip = forwardRef<HTMLButtonElement, ChipProps>(\n (\n {\n disabled: disabledProp = false,\n selected = false,\n \"data-testid\": dataTestId,\n size = \"sm\",\n text,\n on = \"lightBackground\",\n onChange,\n icon: Icon,\n dangerouslyForceFocusStyles,\n }: ChipProps,\n ref,\n ) => {\n const { themeName } = useTheme();\n const transformedSize = themeName === \"cambio\" ? \"sm\" : size;\n const isHydrated = useIsHydrated();\n const disabled = !isHydrated || disabledProp;\n\n const selectedChipCambioStyle =\n on === \"lightBackground\"\n ? styles.selectedChipCambio\n : styles.selectedChipCambioOnDarkBackground;\n\n const deselectedChipCambioStyle =\n on === \"lightBackground\"\n ? styles.deselectedChipCambio\n : styles.deselectedChipCambioOnDarkBackground;\n\n const chipStyles = classnames(\n styles.chip,\n themeName === \"classic\" ? styles.chipClassic : styles.chipCambio,\n styles[transformedSize],\n {\n [themeName === \"classic\"\n ? styles.selectedChip\n : selectedChipCambioStyle]: selected,\n [themeName === \"classic\"\n ? styles.deselectedChip\n : deselectedChipCambioStyle]: !selected,\n [styles.disabled]: disabled,\n [styles.forceFocus]: dangerouslyForceFocusStyles,\n },\n );\n const iconStyles = classnames(styles.icon, {\n [styles.selectedIcon]: selected,\n });\n const typographySize = {\n [\"sm\"]: 200,\n [\"lg\"]: 300,\n } as const;\n\n const color = useMemo(\n () => typographyColor({ themeName, selected, on }),\n [themeName, selected, on],\n );\n\n return (\n <button\n className={chipStyles}\n disabled={disabled}\n data-testid={dataTestId}\n ref={ref}\n type=\"button\"\n aria-pressed={selected}\n onClick={onChange}\n >\n {Icon && <Icon className={iconStyles} />}\n <Box paddingX={Icon ? 1 : 0}>\n <Typography\n size={\n themeName === \"classic\" ? typographySize[transformedSize] : 100\n }\n color={color}\n >\n {text}\n </Typography>\n </Box>\n </button>\n );\n },\n);\n\nChip.displayName = \"Chip\";\n\nexport default Chip;\n","import \"/home/runner/work/syntax/syntax/packages/syntax-core/src/Chip/Chip.module.css\"; export default {\"chip\":\"_chip_1ndh3_1\",\"chipClassic\":\"_chipClassic_1ndh3_10\",\"chipCambio\":\"_chipCambio_1ndh3_15\",\"disabled\":\"_disabled_1ndh3_20\",\"deselectedChip\":\"_deselectedChip_1ndh3_25\",\"selectedChip\":\"_selectedChip_1ndh3_29\",\"deselectedChipCambio\":\"_deselectedChipCambio_1ndh3_34\",\"deselectedChipCambioOnDarkBackground\":\"_deselectedChipCambioOnDarkBackground_1ndh3_38\",\"selectedChipCambio\":\"_selectedChipCambio_1ndh3_42\",\"selectedChipCambioOnDarkBackground\":\"_selectedChipCambioOnDarkBackground_1ndh3_46\",\"icon\":\"_icon_1ndh3_50\",\"selectedIcon\":\"_selectedIcon_1ndh3_58\",\"sm\":\"_sm_1ndh3_62\",\"lg\":\"_lg_1ndh3_68\",\"forceFocus\":\"_forceFocus_1ndh3_75\"}"],"mappings":";;;;;;;;;;;;;;;AAAA,SAAgB,YAAY,eAAe;AAC3C,OAAO,gBAAgB;;;ACDiE,IAAO,sBAAQ,EAAC,QAAO,iBAAgB,eAAc,yBAAwB,cAAa,wBAAuB,YAAW,sBAAqB,kBAAiB,4BAA2B,gBAAe,0BAAyB,wBAAuB,kCAAiC,wCAAuC,kDAAiD,sBAAqB,gCAA+B,sCAAqC,gDAA+C,QAAO,kBAAiB,gBAAe,0BAAyB,MAAK,gBAAe,MAAK,gBAAe,cAAa,uBAAsB;;;ADiJ1tB,SASW,KATX;AAzIN,SAAS,gBAAgB;AAAA,EACvB;AAAA,EACA;AAAA,EACA;AACF,GAIwB;AACtB,MAAI,cAAc,YAAY,OAAO,kBAAkB;AACrD,QAAI,UAAU;AACZ,aAAO;AAAA,IACT,OAAO;AACL,aAAO;AAAA,IACT;AAAA,EACF,OAAO;AACL,QAAI,UAAU;AACZ,aAAO;AAAA,IACT,OAAO;AACL,aAAO;AAAA,IACT;AAAA,EACF;AACF;AAwDA,IAAM,OAAO;AAAA,EACX,CACE;AAAA,IACE,UAAU,eAAe;AAAA,IACzB,WAAW;AAAA,IACX,eAAe;AAAA,IACf,OAAO;AAAA,IACP;AAAA,IACA,KAAK;AAAA,IACL;AAAA,IACA,MAAM;AAAA,IACN;AAAA,EACF,GACA,QACG;AACH,UAAM,EAAE,UAAU,IAAI,SAAS;AAC/B,UAAM,kBAAkB,cAAc,WAAW,OAAO;AACxD,UAAM,aAAa,cAAc;AACjC,UAAM,WAAW,CAAC,cAAc;AAEhC,UAAM,0BACJ,OAAO,oBACH,oBAAO,qBACP,oBAAO;AAEb,UAAM,4BACJ,OAAO,oBACH,oBAAO,uBACP,oBAAO;AAEb,UAAM,aAAa;AAAA,MACjB,oBAAO;AAAA,MACP,cAAc,YAAY,oBAAO,cAAc,oBAAO;AAAA,MACtD,oBAAO,eAAe;AAAA,MACtB;AAAA,QACE,CAAC,cAAc,YACX,oBAAO,eACP,uBAAuB,GAAG;AAAA,QAC9B,CAAC,cAAc,YACX,oBAAO,iBACP,yBAAyB,GAAG,CAAC;AAAA,QACjC,CAAC,oBAAO,QAAQ,GAAG;AAAA,QACnB,CAAC,oBAAO,UAAU,GAAG;AAAA,MACvB;AAAA,IACF;AACA,UAAM,aAAa,WAAW,oBAAO,MAAM;AAAA,MACzC,CAAC,oBAAO,YAAY,GAAG;AAAA,IACzB,CAAC;AACD,UAAM,iBAAiB;AAAA,MACrB,CAAC,IAAI,GAAG;AAAA,MACR,CAAC,IAAI,GAAG;AAAA,IACV;AAEA,UAAM,QAAQ;AAAA,MACZ,MAAM,gBAAgB,EAAE,WAAW,UAAU,GAAG,CAAC;AAAA,MACjD,CAAC,WAAW,UAAU,EAAE;AAAA,IAC1B;AAEA,WACE;AAAA,MAAC;AAAA;AAAA,QACC,WAAW;AAAA,QACX;AAAA,QACA,eAAa;AAAA,QACb;AAAA,QACA,MAAK;AAAA,QACL,gBAAc;AAAA,QACd,SAAS;AAAA,QAER;AAAA,kBAAQ,oBAAC,QAAK,WAAW,YAAY;AAAA,UACtC,oBAAC,eAAI,UAAU,OAAO,IAAI,GACxB;AAAA,YAAC;AAAA;AAAA,cACC,MACE,cAAc,YAAY,eAAe,eAAe,IAAI;AAAA,cAE9D;AAAA,cAEC;AAAA;AAAA,UACH,GACF;AAAA;AAAA;AAAA,IACF;AAAA,EAEJ;AACF;AAEA,KAAK,cAAc;AAEnB,IAAO,eAAQ;","names":[]}
@@ -1,7 +1,7 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});"use client"
2
2
 
3
3
 
4
- var _GRYQKIWRcjs = require('./GRYQKIWR.cjs');
4
+ var _MUNI4VXLcjs = require('./MUNI4VXL.cjs');
5
5
 
6
6
 
7
7
  var _RYUXG4AScjs = require('./RYUXG4AS.cjs');
@@ -16,7 +16,7 @@ var _jsxruntime = require('react/jsx-runtime');
16
16
  var RichSelectChip_default = _react.forwardRef.call(void 0,
17
17
  function RichSelectChip(props, ref) {
18
18
  return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _RYUXG4AScjs.RichSelectItem_default, _X2SDR4SDcjs.__spreadProps.call(void 0, _X2SDR4SDcjs.__spreadValues.call(void 0, {}, props), { ref, children: ({ isSelected, isFocusVisible, isDisabled }) => /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
19
- _GRYQKIWRcjs.Chip_default,
19
+ _MUNI4VXLcjs.Chip_default,
20
20
  {
21
21
  text: props.label,
22
22
  selected: isSelected,
@@ -31,4 +31,4 @@ var RichSelectChip_default = _react.forwardRef.call(void 0,
31
31
 
32
32
 
33
33
  exports.RichSelectChip_default = RichSelectChip_default;
34
- //# sourceMappingURL=XSHPEZBA.cjs.map
34
+ //# sourceMappingURL=ZDDA4AKB.cjs.map
@@ -5,7 +5,7 @@ var _4UJE5GMHcjs = require('./4UJE5GMH.cjs');
5
5
 
6
6
 
7
7
 
8
- var _H6JCVQBUcjs = require('./H6JCVQBU.cjs');
8
+ var _DA3CET5Gcjs = require('./DA3CET5G.cjs');
9
9
 
10
10
 
11
11
  var _XLUVINJWcjs = require('./XLUVINJW.cjs');
@@ -121,7 +121,7 @@ function SelectList({
121
121
  children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
122
122
  "path",
123
123
  {
124
- fill: errorText ? _H6JCVQBUcjs.ColorBaseDestructive700 : _H6JCVQBUcjs.ColorBaseGray800,
124
+ fill: errorText ? _DA3CET5Gcjs.ColorBaseDestructive700 : _DA3CET5Gcjs.ColorBaseGray800,
125
125
  d: "M15.88 9.29 12 13.17 8.12 9.29a.9959.9959 0 0 0-1.41 0c-.39.39-.39 1.02 0 1.41l4.59 4.59c.39.39 1.02.39 1.41 0l4.59-4.59c.39-.39.39-1.02 0-1.41-.39-.38-1.03-.39-1.42 0z"
126
126
  }
127
127
  )
@@ -145,4 +145,4 @@ SelectList.Option = _4UJE5GMHcjs.SelectOption_default;
145
145
 
146
146
 
147
147
  exports.SelectList = SelectList;
148
- //# sourceMappingURL=RZCA77DH.cjs.map
148
+ //# sourceMappingURL=ZDSY6FEO.cjs.map
@@ -2,12 +2,12 @@
2
2
 
3
3
 
4
4
 
5
- var _A4O4F3KKcjs = require('../__chunks/A4O4F3KK.cjs');
5
+ var _QWMAWIWIcjs = require('../__chunks/QWMAWIWI.cjs');
6
6
  require('../__chunks/VKB7KOAH.cjs');
7
7
  require('../__chunks/WFVGNGEP.cjs');
8
8
  require('../__chunks/X2SDR4SD.cjs');
9
9
 
10
10
 
11
11
 
12
- exports.cambioBackgroundColor = _A4O4F3KKcjs.cambioBackgroundColor; exports.classicBackgroundColor = _A4O4F3KKcjs.classicBackgroundColor;
12
+ exports.cambioBackgroundColor = _QWMAWIWIcjs.cambioBackgroundColor; exports.classicBackgroundColor = _QWMAWIWIcjs.classicBackgroundColor;
13
13
  //# sourceMappingURL=backgroundColor.cjs.map
@@ -1,6 +1,6 @@
1
1
  import { Color, CambioColor } from '../constants.js';
2
2
 
3
3
  declare function classicBackgroundColor(color: (typeof Color)[number]): string;
4
- declare function cambioBackgroundColor(color: (typeof CambioColor)[number]): string;
4
+ declare function cambioBackgroundColor(color: (typeof CambioColor)[number], on: "lightBackground" | "darkBackground"): string;
5
5
 
6
6
  export { cambioBackgroundColor, classicBackgroundColor };
@@ -2,7 +2,7 @@
2
2
  import {
3
3
  cambioBackgroundColor,
4
4
  classicBackgroundColor
5
- } from "../__chunks/Y2OAIOQE.js";
5
+ } from "../__chunks/OFW6A65B.js";
6
6
  import "../__chunks/FMQVMNVR.js";
7
7
  import "../__chunks/4U4UW4AK.js";
8
8
  import "../__chunks/UWGNJENA.js";