@uxf/ui 1.0.0-beta.57 → 1.0.0-beta.59

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 (141) hide show
  1. package/_private-utils/get-provider-config.js +2 -1
  2. package/avatar-file-input/avatar-file-input.d.ts +2 -2
  3. package/avatar-file-input/avatar-file-input.js +8 -8
  4. package/avatar-file-input/index.d.ts +1 -1
  5. package/avatar-file-input/index.js +14 -5
  6. package/button/button.stories.js +8 -5
  7. package/button/theme.d.ts +2 -1
  8. package/checkbox/index.d.ts +1 -1
  9. package/checkbox/index.js +15 -3
  10. package/checkbox-input/checkbox-input.d.ts +2 -3
  11. package/checkbox-input/checkbox-input.js +5 -3
  12. package/checkbox-input/checkbox-input.stories.d.ts +2 -3
  13. package/checkbox-input/index.d.ts +1 -1
  14. package/checkbox-input/index.js +14 -5
  15. package/chip/chip.d.ts +7 -0
  16. package/chip/chip.js +14 -0
  17. package/chip/chip.stories.d.ts +7 -0
  18. package/chip/chip.stories.js +22 -0
  19. package/chip/index.d.ts +1 -0
  20. package/chip/index.js +5 -0
  21. package/chip/theme.d.ts +5 -0
  22. package/chip/theme.js +2 -0
  23. package/color-radio-group/color-radio-group.d.ts +17 -0
  24. package/color-radio-group/color-radio-group.js +47 -0
  25. package/color-radio-group/color-radio-group.stories.d.ts +7 -0
  26. package/color-radio-group/color-radio-group.stories.js +79 -0
  27. package/color-radio-group/color-radio.d.ts +8 -0
  28. package/color-radio-group/color-radio.js +28 -0
  29. package/color-radio-group/index.d.ts +1 -0
  30. package/color-radio-group/index.js +5 -0
  31. package/combobox/combobox.d.ts +1 -2
  32. package/combobox/combobox.js +8 -7
  33. package/combobox/index.d.ts +1 -1
  34. package/combobox/index.js +14 -5
  35. package/config/icons-config.d.ts +2 -0
  36. package/config/icons-config.js +5 -0
  37. package/config/icons.d.ts +47 -0
  38. package/config/icons.js +14 -0
  39. package/css/button.css +171 -76
  40. package/css/chip.css +37 -0
  41. package/css/color-radio-group.css +26 -0
  42. package/css/color-radio.css +21 -0
  43. package/css/input.css +123 -68
  44. package/css/label.css +7 -0
  45. package/css/radio-group.css +41 -12
  46. package/css/radio.css +2 -2
  47. package/css/textarea.css +48 -10
  48. package/dropdown/dropdown.js +7 -7
  49. package/dropdown/index.d.ts +1 -1
  50. package/dropdown/index.js +15 -3
  51. package/error-message/error-message.d.ts +2 -2
  52. package/error-message/error-message.js +2 -1
  53. package/error-message/index.d.ts +1 -1
  54. package/error-message/index.js +14 -5
  55. package/form-control/form-control.js +2 -2
  56. package/hooks/use-dropdown.js +3 -1
  57. package/icon/icon.d.ts +2 -2
  58. package/icon/icon.js +11 -7
  59. package/icon/icon.stories.js +12 -8
  60. package/icon/index.d.ts +1 -5
  61. package/icon/index.js +14 -13
  62. package/icon/theme.d.ts +1 -2
  63. package/image-gallery/components/close-button.js +3 -3
  64. package/image-gallery/components/next-button.js +3 -3
  65. package/image-gallery/components/previous-button.js +3 -3
  66. package/input/index.d.ts +9 -10
  67. package/input/index.js +10 -13
  68. package/input/input-element.d.ts +2 -2
  69. package/input/input-element.js +5 -5
  70. package/input/input-left-addon.d.ts +3 -3
  71. package/input/input-left-addon.js +2 -1
  72. package/input/input-left-element.d.ts +3 -3
  73. package/input/input-left-element.js +2 -1
  74. package/input/input-right-addon.d.ts +2 -3
  75. package/input/input-right-addon.js +2 -1
  76. package/input/input-right-element.d.ts +3 -3
  77. package/input/input-right-element.js +2 -1
  78. package/input/input.d.ts +2 -2
  79. package/input/input.js +5 -4
  80. package/input/input.stories.d.ts +5 -5
  81. package/input/input.stories.js +13 -3
  82. package/label/index.d.ts +1 -1
  83. package/label/index.js +14 -5
  84. package/label/label.d.ts +1 -2
  85. package/label/label.js +4 -4
  86. package/package.json +4 -3
  87. package/radio/index.d.ts +1 -1
  88. package/radio/index.js +15 -3
  89. package/radio-group/index.d.ts +1 -1
  90. package/radio-group/index.js +15 -3
  91. package/radio-group/radio-group.js +2 -2
  92. package/radio-group/radio-group.stories.js +2 -2
  93. package/raster-image/index.d.ts +1 -1
  94. package/raster-image/index.js +14 -5
  95. package/raster-image/raster-image.d.ts +4 -4
  96. package/raster-image/raster-image.js +7 -5
  97. package/raster-image/raster-image.stories.d.ts +2 -3
  98. package/select/index.d.ts +1 -1
  99. package/select/index.js +14 -5
  100. package/select/select.d.ts +1 -2
  101. package/select/select.js +8 -7
  102. package/text-input/text-input.d.ts +1 -1
  103. package/text-input/text-input.js +4 -4
  104. package/text-input/text-input.stories.js +4 -1
  105. package/textarea/index.d.ts +1 -1
  106. package/textarea/index.js +14 -5
  107. package/textarea/textarea.d.ts +1 -2
  108. package/textarea/textarea.js +8 -8
  109. package/textarea/textarea.stories.js +32 -20
  110. package/toggle/index.d.ts +1 -1
  111. package/toggle/index.js +14 -5
  112. package/toggle/toggle.d.ts +2 -3
  113. package/toggle/toggle.js +7 -6
  114. package/toggle/toggle.stories.d.ts +2 -3
  115. package/utils/icons-config.js +43 -0
  116. package/utils/storybook-config.js +1 -1
  117. package/utils/tailwind-config.js +152 -0
  118. package/hooks/use-latest.d.ts +0 -2
  119. package/hooks/use-latest.js +0 -12
  120. package/icon/camera-icon.d.ts +0 -3
  121. package/icon/camera-icon.js +0 -11
  122. package/icon/chevron-down-icon.d.ts +0 -3
  123. package/icon/chevron-down-icon.js +0 -11
  124. package/icon/chevron-up-icon.d.ts +0 -3
  125. package/icon/chevron-up-icon.js +0 -11
  126. package/icon/pin-icon.d.ts +0 -3
  127. package/icon/pin-icon.js +0 -11
  128. package/image-gallery/components/icon-chevron-left.d.ts +0 -3
  129. package/image-gallery/components/icon-chevron-left.js +0 -11
  130. package/image-gallery/components/icon-chevron-right.d.ts +0 -3
  131. package/image-gallery/components/icon-chevron-right.js +0 -11
  132. package/image-gallery/components/icon-close.d.ts +0 -3
  133. package/image-gallery/components/icon-close.js +0 -11
  134. package/utils/cx.d.ts +0 -3
  135. package/utils/cx.js +0 -54
  136. package/utils/forward-ref.d.ts +0 -12
  137. package/utils/forward-ref.js +0 -10
  138. package/utils/rem.d.ts +0 -1
  139. package/utils/rem.js +0 -5
  140. package/utils/sr-only-mixin.d.ts +0 -2
  141. package/utils/sr-only-mixin.js +0 -14
