@zohodesk/components 1.5.2 → 1.5.4

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 (43) hide show
  1. package/README.md +15 -0
  2. package/assets/Appearance/dark/mode/Component_DarkMode.module.css +2 -0
  3. package/assets/Appearance/light/mode/Component_LightMode.module.css +2 -0
  4. package/assets/Appearance/pureDark/mode/Component_PureDarkMode.module.css +2 -0
  5. package/es/CheckBox/CheckBox.js +21 -10
  6. package/es/CheckBox/CheckBox.module.css +21 -6
  7. package/es/CheckBox/__tests__/CheckBox.spec.js +9 -0
  8. package/es/CheckBox/__tests__/__snapshots__/CheckBox.spec.js.snap +162 -93
  9. package/es/CheckBox/props/propTypes.js +4 -1
  10. package/es/Label/Label.js +19 -1
  11. package/es/Label/__tests__/Label.spec.js +58 -0
  12. package/es/Label/__tests__/__snapshots__/Label.spec.js.snap +66 -0
  13. package/es/Label/props/defaultProps.js +1 -0
  14. package/es/Label/props/propTypes.js +7 -1
  15. package/es/ListItem/__tests__/__snapshots__/ListItemWithCheckBox.spec.js.snap +7 -7
  16. package/es/ListItem/__tests__/__snapshots__/ListItemWithRadio.spec.js.snap +7 -7
  17. package/es/Radio/Radio.js +20 -9
  18. package/es/Radio/Radio.module.css +38 -5
  19. package/es/Radio/__tests__/Radio.spec.js +10 -0
  20. package/es/Radio/__tests__/__snapshots__/Radio.spec.js.snap +154 -81
  21. package/es/Radio/props/propTypes.js +4 -1
  22. package/es/Tag/Tag.js +5 -2
  23. package/es/Tag/props/propTypes.js +2 -0
  24. package/lib/CheckBox/CheckBox.js +23 -9
  25. package/lib/CheckBox/CheckBox.module.css +21 -6
  26. package/lib/CheckBox/__tests__/CheckBox.spec.js +21 -12
  27. package/lib/CheckBox/__tests__/__snapshots__/CheckBox.spec.js.snap +162 -93
  28. package/lib/CheckBox/props/propTypes.js +5 -1
  29. package/lib/Label/Label.js +21 -1
  30. package/lib/Label/__tests__/Label.spec.js +58 -0
  31. package/lib/Label/__tests__/__snapshots__/Label.spec.js.snap +66 -0
  32. package/lib/Label/props/defaultProps.js +1 -0
  33. package/lib/Label/props/propTypes.js +8 -1
  34. package/lib/ListItem/__tests__/__snapshots__/ListItemWithCheckBox.spec.js.snap +7 -7
  35. package/lib/ListItem/__tests__/__snapshots__/ListItemWithRadio.spec.js.snap +7 -7
  36. package/lib/Radio/Radio.js +22 -8
  37. package/lib/Radio/Radio.module.css +38 -5
  38. package/lib/Radio/__tests__/Radio.spec.js +10 -0
  39. package/lib/Radio/__tests__/__snapshots__/Radio.spec.js.snap +154 -81
  40. package/lib/Radio/props/propTypes.js +5 -1
  41. package/lib/Tag/Tag.js +6 -2
  42. package/lib/Tag/props/propTypes.js +2 -0
  43. package/package.json +9 -9
package/README.md CHANGED
@@ -2,6 +2,21 @@
2
2
 
3
3
  Dot UI is a customizable React component library built to deliver a clean, accessible, and developer-friendly UI experience. It offers a growing set of reusable components designed to align with modern design systems and streamline application development across projects.
4
4
 
5
+ # 1.5.4
6
+
7
+ - **Tag**
8
+ - Added support for rendering left & right custom children using `renderLeftChildren`,`renderRightChildren` prop.
9
+
10
+ # 1.5.3
11
+
12
+ - **CheckBox, Radio**
13
+ - `secondaryText` prop supported to render secondary value next to the control.
14
+ - `customSecondaryText` key supported under `customClass` prop to customize secondary text styling.
15
+
16
+ - **Label**
17
+ - `renderRightPlaceholderNode` prop supported to render elements after the label text.
18
+ - `customProps` prop supported to pass additional props through `containerProps` & `rightPlaceholderNodeProps`.
19
+
5
20
  # 1.5.2
