@onepercentio/one-ui 1.0.3 → 1.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/dist/assets/styles/mixins.scss +12 -10
  2. package/dist/components/Button/Button.d.ts +6 -9
  3. package/dist/components/Button/Button.js +3 -5
  4. package/dist/components/Form/FormField/FormField.js +5 -3
  5. package/dist/components/Form/FormField/FormField.types.d.ts +2 -0
  6. package/dist/components/Form/FormField/FormField.types.js +1 -1
  7. package/dist/components/ProgressBar/ProgressBar.d.ts +4 -2
  8. package/dist/components/ProgressBar/ProgressBar.js +8 -4
  9. package/dist/components/ProgressBar/ProgressBar.module.scss +3 -3
  10. package/dist/components/Select/Select.d.ts +17 -9
  11. package/dist/components/Select/Select.js +24 -11
  12. package/dist/components/Select/Select.module.scss +3 -1
  13. package/dist/components/Slider/Slider.d.ts +7 -0
  14. package/dist/components/Slider/Slider.e2e.d.ts +4 -0
  15. package/dist/components/Slider/Slider.js +66 -0
  16. package/dist/components/Slider/Slider.module.scss +7 -0
  17. package/dist/components/Table/Table.d.ts +6 -4
  18. package/dist/components/Table/Table.js +26 -35
  19. package/dist/components/Table/Table.module.scss +0 -2
  20. package/dist/context/OneUIProvider.js +1 -1
  21. package/dist/hooks/useMergeRefs.d.ts +1 -1
  22. package/dist/hooks/useMergeRefs.js +2 -2
  23. package/dist/hooks/usePagination.js +1 -1
  24. package/dist-ts/assets/styles/mixins.scss +12 -10
  25. package/dist-ts/components/Button/Button.d.ts +6 -9
  26. package/dist-ts/components/Button/Button.js +2 -3
  27. package/dist-ts/components/Button/Button.js.map +1 -1
  28. package/dist-ts/components/Form/FormField/FormField.js +2 -2
  29. package/dist-ts/components/Form/FormField/FormField.js.map +1 -1
  30. package/dist-ts/components/Form/FormField/FormField.types.d.ts +2 -0
  31. package/dist-ts/components/Form/FormField/FormField.types.js.map +1 -1
  32. package/dist-ts/components/ProgressBar/ProgressBar.d.ts +4 -2
  33. package/dist-ts/components/ProgressBar/ProgressBar.js +2 -2
  34. package/dist-ts/components/ProgressBar/ProgressBar.js.map +1 -1
  35. package/dist-ts/components/ProgressBar/ProgressBar.module.scss +3 -3
  36. package/dist-ts/components/Select/Select.d.ts +17 -9
  37. package/dist-ts/components/Select/Select.js +29 -10
  38. package/dist-ts/components/Select/Select.js.map +1 -1
  39. package/dist-ts/components/Select/Select.module.scss +3 -1
  40. package/dist-ts/components/Slider/Slider.d.ts +7 -0
  41. package/dist-ts/components/Slider/Slider.e2e.d.ts +4 -0
  42. package/dist-ts/components/Slider/Slider.e2e.js +3 -0
  43. package/dist-ts/components/Slider/Slider.e2e.js.map +1 -0
  44. package/dist-ts/components/Slider/Slider.js +56 -0
  45. package/dist-ts/components/Slider/Slider.js.map +1 -0
  46. package/dist-ts/components/Slider/Slider.module.scss +7 -0
  47. package/dist-ts/components/Table/Table.d.ts +6 -4
  48. package/dist-ts/components/Table/Table.js +24 -13
  49. package/dist-ts/components/Table/Table.js.map +1 -1
  50. package/dist-ts/components/Table/Table.module.scss +0 -2
  51. package/dist-ts/hooks/useMergeRefs.d.ts +1 -1
  52. package/dist-ts/hooks/useMergeRefs.js +1 -1
  53. package/dist-ts/hooks/useMergeRefs.js.map +1 -1
  54. package/dist-ts/hooks/usePagination.js.map +1 -1
  55. package/package.json +5 -4
@@ -12,7 +12,8 @@ var _Input = _interopRequireDefault(require("../Input"));
12
12
  var _Loader = _interopRequireDefault(require("../Loader"));
13
13
  var _OneUIProvider = require("../../context/OneUIProvider");
14
14
  var _AnchoredTooltip = require("../AnchoredTooltip/AnchoredTooltip");
15
- const _excluded = ["items", "selected", "label", "onClick", "loading", "rootClassName", "dropdownClassName", "alignTo", "filter"];
15
+ const _excluded = ["items", "label", "loading", "rootClassName", "dropdownClassName", "alignTo", "filter"],
16
+ _excluded2 = ["selected", "onClick"];
16
17
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
17
18
  function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
18
19
  function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
@@ -24,9 +25,7 @@ function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t =
24
25
  function Select(_ref) {
25
26
  let {
26
27
  items,
27
- selected,
28
28
  label,
29
- onClick,
30
29
  loading,
31
30
  rootClassName = "",
32
31
  dropdownClassName: _drop = "",
@@ -34,13 +33,22 @@ function Select(_ref) {
34
33
  filter
35
34
  } = _ref,
36
35
  otherProps = _objectWithoutProperties(_ref, _excluded);
36
+ const {
37
+ selected: _,
38
+ onClick: __
39
+ } = otherProps,
40
+ propsToSpread = _objectWithoutProperties(otherProps, _excluded2);
37
41
  const {
38
42
  StateIndicator
39
43
  } = (0, _OneUIProvider.useOneUIContext)().component.select;
40
44
  const collapsableRef = (0, _react.useRef)(null);
41
45
  const _selected = (0, _react.useMemo)(() => {
42
- return items.find(a => a.value === selected);
43
- }, [selected, items]);
46
+ if (otherProps.mode === "multi") return items.filter(a => {
47
+ var _otherProps$selected;
48
+ return (_otherProps$selected = otherProps.selected) === null || _otherProps$selected === void 0 ? void 0 : _otherProps$selected.includes(a.value);
49
+ });
50
+ return items.find(a => a.value === otherProps.selected);
51
+ }, [otherProps.selected, items]);
44
52
  const [open, setOpen] = (0, _react.useState)(false);
45
53
  const [filterTerm, setFilterTerm] = (0, _react.useState)("");
46
54
  const filteredItems = (0, _react.useMemo)(() => {
@@ -65,9 +73,9 @@ function Select(_ref) {
65
73
  }
66
74
  }, [open]);
