@veracity/vui 0.0.15 → 0.2.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 (195) hide show
  1. package/avatar/avatar.js +2 -2
  2. package/box/box.js +1 -1
  3. package/button/button.d.ts +7 -1
  4. package/button/button.js +56 -23
  5. package/button/button.types.d.ts +8 -6
  6. package/button/buttonIcon.d.ts +3 -0
  7. package/{alert/alertText.js → button/buttonIcon.js} +9 -9
  8. package/button/buttonText.d.ts +3 -0
  9. package/button/buttonText.js +30 -0
  10. package/button/buttons.d.ts +4 -3
  11. package/button/buttons.js +4 -3
  12. package/button/consts.js +3 -2
  13. package/button/context.d.ts +2 -2
  14. package/button/context.js +4 -4
  15. package/button/index.d.ts +2 -2
  16. package/button/index.js +2 -2
  17. package/button/theme.d.ts +79 -41
  18. package/button/theme.js +85 -46
  19. package/{button → buttonGroup}/buttonGroup.d.ts +3 -1
  20. package/{button → buttonGroup}/buttonGroup.js +4 -2
  21. package/buttonGroup/context.d.ts +4 -0
  22. package/buttonGroup/context.js +23 -0
  23. package/buttonGroup/helpers.d.ts +3 -0
  24. package/buttonGroup/helpers.js +10 -0
  25. package/buttonGroup/index.d.ts +4 -0
  26. package/{alert → buttonGroup}/index.js +4 -8
  27. package/card/card.d.ts +3 -0
  28. package/{tile/tile.js → card/card.js} +8 -7
  29. package/{tile/tile.types.d.ts → card/card.types.d.ts} +1 -1
  30. package/card/index.d.ts +3 -0
  31. package/{tile → card}/index.js +4 -4
  32. package/card/theme.d.ts +6 -0
  33. package/card/theme.js +10 -0
  34. package/checkbox/checkbox.js +4 -4
  35. package/checkbox/checkbox.types.d.ts +1 -1
  36. package/checkbox/checkboxGroup.types.d.ts +1 -1
  37. package/core/globalStyle.d.ts +4 -1
  38. package/core/globalStyle.js +7 -3
  39. package/core/index.d.ts +2 -0
  40. package/core/index.js +5 -1
  41. package/core/styled.d.ts +4 -0
  42. package/core/styled.js +80 -0
  43. package/core/types/component.d.ts +12 -12
  44. package/core/types/index.d.ts +1 -0
  45. package/core/types/index.js +1 -0
  46. package/core/types/styled.d.ts +11 -0
  47. package/core/utils.d.ts +2 -2
  48. package/core/utils.js +7 -7
  49. package/core/v.d.ts +182 -0
  50. package/core/v.js +6 -0
  51. package/core/vuiProvider.d.ts +13 -2
  52. package/core/vuiProvider.js +1 -1
  53. package/divider/divider.types.d.ts +1 -1
  54. package/heading/heading.types.d.ts +2 -1
  55. package/icon/helpers.d.ts +2 -3
  56. package/icon/helpers.js +6 -8
  57. package/icon/icon.js +3 -2
  58. package/icon/icon.types.d.ts +4 -2
  59. package/icons/library.js +1 -1
  60. package/icons/types.d.ts +1 -1
  61. package/image/image.d.ts +3 -0
  62. package/image/image.js +38 -0
  63. package/image/image.types.d.ts +5 -0
  64. package/image/index.d.ts +3 -0
  65. package/{label → image}/index.js +4 -4
  66. package/image/theme.d.ts +6 -0
  67. package/image/theme.js +10 -0
  68. package/index.d.ts +6 -3
  69. package/index.js +6 -3
  70. package/input/context.d.ts +4 -0
  71. package/{alert → input}/context.js +4 -4
  72. package/input/index.d.ts +2 -0
  73. package/input/index.js +2 -0
  74. package/input/input.d.ts +7 -2
  75. package/input/input.js +33 -22
  76. package/input/input.types.d.ts +7 -3
  77. package/input/inputIcon.d.ts +3 -0
  78. package/input/inputIcon.js +30 -0
  79. package/input/inputInput.d.ts +5 -0
  80. package/input/inputInput.js +36 -0
  81. package/input/theme.d.ts +40 -15
  82. package/input/theme.js +40 -16
  83. package/list/index.d.ts +3 -1
  84. package/list/index.js +3 -1
  85. package/list/list.d.ts +2 -0
  86. package/list/list.js +3 -1
  87. package/list/list.types.d.ts +19 -1
  88. package/list/listHeading.d.ts +2 -2
  89. package/list/listHeading.js +2 -2
  90. package/list/listIcon.js +1 -1
  91. package/list/listItem.d.ts +1 -1
  92. package/list/listItem.js +8 -5
  93. package/list/listText.d.ts +3 -0
  94. package/list/listText.js +30 -0
  95. package/list/theme.d.ts +20 -6
  96. package/list/theme.js +26 -12
  97. package/notification/consts.d.ts +2 -0
  98. package/{alert → notification}/consts.js +7 -7
  99. package/notification/context.d.ts +4 -0
  100. package/notification/context.js +23 -0
  101. package/notification/index.d.ts +8 -0
  102. package/notification/index.js +25 -0
  103. package/notification/notification.d.ts +13 -0
  104. package/{alert/alert.js → notification/notification.js} +25 -25
  105. package/notification/notification.types.d.ts +20 -0
  106. package/notification/notificationButton.d.ts +3 -0
  107. package/{alert/alertButton.js → notification/notificationButton.js} +8 -8
  108. package/notification/notificationIcon.d.ts +3 -0
  109. package/{alert/alertIcon.js → notification/notificationIcon.js} +9 -9
  110. package/notification/notificationText.d.ts +3 -0
  111. package/notification/notificationText.js +30 -0
  112. package/notification/notificationTitle.d.ts +3 -0
  113. package/notification/notificationTitle.js +30 -0
  114. package/{alert → notification}/theme.d.ts +0 -15
  115. package/{alert → notification}/theme.js +1 -22
  116. package/package.json +2 -3
  117. package/panel/index.d.ts +3 -0
  118. package/panel/index.js +20 -0
  119. package/panel/panel.d.ts +3 -0
  120. package/panel/panel.js +39 -0
  121. package/panel/panel.types.d.ts +4 -0
  122. package/{tile → panel}/theme.d.ts +1 -8
  123. package/{tile → panel}/theme.js +4 -11
  124. package/radio/radio.js +4 -4
  125. package/radio/radio.types.d.ts +1 -1
  126. package/radio/radioGroup.types.d.ts +1 -1
  127. package/skeleton/skeleton.types.d.ts +1 -0
  128. package/spinner/spinner.types.d.ts +1 -0
  129. package/svg/cache.js +1 -5
  130. package/svg/svg.js +2 -3
  131. package/switch/index.d.ts +0 -1
  132. package/switch/index.js +0 -1
  133. package/switch/switch.js +6 -6
  134. package/switch/switch.types.d.ts +19 -4
  135. package/switch/switchButton.d.ts +2 -2
  136. package/switch/switchButton.js +18 -19
  137. package/switch/theme.d.ts +41 -46
  138. package/switch/theme.js +50 -72
  139. package/system/borders.d.ts +3 -1
  140. package/system/custom.d.ts +24 -7
  141. package/system/custom.js +33 -13
  142. package/system/system.d.ts +2 -2
  143. package/system/system.js +1 -1
  144. package/t/t.types.d.ts +2 -1
  145. package/tag/context.d.ts +4 -0
  146. package/tag/context.js +23 -0
  147. package/tag/index.d.ts +6 -0
  148. package/tag/index.js +23 -0
  149. package/tag/tag.d.ts +11 -0
  150. package/tag/tag.js +99 -0
  151. package/{label/label.types.d.ts → tag/tag.types.d.ts} +6 -7
  152. package/tag/tag.types.js +2 -0
  153. package/tag/tagIcon.d.ts +3 -0
  154. package/{alert/alertTitle.js → tag/tagIcon.js} +9 -9
  155. package/tag/tagText.d.ts +3 -0
  156. package/tag/tagText.js +30 -0
  157. package/tag/theme.d.ts +65 -0
  158. package/tag/theme.js +78 -0
  159. package/textarea/textarea.js +2 -1
  160. package/textarea/textarea.types.d.ts +1 -0
  161. package/theme/components.d.ts +291 -223
  162. package/theme/components.js +32 -28
  163. package/theme/defaultTheme.d.ts +291 -223
  164. package/utils/assertion.d.ts +14 -0
  165. package/utils/assertion.js +34 -0
  166. package/utils/index.d.ts +1 -0
  167. package/utils/index.js +1 -0
  168. package/utils/object.d.ts +5 -18
  169. package/utils/object.js +17 -50
  170. package/utils/types.d.ts +2 -0
  171. package/alert/alert.d.ts +0 -13
  172. package/alert/alert.types.d.ts +0 -20
  173. package/alert/alertButton.d.ts +0 -3
  174. package/alert/alertIcon.d.ts +0 -3
  175. package/alert/alertText.d.ts +0 -3
  176. package/alert/alertTitle.d.ts +0 -3
  177. package/alert/consts.d.ts +0 -2
  178. package/alert/context.d.ts +0 -4
  179. package/alert/index.d.ts +0 -8
  180. package/label/index.d.ts +0 -3
  181. package/label/label.d.ts +0 -5
  182. package/label/label.js +0 -71
  183. package/label/theme.d.ts +0 -61
  184. package/label/theme.js +0 -107
  185. package/list/listItem.types.d.ts +0 -16
  186. package/switch/switchButton.types.d.ts +0 -19
  187. package/tile/index.d.ts +0 -3
  188. package/tile/tile.d.ts +0 -3
  189. /package/{button → buttonGroup}/buttonGroup.types.d.ts +0 -0
  190. /package/{button → buttonGroup}/buttonGroup.types.js +0 -0
  191. /package/{alert/alert.types.js → card/card.types.js} +0 -0
  192. /package/{label/label.types.js → core/types/styled.js} +0 -0
  193. /package/{list/listItem.types.js → image/image.types.js} +0 -0
  194. /package/{switch/switchButton.types.js → notification/notification.types.js} +0 -0
  195. /package/{tile/tile.types.js → panel/panel.types.js} +0 -0