@@ -3,9 +3,9 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.InputElement = void 0;
7
+ const forwardRef_1 = require("@uxf/core/utils/forwardRef");
6
8
  const react_1 = __importDefault(require("react"));
7
- const forward_ref_1 = require("../utils/forward-ref");
8
- function InputElement(props, ref) {
9
- return (react_1.default.createElement("input", { "aria-describedby": props["aria-describedby"], "aria-invalid": props.isInvalid, className: "uxf-input__element", disabled: props.isDisabled, form: props.form, id: props.id, inputMode: props.inputMode, max: props.max, maxLength: props.maxLength, min: props.min, minLength: props.minLength, onBlur: props.onBlur, onChange: (event) => { var _a; return (_a = props.onChange) === null || _a === void 0 ? void 0 : _a.call(props, event.target.value, event); }, onFocus: props.onFocus, onKeyDown: props.onKeyDown, pattern: props.pattern, placeholder: props.placeholder, readOnly: props.isReadOnly, ref: ref, step: props.step, type: props.type, value: props.value }));
10
- }
11
- exports.default = (0, forward_ref_1.forwardRef)("InputElement", InputElement);
9
+ exports.InputElement = (0, forwardRef_1.forwardRef)("InputElement", (props, ref) => {
10
+ return (react_1.default.createElement("input", { "aria-describedby": props["aria-describedby"], "aria-invalid": props.isInvalid, className: "uxf-input__element", disabled: props.isDisabled, form: props.form, id: props.id, inputMode: props.inputMode, max: props.max, maxLength: props.maxLength, min: props.min, minLength: props.minLength, onBlur: props.onBlur, onChange: (event) => { var _a; return (_a = props.onChange) === null || _a === void 0 ? void 0 : _a.call(props, event.target.value, event); }, onFocus: props.onFocus, onKeyDown: props.onKeyDown, pattern: props.pattern, placeholder: props.placeholder, readOnly: props.isReadOnly, ref: ref, step: props.step, tabIndex: props.isReadOnly ? -1 : undefined, type: props.type, value: props.value }));
11
+ });
@@ -2,8 +2,8 @@ import { ReactNode } from "react";
2
2
  interface InputLeftAddonProps {
3
3
  children: ReactNode;
4
4
  }