67
75
  return /*#__PURE__*/_react.default.createElement(_Collapsable.default, {
68
- title: /*#__PURE__*/_react.default.createElement(_Input.default, _extends({}, otherProps, {
69
- className: "".concat(_SelectModule.default.input, " ").concat(selectClasses.input, " ").concat(!items.length ? _SelectModule.default.empty : ""),
70
- value: _selected ? "labelStr" in _selected ? _selected.labelStr : _selected.label : label || "",
76
+ title: /*#__PURE__*/_react.default.createElement(_Input.default, _extends({}, propsToSpread, {
77
+ className: "".concat(_SelectModule.default.input, " ").concat(selectClasses.input, " ").concat(!items.length ? _SelectModule.default.empty : "", " ").concat(otherProps.disabled ? _SelectModule.default.disabled : ""),
78
+ value: Array.isArray(_selected) ? _selected.length ? "(".concat(_selected.length, ") ").concat("labelStr" in _selected[0] ? _selected[0].labelStr : _selected[0].label) : label || "" : _selected ? "labelStr" in _selected ? _selected.labelStr : _selected.label : label || "",
71
79
  disabled: true,
72
80
  Icon: /*#__PURE__*/_react.default.createElement("div", {
73
81
  className: "".concat(_SelectModule.default.indicator)
@@ -79,7 +87,7 @@ function Select(_ref) {
79
87
  mode: "float",
80
88
  open: open,
81
89
  onToggleOpen: open => {
82
- if (items.length) setOpen(open);
90
+ if (items.length && !otherProps.disabled) setOpen(open);
83
91
  },
84
92
  className: "".concat(otherProps.disabled ? "disabled" : "", " ").concat(rootClassName),
85
93
  contentClassName: "".concat(_SelectModule.default.optionsContainer, " ").concat(selectClasses.dropdown),
@@ -112,8 +120,13 @@ function Select(_ref) {
112
120
  type: "caption",
113
121
  key: i.value,
114
122
  className: "".concat(i === _selected ? "".concat(_SelectModule.default.selected, " ").concat(selectClasses.selectedItem) : "", " ").concat(selectClasses.item || ""),
115
- onClick: () => onClick(i)
123
+ onClick: () => {
124
+ if (otherProps.mode === "multi") {
125
+ const curr = otherProps.selected || [];
126
+ otherProps.onClick([...curr.map(iId => items.find(i => i.value === iId)), i]);
127
+ } else otherProps.onClick(i);
128
+ }
116
129
  }, i), i.label))));
117
130
  }
118
131
  var _default = exports.default = Select;
119
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Collapsable","_interopRequireDefault","_Text","_SelectModule","_Input","_Loader","_OneUIProvider","_AnchoredTooltip","_excluded","e","__esModule","default","t","WeakMap","r","n","o","i","f","__proto__","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","_extends","assign","bind","arguments","length","apply","_objectWithoutProperties","_objectWithoutPropertiesLoose","getOwnPropertySymbols","indexOf","propertyIsEnumerable","Select","_ref","items","selected","label","onClick","loading","rootClassName","dropdownClassName","_drop","alignTo","AnchoredTooltipAlignment","CENTER","filter","otherProps","StateIndicator","useOneUIContext","component","select","collapsableRef","useRef","_selected","useMemo","find","a","value","open","setOpen","useState","filterTerm","setFilterTerm","filteredItems","item","useEffect","current","redimension","useLayoutEffect","selectClasses","dropdown","useOneUIConfig","close","window","addEventListener","removeEventListener","createElement","title","className","concat","Styles","input","empty","labelStr","disabled","Icon","indicator","id","undefined","mode","onToggleOpen","contentClassName","optionsContainer","ref","anchorTo","AnchoredTooltipAnchor","BOTTOM","stopPropagation","searchInput","onChange","_ref2","target","decoration","containerProps","map","type","key","selectedItem","_default","exports"],"sources":["../../../src/components/Select/Select.tsx"],"sourcesContent":["import React, {\n  ComponentProps,\n  DetailedHTMLProps,\n  ElementRef,\n  HTMLAttributes,\n  ReactElement,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport Collapsable from \"../Collapsable\";\nimport Text from \"../Text\";\nimport Styles from \"./Select.module.scss\";\nimport Input from \"../Input\";\nimport Loader from \"../Loader\";\nimport {\n  OneUIContextSpecs,\n  useOneUIConfig,\n  useOneUIContext,\n} from \"../../context/OneUIProvider\";\nimport {\n  AnchoredTooltipAlignment,\n  AnchoredTooltipAnchor,\n} from \"../AnchoredTooltip/AnchoredTooltip\";\n\nexport type SelectItem = (\n  | {\n      label: string;\n      value: string;\n    }\n  | {\n      label: ReactElement;\n      labelStr: string;\n      value: string;\n    }\n) &\n  Omit<\n    DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLElement>,\n    \"ref\" | \"color\"\n  >;\n\n/**\n * A dropdown select\n **/\nfunction Select<I extends SelectItem>({\n  items,\n  selected,\n  label,\n  onClick,\n  loading,\n  rootClassName = \"\",\n  dropdownClassName: _drop = \"\",\n  alignTo = AnchoredTooltipAlignment.CENTER,\n  filter,\n  ...otherProps\n}: {\n  loading?: boolean;\n  items: Readonly<I[]>;\n  onClick: (i: I) => void;\n  rootClassName?: string;\n  dropdownClassName?: string;\n  alignTo?: AnchoredTooltipAlignment;\n  filter?: (item: I, term: string) => boolean;\n} & (\n  | {\n      selected?: I[\"value\"];\n      label: string;\n    }\n  | {\n      selected: I[\"value\"];\n      label?: string;\n    }\n) &\n  Omit<ComponentProps<typeof Input>, \"selected\" | \"onClick\">) {\n  const { StateIndicator } = useOneUIContext().component.select;\n  const collapsableRef = useRef<ElementRef<typeof Collapsable>>(null);\n\n  const _selected = useMemo(() => {\n    return items.find((a) => a.value === selected);\n  }, [selected, items]);\n\n  const [open, setOpen] = useState(false);\n  const [filterTerm, setFilterTerm] = useState(\"\");\n\n  const filteredItems = useMemo(() => {\n    if (filter && filterTerm)\n      return items.filter((item) => filter(item, filterTerm));\n    else return items;\n  }, [filterTerm, items]);\n\n  useEffect(() => {\n    collapsableRef.current!.redimension();\n  }, [filteredItems.length]);\n\n  useLayoutEffect(() => {\n    if (open) setFilterTerm(\"\");\n  }, [open]);\n\n  const selectClasses = _drop\n    ? ({\n        dropdown: _drop,\n      } as NonNullable<OneUIContextSpecs[\"component\"][\"select\"][\"className\"]>)\n    : useOneUIConfig(\"component.select.className\", {});\n\n  useEffect(() => {\n    if (open) {\n      const close = () => {\n        setOpen(false);\n      };\n      window.addEventListener(\"click\", close);\n      return () => window.removeEventListener(\"click\", close);\n    }\n  }, [open]);\n\n  return (\n    <Collapsable\n      title={\n        <Input\n          {...otherProps}\n          className={`${Styles.input} ${selectClasses.input} ${\n            !items.length ? Styles.empty : \"\"\n          }`}\n          value={\n            _selected\n              ? \"labelStr\" in _selected\n                ? _selected.labelStr\n                : _selected.label\n              : label || \"\"\n          }\n          disabled\n          Icon={\n            <div className={`${Styles.indicator}`}>\n              {loading ? <Loader /> : <StateIndicator open={!!open} />}\n            </div>\n          }\n        />\n      }\n      id={undefined}\n      mode=\"float\"\n      open={open}\n      onToggleOpen={(open) => {\n        if (items.length) setOpen(open);\n      }}\n      className={`${otherProps.disabled ? \"disabled\" : \"\"} ${rootClassName}`}\n      contentClassName={`${Styles.optionsContainer} ${selectClasses.dropdown}`}\n      alignTo={alignTo}\n      ref={collapsableRef}\n      anchorTo={AnchoredTooltipAnchor.BOTTOM}\n    >\n      <div\n        className={Styles.items}\n        onClick={(e) => {\n          e.stopPropagation();\n          setOpen(false);\n        }}\n      >\n        {filter && (\n          <div className={Styles.searchInput}>\n            <Input\n              onChange={({ target: { value } }) => setFilterTerm(value)}\n              decoration={<span>🔎&nbsp;</span>}\n              containerProps={{\n                onClick: (e) => e.stopPropagation(),\n              }}\n              value={filterTerm}\n            />\n          </div>\n        )}\n        {filteredItems.map((i) => (\n          <Text\n            type=\"caption\"\n            key={i.value}\n            className={`${\n              i === _selected\n                ? `${Styles.selected} ${selectClasses.selectedItem}`\n                : \"\"\n            } ${selectClasses.item || \"\"}`}\n            onClick={() => onClick(i)}\n            {...i}\n          >\n            {i.label}\n          </Text>\n        ))}\n      </div>\n    </Collapsable>\n  );\n}\n\nexport default Select;\n"],"mappings":"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","ignoreList":[]}
132
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Collapsable","_interopRequireDefault","_Text","_SelectModule","_Input","_Loader","_OneUIProvider","_AnchoredTooltip","_excluded","_excluded2","e","__esModule","default","t","WeakMap","r","n","o","i","f","__proto__","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","_extends","assign","bind","arguments","length","apply","_objectWithoutProperties","_objectWithoutPropertiesLoose","getOwnPropertySymbols","indexOf","propertyIsEnumerable","Select","_ref","items","label","loading","rootClassName","dropdownClassName","_drop","alignTo","AnchoredTooltipAlignment","CENTER","filter","otherProps","selected","_","onClick","__","propsToSpread","StateIndicator","useOneUIContext","component","select","collapsableRef","useRef","_selected","useMemo","mode","a","_otherProps$selected","includes","value","find","open","setOpen","useState","filterTerm","setFilterTerm","filteredItems","item","useEffect","current","redimension","useLayoutEffect","selectClasses","dropdown","useOneUIConfig","close","window","addEventListener","removeEventListener","createElement","title","className","concat","Styles","input","empty","disabled","Array","isArray","labelStr","Icon","indicator","id","undefined","onToggleOpen","contentClassName","optionsContainer","ref","anchorTo","AnchoredTooltipAnchor","BOTTOM","stopPropagation","searchInput","onChange","_ref2","target","decoration","containerProps","map","type","key","selectedItem","curr","iId","_default","exports"],"sources":["../../../src/components/Select/Select.tsx"],"sourcesContent":["import React, {\n  ComponentProps,\n  DetailedHTMLProps,\n  ElementRef,\n  HTMLAttributes,\n  ReactElement,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport Collapsable from \"../Collapsable\";\nimport Text from \"../Text\";\nimport Styles from \"./Select.module.scss\";\nimport Input from \"../Input\";\nimport Loader from \"../Loader\";\nimport {\n  OneUIContextSpecs,\n  useOneUIConfig,\n  useOneUIContext,\n} from \"../../context/OneUIProvider\";\nimport {\n  AnchoredTooltipAlignment,\n  AnchoredTooltipAnchor,\n} from \"../AnchoredTooltip/AnchoredTooltip\";\n\nexport type SelectItem = (\n  | {\n      label: string;\n      value: string;\n    }\n  | {\n      label: ReactElement;\n      labelStr: string;\n      value: string;\n    }\n) &\n  Omit<\n    DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLElement>,\n    \"ref\" | \"color\"\n  >;\n\ntype SingleMode<I extends SelectItem> = {\n  mode?: \"single\";\n  onClick: (i: I) => void;\n} & (\n  | {\n      selected?: I[\"value\"];\n      label: string;\n    }\n  | {\n      selected: I[\"value\"];\n      label?: string;\n    }\n);\n\ntype MultiMode<I extends SelectItem> = {\n  mode: \"multi\";\n  onClick: (i: I[]) => void;\n  selected?: I[\"value\"][];\n};\n\n/**\n * A dropdown select\n **/\nfunction Select<I extends SelectItem>({\n  items,\n  label,\n  loading,\n  rootClassName = \"\",\n  dropdownClassName: _drop = \"\",\n  alignTo = AnchoredTooltipAlignment.CENTER,\n  filter,\n  ...otherProps\n}: {\n  loading?: boolean;\n  items: Readonly<I[]>;\n  rootClassName?: string;\n  dropdownClassName?: string;\n  alignTo?: AnchoredTooltipAlignment;\n  filter?: (item: I, term: string) => boolean;\n} & (SingleMode<I> | MultiMode<I>) &\n  Omit<ComponentProps<typeof Input>, \"selected\" | \"onClick\">) {\n  const { selected: _, onClick: __, ...propsToSpread } = otherProps;\n  const { StateIndicator } = useOneUIContext().component.select;\n  const collapsableRef = useRef<ElementRef<typeof Collapsable>>(null);\n\n  const _selected = useMemo(() => {\n    if (otherProps.mode === \"multi\")\n      return items.filter((a) => otherProps.selected?.includes(a.value));\n    return items.find((a) => a.value === otherProps.selected);\n  }, [otherProps.selected, items]);\n\n  const [open, setOpen] = useState(false);\n  const [filterTerm, setFilterTerm] = useState(\"\");\n\n  const filteredItems = useMemo(() => {\n    if (filter && filterTerm)\n      return items.filter((item) => filter(item, filterTerm));\n    else return items;\n  }, [filterTerm, items]);\n\n  useEffect(() => {\n    collapsableRef.current!.redimension();\n  }, [filteredItems.length]);\n\n  useLayoutEffect(() => {\n    if (open) setFilterTerm(\"\");\n  }, [open]);\n\n  const selectClasses = _drop\n    ? ({\n        dropdown: _drop,\n      } as NonNullable<OneUIContextSpecs[\"component\"][\"select\"][\"className\"]>)\n    : useOneUIConfig(\"component.select.className\", {});\n\n  useEffect(() => {\n    if (open) {\n      const close = () => {\n        setOpen(false);\n      };\n      window.addEventListener(\"click\", close);\n      return () => window.removeEventListener(\"click\", close);\n    }\n  }, [open]);\n\n  return (\n    <Collapsable\n      title={\n        <Input\n          {...propsToSpread}\n          className={`${Styles.input} ${selectClasses.input} ${\n            !items.length ? Styles.empty : \"\"\n          } ${otherProps.disabled ? Styles.disabled : \"\"}`}\n          value={\n            Array.isArray(_selected)\n              ? _selected.length\n                ? `(${_selected.length}) ${\n                    \"labelStr\" in _selected[0]\n                      ? _selected[0].labelStr\n                      : _selected[0].label\n                  }`\n                : label || \"\"\n              : _selected\n              ? \"labelStr\" in _selected\n                ? _selected.labelStr\n                : _selected.label\n              : label || \"\"\n          }\n          disabled\n          Icon={\n            <div className={`${Styles.indicator}`}>\n              {loading ? <Loader /> : <StateIndicator open={!!open} />}\n            </div>\n          }\n        />\n      }\n      id={undefined}\n      mode=\"float\"\n      open={open}\n      onToggleOpen={(open) => {\n        if (items.length && !otherProps.disabled) setOpen(open);\n      }}\n      className={`${otherProps.disabled ? \"disabled\" : \"\"} ${rootClassName}`}\n      contentClassName={`${Styles.optionsContainer} ${selectClasses.dropdown}`}\n      alignTo={alignTo}\n      ref={collapsableRef}\n      anchorTo={AnchoredTooltipAnchor.BOTTOM}\n    >\n      <div\n        className={Styles.items}\n        onClick={(e) => {\n          e.stopPropagation();\n          setOpen(false);\n        }}\n      >\n        {filter && (\n          <div className={Styles.searchInput}>\n            <Input\n              onChange={({ target: { value } }) => setFilterTerm(value)}\n              decoration={<span>🔎&nbsp;</span>}\n              containerProps={{\n                onClick: (e) => e.stopPropagation(),\n              }}\n              value={filterTerm}\n            />\n          </div>\n        )}\n        {filteredItems.map((i) => (\n          <Text\n            type=\"caption\"\n            key={i.value}\n            className={`${\n              i === _selected\n                ? `${Styles.selected} ${selectClasses.selectedItem}`\n                : \"\"\n            } ${selectClasses.item || \"\"}`}\n            onClick={() => {\n              if (otherProps.mode === \"multi\") {\n                const curr = otherProps.selected || [];\n                otherProps.onClick([\n                  ...curr.map((iId) => items.find((i) => i.value === iId)!),\n                  i,\n                ]);\n              } else otherProps.onClick(i);\n            }}\n            {...i}\n          >\n            {i.label}\n          </Text>\n        ))}\n      </div>\n    </Collapsable>\n  );\n}\n\nexport default Select;\n"],"mappings":"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","ignoreList":[]}
@@ -20,7 +20,9 @@
20
20
  opacity: 0.3;
21
21
  }
22
22
  .input {
23
- cursor: pointer;
23
+ &:not(.disabled) {
24
+ cursor: pointer;
25
+ }
24
26
  input {
25
27
  transition: opacity $fast;
26
28
  padding-right: 30px;
@@ -0,0 +1,7 @@
1
+ import { ComponentProps } from "react";
2
+ import { BalancedProgressBar } from "../ProgressBar";
3
+ export default function Slider(p: Pick<ComponentProps<typeof BalancedProgressBar>, "size" | "min" | "max"> & {
4
+ step?: number;
5
+ value?: number;
6
+ onChange(v: number): void;
7
+ }): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,4 @@
1
+ export declare const SLIDER_TEST_IDS: {
2
+ INDICATOR: string;
3
+ BODY: string;
4
+ };
@@ -0,0 +1,66 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = Slider;
7
+ var _react = require("react");
8
+ var _ProgressBar = require("../ProgressBar");
9
+ var _Slider = require("./Slider.e2e");
10
+ var _throttle = _interopRequireDefault(require("lodash/throttle"));
11
+ var _SliderModule = _interopRequireDefault(require("./Slider.module.scss"));
12
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
13
+ function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
14
+ function Slider(p) {
15
+ const {
16
+ value: externalValue,
17
+ onChange
18
+ } = p;
19
+ const [controlledValue, setCurrValue] = (0, _react.useState)(externalValue || p.min);
20
+ const indicator = (0, _react.useRef)(null);
21
+ const body = (0, _react.useRef)(null);
22
+ const throttleOnChange = (0, _react.useMemo)(() => (0, _throttle.default)(onChange, 1000 / 24), []);
23
+ (0, _react.useEffect)(() => {
24
+ throttleOnChange(controlledValue);
25
+ }, [controlledValue]);
26
+ (0, _react.useEffect)(() => {
27
+ setTimeout(() => {
28
+ const position = body.current.getBoundingClientRect();
29
+ function updateValue(e) {
30
+ const isAt = e.pageX;
31
+ const isAtRelativeToBodyWidth = isAt - position.x;
32
+ const isAtPercent = isAtRelativeToBodyWidth * 100 / position.width;
33
+ const mathToFixed = Number(isAtPercent.toFixed(0));
34
+ const normalized = p.min + (p.max - p.min) * (mathToFixed / 100);
35
+ const stepNormalization = (() => {
36
+ if (!p.step) return normalized;else {
37
+ const modulus = normalized % p.step;
38
+ const toOne = modulus / p.step;
39
+ const rounded = Math.round(toOne);
40
+ const incOrNot = rounded * p.step;
41
+ const finalNormalization = normalized - modulus + incOrNot;
42
+ return finalNormalization;
43
+ }
44
+ })();
45
+ setCurrValue(stepNormalization < p.min ? p.min : stepNormalization > p.max ? p.max : stepNormalization);
46
+ }
47
+ indicator.current.setAttribute("data-testid", _Slider.SLIDER_TEST_IDS.INDICATOR);
48
+ indicator.current.classList.add(_SliderModule.default.indicator);
49
+ indicator.current.onmousedown = e => {
50
+ updateValue(e);
51
+ window.addEventListener("mousemove", updateValue);
52
+ window.onmouseup = () => {
53
+ window.removeEventListener("mousemove", updateValue);
54
+ };
55
+ };
56
+ }, 500);
57
+ }, []);
58
+ return /*#__PURE__*/React.createElement(_ProgressBar.BalancedProgressBar, _extends({
59
+ current: externalValue || controlledValue,
60
+ mode: "guide"
61
+ }, p, {
62
+ indicatorRef: indicator,
63
+ bodyRef: body
64
+ }));
65
+ }
66
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_ProgressBar","_Slider","_throttle","_interopRequireDefault","_SliderModule","e","__esModule","default","_extends","Object","assign","bind","n","arguments","length","t","r","hasOwnProperty","call","apply","Slider","p","value","externalValue","onChange","controlledValue","setCurrValue","useState","min","indicator","useRef","body","throttleOnChange","useMemo","throttle","useEffect","setTimeout","position","current","getBoundingClientRect","updateValue","isAt","pageX","isAtRelativeToBodyWidth","x","isAtPercent","width","mathToFixed","Number","toFixed","normalized","max","stepNormalization","step","modulus","toOne","rounded","Math","round","incOrNot","finalNormalization","setAttribute","SLIDER_TEST_IDS","INDICATOR","classList","add","St","onmousedown","window","addEventListener","onmouseup","removeEventListener","React","createElement","BalancedProgressBar","mode","indicatorRef","bodyRef"],"sources":["../../../src/components/Slider/Slider.tsx"],"sourcesContent":["import { ComponentProps, useEffect, useMemo, useRef, useState } from \"react\";\nimport ProgressBar, { BalancedProgressBar } from \"../ProgressBar\";\nimport { SLIDER_TEST_IDS } from \"./Slider.e2e\";\nimport throttle from \"lodash/throttle\";\nimport St from \"./Slider.module.scss\"\n\nexport default function Slider(\n  p: Pick<\n    ComponentProps<typeof BalancedProgressBar>,\n    \"size\" | \"min\" | \"max\"\n  > & { step?: number; value?: number; onChange(v: number): void }\n) {\n  const { value: externalValue, onChange } = p;\n  const [controlledValue, setCurrValue] = useState(externalValue || p.min);\n  const indicator = useRef<HTMLSpanElement>(null!);\n  const body = useRef<HTMLDivElement>(null!);\n  const throttleOnChange = useMemo(() => throttle(onChange, 1000 / 24), []);\n\n  useEffect(() => {\n    throttleOnChange(controlledValue);\n  }, [controlledValue]);\n\n  useEffect(() => {\n    setTimeout(() => {\n      const position = body.current.getBoundingClientRect();\n      function updateValue(e: MouseEvent) {\n        const isAt = e.pageX;\n        const isAtRelativeToBodyWidth = isAt - position.x;\n        const isAtPercent = (isAtRelativeToBodyWidth * 100) / position.width;\n        const mathToFixed = Number(isAtPercent.toFixed(0));\n        const normalized = p.min + (p.max - p.min) * (mathToFixed / 100);\n        const stepNormalization = (() => {\n          if (!p.step) return normalized;\n          else {\n            const modulus = normalized % p.step;\n            const toOne = modulus / p.step;\n            const rounded = Math.round(toOne);\n            const incOrNot = rounded * p.step;\n            const finalNormalization = normalized - modulus + incOrNot;\n            return finalNormalization;\n          }\n        })();\n        setCurrValue(\n          stepNormalization < p.min\n            ? p.min\n            : stepNormalization > p.max\n            ? p.max\n            : stepNormalization\n        );\n      }\n      indicator.current.setAttribute(\"data-testid\", SLIDER_TEST_IDS.INDICATOR);\n      indicator.current.classList.add(St.indicator)\n      indicator.current.onmousedown = (e) => {\n        updateValue(e);\n        window.addEventListener(\"mousemove\", updateValue);\n        window.onmouseup = () => {\n          window.removeEventListener(\"mousemove\", updateValue);\n        };\n      };\n    }, 500);\n  }, []);\n\n  return (\n    <BalancedProgressBar\n      current={externalValue || controlledValue}\n      mode=\"guide\"\n      {...p}\n      indicatorRef={indicator}\n      bodyRef={body}\n    />\n  );\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,7 @@
1
+ @import "../../assets/styles/variables.scss";
2
+ @import "../../assets/styles/mixins.scss";
3
+
4
+ .indicator {
5
+ @include iteractibleElement();
6
+ transition: left var(--animation-speed-transition, $fast) ease-out, transform var(--animation-speed-transition, $fast) ease-out !important;
7
+ }
@@ -1,16 +1,18 @@
1
1
  export type TableProps<I extends any> = {
2
+ /** The list of items to render on the table */
3
+ items: (I & {
4
+ className?: string;
5
+ })[] | undefined;
2
6
  className?: string;
7
+ /** A map of header ID */
3
8
  heading: {
4
9
  [K in keyof I]?: string;
5
10
  };
6
11
  order: (keyof I)[];
7
- items: (I & {
8
- className?: string;
9
- })[];
10
12
  paginable?: {
11
- currentPage: number;
12
13
  totalItems: number;
13
14
  togglePage: (page: number) => void;
15
+ pageSize: number;
14
16
  };
15
17
  };
16
18
  /**
@@ -6,7 +6,6 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports.default = Table;
7
7
  var _react = _interopRequireWildcard(require("react"));
8
8
  var _OneUIProvider = require("../../context/OneUIProvider");
9
- var _Button = _interopRequireDefault(require("../Button"));
10
9
  var _Spacing = _interopRequireDefault(require("../Spacing"));
11
10
  var _UncontrolledTransition = _interopRequireDefault(require("../UncontrolledTransition"));
12
11
  var _TableModule = _interopRequireDefault(require("./Table.module.scss"));
@@ -24,43 +23,33 @@ function Table(_ref) {
24
23
  className = ""
25
24
  } = _ref;
26
25
  const transitionRef = (0, _react.useRef)(null);
26
+ const [currPage, setCurrPage] = (0, _react.useState)(0);
27
27
  const {
28
- controls: {
29
- NextPage = _ref2 => {
30
- let {
31
- disabled
32
- } = _ref2;
33
- return /*#__PURE__*/_react.default.createElement(_Button.default, {
34
- disabled: disabled,
35
- variant: "filled"
36
- }, ">");
37
- },
38
- PrevPage = _ref3 => {
39
- let {
40
- disabled
41
- } = _ref3;
42
- return /*#__PURE__*/_react.default.createElement(_Button.default, {
43
- disabled: disabled,
44
- variant: "filled"
45
- }, "<");
46
- }
28
+ NextPage,
29
+ PrevPage
30
+ } = (0, _OneUIProvider.useOneUIConfig)("component.table.controls");
31
+ const itemsToShow = (0, _react.useMemo)(() => {
32
+ if (paginable) {
33
+ const from = currPage * paginable.pageSize;
34
+ return (items === null || items === void 0 ? void 0 : items.slice(from, from + paginable.pageSize)) || [];
35
+ } else {
36
+ return items;
47
37
  }
48
- } = (0, _OneUIProvider.useOneUIContext)().component.table;
38
+ }, [items, currPage]);
39
+ console.log("Showing", itemsToShow);
49
40
  const {
50
- items: itemsToShow,
51
41
  pages
52
42
  } = (0, _react.useMemo)(() => {
53
43
  if (paginable) {
54
- const numPages = Math.ceil(paginable.totalItems / 5);
44
+ const numPages = Math.ceil(paginable.totalItems / paginable.pageSize);
55
45
  return {
56
- items: items.slice((paginable.currentPage - 1) * 5, (paginable.currentPage - 1) * 5 + 5),
57
46
  pages: numPages
58
47
  };
59
48
  }
60
49
  return {
61
50
  items: items
62
51
  };
63
- }, [items, paginable === null || paginable === void 0 ? void 0 : paginable.currentPage, paginable === null || paginable === void 0 ? void 0 : paginable.totalItems]);
52
+ }, [items, currPage, paginable === null || paginable === void 0 ? void 0 : paginable.totalItems]);
64
53
  const Wrapper = paginable ? _UncontrolledTransition.default : "div";
