@clubmed/trident-ui 1.0.0-beta.4 → 1.0.0-beta.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (135) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/fonts/Actions/tui-actions.css +6 -6
  3. package/fonts/Actions/tui-actions.eot +0 -0
  4. package/fonts/Actions/tui-actions.less +6 -6
  5. package/fonts/Actions/tui-actions.module.less +6 -6
  6. package/fonts/Actions/tui-actions.scss +6 -6
  7. package/fonts/Actions/tui-actions.styl +6 -6
  8. package/fonts/Actions/tui-actions.ttf +0 -0
  9. package/fonts/Actions/tui-actions.woff +0 -0
  10. package/fonts/Actions/tui-actions.woff2 +0 -0
  11. package/fonts/Activities/tui-activities.css +6 -6
  12. package/fonts/Activities/tui-activities.eot +0 -0
  13. package/fonts/Activities/tui-activities.less +6 -6
  14. package/fonts/Activities/tui-activities.module.less +6 -6
  15. package/fonts/Activities/tui-activities.scss +6 -6
  16. package/fonts/Activities/tui-activities.styl +6 -6
  17. package/fonts/Activities/tui-activities.ttf +0 -0
  18. package/fonts/Activities/tui-activities.woff +0 -0
  19. package/fonts/Activities/tui-activities.woff2 +0 -0
  20. package/fonts/Brand/tui-brand.css +6 -6
  21. package/fonts/Brand/tui-brand.eot +0 -0
  22. package/fonts/Brand/tui-brand.less +6 -6
  23. package/fonts/Brand/tui-brand.module.less +6 -6
  24. package/fonts/Brand/tui-brand.scss +6 -6
  25. package/fonts/Brand/tui-brand.styl +6 -6
  26. package/fonts/Brand/tui-brand.ttf +0 -0
  27. package/fonts/Brand/tui-brand.woff +0 -0
  28. package/fonts/Brand/tui-brand.woff2 +0 -0
  29. package/fonts/Covid/tui-covid.css +6 -6
  30. package/fonts/Covid/tui-covid.eot +0 -0
  31. package/fonts/Covid/tui-covid.less +6 -6
  32. package/fonts/Covid/tui-covid.module.less +6 -6
  33. package/fonts/Covid/tui-covid.scss +6 -6
  34. package/fonts/Covid/tui-covid.styl +6 -6
  35. package/fonts/Covid/tui-covid.ttf +0 -0
  36. package/fonts/Covid/tui-covid.woff +0 -0
  37. package/fonts/Covid/tui-covid.woff2 +0 -0
  38. package/fonts/Food/tui-food.css +6 -6
  39. package/fonts/Food/tui-food.eot +0 -0
  40. package/fonts/Food/tui-food.less +6 -6
  41. package/fonts/Food/tui-food.module.less +6 -6
  42. package/fonts/Food/tui-food.scss +6 -6
  43. package/fonts/Food/tui-food.styl +6 -6
  44. package/fonts/Food/tui-food.ttf +0 -0
  45. package/fonts/Food/tui-food.woff +0 -0
  46. package/fonts/Food/tui-food.woff2 +0 -0
  47. package/fonts/HappyToCare/tui-happy-to-care.css +6 -6
  48. package/fonts/HappyToCare/tui-happy-to-care.eot +0 -0
  49. package/fonts/HappyToCare/tui-happy-to-care.less +6 -6
  50. package/fonts/HappyToCare/tui-happy-to-care.module.less +6 -6
  51. package/fonts/HappyToCare/tui-happy-to-care.scss +6 -6
  52. package/fonts/HappyToCare/tui-happy-to-care.styl +6 -6
  53. package/fonts/HappyToCare/tui-happy-to-care.ttf +0 -0
  54. package/fonts/HappyToCare/tui-happy-to-care.woff +0 -0
  55. package/fonts/HappyToCare/tui-happy-to-care.woff2 +0 -0
  56. package/fonts/Places/tui-places.css +6 -6
  57. package/fonts/Places/tui-places.eot +0 -0
  58. package/fonts/Places/tui-places.less +6 -6
  59. package/fonts/Places/tui-places.module.less +6 -6
  60. package/fonts/Places/tui-places.scss +6 -6
  61. package/fonts/Places/tui-places.styl +6 -6
  62. package/fonts/Places/tui-places.ttf +0 -0
  63. package/fonts/Places/tui-places.woff +0 -0
  64. package/fonts/Places/tui-places.woff2 +0 -0
  65. package/fonts/Room/tui-room.css +6 -6
  66. package/fonts/Room/tui-room.eot +0 -0
  67. package/fonts/Room/tui-room.less +6 -6
  68. package/fonts/Room/tui-room.module.less +6 -6
  69. package/fonts/Room/tui-room.scss +6 -6
  70. package/fonts/Room/tui-room.styl +6 -6
  71. package/fonts/Room/tui-room.ttf +0 -0
  72. package/fonts/Room/tui-room.woff +0 -0
  73. package/fonts/Room/tui-room.woff2 +0 -0
  74. package/fonts/Services/tui-services.css +6 -6
  75. package/fonts/Services/tui-services.eot +0 -0
  76. package/fonts/Services/tui-services.less +6 -6
  77. package/fonts/Services/tui-services.module.less +6 -6
  78. package/fonts/Services/tui-services.scss +6 -6
  79. package/fonts/Services/tui-services.styl +6 -6
  80. package/fonts/Services/tui-services.ttf +0 -0
  81. package/fonts/Services/tui-services.woff +0 -0
  82. package/fonts/Services/tui-services.woff2 +0 -0
  83. package/fonts/Socials/tui-socials.css +6 -6
  84. package/fonts/Socials/tui-socials.eot +0 -0
  85. package/fonts/Socials/tui-socials.less +6 -6
  86. package/fonts/Socials/tui-socials.module.less +6 -6
  87. package/fonts/Socials/tui-socials.scss +6 -6
  88. package/fonts/Socials/tui-socials.styl +6 -6
  89. package/fonts/Socials/tui-socials.ttf +0 -0
  90. package/fonts/Socials/tui-socials.woff +0 -0
  91. package/fonts/Socials/tui-socials.woff2 +0 -0
  92. package/fonts/Transports/tui-transports.css +6 -6
  93. package/fonts/Transports/tui-transports.eot +0 -0
  94. package/fonts/Transports/tui-transports.less +6 -6
  95. package/fonts/Transports/tui-transports.module.less +6 -6
  96. package/fonts/Transports/tui-transports.scss +6 -6
  97. package/fonts/Transports/tui-transports.styl +6 -6
  98. package/fonts/Transports/tui-transports.ttf +0 -0
  99. package/fonts/Transports/tui-transports.woff +0 -0
  100. package/fonts/Transports/tui-transports.woff2 +0 -0
  101. package/fonts/Utilities/tui-utilities.css +6 -6
  102. package/fonts/Utilities/tui-utilities.eot +0 -0
  103. package/fonts/Utilities/tui-utilities.less +6 -6
  104. package/fonts/Utilities/tui-utilities.module.less +6 -6
  105. package/fonts/Utilities/tui-utilities.scss +6 -6
  106. package/fonts/Utilities/tui-utilities.styl +6 -6
  107. package/fonts/Utilities/tui-utilities.ttf +0 -0
  108. package/fonts/Utilities/tui-utilities.woff +0 -0
  109. package/fonts/Utilities/tui-utilities.woff2 +0 -0
  110. package/molecules/Forms/Checkboxes/Checkbox.d.ts +1 -1
  111. package/molecules/Forms/Checkboxes/Checkbox.js +37 -37
  112. package/molecules/Forms/Checkboxes/Checkboxes.d.ts +1 -1
  113. package/molecules/Forms/Checkboxes/Checkboxes.js +30 -31
  114. package/molecules/Forms/DateField.d.ts +1 -17
  115. package/molecules/Forms/DateField.js +98 -99
  116. package/molecules/Forms/Filter.d.ts +1 -1
  117. package/molecules/Forms/Filter.js +38 -38
  118. package/molecules/Forms/FormLabel.js +1 -1
  119. package/molecules/Forms/NumberField.d.ts +3 -3
  120. package/molecules/Forms/NumberField.js +76 -76
  121. package/molecules/Forms/Password/Password.js +35 -36
  122. package/molecules/Forms/Radios/Radio.d.ts +1 -1
  123. package/molecules/Forms/Radios/Radio.js +31 -31
  124. package/molecules/Forms/Radios/RadioGroup.d.ts +1 -1
  125. package/molecules/Forms/Radios/RadioGroup.js +28 -29
  126. package/molecules/Forms/Range.d.ts +2 -2
  127. package/molecules/Forms/Range.js +181 -183
  128. package/molecules/Forms/Select.d.ts +10 -0
  129. package/molecules/Forms/Select.js +99 -0
  130. package/molecules/Forms/Switch.d.ts +1 -1
  131. package/molecules/Forms/Switch.js +28 -28
  132. package/molecules/Forms/TextField.d.ts +0 -1
  133. package/molecules/Forms/TextField.js +47 -50
  134. package/package.json +1 -1
  135. package/styles/globals.css +4 -0