6
21
 
7
22
  - **TextBoxIcon**
@@ -95,6 +95,7 @@
95
95
  --zdt_checkbox_danger_stroke_border: hsla(0, 100.00%, calc(70.98% + var(--zdc_default_inverse_lower)), calc(1 + var(--zdc_alpha_low)));
96
96
  --zdt_checkbox_label_primary_text: var(--zdt_cta_primary_text);
97
97
  --zdt_checkbox_label_danger_text: hsla(0, 100.00%, calc(70.98% + var(--zdc_default_inverse_lower)), calc(1 + var(--zdc_alpha_low)));
98
+ --zdt_checkbox_secondary_text: hsla(217, 7.76%, calc(54.51% + var(--zdc_default_inverse)), calc(1 + var(--zdc_alpha_high)));
98
99
 
99
100
  /* dropbox */
100
101
  --zdt_dropbox_default_bg: hsla(217, 23.08%, calc(17.84% + var(--zdc_default)), calc(1 + var(--zdc_alpha_high)));
@@ -170,6 +171,7 @@
170
171
  --zdt_radio_danger_fill: hsla(0, 100.00%, calc(70.98% + var(--zdc_default_inverse_lower)), calc(1 + var(--zdc_alpha_low)));
171
172
  --zdt_radio_label_primary_text: var(--zdt_cta_primary_text);
172
173
  --zdt_radio_label_danger_text: hsla(0, 100.00%, calc(70.98% + var(--zdc_default_inverse_lower)), calc(1 + var(--zdc_alpha_low)));
174
+ --zdt_radio_secondary_text: hsla(217, 7.76%, calc(54.51% + var(--zdc_default_inverse)), calc(1 + var(--zdc_alpha_high)));
173
175
 
174
176
  /* listitem */
175
177
  --zdt_listitem_default_text: hsla(210, 7.41%, calc(89.41% + var(--zdc_default_inverse)), calc(1 + var(--zdc_alpha_high)));
@@ -95,6 +95,7 @@
95
95
  --zdt_checkbox_danger_stroke_border: hsla(0, 71.91%, calc(53.92% + var(--zdc_default_inverse_lower)), calc(1 + var(--zdc_alpha_low)));
96
96
  --zdt_checkbox_label_primary_text: var(--zdt_cta_primary_text);
97
97
  --zdt_checkbox_label_danger_text: hsla(0, 71.91%, calc(53.92% + var(--zdc_default_inverse_lower)), calc(1 + var(--zdc_alpha_low)));
98
+ --zdt_checkbox_secondary_text: hsla(218, 9.76%, calc(51.76% + var(--zdc_default_inverse)), calc(1 + var(--zdc_alpha_high)));
98
99
 
99
100
  /* dropbox */
100
101
  --zdt_dropbox_default_bg: hsla(0, 0.00%, calc(100.00% + var(--zdc_default)), calc(1 + var(--zdc_alpha_high)));
@@ -170,6 +171,7 @@
170
171
  --zdt_radio_danger_fill: hsla(0, 71.91%, calc(53.92% + var(--zdc_default_inverse_lower)), calc(1 + var(--zdc_alpha_low)));
171
172
  --zdt_radio_label_primary_text: var(--zdt_cta_primary_text);
172
173
  --zdt_radio_label_danger_text: hsla(0, 71.91%, calc(53.92% + var(--zdc_default_inverse_lower)), calc(1 + var(--zdc_alpha_low)));
174
+ --zdt_radio_secondary_text: hsla(218, 9.76%, calc(51.76% + var(--zdc_default_inverse)), calc(1 + var(--zdc_alpha_high)));
173
175
 
174
176
  /* listitem */
175
177
  --zdt_listitem_default_text: hsla(0, 0.00%, calc(0.00% + var(--zdc_default_inverse)), calc(1 + var(--zdc_alpha_high)));