65
54
  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(TableContext.Provider, {
66
55
  value: {
@@ -72,9 +61,9 @@ function Table(_ref) {
72
61
  className: _TableModule.default.transitionContainer,
73
62
  ref: transitionRef
74
63
  }, /*#__PURE__*/_react.default.createElement(TableComp, {
75
- key: paginable === null || paginable === void 0 ? void 0 : paginable.currentPage,
64
+ key: currPage,
76
65
  className: className
77
- }))), paginable && paginable.totalItems > 5 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_Spacing.default, {
66
+ }))), paginable && paginable.totalItems > paginable.pageSize ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_Spacing.default, {
78
67
  size: "small"
79
68
  }), /*#__PURE__*/_react.default.createElement("div", {
80
69
  className: _TableModule.default.footer
@@ -82,27 +71,29 @@ function Table(_ref) {
82
71
  className: _TableModule.default.iterable,
83
72
  onClick: () => {
84
73
  if (!(transitionRef.current instanceof HTMLDivElement)) transitionRef.current.setOrientation("backward");
85
- paginable.togglePage(paginable.currentPage - 1);
74
+ paginable.togglePage(currPage - 1);
75
+ setCurrPage(currPage - 1);
86
76
  }
87
77
  }, /*#__PURE__*/_react.default.createElement(PrevPage, {
88
- disabled: paginable.currentPage === 1
78
+ disabled: currPage === 0
89
79
  })), /*#__PURE__*/_react.default.createElement("span", {
90
80
  className: _TableModule.default.paging
91
- }, "".concat(paginable.currentPage, "/").concat(pages)), /*#__PURE__*/_react.default.createElement("span", {
81
+ }, "".concat(currPage + 1, "/").concat(pages)), /*#__PURE__*/_react.default.createElement("span", {
92
82
  className: _TableModule.default.iterable,
93
83
  onClick: () => {
94
84
  if (!(transitionRef.current instanceof HTMLDivElement)) transitionRef.current.setOrientation("forward");
95
- paginable.togglePage(paginable.currentPage + 1);
85
+ paginable.togglePage(currPage + 1);
86
+ setCurrPage(currPage + 1);
96
87
  }
97
88
  }, /*#__PURE__*/_react.default.createElement(NextPage, {
98
- disabled: paginable.currentPage === pages
89
+ disabled: currPage === pages - 1
99
90
  })))) : null);