@@ -0,0 +1,99 @@
1
+ import { jsx as t, jsxs as d } from "react/jsx-runtime";
2
+ import { c as l } from "../../index-Cu0xwYjD.js";
3
+ import { useValue as C } from "../../hooks/useValue.js";
4
+ import { useInternalStatus as D } from "../../hooks/useInternalStatus.js";
5
+ import { FormControl as I } from "./FormControl.js";
6
+ import { Icon as n } from "../../atoms/Icons/Icon.js";
7
+ import "../../atoms/Icons/contexts/IconsContext.js";
8
+ import { useId as S } from "react";
9
+ const $ = (c) => {
10
+ const p = S(), {
11
+ id: r = `select-${p}`,
12
+ name: a = r,
13
+ label: u,
14
+ value: m,
15
+ description: b,
16
+ validationStatus: o = "default",
17
+ iconType: i,
18
+ errorMessage: x,
19
+ disabled: s = !1,
20
+ className: f,
21
+ dataTestId: g = r,
22
+ onChange: h,
23
+ children: v,
24
+ ...y
25
+ } = c, { value: w, setValue: N } = C({ name: a, initialValue: m, onChange: h }), e = D({
26
+ isDisabled: s,
27
+ validationStatus: o
28
+ });
29
+ return /* @__PURE__ */ t(
30
+ I,
31
+ {
32
+ id: r,
33
+ label: u,
34
+ description: b,
35
+ dataName: "TextField",
36
+ dataTestId: g,
37
+ disabled: s,
38
+ validationStatus: o,
39
+ errorMessage: x,
40
+ children: /* @__PURE__ */ d(
41
+ "div",
42
+ {
43
+ className: l("relative rounded-pill z-0", {
44
+ "bg-white": e !== "disabled",
45
+ "bg-pearl": e === "disabled"
46
+ }),
47
+ children: [
48
+ /* @__PURE__ */ t(
49
+ "select",
50
+ {
51
+ ...y,
52
+ id: r,
53
+ name: a,
54
+ disabled: s,
55
+ value: w,
56
+ onChange: (k) => N(k.target.value),
57
+ className: l(
58
+ "text-b3 rounded-pill w-full border px-20 py-12 font-normal outline-none appearance-none bg-transparent",
59
+ {
60
+ "border-lightGrey focus:border-black active:border-black pe-[52px]": e === "default",
61
+ "pe-[84px]": e === "error" || e === "success",
62
+ "text-black": e !== "disabled",
63
+ "text-grey": e === "disabled",
64
+ "border-red": e === "error",
65
+ "border-green": e === "success"
66
+ },
67
+ f
68
+ ),
69
+ "aria-label": a,
70
+ children: v
71
+ }
72
+ ),
73
+ /* @__PURE__ */ t(
74
+ "div",
75
+ {
76
+ className: l(
77
+ "pointer-events-none absolute inset-0 flex items-center justify-between px-20 py-12 -z-1",
78
+ {
79
+ "text-grey": e === "disabled",
80
+ "text-red": e === "error",
81
+ "text-green": e === "success"
82
+ }
83
+ ),
84
+ children: /* @__PURE__ */ d("span", { className: "ms-auto flex gap-x-8", children: [
85
+ e === "error" && /* @__PURE__ */ t(n, { name: "CrossDefault", width: "24px", type: i }),
86
+ e === "success" && /* @__PURE__ */ t(n, { name: "CheckDefault", width: "24px", type: i }),
87
+ /* @__PURE__ */ t("button", { className: "pointer-events-auto inline-flex", children: /* @__PURE__ */ t(n, { name: "ArrowDefaultDown", type: "svg", width: "24px", color: "black" }) })
88
+ ] })
89
+ }
90
+ )
91
+ ]
92
+ }
93
+ )
94
+ }
95
+ );
96
+ };
97
+ export {
98
+ $ as Select
99
+ };
@@ -2,4 +2,4 @@ import { FormControlProps } from './FormControl.js';
2
2
  export interface SwitchProps extends FormControlProps<boolean> {
3
3
  width?: number;
4
4
  }
