@onepercentio/one-ui 1.0.3 → 1.0.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/styles/mixins.scss +12 -10
- package/dist/components/Button/Button.d.ts +6 -9
- package/dist/components/Button/Button.js +3 -5
- package/dist/components/Form/FormField/FormField.js +5 -3
- package/dist/components/Form/FormField/FormField.types.d.ts +2 -0
- package/dist/components/Form/FormField/FormField.types.js +1 -1
- package/dist/components/ProgressBar/ProgressBar.d.ts +4 -2
- package/dist/components/ProgressBar/ProgressBar.js +8 -4
- package/dist/components/ProgressBar/ProgressBar.module.scss +3 -3
- package/dist/components/Select/Select.d.ts +17 -9
- package/dist/components/Select/Select.js +24 -11
- package/dist/components/Select/Select.module.scss +3 -1
- package/dist/components/Slider/Slider.d.ts +7 -0
- package/dist/components/Slider/Slider.e2e.d.ts +4 -0
- package/dist/components/Slider/Slider.js +66 -0
- package/dist/components/Slider/Slider.module.scss +7 -0
- package/dist/components/Slider/index.d.ts +2 -0
- package/dist/components/Slider/index.js +26 -0
- package/dist/components/Table/Table.d.ts +6 -4
- package/dist/components/Table/Table.js +26 -35
- package/dist/components/Table/Table.module.scss +0 -2
- package/dist/context/OneUIProvider.js +1 -1
- package/dist/hooks/useMergeRefs.d.ts +1 -1
- package/dist/hooks/useMergeRefs.js +2 -2
- package/dist/hooks/usePagination.js +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.js +106 -87
- package/dist-ts/assets/styles/mixins.scss +12 -10
- package/dist-ts/components/Button/Button.d.ts +6 -9
- package/dist-ts/components/Button/Button.js +2 -3
- package/dist-ts/components/Button/Button.js.map +1 -1
- package/dist-ts/components/Form/FormField/FormField.js +2 -2
- package/dist-ts/components/Form/FormField/FormField.js.map +1 -1
- package/dist-ts/components/Form/FormField/FormField.types.d.ts +2 -0
- package/dist-ts/components/Form/FormField/FormField.types.js.map +1 -1
- package/dist-ts/components/ProgressBar/ProgressBar.d.ts +4 -2
- package/dist-ts/components/ProgressBar/ProgressBar.js +2 -2
- package/dist-ts/components/ProgressBar/ProgressBar.js.map +1 -1
- package/dist-ts/components/ProgressBar/ProgressBar.module.scss +3 -3
- package/dist-ts/components/Select/Select.d.ts +17 -9
- package/dist-ts/components/Select/Select.js +29 -10
- package/dist-ts/components/Select/Select.js.map +1 -1
- package/dist-ts/components/Select/Select.module.scss +3 -1
- package/dist-ts/components/Slider/Slider.d.ts +7 -0
- package/dist-ts/components/Slider/Slider.e2e.d.ts +4 -0
- package/dist-ts/components/Slider/Slider.e2e.js +3 -0
- package/dist-ts/components/Slider/Slider.e2e.js.map +1 -0
- package/dist-ts/components/Slider/Slider.js +56 -0
- package/dist-ts/components/Slider/Slider.js.map +1 -0
- package/dist-ts/components/Slider/Slider.module.scss +7 -0
- package/dist-ts/components/Slider/index.d.ts +2 -0
- package/dist-ts/components/Slider/index.js +3 -0
- package/dist-ts/components/Slider/index.js.map +1 -0
- package/dist-ts/components/Table/Table.d.ts +6 -4
- package/dist-ts/components/Table/Table.js +24 -13
- package/dist-ts/components/Table/Table.js.map +1 -1
- package/dist-ts/components/Table/Table.module.scss +0 -2
- package/dist-ts/hooks/useMergeRefs.d.ts +1 -1
- package/dist-ts/hooks/useMergeRefs.js +1 -1
- package/dist-ts/hooks/useMergeRefs.js.map +1 -1
- package/dist-ts/hooks/usePagination.js.map +1 -1
- package/dist-ts/index.d.ts +2 -0
- package/dist-ts/index.js +2 -0
- package/dist-ts/index.js.map +1 -1
- package/package.json +6 -5
|
@@ -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", "
|
|
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.
|
|
43
|
-
|
|
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({},
|
|
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: () =>
|
|
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":[]}
|
|
@@ -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,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
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
var _exportNames = {};
|
|
7
|
+
Object.defineProperty(exports, "default", {
|
|
8
|
+
enumerable: true,
|
|
9
|
+
get: function () {
|
|
10
|
+
return _Slider.default;
|
|
11
|
+
}
|
|
12
|
+
});
|
|
13
|
+
var _Slider = _interopRequireWildcard(require("./Slider"));
|
|
14
|
+
Object.keys(_Slider).forEach(function (key) {
|
|
15
|
+
if (key === "default" || key === "__esModule") return;
|
|
16
|
+
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
|
|
17
|
+
if (key in exports && exports[key] === _Slider[key]) return;
|
|
18
|
+
Object.defineProperty(exports, key, {
|
|
19
|
+
enumerable: true,
|
|
20
|
+
get: function () {
|
|
21
|
+
return _Slider[key];
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
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); }
|
|
26
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfU2xpZGVyIiwiX2ludGVyb3BSZXF1aXJlV2lsZGNhcmQiLCJyZXF1aXJlIiwiT2JqZWN0Iiwia2V5cyIsImZvckVhY2giLCJrZXkiLCJwcm90b3R5cGUiLCJoYXNPd25Qcm9wZXJ0eSIsImNhbGwiLCJfZXhwb3J0TmFtZXMiLCJleHBvcnRzIiwiZGVmaW5lUHJvcGVydHkiLCJlbnVtZXJhYmxlIiwiZ2V0IiwiZSIsInQiLCJXZWFrTWFwIiwiciIsIm4iLCJfX2VzTW9kdWxlIiwibyIsImkiLCJmIiwiX19wcm90b19fIiwiZGVmYXVsdCIsImhhcyIsInNldCIsImdldE93blByb3BlcnR5RGVzY3JpcHRvciJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1NsaWRlci9pbmRleC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgZGVmYXVsdCB9IGZyb20gXCIuL1NsaWRlclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vU2xpZGVyXCI7Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQSxJQUFBQSxPQUFBLEdBQUFDLHVCQUFBLENBQUFDLE9BQUE7QUFDQUMsTUFBQSxDQUFBQyxJQUFBLENBQUFKLE9BQUEsRUFBQUssT0FBQSxXQUFBQyxHQUFBO0VBQUEsSUFBQUEsR0FBQSxrQkFBQUEsR0FBQTtFQUFBLElBQUFILE1BQUEsQ0FBQUksU0FBQSxDQUFBQyxjQUFBLENBQUFDLElBQUEsQ0FBQUMsWUFBQSxFQUFBSixHQUFBO0VBQUEsSUFBQUEsR0FBQSxJQUFBSyxPQUFBLElBQUFBLE9BQUEsQ0FBQUwsR0FBQSxNQUFBTixPQUFBLENBQUFNLEdBQUE7RUFBQUgsTUFBQSxDQUFBUyxjQUFBLENBQUFELE9BQUEsRUFBQUwsR0FBQTtJQUFBTyxVQUFBO0lBQUFDLEdBQUEsV0FBQUEsQ0FBQTtNQUFBLE9BQUFkLE9BQUEsQ0FBQU0sR0FBQTtJQUFBO0VBQUE7QUFBQTtBQUF5QixTQUFBTCx3QkFBQWMsQ0FBQSxFQUFBQyxDQUFBLDZCQUFBQyxPQUFBLE1BQUFDLENBQUEsT0FBQUQsT0FBQSxJQUFBRSxDQUFBLE9BQUFGLE9BQUEsWUFBQWhCLHVCQUFBLFlBQUFBLENBQUFjLENBQUEsRUFBQUMsQ0FBQSxTQUFBQSxDQUFBLElBQUFELENBQUEsSUFBQUEsQ0FBQSxDQUFBSyxVQUFBLFNBQUFMLENBQUEsTUFBQU0sQ0FBQSxFQUFBQyxDQUFBLEVBQUFDLENBQUEsS0FBQUMsU0FBQSxRQUFBQyxPQUFBLEVBQUFWLENBQUEsaUJBQUFBLENBQUEsdUJBQUFBLENBQUEseUJBQUFBLENBQUEsU0FBQVEsQ0FBQSxNQUFBRixDQUFBLEdBQUFMLENBQUEsR0FBQUcsQ0FBQSxHQUFBRCxDQUFBLFFBQUFHLENBQUEsQ0FBQUssR0FBQSxDQUFBWCxDQUFBLFVBQUFNLENBQUEsQ0FBQVAsR0FBQSxDQUFBQyxDQUFBLEdBQUFNLENBQUEsQ0FBQU0sR0FBQSxDQUFBWixDQUFBLEVBQUFRLENBQUEsZ0JBQUFQLENBQUEsSUFBQUQsQ0FBQSxnQkFBQUMsQ0FBQSxPQUFBUixjQUFBLENBQUFDLElBQUEsQ0FBQU0sQ0FBQSxFQUFBQyxDQUFBLE9BQUFNLENBQUEsSUFBQUQsQ0FBQSxHQUFBbEIsTUFBQSxDQUFBUyxjQUFBLEtBQUFULE1BQUEsQ0FBQXlCLHdCQUFBLENBQUFiLENBQUEsRUFBQUMsQ0FBQSxPQUFBTSxDQUFBLENBQUFSLEdBQUEsSUFBQVEsQ0FBQSxDQUFBSyxHQUFBLElBQUFOLENBQUEsQ0FBQUUsQ0FBQSxFQUFBUCxDQUFBLEVBQUFNLENBQUEsSUFBQUMsQ0FBQSxDQUFBUCxDQUFBLElBQUFELENBQUEsQ0FBQUMsQ0FBQSxXQUFBTyxDQUFBLEtBQUFSLENBQUEsRUFBQUMsQ0FBQSIsImlnbm9yZUxpc3QiOltdfQ==
|
|
@@ -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
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
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
|
-
}
|
|
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 /
|
|
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,
|
|
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:
|
|
64
|
+
key: currPage,
|
|
76
65
|
className: className
|
|
77
|
-
}))), paginable && paginable.totalItems >
|
|
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(
|
|
74
|
+
paginable.togglePage(currPage - 1);
|
|
75
|
+
setCurrPage(currPage - 1);
|
|
86
76
|
}
|
|
87
77
|
}, /*#__PURE__*/_react.default.createElement(PrevPage, {
|
|
88
|
-
disabled:
|
|
78
|
+
disabled: currPage === 0
|
|
89
79
|
})), /*#__PURE__*/_react.default.createElement("span", {
|
|
90
80
|
className: _TableModule.default.paging
|
|
91
|
-
}, "".concat(
|
|
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(
|
|
85
|
+
paginable.togglePage(currPage + 1);
|
|
86
|
+
setCurrPage(currPage + 1);
|
|
96
87
|
}
|
|
97
88
|
}, /*#__PURE__*/_react.default.createElement(NextPage, {
|
|
98
|
-
disabled:
|
|
89
|
+
disabled: currPage === pages - 1
|
|
99
90
|
})))) : null);
|
|
100
91
|
}
|
|
101
92
|
const TableContext = /*#__PURE__*/(0, _react.createContext)(null);
|
|
102
|
-
function TableComp(
|
|
93
|
+
function TableComp(_ref2) {
|
|
103
94
|
let {
|
|
104
95
|
className
|
|
105
|
-
} =
|
|
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":[]}
|