package/avatar/avatar.js CHANGED
@@ -58,7 +58,7 @@ exports.AvatarBase = styled_components_2.default.span.withConfig(core_1.forwardP
58
58
  function defaultGetInitials(name) {
59
59
  if (name === void 0) { name = ''; }
60
60
  var _a = __read(name.split(' '), 2), _b = _a[0], first = _b === void 0 ? '' : _b, _c = _a[1], last = _c === void 0 ? '' : _c;
61
- return "" + first.charAt(0) + last.charAt(0);
61
+ return ("" + first.charAt(0) + last.charAt(0)).toUpperCase();
62
62
  }
63
63
  exports.Avatar = core_1.vui(function (props, ref) {
64
64
  var _a = core_1.omitThemingProps(props), children = _a.children, className = _a.className, _b = _a.getInitials, getInitials = _b === void 0 ? defaultGetInitials : _b, icon = _a.icon, _c = _a.isInteractive, isInteractive = _c === void 0 ? props.onClick !== undefined : _c, isSquare = _a.isSquare, _d = _a.name, name = _d === void 0 ? '' : _d, src = _a.src, rest = __rest(_a, ["children", "className", "getInitials", "icon", "isInteractive", "isSquare", "name", "src"]);
@@ -75,7 +75,7 @@ exports.Avatar = core_1.vui(function (props, ref) {
75
75
  userSelect: 'none'
76
76
  }
77
77
  : {};
78
- return (react_1.default.createElement(exports.AvatarBase, __assign({ borderRadius: borderRadius, className: utils_1.cs('vui-avatar', className), fontWeight: "medium", h: h, ref: ref, transitionDuration: "fast", w: h }, styles, interactiveProps, rest), children ? (children) : src ? (react_1.default.createElement(AvatarImage, { borderRadius: borderRadius, src: src })) : icon ? (react_1.default.createElement(icon_1.default, { icon: icon, size: iconSize })) : initials ? (initials) : null));
78
+ return (react_1.default.createElement(exports.AvatarBase, __assign({ borderRadius: borderRadius, className: utils_1.cs('vui-avatar', className), fontWeight: "medium", h: h, ref: ref, transitionDuration: "fast", w: h }, styles, interactiveProps, rest), children ? (children) : src ? (react_1.default.createElement(AvatarImage, { borderRadius: borderRadius, src: src })) : icon ? (react_1.default.createElement(icon_1.default, { name: icon, size: iconSize })) : initials ? (initials) : null));
79
79
  });
80
80
  exports.Avatar.displayName = 'Avatar';
81
81
  exports.default = exports.Avatar;
package/box/box.js CHANGED
@@ -51,7 +51,7 @@ exports.Box = core_1.vui(function (props, ref) {
51
51
  hoverBoxShadow: hoverShadow,
52
52
  justifyContent: justify !== null && justify !== void 0 ? justify : justifyContent
53
53
  });
54
- return (react_1.default.createElement(exports.BoxBase, __assign({ borderRadius: "md", className: utils_1.cs('vui-box', className), ref: ref, transitionDuration: "normal" }, styles, aliasedProps, rest)));
54
+ return (react_1.default.createElement(exports.BoxBase, __assign({ className: utils_1.cs('vui-box', className), ref: ref, transitionDuration: "normal" }, styles, aliasedProps, rest)));
55
55
  });