5
- export declare function Switch({ id, name, className, checked: initialChecked, disabled, width, onChange, tabIndex, children, }: SwitchProps): import("react/jsx-runtime").JSX.Element;
5
+ export declare function Switch(props: SwitchProps): import("react/jsx-runtime").JSX.Element;
@@ -1,30 +1,30 @@
1
1
  import { jsxs as l, jsx as e } from "react/jsx-runtime";
2
- import { c as m } from "../../index-Cu0xwYjD.js";
3
- import { useValue as x } from "../../hooks/useValue.js";
2
+ import { c as x } from "../../index-Cu0xwYjD.js";
3
+ import { useValue as f } from "../../hooks/useValue.js";
4
4
  import "../../controls-l0sNRNKZ.js";
5
- let f = 0;
6
- function d({
7
- id: a = `switch-${++f}`,
8
- name: r = a,
9
- className: s,
10
- checked: o,
11
- disabled: c,
12
- width: t = 56,
13
- onChange: n,
14
- tabIndex: h = 0,
15
- children: p
16
- }) {
17
- const { value: i, setValue: u } = x({
18
- initialValue: o,
19
- name: r,
20
- onChange: n
5
+ import { useId as w } from "react";
6
+ function k(r) {
7
+ const s = w(), {
8
+ id: n = s,
9
+ name: a = n,
10
+ className: o,
11
+ checked: h,
12
+ disabled: t,
13
+ width: i = 56,
14
+ onChange: d,
15
+ tabIndex: m = 0,
16
+ children: p
17
+ } = r, { value: c, setValue: u } = f({
18
+ initialValue: h,
19
+ name: a,
20
+ onChange: d
21
21
  });
22
22
  return /* @__PURE__ */ l(
23
23
  "label",
24
24
  {
25
- className: m(s, "relative flex items-center gap-[10px]", {
26
- "text-grey": c,
27
- "cursor-pointer": !c
25
+ className: x(o, "relative flex items-center gap-[10px]", {
26
+ "text-grey": t,
27
+ "cursor-pointer": !t
28
28
  }),
29
29
  "data-testid": "SwitchContainer",
30
30
  children: [
@@ -33,19 +33,19 @@ function d({
33
33
  "input",
34
34
  {
35
35
  type: "checkbox",
36
- name: r,
37
- tabIndex: h,
38
- checked: i,
39
- disabled: c,
36
+ name: a,
37
+ tabIndex: m,
38
+ checked: c,
39
+ disabled: t,
40
40
  role: "switch",
41
41
  className: "absolute w-full h-full opacity-0 cursor-pointer",
42
42
  onChange: () => {
43
- !c && u(!i);
43
+ !t && u(!c);
44
44
  },
45
45
  "data-name": "Switch"
46
46
  }
47
47
  ),
48
- /* @__PURE__ */ e("span", { style: { height: t * 4 / 7, width: t }, children: /* @__PURE__ */ e("svg", { viewBox: "0 0 24 24", width: t * 3 / 7, children: /* @__PURE__ */ l("g", { children: [
48
+ /* @__PURE__ */ e("span", { style: { height: i * 4 / 7, width: i }, children: /* @__PURE__ */ e("svg", { viewBox: "0 0 24 24", width: i * 3 / 7, children: /* @__PURE__ */ l("g", { children: [
49
49
  /* @__PURE__ */ e("circle", { cx: 12, cy: 12, r: 12, fill: "hsl(var(--color-white))" }),
50
50
  /* @__PURE__ */ e("circle", { cx: 12, cy: 12, r: 4, fill: "hsl(var(--color-grey))" })
51
51
  ] }) }) })
@@ -56,5 +56,5 @@ function d({
56
56
  );
57
57
  }
58
58
  export {
59
- d as Switch
59
+ k as Switch
60
60
  };
@@ -5,7 +5,6 @@ export interface TextFieldProps<Value> extends FormControlProps<Value> {
5
5
  * Description text
6
6
  */
7
7
  description?: string;
8
- hasDropdown?: boolean;
9
8
  icon?: IconicNames;
10
9
  iconType?: IconicTypes;
11
10
  errorMessage?: string;
@@ -1,74 +1,72 @@
1
- import { jsx as t, jsxs as d } from "react/jsx-runtime";
2
- import { c as p } from "../../index-Cu0xwYjD.js";
3
- import { useValue as k } from "../../hooks/useValue.js";
4
- import { useInternalStatus as C } from "../../hooks/useInternalStatus.js";
5
- import { FormControl as T } from "./FormControl.js";
6
- import { Icon as r } from "../../atoms/Icons/Icon.js";
1
+ import { jsx as t, jsxs as o } from "react/jsx-runtime";
2
+ import { c } from "../../index-Cu0xwYjD.js";
3
+ import { useValue as I } from "../../hooks/useValue.js";
4
+ import { useInternalStatus as T } from "../../hooks/useInternalStatus.js";
5
+ import { FormControl as k } from "./FormControl.js";
6
+ import { Icon as i } from "../../atoms/Icons/Icon.js";
7
7
  import "../../atoms/Icons/contexts/IconsContext.js";
8
- let F = 0;
9
- const $ = (u) => {
10
- const {
11
- id: a = `text-field-${++F}`,
12
- name: s = a,
13
- label: m,
8
+ import { useId as F } from "react";
9
+ const A = (m) => {
10
+ const p = F(), {
11
+ id: r = p,
12
+ name: a = r,
13
+ label: u,
14
14
  value: x,
15
15
  description: b,
16
- validationStatus: c = "default",
17
- hasDropdown: l = !1,
18
- icon: o,
19
- iconType: i,
16
+ validationStatus: n = "default",
17
+ icon: s,
18
+ iconType: d,
20
19
  errorMessage: f,
21
- disabled: n = !1,
22
- className: h,
23
- dataTestId: g = "TextField",
20
+ disabled: l = !1,
21
+ className: g,
22
+ dataTestId: h = "TextField",
24
23
  onChange: v,
25
- ...w
26
- } = u, { value: y, setValue: N } = k({ name: s, initialValue: x, onChange: v }), e = C({
27
- isDisabled: n,
28
- validationStatus: c
24
+ ...y
25
+ } = m, { value: w, setValue: N } = I({ name: a, initialValue: x, onChange: v }), e = T({
26
+ isDisabled: l,
27
+ validationStatus: n
29
28
  });
30
29
  return /* @__PURE__ */ t(
31
- T,
30
+ k,
32
31
  {
33
- id: a,
34
- label: m,
32
+ id: r,
33
+ label: u,
35
34
  description: b,
36
35
  dataName: "TextField",
37
- dataTestId: g,
38
- disabled: n,
39
- validationStatus: c,
36
+ dataTestId: h,
37
+ disabled: l,
38
+ validationStatus: n,
40
39
  errorMessage: f,
41
- children: /* @__PURE__ */ d("div", { className: "relative", children: [
40
+ children: /* @__PURE__ */ o("div", { className: "relative", children: [
42
41
  /* @__PURE__ */ t(
43
42
  "input",
44
43
  {
45
- ...w,
46
- id: a,
47
- name: s,
48
- disabled: n,
49
- value: y,
50
- onChange: (D) => N(D.target.value),
51
- className: p(
44
+ ...y,
45
+ id: r,
46
+ name: a,
47
+ disabled: l,
48
+ value: w,
49
+ onChange: (C) => N(C.target.value),
50
+ className: c(
52
51
  "text-b3 rounded-pill w-full border px-20 py-12 font-normal outline-none",
53
52
  {
54
53
  "border-lightGrey focus:border-black active:border-black": e === "default",
55
- "ps-[52px]": o,
56
- "pe-[52px]": l || e === "error" || e === "success",
57
- "pe-[84px]": l && (e === "error" || e === "success"),
54
+ "ps-[52px]": s,
55
+ "pe-[52px]": e === "error" || e === "success",
58
56
  "bg-white text-black": e !== "disabled",
59
57
  "bg-pearl text-grey": e === "disabled",
60
58
  "border-red": e === "error",
61
59
  "border-green": e === "success"
62
60
  },
63
- h
61
+ g
64
62
  ),
65
- "aria-label": s
63
+ "aria-label": a
66
64
  }
67
65
  ),
68
- /* @__PURE__ */ d(
66
+ /* @__PURE__ */ o(
69
67
  "div",
70
68
  {
71
- className: p(
69
+ className: c(
72
70
  "pointer-events-none absolute inset-0 flex items-center justify-between px-20 py-12",
73
71
  {
74
72
  "text-grey": e === "disabled",
@@ -77,11 +75,10 @@ const $ = (u) => {
77
75
  }
78
76
  ),
79
77
  children: [
80
- o && /* @__PURE__ */ t(r, { name: o, width: "24px" }),
81
- /* @__PURE__ */ d("span", { className: "ms-auto flex gap-x-8", children: [
82
- e === "error" && /* @__PURE__ */ t(r, { name: "CrossDefault", width: "24px", type: i }),
83
- e === "success" && /* @__PURE__ */ t(r, { name: "CheckDefault", width: "24px", type: i }),
84
- l && /* @__PURE__ */ t("button", { className: "pointer-events-auto", children: /* @__PURE__ */ t(r, { name: "ArrowDefaultDown", width: "24px", color: "black", type: i }) })
78
+ s && /* @__PURE__ */ t(i, { name: s, width: "24px" }),
79
+ /* @__PURE__ */ o("span", { className: "ms-auto flex gap-x-8", children: [
80
+ e === "error" && /* @__PURE__ */ t(i, { name: "CrossDefault", width: "24px", type: d }),
81
+ e === "success" && /* @__PURE__ */ t(i, { name: "CheckDefault", width: "24px", type: d })
85
82
  ] })
86
83
  ]
87
84
  }
@@ -91,5 +88,5 @@ const $ = (u) => {
91
88
  );
92
89
  };
93
90
  export {
94
- $ as TextField
91
+ A as TextField
95
92
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@clubmed/trident-ui",
3
- "version": "1.0.0-beta.4",
3
+ "version": "1.0.0-beta.6",
4
4
  "type": "module",
5
5
  "description": "Shared ClubMed React UI components",
6
6
  "keywords": [
@@ -84,6 +84,10 @@
84
84
  appearance: none;
85
85
  }
86
86
 
87
+ select:invalid {
88
+ @apply text-middleGrey;
89
+ }
90
+
87
91
  .date-field {
88
92
  @apply appearance-none;
89
93
  }