@@ -95,6 +95,7 @@
95
95
  --zdt_checkbox_danger_stroke_border: hsla(0, 100.00%, calc(70.98% + var(--zdc_default_inverse_lower)), calc(1 + var(--zdc_alpha_low)));
96
96
  --zdt_checkbox_label_primary_text: var(--zdt_cta_primary_text);
97
97
  --zdt_checkbox_label_danger_text: hsla(0, 100.00%, calc(70.98% + var(--zdc_default_inverse_lower)), calc(1 + var(--zdc_alpha_low)));
98
+ --zdt_checkbox_secondary_text: hsla(217, 7.76%, calc(54.51% + var(--zdc_default_inverse)), calc(1 + var(--zdc_alpha_high)));
98
99
 
99
100
  /* dropbox */
100
101
  --zdt_dropbox_default_bg: hsla(0, 0.00%, calc(12.94% + var(--zdc_default)), calc(1 + var(--zdc_alpha_high)));
@@ -170,6 +171,7 @@
170
171
  --zdt_radio_danger_fill: hsla(0, 100.00%, calc(70.98% + var(--zdc_default_inverse_lower)), calc(1 + var(--zdc_alpha_low)));
171
172
  --zdt_radio_label_primary_text: var(--zdt_cta_primary_text);
172
173
  --zdt_radio_label_danger_text: hsla(0, 100.00%, calc(70.98% + var(--zdc_default_inverse_lower)), calc(1 + var(--zdc_alpha_low)));
174
+ --zdt_radio_secondary_text: hsla(217, 7.76%, calc(54.51% + var(--zdc_default_inverse)), calc(1 + var(--zdc_alpha_high)));
173
175
 
174
176
  /* listitem */
175
177
  --zdt_listitem_default_text: hsla(210, 7.41%, calc(89.41% + var(--zdc_default_inverse)), calc(1 + var(--zdc_alpha_high)));
@@ -2,6 +2,7 @@ import React from 'react';
2
2
  import { propTypes } from "./props/propTypes";
3
3
  import { defaultProps } from "./props/defaultProps";
4
4
  import Label from "../Label/Label";
5
+ import Typography from "../Typography/Typography";
5
6
  import { Container, Box } from "../Layout";
6
7
  import CssProvider from "../Provider/CssProvider";
7
8
  import style from "./CheckBox.module.css";
@@ -53,17 +54,20 @@ export default class CheckBox extends React.Component {
53
54
  customClass,
54
55
  customProps,
55
56
  dataSelectorId,
56
- renderRightPlaceholderNode
57
+ renderRightPlaceholderNode,
58
+ secondaryText
57
59
  } = this.props;
58
60
  let {
59
61
  CheckBoxProps = {},
60
- LabelProps = {}
62
+ LabelProps = {},
63
+ secondaryTextProps = {}
61
64
  } = customProps;
62
65
  let {
63
66
  customCheckBox = '',
64
67
  customLabel = '',
65
68
  customCBoxSize = '',
66
- customTickSize = ''
69
+ customTickSize = '',
70
+ customSecondaryText = ''
67
71
  } = customClass;
68
72
  let accessMode = isReadOnly ? style.readonly : disabled ? CssProvider('isDisabled') : style.pointer;
69
73
  let toolTip = disabled ? disabledTitle : title ? title : null;