100
91
  }
101
92
  const TableContext = /*#__PURE__*/(0, _react.createContext)(null);
102
- function TableComp(_ref4) {
93
+ function TableComp(_ref2) {
103
94
  let {
104
95
  className
105
- } = _ref4;
96
+ } = _ref2;
106
97
  const {
107
98
  itemsToShow,
108
99
  keys,
@@ -119,4 +110,4 @@ function TableComp(_ref4) {
119
110
  key: String(key)
120
111
  }, i[key]))))));
121
112
  }
122
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_OneUIProvider","_Button","_interopRequireDefault","_Spacing","_UncontrolledTransition","_TableModule","e","__esModule","default","t","WeakMap","r","n","o","i","f","__proto__","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","Table","_ref","paginable","heading","order","items","className","transitionRef","useRef","controls","NextPage","_ref2","disabled","createElement","variant","PrevPage","_ref3","useOneUIContext","component","table","itemsToShow","pages","useMemo","numPages","Math","ceil","totalItems","slice","currentPage","Wrapper","UncontrolledTransition","Fragment","TableContext","Provider","value","keys","Styles","transitionContainer","ref","TableComp","key","size","footer","iterable","onClick","current","HTMLDivElement","setOrientation","togglePage","paging","concat","createContext","_ref4","useContext","container","map","String","index"],"sources":["../../../src/components/Table/Table.tsx"],"sourcesContent":["import React, {\n  createContext,\n  ElementRef,\n  useContext,\n  useMemo,\n  useRef,\n} from \"react\";\nimport { useOneUIContext } from \"../../context/OneUIProvider\";\nimport Button from \"../Button\";\nimport Spacing from \"../Spacing\";\nimport UncontrolledTransition from \"../UncontrolledTransition\";\nimport Styles from \"./Table.module.scss\";\n\nexport type TableProps<I extends any> = {\n  className?: string;\n  heading: {\n    [K in keyof I]?: string;\n  };\n  order: (keyof I)[];\n  items: (I & { className?: string })[];\n  paginable?: {\n    currentPage: number;\n    totalItems: number;\n    togglePage: (page: number) => void;\n  };\n};\n\n/**\n * A simple table layout\n **/\nexport default function Table<I extends any>({\n  paginable,\n  heading,\n  order,\n  items,\n  className = \"\",\n}: TableProps<I>) {\n  const transitionRef =\n    useRef<ElementRef<typeof UncontrolledTransition> | HTMLDivElement>(null);\n  const {\n    controls: {\n      NextPage = ({ disabled }) => (\n        <Button disabled={disabled} variant=\"filled\">\n          {\">\"}\n        </Button>\n      ),\n      PrevPage = ({ disabled }) => (\n        <Button disabled={disabled} variant=\"filled\">\n          {\"<\"}\n        </Button>\n      ),\n    },\n  } = useOneUIContext().component.table;\n\n  const { items: itemsToShow, pages } = useMemo(() => {\n    if (paginable) {\n      const numPages = Math.ceil(paginable.totalItems / 5);\n\n      return {\n        items: items.slice(\n          (paginable.currentPage - 1) * 5,\n          (paginable.currentPage - 1) * 5 + 5\n        ),\n        pages: numPages,\n      };\n    }\n    return {\n      items: items,\n    };\n  }, [items, paginable?.currentPage, paginable?.totalItems]);\n\n  const Wrapper = paginable ? UncontrolledTransition : \"div\";\n\n  return (\n    <>\n      <TableContext.Provider\n        value={{\n          itemsToShow,\n          keys: order,\n          heading,\n        }}\n      >\n        <Wrapper\n          className={Styles.transitionContainer}\n          ref={transitionRef as any}\n        >\n          <TableComp key={paginable?.currentPage} className={className} />\n        </Wrapper>\n      </TableContext.Provider>\n      {paginable && paginable.totalItems > 5 ? (\n        <>\n          <Spacing size=\"small\" />\n          <div className={Styles.footer} data-testid=\"controls\">\n            <span\n              className={Styles.iterable}\n              onClick={() => {\n                if (!(transitionRef.current instanceof HTMLDivElement))\n                  transitionRef.current!.setOrientation(\"backward\");\n                paginable.togglePage(paginable.currentPage - 1);\n              }}\n            >\n              <PrevPage disabled={paginable.currentPage === 1} />\n            </span>\n            <span\n              className={Styles.paging}\n            >{`${paginable.currentPage}/${pages}`}</span>\n            <span\n              className={Styles.iterable}\n              onClick={() => {\n                if (!(transitionRef.current instanceof HTMLDivElement))\n                  transitionRef.current!.setOrientation(\"forward\");\n                paginable.togglePage(paginable.currentPage + 1);\n              }}\n            >\n              <NextPage disabled={paginable.currentPage === pages} />\n            </span>\n          </div>\n        </>\n      ) : null}\n    </>\n  );\n}\n\nconst TableContext = createContext<{\n  itemsToShow: any[];\n  keys: any[];\n  heading: { [k: string]: string | undefined };\n}>(null as any);\n\nfunction TableComp({ className }: { className: string }) {\n  const { itemsToShow, keys, heading } = useContext(TableContext);\n  return (\n    <table className={`${Styles.container} ${className}`}>\n      <thead>\n        <tr>\n          {keys.map((key) => (\n            <th key={String(key)}>{heading[key]}</th>\n          ))}\n        </tr>\n      </thead>\n      <tbody>\n        {itemsToShow.map((i, index) => (\n          <tr key={String(index)} className={i.className}>\n            {keys.map((key) => (\n              <td key={String(key)}>{i[key]}</td>\n            ))}\n          </tr>\n        ))}\n      </tbody>\n    </table>\n  );\n}\n"],"mappings":"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","ignoreList":[]}
113
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_OneUIProvider","_Spacing","_interopRequireDefault","_UncontrolledTransition","_TableModule","e","__esModule","default","t","WeakMap","r","n","o","i","f","__proto__","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","Table","_ref","paginable","heading","order","items","className","transitionRef","useRef","currPage","setCurrPage","useState","NextPage","PrevPage","useOneUIConfig","itemsToShow","useMemo","from","pageSize","slice","console","log","pages","numPages","Math","ceil","totalItems","Wrapper","UncontrolledTransition","createElement","Fragment","TableContext","Provider","value","keys","Styles","transitionContainer","ref","TableComp","key","size","footer","iterable","onClick","current","HTMLDivElement","setOrientation","togglePage","disabled","paging","concat","createContext","_ref2","useContext","container","map","String","index"],"sources":["../../../src/components/Table/Table.tsx"],"sourcesContent":["import React, {\n  createContext,\n  ElementRef,\n  useContext,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { useOneUIConfig } from \"../../context/OneUIProvider\";\nimport Spacing from \"../Spacing\";\nimport UncontrolledTransition from \"../UncontrolledTransition\";\nimport Styles from \"./Table.module.scss\";\n\nexport type TableProps<I extends any> = {\n  /** The list of items to render on the table */\n  items: (I & { className?: string })[] | undefined;\n  className?: string;\n  /** A map of header ID */\n  heading: {\n    [K in keyof I]?: string;\n  };\n  order: (keyof I)[];\n  paginable?: {\n    totalItems: number;\n    togglePage: (page: number) => void;\n    pageSize: number;\n  };\n};\n\n/**\n * A simple table layout\n **/\nexport default function Table<I extends any>({\n  paginable,\n  heading,\n  order,\n  items,\n  className = \"\",\n}: TableProps<I>) {\n  const transitionRef = useRef<\n    ElementRef<typeof UncontrolledTransition> | HTMLDivElement\n  >(null);\n\n  const [currPage, setCurrPage] = useState(0);\n\n  const { NextPage, PrevPage } = useOneUIConfig(\"component.table.controls\");\n  const itemsToShow = useMemo(() => {\n    if (paginable) {\n      const from = currPage * paginable.pageSize;\n      return items?.slice(from, from + paginable.pageSize) || [];\n    } else {\n      return items;\n    }\n  }, [items, currPage]);\n  console.log(\"Showing\", itemsToShow);\n  \n\n  const { pages } = useMemo(() => {\n    if (paginable) {\n      const numPages = Math.ceil(paginable.totalItems / paginable.pageSize);\n\n      return {\n        pages: numPages,\n      };\n    }\n    return {\n      items: items,\n    };\n  }, [items, currPage, paginable?.totalItems]);\n\n  const Wrapper = paginable ? UncontrolledTransition : \"div\";\n\n  return (\n    <>\n      <TableContext.Provider\n        value={{\n          itemsToShow,\n          keys: order,\n          heading,\n        }}\n      >\n        <Wrapper\n          className={Styles.transitionContainer}\n          ref={transitionRef as any}\n        >\n          <TableComp key={currPage} className={className} />\n        </Wrapper>\n      </TableContext.Provider>\n      {paginable && paginable.totalItems > paginable.pageSize ? (\n        <>\n          <Spacing size=\"small\" />\n          <div className={Styles.footer} data-testid=\"controls\">\n            <span\n              className={Styles.iterable}\n              onClick={() => {\n                if (!(transitionRef.current instanceof HTMLDivElement))\n                  transitionRef.current!.setOrientation(\"backward\");\n                paginable.togglePage(currPage - 1);\n                setCurrPage(currPage - 1);\n              }}\n            >\n              <PrevPage disabled={currPage === 0} />\n            </span>\n            <span className={Styles.paging}>{`${currPage + 1}/${pages}`}</span>\n            <span\n              className={Styles.iterable}\n              onClick={() => {\n                if (!(transitionRef.current instanceof HTMLDivElement))\n                  transitionRef.current!.setOrientation(\"forward\");\n                paginable.togglePage(currPage + 1);\n                setCurrPage(currPage + 1);\n              }}\n            >\n              <NextPage disabled={currPage === pages! - 1} />\n            </span>\n          </div>\n        </>\n      ) : null}\n    </>\n  );\n}\n\nconst TableContext = createContext<{\n  itemsToShow: any[];\n  keys: any[];\n  heading: { [k: string]: string | undefined };\n}>(null as any);\n\nfunction TableComp({ className }: { className: string }) {\n  const { itemsToShow, keys, heading } = useContext(TableContext);\n  return (\n    <table className={`${Styles.container} ${className}`}>\n      <thead>\n        <tr>\n          {keys.map((key) => (\n            <th key={String(key)}>{heading[key]}</th>\n          ))}\n        </tr>\n      </thead>\n      <tbody>\n        {itemsToShow.map((i, index) => (\n          <tr key={String(index)} className={i.className}>\n            {keys.map((key) => (\n              <td key={String(key)}>{i[key]}</td>\n            ))}\n          </tr>\n        ))}\n      </tbody>\n    </table>\n  );\n}\n"],"mappings":"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","ignoreList":[]}
@@ -61,8 +61,6 @@
61
61
  --button-min-height: auto;