56
56
  exports.Box.displayName = 'Box';
57
57
  exports.default = exports.Box;
@@ -1,5 +1,11 @@
1
1
  import { ButtonProps } from './button.types';
2
+ import ButtonIcon from './buttonIcon';
3
+ import ButtonText from './buttonText';
4
+ import { VuiComponent } from '../core';
2
5
  import { SystemProps } from '../system';
3
6
  export declare const ButtonBase: import("styled-components").StyledComponent<"button", import("styled-components").DefaultTheme, SystemProps, never>;
4
- export declare const Button: import("../core").VuiComponent<"button", ButtonProps>;
7
+ export declare const Button: VuiComponent<"button", ButtonProps> & {
8
+ Icon: typeof ButtonIcon;
9
+ Text: typeof ButtonText;
10
+ };
5
11
  export default Button;
package/button/button.js CHANGED
@@ -14,6 +14,25 @@ var __assign = (this && this.__assign) || function () {
14
14
  };
15
15
  return __assign.apply(this, arguments);
16
16
  };
17
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
18
+ if (k2 === undefined) k2 = k;
19
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
20
+ }) : (function(o, m, k, k2) {
21
+ if (k2 === undefined) k2 = k;
22
+ o[k2] = m[k];
23
+ }));
24
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
25
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
26
+ }) : function(o, v) {
27
+ o["default"] = v;
28
+ });
29
+ var __importStar = (this && this.__importStar) || function (mod) {
30
+ if (mod && mod.__esModule) return mod;
31
+ var result = {};
32
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
33
+ __setModuleDefault(result, mod);
34
+ return result;
35
+ };
17
36
  var __rest = (this && this.__rest) || function (s, e) {
18
37
  var t = {};
19
38
  for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
@@ -30,52 +49,66 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
30
49
  };
31
50
  Object.defineProperty(exports, "__esModule", { value: true });
32
51
  exports.Button = exports.ButtonBase = void 0;
33
- var react_1 = __importDefault(require("react"));
52
+ var react_1 = __importStar(require("react"));
34
53
  var styled_components_1 = __importDefault(require("styled-components"));
54
+ var buttonIcon_1 = __importDefault(require("./buttonIcon"));
55
+ var buttonText_1 = __importDefault(require("./buttonText"));
35
56
  var consts_1 = require("./consts");
36
57
  var context_1 = require("./context");
58
+ var context_2 = require("../buttonGroup/context");
37
59
  var core_1 = require("../core");
38
- var icon_1 = __importDefault(require("../icon"));
39
60
  var system_1 = require("../system");
40
61
  var utils_1 = require("../utils");