@@ -95,7 +99,8 @@ export default class CheckBox extends React.Component {
95
99
  dataSelectorId: dataSelectorId || id,
96
100
  ...CheckBoxProps
97
101
  }, /*#__PURE__*/React.createElement(Box, {
98
- className: `${style.boxContainer} ${style[size]} ${customCBoxSize} ${isFilled ? style.filled : ''} ${!isEditable ? `${style[`disabled`]}` : ''}`
102
+ className: `${style.boxContainer} ${secondaryText ? style.withSecondaryText : ''} ${style[size]} ${customCBoxSize} ${isFilled ? style.filled : ''} ${!isEditable ? `${style[`disabled`]}` : ''}`,
103
+ align: secondaryText ? "start" : undefined
99
104
  }, /*#__PURE__*/React.createElement("input", {
100
105
  type: "hidden",
101
106
  id: id,
@@ -143,10 +148,10 @@ export default class CheckBox extends React.Component {
143
148
  y1: "20",
144
149
  x2: "28.53",
145
150
  y2: "20"
146
- }) : null))), text && /*#__PURE__*/React.createElement(Box, {
151
+ }) : null))), (text || secondaryText) && /*#__PURE__*/React.createElement(Box, {
147
152
  flexible: true,
148
- className: style.text
149
- }, /*#__PURE__*/React.createElement(Label, {
153
+ className: style.labelContainer
154
+ }, text && /*#__PURE__*/React.createElement(Label, {
150
155
  text: text,
151
156
  palette: disabled ? 'disable' : labelPalette,
152
157
  id: id,
@@ -155,11 +160,17 @@ export default class CheckBox extends React.Component {
155
160
  clipped: isClipped,
156
161
  variant: variant,
157
162
  customClass: `${active && !disabled ? `${style[`active${palette}Label`]}` : ''}
158
- ${checked && active ? `${style[`checked${palette}Label`]}` : ''}
159
- ${accessMode} ${customLabel}`,
163
+ ${checked && active ? `${style[`checked${palette}Label`]}` : ''}
164
+ ${accessMode} ${customLabel}`,
160
165
  title: toolTip ? toolTip : text,
161
166
  ...LabelProps
162
- })), renderRightPlaceholderNode ? renderRightPlaceholderNode : null);
167
+ }), secondaryText ? /*#__PURE__*/React.createElement(Typography, {
168
+ $ui_size: "12",
169
+ $ui_lineHeight: "1.2",
170
+ ...secondaryTextProps,
171
+ $i18n_dataTitle: toolTip ? null : secondaryText,
172
+ $ui_className: `${style.secondaryText} ${customSecondaryText}`
173
+ }, secondaryText) : null), renderRightPlaceholderNode ? renderRightPlaceholderNode : null);
163
174
  }
164
175
 
165
176
  }
@@ -90,12 +90,6 @@
90
90
  [dir=rtl] .linePath {
91
91
  animation: lineAnimate var(--zd_transition3) ease forwards;
92
92
  }
93
- [dir=ltr] .text {
94
- margin-left: var(--zd_size6) ;
95
- }
96
- [dir=rtl] .text {
97
- margin-right: var(--zd_size6) ;
98
- }
99
93
 
100
94
  .checkedprimary,
101
95
  .checkeddanger {
@@ -141,6 +135,27 @@
141
135
  .disabled {
142
136
  opacity: 0.7
143
137
  }
138
+
139
+ .withSecondaryText {
140
+ margin-top: var(--zd_size1) ;
141
+ }
142
+
143
+ .secondaryText {
144
+ color: var(--zdt_checkbox_secondary_text);
145
+ }
146
+
147
+ .labelContainer {
148
+ composes: dflex flexcolumn from '../common/common.module.css';
149
+ gap: var(--zd_size4) ;
150
+ }
151
+
152
+ [dir=ltr] .labelContainer {
153
+ margin-left: var(--zd_size6) ;
154
+ }
155
+
156
+ [dir=rtl] .labelContainer {
157
+ margin-right: var(--zd_size6) ;
158
+ }
144
159
  @keyframes tickAnimate {
145
160
  0% {
146
161
  stroke-dashoffset: 40;
@@ -160,6 +160,15 @@ describe('CheckBox component', () => {
160
160
  }));
161
161
  expect(asFragment()).toMatchSnapshot();
162
162
  });
163
+ test('Should render secondaryText', () => {
164
+ const {
165
+ asFragment
166
+ } = render( /*#__PURE__*/React.createElement(CheckBox, {
167
+ text: "checkboxText",
168
+ secondaryText: "secondaryText"
169
+ }));
170
+ expect(asFragment()).toMatchSnapshot();
171
+ });
163
172
  test('Should be render activeStyle is minus', () => {
164
173
  const {
165
174
  asFragment