62
62
 
63
63
  .paging {
64
- font-family: $mainFontFamily;
65
- color: $digitalBlue;
66
64
  margin: 0px 12px;
67
65
  font-size: 18px;
68
66
  }
@@ -96,4 +96,4 @@ function useCurrentImageScale() {
96
96
  const context = (0, _react.useContext)(Context);
97
97
  return context.state.imageScale;
98
98
  }
99
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_get","_interopRequireDefault","require","_merge","_cloneDeep","_react","_interopRequireWildcard","_useAdaptiveImage","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","Context","createContext","OneUIProvider","_ref","children","config","prevCtx","useContext","scale","useAdaptiveImage","mergedConfig","useMemo","merge","clone","state","imageScale","createElement","Provider","value","_default","exports","pathToJson","path","key","exampleConfig","arguments","length","undefined","split","slice","replace","concat","reduce","result","idx","arr","k","ErrorWrapper","originalObject","Proxy","_target","Symbol","toPrimitive","filter","Boolean","join","pathJson","Error","JSON","stringify","useOneUIContext","context","process","env","NODE_ENV","useOneUIView","oneuiConfigPath","componentName","providedValue","useOneUIConfig","prop","defaultValue","val","endsWith","useCurrentImageScale"],"sources":["../../src/context/OneUIProvider.tsx"],"sourcesContent":["import { JSX } from \"react\";\nimport get from \"lodash/get\";\nimport merge from \"lodash/merge\";\nimport clone from \"lodash/cloneDeep\";\nimport { Get } from \"type-fest\";\nimport React, { ComponentProps, ReactElement, ReactNode, useMemo } from \"react\";\nimport { createContext, PropsWithChildren, useContext } from \"react\";\nimport { ImageScales } from \"@muritavo/webpack-microfrontend-scripts/bin/types/ImageScales\";\nimport { UploadTask } from \"firebase/storage\";\nimport {\n  FieldPath,\n  FromOnePercentUtility,\n  NamespaceAccessors,\n  Path,\n  PathObject,\n} from \"../type-utils\";\nimport useAdaptiveImage from \"../hooks/ui/useAdaptiveImage\";\nimport Button from \"../components/Button\";\nimport CheckBox from \"../components/CheckBox\";\nimport Radio from \"../components/Radio/Radio\";\nimport { FileInputViewProps } from \"../components/FileInput/View/View.types\";\nimport {\n  AnswerByField,\n  FormField,\n  GenericFormFieldProps,\n} from \"../components/Form/FormField/FormField.types\";\nimport { BaseQuestion, FormMode } from \"../components/Form/Form.types\";\n\ntype DeepPartial<T> = {\n  [P in keyof T]?: NonNullable<T[P]> extends Function\n    ? T[P]\n    : DeepPartial<T[P]>;\n};\n\ntype IfUtilityHas<\n  N extends NamespaceAccessors,\n  Declare\n> = FromOnePercentUtility<N> extends `To define this property you need to set OnepercentUtility.${string} globally`\n  ? undefined\n  : Declare;\n\nexport type OneUIContextSpecs = {\n  component: {\n    spacing: {\n      variants: {\n        [k in FromOnePercentUtility<\"UIElements.SpacingVariants\">]: string;\n      };\n    };\n    collapsable: {\n      className: string;\n    };\n    form: {\n      fieldWrapper: {\n        [k in `${keyof typeof FormMode}-${FormField[\"type\"]}`]:\n          | string\n          | ((p: PropsWithChildren<FormField & { value: any }>) => ReactNode);\n      };\n      titleVariant: FromOnePercentUtility<\"UIElements.TextVariants\">;\n      labelVariant: FromOnePercentUtility<\"UIElements.TextVariants\">;\n      /** Label shown when a field is optional */\n      optionalLabel: string;\n\n      /** Label shown when a required field was not provided */\n      requiredLabel: string;\n\n      onFileUpload(questionId: string, file: File): UploadTask;\n\n      extensions: IfUtilityHas<\n        \"UIElements.FormExtension\",\n        {\n          [K in FromOnePercentUtility<\"UIElements.FormExtension\">[\"fields\"][\"type\"]]: {\n            Input: (props: GenericFormFieldProps<K>) => ReactElement;\n            validator: (\n              answer: AnswerByField<{ type: K }> | undefined,\n              question: BaseQuestion &\n                (FromOnePercentUtility<\"UIElements.FormExtension\">[\"fields\"] & {\n                  type: K;\n                })\n            ) => {\n              isValid: boolean;\n              error?: string;\n            };\n          };\n        }\n      >;\n    };\n    text: IfUtilityHas<\n      \"UIElements.TextVariants\",\n      {\n        className: {\n          [k in React.ComponentProps<\n            typeof import(\"../components/Text\")[\"default\"]\n          >[\"type\"]]: string;\n        };\n        htmlTag: {\n          [k in React.ComponentProps<\n            typeof import(\"../components/Text\")[\"default\"]\n          >[\"type\"]]: \"p\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\";\n        };\n      }\n    >;\n    button?: {\n      className?: {\n        [k in NonNullable<\n          React.ComponentProps<\n            typeof import(\"../components/Button\")[\"default\"]\n          >[\"variant\"]\n        >]?: string;\n      };\n      Component?: (props: ComponentProps<typeof Button>) => ReactElement;\n    };\n    input: {\n      className: {\n        /** The wrapper around input tag & caption element (used for error and caption) */\n        container: string;\n        /** The input html tag */\n        input: string;\n      };\n    };\n    fileInput: {\n      View: (props: FileInputViewProps) => ReactElement;\n    };\n    passwordInput: {\n      iconSrc: {\n        passwordHidden: string;\n        passwordVisible: string;\n      };\n    };\n    asyncWrapper: {\n      LoadingComponent?: () => JSX.Element;\n      messages: {\n        error: {\n          title: string;\n          retryBtn: string;\n        };\n      };\n    };\n    select: {\n      StateIndicator: (props: { open: boolean }) => JSX.Element;\n      className?: {\n        dropdown?: string;\n        item?: string;\n        selectedItem?: string;\n        input?: string;\n      };\n    };\n    header: {\n      LogoImage: () => JSX.Element;\n      MoreOptions: ({ open }: { open: boolean }) => JSX.Element;\n    };\n    table: {\n      controls: {\n        PrevPage: ({ disabled }: { disabled: boolean }) => JSX.Element;\n        NextPage: ({ disabled }: { disabled: boolean }) => JSX.Element;\n      };\n    };\n    tooltip: {\n      className?: string;\n    };\n    adaptiveDialog: {\n      dialogClassName: string;\n      backdropClassName: string;\n      variant: {\n        [k in FromOnePercentUtility<\"UIElements.AdaptiveDialogVariants\">]: string;\n      };\n    };\n    adaptiveSidebar: {\n      className: string;\n      controlClassName: string;\n    };\n    checkbox: {\n      Component?: (props: ComponentProps<typeof CheckBox>) => ReactElement;\n    };\n    radio: {\n      Component?: (props: ComponentProps<typeof Radio>) => ReactElement;\n    };\n    tabs: {\n      item: string;\n      container: string;\n    };\n  };\n  hook: {\n    ui: {\n      usePaginationControls: {\n        LeftControl: () => ReactElement;\n        RightControl: () => ReactElement;\n        className?: string;\n      };\n    };\n  };\n  state: {\n    imageScale: ImageScales;\n  };\n};\n\nexport type ContextConfigSpecs = DeepPartial<OneUIContextSpecs> &\n  PathObject<OneUIContextSpecs, \"component.text\">;\n\nconst Context = createContext<ContextConfigSpecs>(null as any);\n\nfunction OneUIProvider({\n  children,\n  config,\n}: PropsWithChildren<{ config: ContextConfigSpecs }>) {\n  const prevCtx = useContext(Context);\n  const scale = useAdaptiveImage();\n  const mergedConfig = useMemo(() => {\n    return merge(clone(prevCtx), config, {\n      state: {\n        imageScale: scale,\n      },\n    });\n  }, [prevCtx, config, scale]);\n\n  return <Context.Provider value={mergedConfig}>{children}</Context.Provider>;\n}\n\nexport default OneUIProvider;\n\nfunction pathToJson(\n  path: string,\n  key?: string | Symbol,\n  exampleConfig = \"THE_MISSING_CONFIG\"\n) {\n  if (!key) {\n    key = path.split(\".\").slice(-1)[0];\n    path = path.replace(`.${key}`, \"\");\n  }\n\n  return path\n    .split(\".\")\n    .concat(key as string)\n    .reduce((result, key, idx, arr) => {\n      (arr.slice(0, idx).reduce((r, k) => (r as any)[k], result) as any)[key] =\n        idx === arr.length - 1 ? exampleConfig : {};\n      return result;\n    }, {});\n}\n\nfunction ErrorWrapper(\n  originalObject: any,\n  path: string = \"config\"\n): typeof Proxy {\n  return new Proxy(\n    typeof originalObject !== \"object\" ? {} : originalObject || {},\n    {\n      get(_target, key) {\n        if (key === Symbol.toPrimitive) {\n          return () => _target[key];\n        }\n        try {\n          const value = originalObject[key];\n          if (typeof value === \"undefined\") return undefined;\n          if (typeof value === \"object\")\n            return ErrorWrapper(value, [path, key].filter(Boolean).join(\".\"));\n          return value;\n        } catch (e) {\n          const pathJson = pathToJson(path, key);\n          throw new Error(\n            `A component is using the UI config ${[path, key].join(\".\")}.\n\nPlease define it using:\nimport OneUIProvider from \"@onepercent/one-ui/dist/context/OneUIProvider\";\n\n  ...\n${`<OneUIProvider config={${JSON.stringify(pathJson, null, 4)}}>\n...\n</OneUIProvider>`.replace(/[ ]/g, \"-\")}`\n          );\n        }\n      },\n    }\n  );\n}\n\nexport function useOneUIContext() {\n  const context = useContext(Context);\n\n  if (process.env.NODE_ENV === \"development\")\n    return ErrorWrapper(context) as unknown as OneUIContextSpecs;\n\n  return context as OneUIContextSpecs;\n}\n\nexport function useOneUIView<P extends FieldPath<OneUIContextSpecs>>(\n  oneuiConfigPath: P,\n  componentName: string\n) {\n  const providedValue = useOneUIConfig(oneuiConfigPath);\n  if (!providedValue) {\n    throw new Error(`The component ${componentName} requires a view to be set on OneUI initialization\n\nViews ready for use with this component shall be available at:\nimport SomeView from \"@onepercentio/one-ui/dist/components/${componentName}/View/SomeView\";\n    \nPlease define it using:\nimport OneUIProvider from \"@onepercentio/one-ui/dist/context/OneUIProvider\";\n\n  ...\n${`<OneUIProvider config={${JSON.stringify(\n  pathToJson(oneuiConfigPath, undefined, \"SomeView\"),\n  null,\n  4\n)}}>\n...\n</OneUIProvider>`.replace(/[ ]/g, \"-\")}`);\n  }\n\n  return providedValue;\n}\n\nexport function useOneUIConfig<P extends FieldPath<OneUIContextSpecs>>(\n  prop: P\n): Get<OneUIContextSpecs, P>;\nexport function useOneUIConfig<\n  P extends FieldPath<OneUIContextSpecs>,\n  T extends DeepPartial<Get<OneUIContextSpecs, P>>\n>(prop: P, defaultValue: T): NonNullable<Get<OneUIContextSpecs, P>>;\nexport function useOneUIConfig<\n  P extends FieldPath<OneUIContextSpecs>,\n  T extends Get<OneUIContextSpecs, P>\n>(prop: P, defaultValue?: T): Get<OneUIContextSpecs, P> | T {\n  const context = useContext(Context);\n  if (process.env.NODE_ENV === \"development\") {\n    const val = useMemo(() => {\n      return get(context, prop);\n    }, [context, prop]);\n    if (\n      typeof val === \"string\" ||\n      typeof val === \"function\" ||\n      prop.endsWith(\".Component\") ||\n      prop.endsWith(\".View\")\n    )\n      return (val as any) || defaultValue;\n\n    if (typeof val === \"boolean\") return val as any;\n    return ErrorWrapper(val || defaultValue) as unknown as NonNullable<T>;\n  }\n  const value = useMemo(() => {\n    return get(context, prop);\n  }, [context, prop]);\n  return value || defaultValue;\n}\n\nexport function useCurrentImageScale() {\n  const context = useContext(Context);\n\n  return context.state!.imageScale!;\n}\n"],"mappings":"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","ignoreList":[]}
99
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_get","_interopRequireDefault","require","_merge","_cloneDeep","_react","_interopRequireWildcard","_useAdaptiveImage","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","Context","createContext","OneUIProvider","_ref","children","config","prevCtx","useContext","scale","useAdaptiveImage","mergedConfig","useMemo","merge","clone","state","imageScale","createElement","Provider","value","_default","exports","pathToJson","path","key","exampleConfig","arguments","length","undefined","split","slice","replace","concat","reduce","result","idx","arr","k","ErrorWrapper","originalObject","Proxy","_target","Symbol","toPrimitive","filter","Boolean","join","pathJson","Error","JSON","stringify","useOneUIContext","context","process","env","NODE_ENV","useOneUIView","oneuiConfigPath","componentName","providedValue","useOneUIConfig","prop","defaultValue","val","endsWith","useCurrentImageScale"],"sources":["../../src/context/OneUIProvider.tsx"],"sourcesContent":["import { JSX } from \"react\";\nimport get from \"lodash/get\";\nimport merge from \"lodash/merge\";\nimport clone from \"lodash/cloneDeep\";\nimport { Get } from \"type-fest\";\nimport React, { ComponentProps, ReactElement, ReactNode, useMemo } from \"react\";\nimport { createContext, PropsWithChildren, useContext } from \"react\";\nimport { ImageScales } from \"@muritavo/webpack-microfrontend-scripts/bin/types/ImageScales\";\nimport { UploadTask } from \"firebase/storage\";\nimport {\n  FieldPath,\n  FromOnePercentUtility,\n  NamespaceAccessors,\n  Path,\n  PathObject,\n} from \"../type-utils\";\nimport useAdaptiveImage from \"../hooks/ui/useAdaptiveImage\";\nimport Button from \"../components/Button\";\nimport CheckBox from \"../components/CheckBox\";\nimport Radio from \"../components/Radio/Radio\";\nimport { FileInputViewProps } from \"../components/FileInput/View/View.types\";\nimport {\n  AnswerByField,\n  FormField,\n  GenericFormFieldProps,\n} from \"../components/Form/FormField/FormField.types\";\nimport { BaseQuestion, FormMode } from \"../components/Form/Form.types\";\n\ntype DeepPartial<T> = {\n  [P in keyof T]?: NonNullable<T[P]> extends Function\n    ? T[P]\n    : DeepPartial<T[P]>;\n};\n\ntype IfUtilityHas<\n  N extends NamespaceAccessors,\n  Declare\n> = FromOnePercentUtility<N> extends `To define this property you need to set OnepercentUtility.${string} globally`\n  ? undefined\n  : Declare;\n\nexport type OneUIContextSpecs = {\n  component: {\n    spacing: {\n      variants: {\n        [k in FromOnePercentUtility<\"UIElements.SpacingVariants\">]: string;\n      };\n    };\n    collapsable: {\n      className: string;\n    };\n    form: {\n      fieldWrapper: {\n        [k in `${keyof typeof FormMode}-${FormField[\"type\"]}`]:\n          | string\n          | ((p: PropsWithChildren<FormField & { value: any }>) => ReactNode);\n      };\n      titleVariant: FromOnePercentUtility<\"UIElements.TextVariants\">;\n      labelVariant: FromOnePercentUtility<\"UIElements.TextVariants\">;\n      /** Label shown when a field is optional */\n      optionalLabel: string;\n\n      /** Label shown when a required field was not provided */\n      requiredLabel: string;\n\n      onFileUpload(questionId: string, file: File): UploadTask;\n\n      extensions: IfUtilityHas<\n        \"UIElements.FormExtension\",\n        {\n          [K in FromOnePercentUtility<\"UIElements.FormExtension\">[\"fields\"][\"type\"]]: {\n            Input: (props: GenericFormFieldProps<K>) => ReactElement;\n            validator: (\n              answer: AnswerByField<{ type: K }> | undefined,\n              question: BaseQuestion &\n                (FromOnePercentUtility<\"UIElements.FormExtension\">[\"fields\"] & {\n                  type: K;\n                })\n            ) => {\n              isValid: boolean;\n              error?: string;\n            };\n          };\n        }\n      >;\n    };\n    text: IfUtilityHas<\n      \"UIElements.TextVariants\",\n      {\n        className: {\n          [k in React.ComponentProps<\n            typeof import(\"../components/Text\")[\"default\"]\n          >[\"type\"]]: string;\n        };\n        htmlTag: {\n          [k in React.ComponentProps<\n            typeof import(\"../components/Text\")[\"default\"]\n          >[\"type\"]]: \"p\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\";\n        };\n      }\n    >;\n    button?: {\n      className?: {\n        [k in NonNullable<\n          React.ComponentProps<\n            typeof import(\"../components/Button\")[\"default\"]\n          >[\"variant\"]\n        >]?: string;\n      };\n      Component?: (props: ComponentProps<typeof Button>) => ReactElement;\n    };\n    input: {\n      className: {\n        /** The wrapper around input tag & caption element (used for error and caption) */\n        container: string;\n        /** The input html tag */\n        input: string;\n      };\n    };\n    fileInput: {\n      View: (props: FileInputViewProps) => ReactElement;\n    };\n    passwordInput: {\n      iconSrc: {\n        passwordHidden: string;\n        passwordVisible: string;\n      };\n    };\n    asyncWrapper: {\n      LoadingComponent?: () => JSX.Element;\n      messages: {\n        error: {\n          title: string;\n          retryBtn: string;\n        };\n      };\n    };\n    select: {\n      StateIndicator: (props: { open: boolean }) => JSX.Element;\n      className?: {\n        dropdown?: string;\n        item?: string;\n        selectedItem?: string;\n        input?: string;\n      };\n    };\n    header: {\n      LogoImage: () => JSX.Element;\n      MoreOptions: ({ open }: { open: boolean }) => JSX.Element;\n    };\n    table: {\n      controls: {\n        PrevPage: ({ disabled }: { disabled: boolean }) => JSX.Element;\n        NextPage: ({ disabled }: { disabled: boolean }) => JSX.Element;\n      };\n    };\n    tooltip: {\n      className?: string;\n    };\n    adaptiveDialog: {\n      dialogClassName: string;\n      backdropClassName: string;\n      variant: {\n        [k in FromOnePercentUtility<\"UIElements.AdaptiveDialogVariants\">]: string;\n      };\n    };\n    adaptiveSidebar: {\n      className: string;\n      controlClassName: string;\n    };\n    checkbox: {\n      Component?: (props: ComponentProps<typeof CheckBox>) => ReactElement;\n    };\n    radio: {\n      Component?: (props: ComponentProps<typeof Radio>) => ReactElement;\n    };\n    tabs: {\n      item: string;\n      container: string;\n    };\n  };\n  hook: {\n    ui: {\n      usePaginationControls: {\n        LeftControl: () => ReactElement;\n        RightControl: () => ReactElement;\n        className?: string;\n      };\n    };\n  };\n  state: {\n    imageScale: ImageScales;\n  };\n};\n\nexport type ContextConfigSpecs = DeepPartial<OneUIContextSpecs> &\n  PathObject<OneUIContextSpecs, \"component.text\">;\n\nconst Context = createContext<ContextConfigSpecs>(null as any);\n\nfunction OneUIProvider({\n  children,\n  config,\n}: PropsWithChildren<{ config: ContextConfigSpecs }>) {\n  const prevCtx = useContext(Context);\n  const scale = useAdaptiveImage();\n  const mergedConfig = useMemo(() => {\n    return merge(clone(prevCtx), config, {\n      state: {\n        imageScale: scale,\n      },\n    });\n  }, [prevCtx, config, scale]);\n\n  return <Context.Provider value={mergedConfig}>{children}</Context.Provider>;\n}\n\nexport default OneUIProvider;\n\nfunction pathToJson(\n  path: string,\n  key?: string | Symbol,\n  exampleConfig = \"THE_MISSING_CONFIG\"\n) {\n  if (!key) {\n    key = path.split(\".\").slice(-1)[0];\n    path = path.replace(`.${key}`, \"\");\n  }\n\n  return path\n    .split(\".\")\n    .concat(key as string)\n    .reduce((result, key, idx, arr) => {\n      (arr.slice(0, idx).reduce((r, k) => (r as any)[k], result) as any)[key] =\n        idx === arr.length - 1 ? exampleConfig : {};\n      return result;\n    }, {});\n}\n\nfunction ErrorWrapper(\n  originalObject: any,\n  path: string = \"config\"\n): typeof Proxy {\n  return new Proxy(\n    typeof originalObject !== \"object\" ? {} : originalObject || {},\n    {\n      get(_target, key) {\n        if (key === Symbol.toPrimitive) {\n          return () => _target[key];\n        }\n        try {\n          const value = originalObject[key];\n          if (typeof value === \"undefined\") return undefined;\n          if (typeof value === \"object\")\n            return ErrorWrapper(value, [path, key].filter(Boolean).join(\".\"));\n          return value;\n        } catch (e) {\n          const pathJson = pathToJson(path, key);\n          throw new Error(\n            `A component is using the UI config ${[path, key].join(\".\")}.\n\nPlease define it using:\nimport OneUIProvider from \"@onepercent/one-ui/dist/context/OneUIProvider\";\n\n  ...\n${`<OneUIProvider config={${JSON.stringify(pathJson, null, 4)}}>\n...\n</OneUIProvider>`.replace(/[ ]/g, \"-\")}`\n          );\n        }\n      },\n    }\n  );\n}\n\nexport function useOneUIContext() {\n  const context = useContext(Context);\n\n  if (process.env.NODE_ENV === \"development\")\n    return ErrorWrapper(context) as unknown as OneUIContextSpecs;\n\n  return context as OneUIContextSpecs;\n}\n\nexport function useOneUIView<P extends FieldPath<OneUIContextSpecs>>(\n  oneuiConfigPath: P,\n  componentName: string\n) {\n  const providedValue = useOneUIConfig(oneuiConfigPath);\n  if (!providedValue) {\n    throw new Error(`The component ${componentName} requires a view to be set on OneUI initialization\n\nViews ready for use with this component shall be available at:\nimport SomeView from \"@onepercentio/one-ui/dist/components/${componentName}/View/SomeView\";\n    \nPlease define it using:\nimport OneUIProvider from \"@onepercentio/one-ui/dist/context/OneUIProvider\";\n\n  ...\n${`<OneUIProvider config={${JSON.stringify(\n  pathToJson(oneuiConfigPath, undefined, \"SomeView\"),\n  null,\n  4\n)}}>\n...\n</OneUIProvider>`.replace(/[ ]/g, \"-\")}`);\n  }\n\n  return providedValue;\n}\n\nexport function useOneUIConfig<P extends FieldPath<OneUIContextSpecs>>(\n  prop: P\n): Get<OneUIContextSpecs, P>;\nexport function useOneUIConfig<\n  P extends FieldPath<OneUIContextSpecs>,\n  T extends DeepPartial<Get<OneUIContextSpecs, P>>\n>(prop: P, defaultValue: T): NonNullable<Get<OneUIContextSpecs, P>>;\nexport function useOneUIConfig<\n  P extends FieldPath<OneUIContextSpecs>,\n  T extends Get<OneUIContextSpecs, P>\n>(prop: P, defaultValue?: T): Get<OneUIContextSpecs, P> | T {\n  const context = useContext(Context);  \n  if (process.env.NODE_ENV === \"development\") {\n    const val = useMemo(() => {\n      return get(context, prop);\n    }, [context, prop]);\n    if (\n      typeof val === \"string\" ||\n      typeof val === \"function\" ||\n      prop.endsWith(\".Component\") ||\n      prop.endsWith(\".View\")\n    )\n      return (val as any) || defaultValue;\n\n    if (typeof val === \"boolean\") return val as any;\n    return ErrorWrapper(val || defaultValue) as unknown as NonNullable<T>;\n  }\n  const value = useMemo(() => {\n    return get(context, prop);\n  }, [context, prop]);\n  return value || defaultValue;\n}\n\nexport function useCurrentImageScale() {\n  const context = useContext(Context);\n\n  return context.state!.imageScale!;\n}\n"],"mappings":"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","ignoreList":[]}
@@ -2,7 +2,7 @@ import { useRef } from "react";
2
2
  /**
3
3
  * This function exists so we can work with multiple refs as a single one
4
4
  */
5
- export default function useMergeRefs<T extends ReturnType<typeof useRef>>(mainRef: T, ...otherRefs: T[]): T;
5
+ export default function useMergeRefs<T extends ReturnType<typeof useRef>>(mainRef: T, ...otherRefs: (T | undefined)[]): T;
6
6
  /**
7
7
  * This function exists so we can work with multiple refs as a single one, almost immediatly
8
8
  */