41
62
  var ContentWrapper = styled_components_1.default.span(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n\tvisibility: hidden;\n"], ["\n\tvisibility: hidden;\n"])));
42
63
  var StateWrapper = styled_components_1.default.span.withConfig(core_1.forwardPropConfig(system_1.system))(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n\tbottom: 0;\n\tdisplay: flex;\n\tleft: 0;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\n\t", "\n"], ["\n\tbottom: 0;\n\tdisplay: flex;\n\tleft: 0;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\n\t", "\n"])), system_1.system);
43
- exports.ButtonBase = styled_components_1.default.button.withConfig(core_1.forwardPropConfig(system_1.system))(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n\talign-items: center;\n\tdisplay: inline-flex;\n\tflex-shrink: 0;\n\tjustify-content: center;\n\tline-height: normal;\n\toverflow: hidden;\n\tposition: relative;\n\tuser-select: none;\n\twidth: fit-content;\n\n\t&:focus {\n\t\tborder-color: transparent;\n\t\toutline: none;\n\t\tz-index: 1;\n\t}\n\n\t", "\n\n\t&:disabled {\n\t\t/* Specified here to avoid conflict with active/hover props */\n\t\tbackground-color: var(--vui-colors-disabled-bg);\n\t\tborder-color: var(--vui-colors-disabled-border);\n\t\tcolor: var(--vui-colors-disabled-font);\n\t\tcursor: not-allowed;\n\t}\n"], ["\n\talign-items: center;\n\tdisplay: inline-flex;\n\tflex-shrink: 0;\n\tjustify-content: center;\n\tline-height: normal;\n\toverflow: hidden;\n\tposition: relative;\n\tuser-select: none;\n\twidth: fit-content;\n\n\t&:focus {\n\t\tborder-color: transparent;\n\t\toutline: none;\n\t\tz-index: 1;\n\t}\n\n\t", "\n\n\t&:disabled {\n\t\t/* Specified here to avoid conflict with active/hover props */\n\t\tbackground-color: var(--vui-colors-disabled-bg);\n\t\tborder-color: var(--vui-colors-disabled-border);\n\t\tcolor: var(--vui-colors-disabled-font);\n\t\tcursor: not-allowed;\n\t}\n"])), system_1.system);
64
+ exports.ButtonBase = styled_components_1.default.button.withConfig(core_1.forwardPropConfig(system_1.system))(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n\talign-items: center;\n\tdisplay: inline-flex;\n\tflex-shrink: 0;\n\tjustify-content: center;\n\tline-height: normal;\n\toverflow: hidden;\n\tposition: relative;\n\tuser-select: none;\n\twidth: fit-content;\n\n\t&:focus,\n\t&:focus:hover {\n\t\tborder-color: transparent;\n\t\toutline: none;\n\t\tz-index: 1;\n\t}\n\n\t", "\n\n\t&:disabled {\n\t\t/* Specified here to avoid conflict with active/hover props */\n\t\tbackground-color: var(--vui-colors-disabled-bg);\n\t\tborder-color: var(--vui-colors-disabled-border);\n\t\tcolor: var(--vui-colors-disabled-font);\n\t\tcursor: not-allowed;\n\t}\n"], ["\n\talign-items: center;\n\tdisplay: inline-flex;\n\tflex-shrink: 0;\n\tjustify-content: center;\n\tline-height: normal;\n\toverflow: hidden;\n\tposition: relative;\n\tuser-select: none;\n\twidth: fit-content;\n\n\t&:focus,\n\t&:focus:hover {\n\t\tborder-color: transparent;\n\t\toutline: none;\n\t\tz-index: 1;\n\t}\n\n\t", "\n\n\t&:disabled {\n\t\t/* Specified here to avoid conflict with active/hover props */\n\t\tbackground-color: var(--vui-colors-disabled-bg);\n\t\tborder-color: var(--vui-colors-disabled-border);\n\t\tcolor: var(--vui-colors-disabled-font);\n\t\tcursor: not-allowed;\n\t}\n"])), system_1.system);
44
65
  exports.Button = core_1.vui(function (props, ref) {
45
- var _a, _b;
46
- var buttonGroupProps = context_1.useButtonGroup();
66
+ var _a, _b, _c, _d;
67
+ var buttonGroupProps = context_2.useButtonGroup();
47
68
  var mergedProps = __assign(__assign({}, buttonGroupProps), props);
48
- var _c = core_1.omitThemingProps(mergedProps), borderWidthProp = _c.borderWidth, children = _c.children, className = _c.className, disabled = _c.disabled, icon = _c.icon, iconLeftProp = _c.iconLeft, iconRightProp = _c.iconRight, isElevated = _c.isElevated, isFullWidth = _c.isFullWidth, isLoading = _c.isLoading, // eslint-disable-line
49
- isRound = _c.isRound, isSplit = _c.isSplit, itemLeftProp = _c.itemLeft, itemRightProp = _c.itemRight, _d = _c.state, state = _d === void 0 ? props.isLoading ? 'loading' : '' : _d, stateMapping = _c.stateMapping, text = _c.text, rest = __rest(_c, ["borderWidth", "children", "className", "disabled", "icon", "iconLeft", "iconRight", "isElevated", "isFullWidth", "isLoading", "isRound", "isSplit", "itemLeft", "itemRight", "state", "stateMapping", "text"]);
69
+ var borderWidthProp = mergedProps.borderWidth, children = mergedProps.children, className = mergedProps.className, colorSchemeProp = mergedProps.colorScheme, disabled = mergedProps.disabled, icon = mergedProps.icon, iconLeft = mergedProps.iconLeft, iconRight = mergedProps.iconRight, isElevated = mergedProps.isElevated, isFullWidth = mergedProps.isFullWidth, isLoading = mergedProps.isLoading, // eslint-disable-line
70
+ isRound = mergedProps.isRound, isSplit = mergedProps.isSplit, size = mergedProps.size, _e = mergedProps.state, state = _e === void 0 ? props.isLoading ? 'loading' : '' : _e, stateMapping = mergedProps.stateMapping, text = mergedProps.text, variant = mergedProps.variant, rest = __rest(mergedProps, ["borderWidth", "children", "className", "colorScheme", "disabled", "icon", "iconLeft", "iconRight", "isElevated", "isFullWidth", "isLoading", "isRound", "isSplit", "size", "state", "stateMapping", "text", "variant"]);
50
71
  var hasState = Boolean(state);
51
72
  var states = __assign(__assign({}, consts_1.buttonStateMapping), stateMapping);
52
- var _e = (_a = states[state]) !== null && _a !== void 0 ? _a : {}, iconProps = _e.iconProps, stateProps = __rest(_e, ["iconProps"]);
53
- var _f = core_1.useStyleConfig('Button', mergedProps), borderWidth = _f.borderWidth, h = _f.h, _g = _f.iconSize, iconSize = _g === void 0 ? 'md' : _g, minW = _f.minW, _h = _f.spaceX, spaceX = _h === void 0 ? 0 : _h, styles = __rest(_f, ["borderWidth", "h", "iconSize", "minW", "spaceX"]);
73
+ var _f = (_a = states[state]) !== null && _a !== void 0 ? _a : {}, stateIconProps = _f.iconProps, stateProps = __rest(_f, ["iconProps"]);
74
+ var colorScheme = utils_1.filterUndefined({
75
+ colorScheme: (_c = (_b = states[state]) === null || _b === void 0 ? void 0 : _b.colorScheme) !== null && _c !== void 0 ? _c : colorSchemeProp
76
+ });
77
+ var styles = core_1.useStyleConfig('Button', __assign(__assign({}, mergedProps), colorScheme));
78
+ var _g = styles.container, borderWidth = _g.borderWidth, h = _g.h, _h = _g.spaceX, spaceX = _h === void 0 ? 0 : _h, buttonStyles = __rest(_g, ["borderWidth", "h", "spaceX"]);
79
+ var context = react_1.useMemo(function () { return utils_1.filterUndefined({ colorScheme: colorScheme, disabled: disabled, size: size, variant: variant }); }, [
80
+ colorScheme,
81
+ disabled,
82
+ size,
83
+ variant
84
+ ]);
54
85
  var Content = hasState ? ContentWrapper : react_1.default.Fragment;
55
- var border = (_b = borderWidthProp !== null && borderWidthProp !== void 0 ? borderWidthProp : borderWidth) !== null && _b !== void 0 ? _b : 0;
86
+ // Apply more space for text and less space for icons
87
+ var border = (_d = borderWidthProp !== null && borderWidthProp !== void 0 ? borderWidthProp : borderWidth) !== null && _d !== void 0 ? _d : 0;
56
88
  var spaceXItem = spaceX - border + 'px';
57
89
  var spaceXText = spaceX * 2 - border + 'px';
58
90
  var iconRightMl = isSplit ? 'auto' : spaceXItem;
59
- var iconLeft = iconLeftProp && react_1.default.createElement(icon_1.default, { icon: iconLeftProp, mr: spaceXItem, size: iconSize });
60
- var iconRight = iconRightProp && react_1.default.createElement(icon_1.default, { icon: iconRightProp, ml: iconRightMl, size: iconSize });
61
- var itemLeft = itemLeftProp !== null && itemLeftProp !== void 0 ? itemLeftProp : iconLeft;
62
- var itemRight = itemRightProp !== null && itemRightProp !== void 0 ? itemRightProp : iconRight;
63
- var pl = icon || itemLeft ? spaceXItem : spaceXText;
64
- var pr = icon || itemRight ? spaceXItem : spaceXText;
65
- var minWidth = !icon ? minW : undefined;
91
+ var pl = icon || iconLeft ? spaceXItem : spaceXText;
92
+ var pr = icon || iconRight ? spaceXItem : spaceXText;
66
93
  var aliasedProps = utils_1.filterUndefined({
67
94
  borderRadius: isRound ? h / 2 : undefined,
68
95
  boxShadow: isElevated ? '2' : undefined,
96
+ minW: icon ? 0 : undefined,
69
97
  pointerEvents: hasState ? 'none' : undefined,
70
98
  w: isFullWidth ? '100%' : undefined
71
99
  });
72
- return (react_1.default.createElement(exports.ButtonBase, __assign({ borderRadius: "md", borderWidth: border, className: utils_1.cs('vui-button', className), disabled: disabled, focusRing: 3, fontWeight: "medium", h: h, minW: minWidth, pl: pl, pr: pr, ref: ref, transitionDuration: "fast", type: "button" }, styles, aliasedProps, rest),
73
- hasState && (react_1.default.createElement(StateWrapper, __assign({ onClick: function (e) { return e.stopPropagation(); } }, stateProps),
74
- react_1.default.createElement(icon_1.default, __assign({ m: "auto", size: iconSize }, iconProps)))),
75
- react_1.default.createElement(Content, null, icon ? (react_1.default.createElement(icon_1.default, { icon: icon, size: iconSize })) : (react_1.default.createElement(react_1.default.Fragment, null,
76
- itemLeft, children !== null && children !== void 0 ? children : text,
77
- itemRight)))));
100
+ return (react_1.default.createElement(context_1.ButtonProvider, { value: context },
101
+ react_1.default.createElement(exports.ButtonBase, __assign({ borderRadius: "md", borderWidth: border, className: utils_1.cs('vui-button', className), disabled: disabled, focusRing: 3, fontWeight: "medium", h: h, pl: pl, pr: pr, ref: ref, transitionDuration: "fast", type: "button" }, buttonStyles, aliasedProps, rest),
102
+ hasState && (react_1.default.createElement(StateWrapper, __assign({ onClick: function (e) { return e.stopPropagation(); } }, stateProps),
103
+ react_1.default.createElement(buttonIcon_1.default, __assign({ m: "auto" }, stateIconProps)))),
104
+ react_1.default.createElement(Content, null,
105
+ utils_1.isString(icon) ? react_1.default.createElement(buttonIcon_1.default, { name: icon }) : icon,
106
+ !icon && (react_1.default.createElement(react_1.default.Fragment, null,
107
+ utils_1.isString(iconLeft) ? react_1.default.createElement(buttonIcon_1.default, { mr: spaceXItem, name: iconLeft }) : iconLeft, children !== null && children !== void 0 ? children : (utils_1.isReactText(text) ? react_1.default.createElement(buttonText_1.default, { text: text }) : text),
108
+ utils_1.isString(iconRight) ? react_1.default.createElement(buttonIcon_1.default, { ml: iconRightMl, name: iconRight }) : iconRight))))));
78
109
  });
79
110
  exports.Button.displayName = 'Button';
111
+ exports.Button.Icon = buttonIcon_1.default;
112
+ exports.Button.Text = buttonText_1.default;
80
113
  exports.default = exports.Button;
81
114
  var templateObject_1, templateObject_2, templateObject_3;
@@ -2,23 +2,25 @@
2
2
  import { IconProp, IconProps } from '../icon';
3
3
  import { SystemProps } from '../system';
4
4
  import { ThemingProps } from '../theme';
5
+ import { AnyElement } from '../utils';
5
6
  export interface ButtonProps extends SystemProps, ThemingProps<'Button'> {
6
7
  colorScheme?: 'blue' | 'green' | 'grey' | 'pink' | 'prussian' | 'red';
7
- icon?: IconProp;
8
- iconLeft?: IconProp;
9
- iconRight?: IconProp;
8
+ icon?: IconProp | AnyElement;
9
+ iconLeft?: IconProp | AnyElement;
10
+ iconRight?: IconProp | AnyElement;
10
11
  isElevated?: boolean;
11
12
  isFullWidth?: boolean;
12
13
  isLoading?: boolean;
13
14
  isRound?: boolean;
14
15
  isSplit?: boolean;
15
- itemLeft?: React.ReactNode;
16
- itemRight?: React.ReactNode;
17
16
  state?: ButtonState;
18
17
  stateMapping?: ButtonStateMapping;
19
- text?: number | string;
18
+ text?: React.ReactNode;
20
19
  }
21
20
  export declare type ButtonState = 'error' | 'loading' | 'success';
22
21
  export declare type ButtonStateMapping = Record<string, SystemProps & {
22
+ colorScheme: ButtonProps['colorScheme'];
23
23
  iconProps: IconProps;
24
24
  }>;
25
+ /** Narrower prop definition for IconButton component */
26
+ export declare type IconButtonProps = Omit<ButtonProps, 'iconLeft' | 'iconRight' | 'text'>;
@@ -0,0 +1,3 @@
1
+ import { IconProps } from '../icon';
2
+ export declare const ButtonIcon: import("../core").VuiComponent<"svg", IconProps>;
3
+ export default ButtonIcon;
@@ -14,17 +14,17 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
14
14
  return (mod && mod.__esModule) ? mod : { "default": mod };
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
- exports.AlertText = void 0;
17
+ exports.ButtonIcon = void 0;
18
18
  var react_1 = __importDefault(require("react"));
19
19
  var context_1 = require("./context");
20
20
  var core_1 = require("../core");
21
- var p_1 = __importDefault(require("../p"));
22
- exports.AlertText = core_1.vui(function (props, ref) {
21
+ var icon_1 = __importDefault(require("../icon"));
22
+ exports.ButtonIcon = core_1.vui(function (props, ref) {
23
23
  var _a;
24
- var alertProps = (_a = context_1.useAlert()) !== null && _a !== void 0 ? _a : {};
25
- var mergedProps = __assign(__assign({}, alertProps), props);
26
- var styles = core_1.useStyleConfig('Alert', mergedProps);
27
- return react_1.default.createElement(p_1.default, __assign({ className: "vui-alertText", flex: "1", minW: 0, py: 0.5, ref: ref }, styles.text, props));
24
+ var buttonProps = (_a = context_1.useButton()) !== null && _a !== void 0 ? _a : {};
25
+ var mergedProps = __assign(__assign({}, buttonProps), props);
26
+ var styles = core_1.useStyleConfig('Button', mergedProps);
27
+ return react_1.default.createElement(icon_1.default, __assign({ className: "vui-buttonIcon", ref: ref }, styles.icon, props));
28
28
  });
29
- exports.AlertText.displayName = 'AlertText';
30
- exports.default = exports.AlertText;
29
+ exports.ButtonIcon.displayName = 'ButtonIcon';
30
+ exports.default = exports.ButtonIcon;
@@ -0,0 +1,3 @@
1
+ import { TProps } from '../t';
2
+ export declare const ButtonText: import("../core").VuiComponent<"span", TProps>;
3
+ export default ButtonText;
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __importDefault = (this && this.__importDefault) || function (mod) {
14
+ return (mod && mod.__esModule) ? mod : { "default": mod };
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.ButtonText = void 0;
18
+ var react_1 = __importDefault(require("react"));
19
+ var context_1 = require("./context");
20
+ var core_1 = require("../core");
21
+ var t_1 = __importDefault(require("../t"));
22
+ exports.ButtonText = core_1.vui(function (props, ref) {
23
+ var _a;
24
+ var buttonProps = (_a = context_1.useButton()) !== null && _a !== void 0 ? _a : {};
25
+ var mergedProps = __assign(__assign({}, buttonProps), props);
26
+ var styles = core_1.useStyleConfig('Button', mergedProps);
27
+ return react_1.default.createElement(t_1.default, __assign({ className: "vui-buttonText", fontSize: "inherit", ref: ref }, styles.text, props));
28
+ });
29
+ exports.ButtonText.displayName = 'ButtonText';
30
+ exports.default = exports.ButtonText;
@@ -1,8 +1,9 @@
1
- import { ButtonProps } from './button.types';
1
+ import { ButtonProps, IconButtonProps } from './button.types';
2
2
  export declare const AppButton: import("../core").VuiComponent<"button", ButtonProps>;
3
- export declare const BackButton: import("../core").VuiComponent<"button", ButtonProps>;
4
- export declare const CloseButton: import("../core").VuiComponent<"button", ButtonProps>;
3
+ export declare const BackButton: import("../core").VuiComponent<"button", IconButtonProps>;
4
+ export declare const CloseButton: import("../core").VuiComponent<"button", IconButtonProps>;
5
5
  export declare const CTAButton: import("../core").VuiComponent<"button", ButtonProps>;
6
6
  export declare const DangerButton: import("../core").VuiComponent<"button", ButtonProps>;
7
+ export declare const IconButton: import("../core").VuiComponent<"button", IconButtonProps>;
7
8
  export declare const LineButton: import("../core").VuiComponent<"button", ButtonProps>;
8
9
  export declare const TextButton: import("../core").VuiComponent<"button", ButtonProps>;
package/button/buttons.js CHANGED
@@ -14,14 +14,15 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
14
14
  return (mod && mod.__esModule) ? mod : { "default": mod };
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
- exports.TextButton = exports.LineButton = exports.DangerButton = exports.CTAButton = exports.CloseButton = exports.BackButton = exports.AppButton = void 0;
17
+ exports.TextButton = exports.LineButton = exports.IconButton = exports.DangerButton = exports.CTAButton = exports.CloseButton = exports.BackButton = exports.AppButton = void 0;
18
18
  var react_1 = __importDefault(require("react"));
19
19
  var button_1 = __importDefault(require("./button"));
20
20
  var core_1 = require("../core");
21
21
  exports.AppButton = core_1.vui(function (props, ref) { return (react_1.default.createElement(button_1.default, __assign({ colorScheme: "blue", ref: ref, variant: "solid" }, props))); });
22
- exports.BackButton = core_1.vui(function (props, ref) { return (react_1.default.createElement(button_1.default, __assign({ colorScheme: "blue", icon: "falChevronLeft", ref: ref, variant: "text" }, props))); });
23
- exports.CloseButton = core_1.vui(function (props, ref) { return (react_1.default.createElement(button_1.default, __assign({ colorScheme: "blue", icon: "falTimes", ref: ref, variant: "text" }, props))); });
22
+ exports.BackButton = core_1.vui(function (props, ref) { return (react_1.default.createElement(exports.IconButton, __assign({ colorScheme: "blue", icon: "falChevronLeft", ref: ref, variant: "text" }, props))); });
23
+ exports.CloseButton = core_1.vui(function (props, ref) { return (react_1.default.createElement(exports.IconButton, __assign({ colorScheme: "blue", icon: "falTimes", ref: ref, variant: "text" }, props))); });
24
24
  exports.CTAButton = core_1.vui(function (props, ref) { return (react_1.default.createElement(button_1.default, __assign({ colorScheme: "green", ref: ref, variant: "solid" }, props))); });
25
25
  exports.DangerButton = core_1.vui(function (props, ref) { return (react_1.default.createElement(button_1.default, __assign({ colorScheme: "red", ref: ref, variant: "solid" }, props))); });
26
+ exports.IconButton = core_1.vui(function (props, ref) { return (react_1.default.createElement(button_1.default, __assign({ colorScheme: "blue", ref: ref, variant: "text" }, props))); });
26
27
  exports.LineButton = core_1.vui(function (props, ref) { return (react_1.default.createElement(button_1.default, __assign({ colorScheme: "blue", ref: ref, variant: "outlined" }, props))); });
27
28
  exports.TextButton = core_1.vui(function (props, ref) { return (react_1.default.createElement(button_1.default, __assign({ colorScheme: "blue", ref: ref, variant: "text" }, props))); });
package/button/consts.js CHANGED
@@ -3,13 +3,14 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.buttonStateMapping = void 0;
4
4
  exports.buttonStateMapping = {
5
5
  error: {
6
- bg: 'red.80',
6
+ colorScheme: 'red',
7
7
  iconProps: {
8
8
  animation: 'fadeDown',
9
9
  icon: 'falTimesCircle'
10
10
  }
11
11
  },
12
12
  loading: {
13
+ colorScheme: 'blue',
13
14
  iconProps: {
14
15
  animation: 'vui-spin 0.6s linear infinite',
15
16
  fill: ['', 'transparent'],
@@ -17,7 +18,7 @@ exports.buttonStateMapping = {
17
18
  }
18
19
  },
19
20
  success: {
20
- bg: 'green.80',
21
+ colorScheme: 'green',
21
22
  iconProps: {
22
23
  animation: 'fadeDown',
23
24
  icon: 'falCheckCircle'
@@ -1,4 +1,4 @@
1
1
  /// <reference types="react" />
2
2
  import { Dict } from '../utils';
3
- declare const ButtonGroupProvider: import("react").Provider<Dict<any>>, useButtonGroup: () => Dict<any>;
4
- export { ButtonGroupProvider, useButtonGroup };
3
+ declare const ButtonProvider: import("react").Provider<Dict<any>>, useButton: () => Dict<any>;
4
+ export { ButtonProvider, useButton };
package/button/context.js CHANGED
@@ -16,8 +16,8 @@ var __read = (this && this.__read) || function (o, n) {
16
16
  return ar;
17
17
  };
18
18
  Object.defineProperty(exports, "__esModule", { value: true });
19
- exports.useButtonGroup = exports.ButtonGroupProvider = void 0;
19
+ exports.useButton = exports.ButtonProvider = void 0;
20
20
  var core_1 = require("../core");
21
- var _a = __read(core_1.createContext({ isOptional: true }), 2), ButtonGroupProvider = _a[0], useButtonGroup = _a[1];
22
- exports.ButtonGroupProvider = ButtonGroupProvider;
23
- exports.useButtonGroup = useButtonGroup;
21
+ var _a = __read(core_1.createContext({ isOptional: true }), 2), ButtonProvider = _a[0], useButton = _a[1];
22
+ exports.ButtonProvider = ButtonProvider;
23
+ exports.useButton = useButton;
package/button/index.d.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  export * from './button';
2
2
  export * from './button.types';
3
3
  export * from './buttons';
4
- export * from './buttonGroup';
5
- export * from './buttonGroup.types';
4
+ export * from './buttonIcon';
5
+ export * from './buttonText';
6
6
  export * from './context';
7
7
  export { default } from './button';
package/button/index.js CHANGED
@@ -17,8 +17,8 @@ exports.default = void 0;
17
17
  __exportStar(require("./button"), exports);
18
18
  __exportStar(require("./button.types"), exports);
19
19
  __exportStar(require("./buttons"), exports);
20
- __exportStar(require("./buttonGroup"), exports);
21
- __exportStar(require("./buttonGroup.types"), exports);
20
+ __exportStar(require("./buttonIcon"), exports);
21
+ __exportStar(require("./buttonText"), exports);
22
22
  __exportStar(require("./context"), exports);
23
23
  var button_1 = require("./button");
24
24
  Object.defineProperty(exports, "default", { enumerable: true, get: function () { return __importDefault(button_1).default; } });
package/button/theme.d.ts CHANGED
@@ -1,30 +1,47 @@
1
1
  import { Dict } from '../utils';
2
2
  declare function variantOutlined(props: Dict): {
3
- hoverBg: string;
4
- activeBg: string;
5
- bg: string;
6
- color: string;
7
- borderColor: string;
8
- borderWidth: number;
9
- };
10
- declare function variantSubtle(props: Dict): {
11
- hoverBg: string;
12
- activeBg: string;
13
- bg: string;
14
- color: string;
3
+ container: {
4
+ borderColor: string;
5
+ hoverBorderColor: string;
6
+ hoverBg: string;
7
+ activeBg: string;
8
+ bg: string;
9
+ borderWidth: number;
10
+ color: string;
11
+ };
15
12
  };
16
13
  declare function variantSolid(props: Dict): {
17
- borderColor: string;
18
- hoverBg: string;
19
- activeBg: string;
20
- bg: string;
21
- color: string;
14
+ container: {
15
+ hoverBg: string;
16
+ hoverBorderColor: string;
17
+ activeBg: string;
18
+ bg: string;
19
+ borderColor: string;
20
+ borderWidth: number;
21
+ color: string;
22
+ };
23
+ };
24
+ declare function variantSubtle(props: Dict): {
25
+ container: {
26
+ hoverBg: string;
27
+ hoverBorderColor: string;
28
+ activeBg: string;
29
+ bg: string;
30
+ borderColor: string;
31
+ borderWidth: number;
32
+ color: string;
33
+ };
22
34
  };
23
35
  declare function variantText(props: Dict): {
24
- hoverBg: string;
25
- activeBg: string;
26
- bg: string;
27
- color: string;
36
+ container: {
37
+ hoverBg: string;
38
+ hoverBorderColor: string;
39
+ activeBg: string;
40
+ bg: string;
41
+ borderColor: string;
42
+ borderWidth: number;
43
+ color: string;
44
+ };
28
45
  };
29
46
  declare const _default: {
30
47
  defaultProps: {
@@ -32,34 +49,55 @@ declare const _default: {
32
49
  size: string;
33
50
  variant: string;
34
51
  };
52
+ parts: string[];
35
53
  sizes: {
36
54
  xs: {
37
- fontSize: string;
38
- h: number;
39
- iconSize: string;
40
- minW: number;
41
- spaceX: number;
55
+ container: {
56
+ fontSize: string;
57
+ h: number;
58
+ minW: number;
59
+ spaceX: number;
60
+ };
61
+ icon: {
62
+ size: string;
63
+ };
64
+ text: {};
42
65
  };
43
66
  sm: {
44
- fontSize: string;
45
- h: number;
46
- iconSize: string;
47
- minW: number;
48
- spaceX: number;
67
+ container: {
68
+ fontSize: string;
69
+ h: number;
70
+ minW: number;
71
+ spaceX: number;
72
+ };
73
+ icon: {
74
+ size: string;
75
+ };
76
+ text: {};
49
77
  };
50
78
  md: {
51
- fontSize: string;
52
- h: number;
53
- iconSize: string;
54
- minW: number;
55
- spaceX: number;
79
+ container: {
80
+ fontSize: string;
81
+ h: number;
82
+ minW: number;
83
+ spaceX: number;
84
+ };
85
+ icon: {
86
+ size: string;
87
+ };
88
+ text: {};
56
89
  };
57
90
  lg: {
58
- fontSize: string;
59
- h: number;
60
- iconSize: string;
61
- minW: number;
62
- spaceX: number;
91
+ container: {
92
+ fontSize: string;
93
+ h: number;
94
+ minW: number;
95
+ spaceX: number;
96
+ };
97
+ icon: {
98
+ size: string;
99
+ };
100
+ text: {};
63
101
  };
64
102
  };
65
103
  variants: {