@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.
- package/README.md +15 -0
- package/assets/Appearance/dark/mode/Component_DarkMode.module.css +2 -0
- package/assets/Appearance/light/mode/Component_LightMode.module.css +2 -0
- package/assets/Appearance/pureDark/mode/Component_PureDarkMode.module.css +2 -0
- package/es/CheckBox/CheckBox.js +21 -10
- package/es/CheckBox/CheckBox.module.css +21 -6
- package/es/CheckBox/__tests__/CheckBox.spec.js +9 -0
- package/es/CheckBox/__tests__/__snapshots__/CheckBox.spec.js.snap +162 -93
- package/es/CheckBox/props/propTypes.js +4 -1
- package/es/Label/Label.js +19 -1
- package/es/Label/__tests__/Label.spec.js +58 -0
- package/es/Label/__tests__/__snapshots__/Label.spec.js.snap +66 -0
- package/es/Label/props/defaultProps.js +1 -0
- package/es/Label/props/propTypes.js +7 -1
- package/es/ListItem/__tests__/__snapshots__/ListItemWithCheckBox.spec.js.snap +7 -7
- package/es/ListItem/__tests__/__snapshots__/ListItemWithRadio.spec.js.snap +7 -7
- package/es/Radio/Radio.js +20 -9
- package/es/Radio/Radio.module.css +38 -5
- package/es/Radio/__tests__/Radio.spec.js +10 -0
- package/es/Radio/__tests__/__snapshots__/Radio.spec.js.snap +154 -81
- package/es/Radio/props/propTypes.js +4 -1
- package/es/Tag/Tag.js +5 -2
- package/es/Tag/props/propTypes.js +2 -0
- package/lib/CheckBox/CheckBox.js +23 -9
- package/lib/CheckBox/CheckBox.module.css +21 -6
- package/lib/CheckBox/__tests__/CheckBox.spec.js +21 -12
- package/lib/CheckBox/__tests__/__snapshots__/CheckBox.spec.js.snap +162 -93
- package/lib/CheckBox/props/propTypes.js +5 -1
- package/lib/Label/Label.js +21 -1
- package/lib/Label/__tests__/Label.spec.js +58 -0
- package/lib/Label/__tests__/__snapshots__/Label.spec.js.snap +66 -0
- package/lib/Label/props/defaultProps.js +1 -0
- package/lib/Label/props/propTypes.js +8 -1
- package/lib/ListItem/__tests__/__snapshots__/ListItemWithCheckBox.spec.js.snap +7 -7
- package/lib/ListItem/__tests__/__snapshots__/ListItemWithRadio.spec.js.snap +7 -7
- package/lib/Radio/Radio.js +22 -8
- package/lib/Radio/Radio.module.css +38 -5
- package/lib/Radio/__tests__/Radio.spec.js +10 -0
- package/lib/Radio/__tests__/__snapshots__/Radio.spec.js.snap +154 -81
- package/lib/Radio/props/propTypes.js +5 -1
- package/lib/Tag/Tag.js +6 -2
- package/lib/Tag/props/propTypes.js +2 -0
- 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)));
|
package/es/CheckBox/CheckBox.js
CHANGED
|
@@ -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.
|
|
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
|
-
|
|
159
|
-
|
|
163
|
+
${checked && active ? `${style[`checked${palette}Label`]}` : ''}
|
|
164
|
+
${accessMode} ${customLabel}`,
|
|
160
165
|
title: toolTip ? toolTip : text,
|
|
161
166
|
...LabelProps
|
|
162
|
-
})
|
|
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
|