5
- declare function InputLeftAddon(props: InputLeftAddonProps): JSX.Element;
6
- declare namespace InputLeftAddon {
5
+ export declare function InputLeftAddon(props: InputLeftAddonProps): JSX.Element;
6
+ export declare namespace InputLeftAddon {
7
7
  var displayName: string;
8
8
  }
9
- export default InputLeftAddon;
9
+ export {};
@@ -3,9 +3,10 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.InputLeftAddon = void 0;
6
7
  const react_1 = __importDefault(require("react"));
7
8
  function InputLeftAddon(props) {
8
9
  return react_1.default.createElement("div", { className: "uxf-input__left-addon" }, props.children);
9
10
  }
11
+ exports.InputLeftAddon = InputLeftAddon;
10
12
  InputLeftAddon.displayName = "InputLeftAddon";
11
- exports.default = InputLeftAddon;
@@ -2,8 +2,8 @@ import { ReactNode } from "react";
2
2
  interface InputLeftElementProps {
3
3
  children?: ReactNode;
4
4
  }
5
- declare function InputLeftElement(props: InputLeftElementProps): JSX.Element;
6
- declare namespace InputLeftElement {
5
+ export declare function InputLeftElement(props: InputLeftElementProps): JSX.Element;
6
+ export declare namespace InputLeftElement {
7
7
  var displayName: string;
8
8
  }
9
- export default InputLeftElement;
9
+ export {};
@@ -3,9 +3,10 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.InputLeftElement = void 0;
6
7
  const react_1 = __importDefault(require("react"));
7
8
  function InputLeftElement(props) {
8
9
  return react_1.default.createElement("div", { className: "uxf-input__left-element" }, props.children);
9
10
  }
11
+ exports.InputLeftElement = InputLeftElement;
10
12
  InputLeftElement.displayName = "InputLeftElement";
11
- exports.default = InputLeftElement;
@@ -2,8 +2,7 @@ import { ReactNode } from "react";
2
2
  export interface InputRightAddonProps {
3
3
  children: ReactNode;
4
4
  }
5
- declare function InputRightAddon(props: InputRightAddonProps): JSX.Element;
6
- declare namespace InputRightAddon {
5
+ export declare function InputRightAddon(props: InputRightAddonProps): JSX.Element;
6
+ export declare namespace InputRightAddon {
7
7
  var displayName: string;
8
8
  }
9
- export default InputRightAddon;
@@ -3,9 +3,10 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.InputRightAddon = void 0;
6
7
  const react_1 = __importDefault(require("react"));
7
8
  function InputRightAddon(props) {
8
9
  return react_1.default.createElement("div", { className: "uxf-input__right-addon" }, props.children);
9
10
  }
11
+ exports.InputRightAddon = InputRightAddon;
10
12
  InputRightAddon.displayName = "InputRightAddon";
11
- exports.default = InputRightAddon;
@@ -2,8 +2,8 @@ import { ReactNode } from "react";
2
2
  interface InputRightElementProps {
3
3
  children?: ReactNode;
4
4
  }
5
- declare function InputRightElement(props: InputRightElementProps): JSX.Element;
6
- declare namespace InputRightElement {
5
+ export declare function InputRightElement(props: InputRightElementProps): JSX.Element;
6
+ export declare namespace InputRightElement {
7
7
  var displayName: string;
8
8
  }
9
- export default InputRightElement;
9
+ export {};
@@ -3,9 +3,10 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.InputRightElement = void 0;
6
7
  const react_1 = __importDefault(require("react"));
7
8
  function InputRightElement(props) {
8
9
  return react_1.default.createElement("div", { className: "uxf-input__right-element" }, props.children);
9
10
  }
11
+ exports.InputRightElement = InputRightElement;
10
12
  InputRightElement.displayName = "InputRightElement";
11
- exports.default = InputRightElement;
package/input/input.d.ts CHANGED
@@ -1,8 +1,8 @@
1
- import { ReactNode } from "react";
1
+ import React, { ReactNode } from "react";
2
2
  import { InputGroupSizes, InputGroupVariants } from "@uxf/ui/input/theme";
3
3
  export interface InputProps {
4
4
  children: ReactNode;
5
5
  variant?: keyof InputGroupVariants;
6
6
  size?: keyof InputGroupSizes;
7
7
  }
8
- export declare function Input(props: InputProps): JSX.Element;
8
+ export declare const Input: React.ForwardRefExoticComponent<InputProps & React.RefAttributes<HTMLInputElement>>;
package/input/input.js CHANGED
@@ -24,6 +24,8 @@ var __importStar = (this && this.__importStar) || function (mod) {
24
24
  };
25
25
  Object.defineProperty(exports, "__esModule", { value: true });
26
26
  exports.Input = void 0;
27
+ const composeRefs_1 = require("@uxf/core/utils/composeRefs");
28
+ const forwardRef_1 = require("@uxf/core/utils/forwardRef");
27
29
  const react_1 = __importStar(require("react"));
28
30
  const cx_1 = require("@uxf/core/utils/cx");
29
31
  const classes_1 = require("@uxf/core/constants/classes");
@@ -32,7 +34,7 @@ function getChildrenById(children, componentName) {
32
34
  .filter(react_1.isValidElement)
33
35
  .find((ch) => ch.type.displayName === componentName);
34
36
  }
35
- function Input(props) {
37
+ exports.Input = (0, forwardRef_1.forwardRef)("Input", (props, ref) => {
36
38
  const inputWrapperRef = (0, react_1.useRef)(null);
37
39
  const inputRef = (0, react_1.useRef)(null);
38
40
  const [focused, setFocused] = (0, react_1.useState)(false);
@@ -56,8 +58,7 @@ function Input(props) {
56
58
  leftAddon,
57
59
  react_1.default.createElement("div", { className: "uxf-input__wrapper", ref: inputWrapperRef, onClick: () => { var _a; return (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus(); } },
58
60
  leftElement,
59
- mainInput ? (0, react_1.cloneElement)(mainInput, { ref: inputRef, onFocus, onBlur }) : null,
61
+ mainInput ? (0, react_1.cloneElement)(mainInput, { ref: (0, composeRefs_1.composeRefs)(ref, inputRef), onFocus, onBlur }) : null,
60
62
  rightElement),
61
63
  rightAddon));
62
- }
63
- exports.Input = Input;
64
+ });
@@ -1,12 +1,12 @@
1
1
  import React from "react";
2
2
  declare const _default: {
3
3
  title: string;
4
- component: typeof import("./input").Input & {
4
+ component: React.ForwardRefExoticComponent<import("./input").InputProps & React.RefAttributes<HTMLInputElement>> & {
5
5
  Element: React.ForwardRefExoticComponent<import("./input-element").InputElementProps & React.RefAttributes<HTMLInputElement>>;
6
- LeftElement: typeof import("./input-left-element").default;
7
- RightElement: typeof import("./input-right-element").default;
8
- LeftAddon: typeof import("./input-left-addon").default;
9
- RightAddon: typeof import("./input-right-addon").default;
6
+ LeftElement: typeof import("./input-left-element").InputLeftElement;
7
+ RightElement: typeof import("./input-right-element").InputRightElement;
8
+ LeftAddon: typeof import("./input-left-addon").InputLeftAddon;
9
+ RightAddon: typeof import("./input-right-addon").InputRightAddon;
10
10
  };
11
11
  };
12
12
  export default _default;
@@ -38,8 +38,7 @@ exports.default = {
38
38
  function Default() {
39
39
  const [value, onChange] = (0, react_1.useState)("");
40
40
  const [isInvalid, setInvalid] = (0, react_1.useState)(false);
41
- return (react_1.default.createElement("div", { className: "space-y-2" },
42
- react_1.default.createElement("input", { type: "checkbox", checked: isInvalid, onChange: (e) => setInvalid(e.target.checked) }),
41
+ const storyInputs = (react_1.default.createElement(react_1.default.Fragment, null,
43
42
  react_1.default.createElement(input_1.Input, null,
44
43
  react_1.default.createElement(input_1.Input.LeftAddon, null, "InputLeftAddon"),
45
44
  react_1.default.createElement(input_1.Input.LeftElement, null, "InputLeftElement"),
@@ -50,12 +49,23 @@ function Default() {
50
49
  react_1.default.createElement(input_1.Input.LeftAddon, null, "https://"),
51
50
  react_1.default.createElement(input_1.Input.Element, { value: value, onChange: (0, action_1.action)("onChange", onChange), placeholder: "Placeholder", isInvalid: isInvalid }),
52
51
  react_1.default.createElement(input_1.Input.RightAddon, null, ".uxf.cz")),
52
+ react_1.default.createElement(input_1.Input, null,
53
+ react_1.default.createElement(input_1.Input.Element, { value: value, onChange: (0, action_1.action)("onChange", onChange), placeholder: "Placeholder", isInvalid: isInvalid }),
54
+ react_1.default.createElement(input_1.Input.RightAddon, null, ".test.cz")),
53
55
  react_1.default.createElement(input_1.Input, null,
54
56
  react_1.default.createElement(input_1.Input.LeftElement, null, "\uD83C\uDF37"),
55
57
  react_1.default.createElement(input_1.Input.Element, { value: value, onChange: (0, action_1.action)("onChange", onChange), placeholder: "Placeholder", isInvalid: isInvalid }),
56
58
  react_1.default.createElement(input_1.Input.RightElement, null, "\uD83D\uDD14")),
57
59
  react_1.default.createElement(input_1.Input, null,
58
- react_1.default.createElement(input_1.Input.Element, { value: value, onChange: (0, action_1.action)("onChange", onChange), placeholder: "Placeholder", isInvalid: isInvalid }))));
60
+ react_1.default.createElement(input_1.Input.Element, { value: value, onChange: (0, action_1.action)("onChange", onChange), placeholder: "Placeholder", isInvalid: isInvalid })),
61
+ react_1.default.createElement(input_1.Input, null,
62
+ react_1.default.createElement(input_1.Input.Element, { value: value, onChange: (0, action_1.action)("onChange", onChange), placeholder: "Disabled", isInvalid: isInvalid, isDisabled: true })),
63
+ react_1.default.createElement(input_1.Input, null,
64
+ react_1.default.createElement(input_1.Input.Element, { value: value, onChange: (0, action_1.action)("onChange", onChange), placeholder: "Read Only", isInvalid: isInvalid, isReadOnly: true }))));
65
+ return (react_1.default.createElement(react_1.default.Fragment, null,
66
+ react_1.default.createElement("input", { type: "checkbox", checked: isInvalid, onChange: (e) => setInvalid(e.target.checked) }),
67
+ react_1.default.createElement("div", { className: "light space-y-2 p-20" }, storyInputs),
68
+ react_1.default.createElement("div", { className: "dark space-y-2 bg-gray-900 p-20" }, storyInputs)));
59
69
  }
60
70
  exports.Default = Default;
61
71
  function ComponentStructure() {
package/label/index.d.ts CHANGED
@@ -1 +1 @@
1
- export { default as Label } from "./label";
1
+ export * from "./label";
package/label/index.js CHANGED
@@ -1,8 +1,17 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
4
15
  };
5
16
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.Label = void 0;
7
- var label_1 = require("./label");
8
- Object.defineProperty(exports, "Label", { enumerable: true, get: function () { return __importDefault(label_1).default; } });
17
+ __exportStar(require("./label"), exports);
package/label/label.d.ts CHANGED
@@ -8,5 +8,4 @@ export interface LabelProps {
8
8
  isRequired?: boolean;
9
9
  onClick?: MouseEventHandler<HTMLLabelElement>;
10
10
  }
11
- declare const _default: React.ForwardRefExoticComponent<LabelProps & React.RefAttributes<HTMLLabelElement>>;
12
- export default _default;
11
+ export declare const Label: React.ForwardRefExoticComponent<LabelProps & React.RefAttributes<HTMLLabelElement>>;
package/label/label.js CHANGED
@@ -3,12 +3,12 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Label = void 0;
6
7
  const classes_1 = require("@uxf/core/constants/classes");
7
8
  const cx_1 = require("@uxf/core/utils/cx");
9
+ const forwardRef_1 = require("@uxf/core/utils/forwardRef");
8
10
  const react_1 = __importDefault(require("react"));
9
- const forward_ref_1 = require("../utils/forward-ref");
10
- function Label(props, ref) {
11
+ exports.Label = (0, forwardRef_1.forwardRef)("Label", (props, ref) => {
11
12
  const className = (0, cx_1.cx)("uxf-label", props.isRequired && classes_1.CLASSES.IS_REQUIRED, props.className);
12
13
  return (react_1.default.createElement("label", { className: className, form: props.form, htmlFor: props.htmlFor, id: props.id, onClick: props.onClick, ref: ref }, props.children));
13
- }
14
- exports.default = (0, forward_ref_1.forwardRef)("Label", Label);
14
+ });
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@uxf/ui",
3
- "version": "1.0.0-beta.57",
3
+ "version": "1.0.0-beta.59",
4
4
  "description": "",
5
5
  "publishConfig": {
6
6
  "access": "public"
@@ -16,10 +16,11 @@
16
16
  "@floating-ui/react-dom": "^1.0.0",
17
17
  "@headlessui/react": "^1.7.2",
18
18
  "@uxf/core": "^3.1.0",
19
- "@uxf/styles": "^2.0.0",
19
+ "@uxf/styles": "^2.0.1",
20
20
  "jump.js": "^1.0.2"
21
21
  },
22
22
  "devDependencies": {
23
- "@types/jump.js": "^1.0.4"
23
+ "@types/jump.js": "^1.0.4",
24
+ "@uxf/icons-generator": "^1.2.1"
24
25
  }
25
26
  }
package/radio/index.d.ts CHANGED
@@ -1 +1 @@
1
- export { Radio } from "./radio";
1
+ export * from "./radio";
package/radio/index.js CHANGED
@@ -1,5 +1,17 @@
1
1
  "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
2
16
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Radio = void 0;
4
- var radio_1 = require("./radio");
5
- Object.defineProperty(exports, "Radio", { enumerable: true, get: function () { return radio_1.Radio; } });
17
+ __exportStar(require("./radio"), exports);
@@ -1 +1 @@
1
- export { RadioGroup } from "./radio-group";
1
+ export * from "./radio-group";
@@ -1,5 +1,17 @@
1
1
  "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
2
16
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.RadioGroup = void 0;
4
- var radio_group_1 = require("./radio-group");
5
- Object.defineProperty(exports, "RadioGroup", { enumerable: true, get: function () { return radio_group_1.RadioGroup; } });
17
+ __exportStar(require("./radio-group"), exports);
@@ -35,11 +35,11 @@ const classes_1 = require("@uxf/core/constants/classes");
35
35
  const forwardRef_1 = require("@uxf/core/utils/forwardRef");
36
36
  exports.RadioGroup = (0, forwardRef_1.forwardRef)("RadioGroup", (props, ref) => {
37
37
  // eslint-disable-next-line react/destructuring-assignment
38
- const { isDisabled, error, hiddenLabel, id, isInvalid, label, onChange, options, style, value, variant = "list", } = props;
38
+ const { className, error, hiddenLabel, id, isDisabled, isInvalid, label, onChange, options, style, value, variant = "list", } = props;
39
39
  const innerRef = (0, react_2.useRef)(null);
40
40
  (0, use_input_submit_1.useInputSubmit)(innerRef, "radio-group", isDisabled);
41
41
  const errorId = isInvalid ? `${id}--errormessage` : undefined;
42
- const rootClassName = (0, cx_1.cx)("uxf-radio-group", variant === "list" && "uxf-radio-group--list", variant === "radioButton" && "uxf-radio-group--radioButton", isDisabled && classes_1.CLASSES.IS_DISABLED, isInvalid && classes_1.CLASSES.IS_INVALID);
42
+ const rootClassName = (0, cx_1.cx)("uxf-radio-group", variant === "list" && "uxf-radio-group--list", variant === "radioButton" && "uxf-radio-group--radioButton", isDisabled && classes_1.CLASSES.IS_DISABLED, isInvalid && classes_1.CLASSES.IS_INVALID, className);
43
43
  return (react_2.default.createElement(react_1.RadioGroup, { className: rootClassName, disabled: isDisabled, id: id, onChange: onChange, style: style, value: value },
44
44
  react_2.default.createElement(react_1.RadioGroup.Label, { as: label_1.Label, className: `uxf-radio-group__label ${hiddenLabel ? "uxf-radio-group__label--hidden" : ""}`, ref: ref }, label),
45
45
  react_2.default.createElement("div", { className: "uxf-radio-group__options-wrapper" }, options.map((option) => (react_2.default.createElement(react_1.RadioGroup.Option, { className: (0, cx_1.cx)("uxf-radio-group__option", props.isDisabled && classes_1.CLASSES.IS_DISABLED), disabled: option.disabled, key: option.value.toString(), value: option.value }, (o) => (react_2.default.createElement("div", { className: (0, cx_1.cx)("uxf-radio-group__option__wrapper", o.checked && classes_1.CLASSES.IS_SELECTED) },
@@ -47,12 +47,12 @@ const options = [
47
47
  function Default() {
48
48
  const [value, setValue] = (0, react_1.useState)(options[0].value);
49
49
  return (react_1.default.createElement(react_1.default.Fragment, null,
50
- react_1.default.createElement("div", { className: "space-z-2 flex" },
50
+ react_1.default.createElement("div", { className: "flex space-y-2" },
51
51
  react_1.default.createElement("div", { className: "light w-1/2 p-20" },
52
52
  react_1.default.createElement(index_1.RadioGroup, { id: "radiogroup", label: "Light Radio group", onChange: (v) => setValue(v), options: options, value: value })),
53
53
  react_1.default.createElement("div", { className: "dark w-1/2 bg-gray-900 p-20" },
54
54
  react_1.default.createElement(index_1.RadioGroup, { id: "radiogroup", label: "Dark Radio group", onChange: (v) => setValue(v), options: options, value: value }))),
55
- react_1.default.createElement("div", { className: "space-z-2 flex" },
55
+ react_1.default.createElement("div", { className: "flex space-y-2" },
56
56
  react_1.default.createElement("div", { className: "light w-1/2 p-20" },
57
57
  react_1.default.createElement(index_1.RadioGroup, { id: "radiogroup", label: "Light Radio group radio button", onChange: (v) => setValue(v), options: options, value: value, variant: "radioButton" })),
58
58
  react_1.default.createElement("div", { className: "dark w-1/2 bg-gray-900 p-20" },
@@ -1 +1 @@
1
- export { default as RasterImage } from "./raster-image";
1
+ export * from "./raster-image";
@@ -1,8 +1,17 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
4
15
  };
5
16
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.RasterImage = void 0;
7
- var raster_image_1 = require("./raster-image");
8
- Object.defineProperty(exports, "RasterImage", { enumerable: true, get: function () { return __importDefault(raster_image_1).default; } });
17
+ __exportStar(require("./raster-image"), exports);
@@ -1,7 +1,7 @@
1
- import { ImgHTMLAttributes } from "react";
1
+ import { FC, ImgHTMLAttributes } from "react";
2
2
  import { FileResponse } from "../utils/image";
3
3
  declare type ImgProps = ImgHTMLAttributes<HTMLImageElement>;
4
- interface Props {
4
+ export interface RasterImageProps {
5
5
  alt: string;
6
6
  className?: string;
7
7
  height: number;
@@ -12,5 +12,5 @@ interface Props {
12
12
  src?: FileResponse | null;
13
13
  width: number;
14
14
  }
15
- declare function RasterImage(props: Props): JSX.Element;
16
- export default RasterImage;
15
+ export declare const RasterImage: FC<RasterImageProps>;
16
+ export {};
@@ -3,11 +3,12 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- const react_1 = __importDefault(require("react"));
6
+ exports.RasterImage = void 0;
7
7
  const cx_1 = require("@uxf/core/utils/cx");
8
- const image_1 = require("../utils/image");
9
8
  const resizer_1 = require("@uxf/core/utils/resizer");
10
- function RasterImage(props) {
9
+ const react_1 = __importDefault(require("react"));
10
+ const image_1 = require("../utils/image");
11
+ const RasterImage = (props) => {
11
12
  var _a, _b;
12
13
  // eslint-disable-next-line react/destructuring-assignment
13
14
  const { alt, className, height, imgClassName, loading = "lazy", mode = "responsive", src, width, ...restProps } = props;
@@ -15,5 +16,6 @@ function RasterImage(props) {
15
16
  return (react_1.default.createElement(Element, { className: `uxf-raster-image ${className || ""}` }, src ? (react_1.default.createElement(react_1.default.Fragment, null,
16
17
  (0, image_1.getImgSources)(src, width, height),
17
18
  react_1.default.createElement("img", { alt: alt, className: (0, cx_1.cx)("uxf-raster-image__img", mode === "contain" && "uxf-raster-image__img--contain", mode === "cover" && "uxf-raster-image__img--cover", imgClassName), loading: loading, src: (_a = (0, resizer_1.resizerImageUrl)(src, width, height, {})) !== null && _a !== void 0 ? _a : undefined, srcSet: (_b = (0, image_1.getImgSrcSet)(src, width, height)) !== null && _b !== void 0 ? _b : undefined, ...restProps }))) : null));
18
- }
19
- exports.default = RasterImage;
19
+ };
20
+ exports.RasterImage = RasterImage;
21
+ exports.RasterImage.displayName = "RasterImage";
@@ -1,8 +1,7 @@
1
- /// <reference types="react" />
2
- import { RasterImage } from "./index";
1
+ import React from "react";
3
2
  declare const _default: {
4
3
  title: string;
5
- component: typeof RasterImage;
4
+ component: React.FC<import("./raster-image").RasterImageProps>;
6
5
  };
7
6
  export default _default;
8
7
  export declare function Default(): JSX.Element;
package/select/index.d.ts CHANGED
@@ -1 +1 @@
1
- export { default as Select, SelectProps } from "./select";
1
+ export * from "./select";
package/select/index.js CHANGED
@@ -1,8 +1,17 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
4
15
  };
5
16
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.Select = void 0;
7
- var select_1 = require("./select");
8
- Object.defineProperty(exports, "Select", { enumerable: true, get: function () { return __importDefault(select_1).default; } });
17
+ __exportStar(require("./select"), exports);
@@ -21,5 +21,4 @@ export interface SelectProps<Value = SelectValue, Option = SelectOption<Value>>
21
21
  placeholder?: string;
22
22
  renderOption?: (option: Option) => ReactNode;
23
23
  }
24
- declare const _default: React.ForwardRefExoticComponent<SelectProps<SelectValue, SelectOption<SelectValue>> & React.RefAttributes<HTMLDivElement>>;
25
- export default _default;
24
+ export declare const Select: React.ForwardRefExoticComponent<SelectProps<SelectValue, SelectOption<SelectValue>> & React.RefAttributes<HTMLDivElement>>;
package/select/select.js CHANGED
@@ -23,18 +23,19 @@ var __importStar = (this && this.__importStar) || function (mod) {
23
23
  return result;
24
24
  };
25
25
  Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.Select = void 0;
26
27
  const react_1 = require("@headlessui/react");
27
28
  const classes_1 = require("@uxf/core/constants/classes");
28
29
  const useInputFocus_1 = require("@uxf/core/hooks/useInputFocus");
29
30
  const composeRefs_1 = require("@uxf/core/utils/composeRefs");
30
31
  const cx_1 = require("@uxf/core/utils/cx");
32
+ const forwardRef_1 = require("@uxf/core/utils/forwardRef");
31
33
  const react_2 = __importStar(require("react"));
32
34
  const use_dropdown_1 = require("../hooks/use-dropdown");
33
35
  const icon_1 = require("../icon");
34
36
  const label_1 = require("../label");
35
- const forward_ref_1 = require("../utils/forward-ref");
36
- function Select(props, ref) {
37
- var _a, _b, _c;
37
+ exports.Select = (0, forwardRef_1.forwardRef)("Select", (props, ref) => {
38
+ var _a, _b, _c, _d;
38
39
  const generatedId = (0, react_2.useId)();
39
40
  const id = (_a = props.id) !== null && _a !== void 0 ? _a : generatedId;
40
41
  const selectedOption = props.options.find((option) => option.id === props.value);
@@ -44,16 +45,16 @@ function Select(props, ref) {
44
45
  const dropdown = (0, use_dropdown_1.useDropdown)((_b = props.dropdownPlacement) !== null && _b !== void 0 ? _b : "bottom", true);
45
46
  const stableRef = (0, react_2.useMemo)(() => (0, composeRefs_1.composeRefs)(innerRef, ref, dropdown.reference), [ref, dropdown.reference]);
46
47
  const getIconClassName = (open) => (0, cx_1.cx)("uxf-select__button-icon", open && "is-open");
47
- const iconSize = (_c = props.iconSize) !== null && _c !== void 0 ? _c : 12;
48
+ const iconName = (_c = props.iconName) !== null && _c !== void 0 ? _c : "caretDown";
49
+ const iconSize = (_d = props.iconSize) !== null && _d !== void 0 ? _d : 24;
48
50
  return (react_2.default.createElement(react_1.Listbox, { as: "div", className: (0, cx_1.cx)("uxf-select", props.isInvalid && classes_1.CLASSES.IS_INVALID, props.isRequired && classes_1.CLASSES.IS_REQUIRED, props.isReadOnly && classes_1.CLASSES.IS_READONLY, props.isDisabled && classes_1.CLASSES.IS_DISABLED, props.className), onChange: (v) => { var _a; return (_a = props.onChange) === null || _a === void 0 ? void 0 : _a.call(props, v.id); }, value: selectedOption, disabled: props.isDisabled || props.isReadOnly }, (renderProps) => (react_2.default.createElement(react_2.default.Fragment, null,
49
51
  react_2.default.createElement(react_1.Listbox.Label, { as: label_1.Label, onClick: props.isDisabled || props.isReadOnly ? undefined : input.focus }, props.label),
50
52
  react_2.default.createElement(react_1.Listbox.Button, { as: "div", className: (0, cx_1.cx)("uxf-select__button", (renderProps.open || input.focused) && classes_1.CLASSES.IS_FOCUSED, renderProps.disabled && classes_1.CLASSES.IS_DISABLED, props.isReadOnly && classes_1.CLASSES.IS_READONLY, props.isInvalid && classes_1.CLASSES.IS_INVALID, dropdown.placement === "bottom" && "is-open--bottom", dropdown.placement === "top" && "is-open--top", renderProps.open && "is-open"), onBlur: input.onBlur, onFocus: input.onFocus, tabIndex: props.isDisabled || props.isReadOnly ? undefined : 0, ref: stableRef, "aria-invalid": props.isInvalid, "aria-describedby": errorId },
51
53
  react_2.default.createElement("div", { className: (0, cx_1.cx)("uxf-select__button-text", !(selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.label) && "is-empty") }, (selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.label) || props.placeholder),
52
- props.iconName ? (react_2.default.createElement(icon_1.Icon, { className: getIconClassName(renderProps.open), name: props.iconName, size: iconSize })) : (react_2.default.createElement(icon_1.Icon, { Component: icon_1.ChevronDownIcon, className: getIconClassName(renderProps.open), size: iconSize }))),
54
+ react_2.default.createElement(icon_1.Icon, { className: getIconClassName(renderProps.open), name: iconName, size: iconSize })),
53
55
  react_2.default.createElement(react_1.Listbox.Options, { ref: dropdown.floating, className: (0, cx_1.cx)("uxf-dropdown", dropdown.placement === "bottom" && "uxf-dropdown--bottom", dropdown.placement === "top" && "uxf-dropdown--top") }, props.options.map((option) => {
54
56
  var _a, _b, _c, _d;
55
57
  return (react_2.default.createElement(react_1.Listbox.Option, { key: (_b = (_a = props.keyExtractor) === null || _a === void 0 ? void 0 : _a.call(props, option)) !== null && _b !== void 0 ? _b : option.id, value: option, className: (optionState) => (0, cx_1.cx)("uxf-dropdown__item", optionState.active && classes_1.CLASSES.IS_ACTIVE, optionState.disabled && classes_1.CLASSES.IS_DISABLED, optionState.selected && classes_1.CLASSES.IS_SELECTED) }, (_d = (_c = props.renderOption) === null || _c === void 0 ? void 0 : _c.call(props, option)) !== null && _d !== void 0 ? _d : option.label));
56
58
  })),
57
59
  props.helperText && (react_2.default.createElement("div", { className: (0, cx_1.cx)("uxf-helper-text", props.isInvalid && classes_1.CLASSES.IS_INVALID), id: errorId }, props.helperText))))));
58
- }
59
- exports.default = (0, forward_ref_1.forwardRef)("Select", Select);
60
+ });
@@ -1,6 +1,6 @@
1
+ import { InputProps } from "@uxf/ui/input/input";
1
2
  import { FormControlProps } from "@uxf/ui/types";
2
3
  import React, { KeyboardEventHandler, ReactNode } from "react";
3
- import { InputProps } from "@uxf/ui/input/input";
4
4
  declare type EnterKeyHint = "enter" | "done" | "go" | "next" | "previous" | "search" | "send" | undefined;
5
5
  declare type InputMode = "none" | "text" | "tel" | "url" | "email" | "numeric" | "decimal" | "search" | undefined;
6
6
  export interface TextInputProps extends FormControlProps<string>, Pick<InputProps, "size" | "variant"> {
@@ -24,13 +24,13 @@ var __importStar = (this && this.__importStar) || function (mod) {
24
24
  };
25
25
  Object.defineProperty(exports, "__esModule", { value: true });
26
26
  exports.TextInput = void 0;
27
+ const classes_1 = require("@uxf/core/constants/classes");
28
+ const cx_1 = require("@uxf/core/utils/cx");
29
+ const forwardRef_1 = require("@uxf/core/utils/forwardRef");
27
30
  const input_1 = require("@uxf/ui/input");
28
31
  const react_1 = __importStar(require("react"));
29
- const cx_1 = require("@uxf/core/utils/cx");
30
32
  const form_control_1 = require("../form-control");
31
- const classes_1 = require("@uxf/core/constants/classes");
32
- const forward_ref_1 = require("../utils/forward-ref");
33
- exports.TextInput = (0, forward_ref_1.forwardRef)("TextInput", (props, ref) => {
33
+ exports.TextInput = (0, forwardRef_1.forwardRef)("TextInput", (props, ref) => {
34
34
  var _a;
35
35
  const [isFocused, setIsFocused] = (0, react_1.useState)(false);
36
36
  const generatedId = (0, react_1.useId)();
@@ -36,11 +36,14 @@ exports.default = {
36
36
  };
37
37
  function Full() {
38
38
  const [value, onChange] = (0, react_1.useState)("");
39
- return (react_1.default.createElement("div", { className: "space-y-4" },
39
+ const storyTextInputs = (react_1.default.createElement("div", { className: "space-y-4" },
40
40
  react_1.default.createElement(text_input_1.TextInput, { label: "Default input", value: value, onChange: onChange, helperText: "Helper text", leftAddon: "https://", rightAddon: ".cz", leftElement: "\uD83C\uDF37", rightElement: "\uD83D\uDD14", placeholder: "Some beautiful placeholder..." }),
41
41
  react_1.default.createElement(text_input_1.TextInput, { label: "Error input", value: value, onChange: onChange, helperText: "Error helper text", leftAddon: "https://", rightAddon: ".cz", leftElement: "\uD83C\uDF37", rightElement: "\uD83D\uDD14", placeholder: "Some beautiful placeholder...", isInvalid: true }),
42
42
  react_1.default.createElement(text_input_1.TextInput, { label: "Read only input", value: value, onChange: onChange, helperText: "Error helper text", leftAddon: "https://", rightAddon: ".cz", leftElement: "\uD83C\uDF37", rightElement: "\uD83D\uDD14", placeholder: "Some beautiful placeholder...", isReadOnly: true }),
43
43
  react_1.default.createElement(text_input_1.TextInput, { label: "Disabled input", value: value, onChange: onChange, helperText: "Error helper text", leftAddon: "https://", rightAddon: ".cz", leftElement: "\uD83C\uDF37", rightElement: "\uD83D\uDD14", placeholder: "Some beautiful placeholder...", isDisabled: true })));
44
+ return (react_1.default.createElement(react_1.default.Fragment, null,
45
+ react_1.default.createElement("div", { className: "light space-y-2 p-20" }, storyTextInputs),
46
+ react_1.default.createElement("div", { className: "dark space-y-2 bg-gray-900 p-20" }, storyTextInputs)));
44
47
  }
45
48
  exports.Full = Full;
46
49
  function ComponentStructure() {
@@ -1 +1 @@
1
- export { default as Textarea, TextareaProps } from "./textarea";
1
+ export * from "./textarea";