@onepercentio/one-ui 0.27.0 → 0.27.2

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.
@@ -2,19 +2,28 @@ import { ComponentProps } from "react";
2
2
  /**
3
3
  * Shows a progress bar
4
4
  **/
5
- export default function ProgressBar({ size, progress, mode, }: {
5
+ export default function ProgressBar({ progress, ...props }: {
6
+ /**
7
+ * Given in percent
8
+ */
9
+ progress: number;
10
+ } & ({
6
11
  /**
7
12
  * Given as css font size
8
13
  */
9
14
  size: number | string;
15
+ mode?: "gauge" | "guide";
16
+ } | {
10
17
  /**
11
- * Given in percent
18
+ * Given as pixels
12
19
  */
13
- progress: number;
14
- mode?: "gauge" | "guide";
15
- }): import("react/jsx-runtime").JSX.Element;
16
- export declare function BalancedProgressBar({ min, max, current, size, mode, }: {
20
+ size: number;
21
+ mode?: "sections";
22
+ /** The number of sections to split */
23
+ sections: number;
24
+ })): import("react/jsx-runtime").JSX.Element;
25
+ export declare function BalancedProgressBar({ min, max, current, size, ...props }: {
17
26
  min: number;
18
27
  max: number;
19
28
  current: number;
20
- } & Pick<ComponentProps<typeof ProgressBar>, "size" | "mode">): import("react/jsx-runtime").JSX.Element;
29
+ } & Omit<ComponentProps<typeof ProgressBar>, "progress">): import("react/jsx-runtime").JSX.Element;
@@ -10,15 +10,63 @@ var _ProgressBarModule = _interopRequireDefault(require("./ProgressBar.module.sc
10
10
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
11
11
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
12
12
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
13
+ function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
13
14
  /**
14
15
  * Shows a progress bar
15
16
  **/
16
17
  function ProgressBar(_ref) {
17
18
  let {
18
- size,
19
19
  progress,
20
- mode = "guide"
20
+ ...props
21
21
  } = _ref;
22
+ if (props.mode === "sections") {
23
+ const ref = (0, _react.useRef)(null);
24
+ const strokeID = (0, _react.useMemo)(() => `stroke-${(Math.random() * 100000).toFixed(0)}`, []);
25
+ const height = props.size;
26
+ const [width, setWidth] = (0, _react.useState)(0);
27
+ const dashWidth = width / props.sections;
28
+ const spacing = dashWidth * 0.2;
29
+ (0, _react.useEffect)(() => {
30
+ setWidth(ref.current.clientWidth);
31
+ }, []);
32
+ return /*#__PURE__*/_react.default.createElement("svg", {
33
+ ref: ref,
34
+ viewBox: `${-height / 2} 0 ${width + height - spacing} ${height}`,
35
+ preserveAspectRatio: "none",
36
+ width: "100%",
37
+ height: `${height}px`
38
+ }, /*#__PURE__*/_react.default.createElement("defs", null, /*#__PURE__*/_react.default.createElement("linearGradient", {
39
+ id: `${strokeID}`,
40
+ x1: "0%",
41
+ y1: "0%",
42
+ x2: "100%",
43
+ y2: "0%",
44
+ gradientUnits: "userSpaceOnUse"
45
+ }, /*#__PURE__*/_react.default.createElement("stop", {
46
+ offset: "0%",
47
+ "stop-color": "blue"
48
+ }), /*#__PURE__*/_react.default.createElement("stop", {
49
+ offset: `${progress}%`,
50
+ "stop-color": "blue"
51
+ }), /*#__PURE__*/_react.default.createElement("stop", {
52
+ offset: `${progress}%`,
53
+ "stop-color": "green"
54
+ }), /*#__PURE__*/_react.default.createElement("stop", {
55
+ offset: "100%",
56
+ "stop-color": "green"
57
+ }))), /*#__PURE__*/_react.default.createElement("line", {
58
+ x1: "0",
59
+ y1: height / 2,
60
+ x2: width,
61
+ y2: height / 2,
62
+ stroke: `url(#${strokeID})`,
63
+ "stroke-width": height,
64
+ "stroke-dasharray": `${dashWidth - spacing},${spacing}`,
65
+ "stroke-linecap": "round"
66
+ }));
67
+ }
68
+ const mode = props.mode || "guide";
69
+ const size = props.size;
22
70
  return /*#__PURE__*/_react.default.createElement("div", {
23
71
  className: `${_ProgressBarModule.default.container} ${_ProgressBarModule.default[mode]} ${progress === 100 ? _ProgressBarModule.default.completed : ""}`,
24
72
  style: {
@@ -40,7 +88,7 @@ function BalancedProgressBar(_ref2) {
40
88
  max,
41
89
  current,
42
90
  size,
43
- mode
91
+ ...props
44
92
  } = _ref2;
45
93
  const progress = (0, _react.useMemo)(() => {
46
94
  const progressVal = current - min;
@@ -48,10 +96,9 @@ function BalancedProgressBar(_ref2) {
48
96
  const currProgress = progressVal * 100 / maxVal;
49
97
  return currProgress;
50
98
  }, [min, max, current]);
51
- return /*#__PURE__*/_react.default.createElement(ProgressBar, {
99
+ return /*#__PURE__*/_react.default.createElement(ProgressBar, _extends({
52
100
  size: size,
53
- progress: progress,
54
- mode: mode
55
- });
101
+ progress: progress
102
+ }, props));
56
103
  }
57
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfUHJvZ3Jlc3NCYXJNb2R1bGUiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0Iiwib2JqIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJfZ2V0UmVxdWlyZVdpbGRjYXJkQ2FjaGUiLCJub2RlSW50ZXJvcCIsIldlYWtNYXAiLCJjYWNoZUJhYmVsSW50ZXJvcCIsImNhY2hlTm9kZUludGVyb3AiLCJjYWNoZSIsImhhcyIsImdldCIsIm5ld09iaiIsImhhc1Byb3BlcnR5RGVzY3JpcHRvciIsIk9iamVjdCIsImRlZmluZVByb3BlcnR5IiwiZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yIiwia2V5IiwicHJvdG90eXBlIiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwiZGVzYyIsInNldCIsIlByb2dyZXNzQmFyIiwiX3JlZiIsInNpemUiLCJwcm9ncmVzcyIsIm1vZGUiLCJjcmVhdGVFbGVtZW50IiwiY2xhc3NOYW1lIiwiU3R5bGVzIiwiY29udGFpbmVyIiwiY29tcGxldGVkIiwic3R5bGUiLCJmb250U2l6ZSIsIndpZHRoIiwibGVmdCIsIkJhbGFuY2VkUHJvZ3Jlc3NCYXIiLCJfcmVmMiIsIm1pbiIsIm1heCIsImN1cnJlbnQiLCJ1c2VNZW1vIiwicHJvZ3Jlc3NWYWwiLCJtYXhWYWwiLCJjdXJyUHJvZ3Jlc3MiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Qcm9ncmVzc0Jhci9Qcm9ncmVzc0Jhci50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudFByb3BzLCB1c2VNZW1vIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgU3R5bGVzIGZyb20gXCIuL1Byb2dyZXNzQmFyLm1vZHVsZS5zY3NzXCI7XG5cbi8qKlxuICogU2hvd3MgYSBwcm9ncmVzcyBiYXJcbiAqKi9cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIFByb2dyZXNzQmFyKHtcbiAgc2l6ZSxcbiAgcHJvZ3Jlc3MsXG4gIG1vZGUgPSBcImd1aWRlXCIsXG59OiB7XG4gIC8qKlxuICAgKiBHaXZlbiBhcyBjc3MgZm9udCBzaXplXG4gICAqL1xuICBzaXplOiBudW1iZXIgfCBzdHJpbmc7XG4gIC8qKlxuICAgKiBHaXZlbiBpbiBwZXJjZW50XG4gICAqL1xuICBwcm9ncmVzczogbnVtYmVyO1xuXG4gIG1vZGU/OiBcImdhdWdlXCIgfCBcImd1aWRlXCI7XG59KSB7XG4gIHJldHVybiAoXG4gICAgPGRpdlxuICAgICAgY2xhc3NOYW1lPXtgJHtTdHlsZXMuY29udGFpbmVyfSAke1N0eWxlc1ttb2RlXX0gJHtcbiAgICAgICAgcHJvZ3Jlc3MgPT09IDEwMCA/IFN0eWxlcy5jb21wbGV0ZWQgOiBcIlwiXG4gICAgICB9YH1cbiAgICAgIHN0eWxlPXt7IGZvbnRTaXplOiBzaXplIH19XG4gICAgPlxuICAgICAgPHNwYW4gc3R5bGU9e3sgd2lkdGg6IGAke3Byb2dyZXNzfSVgIH19IC8+XG4gICAgICB7bW9kZSA9PT0gXCJndWlkZVwiICYmIDxzcGFuIHN0eWxlPXt7IGxlZnQ6IGAke3Byb2dyZXNzfSVgIH19IC8+fVxuICAgIDwvZGl2PlxuICApO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gQmFsYW5jZWRQcm9ncmVzc0Jhcih7XG4gIG1pbixcbiAgbWF4LFxuICBjdXJyZW50LFxuICBzaXplLFxuICBtb2RlLFxufToge1xuICBtaW46IG51bWJlcjtcbiAgbWF4OiBudW1iZXI7XG4gIGN1cnJlbnQ6IG51bWJlcjtcbn0gJiBQaWNrPENvbXBvbmVudFByb3BzPHR5cGVvZiBQcm9ncmVzc0Jhcj4sIFwic2l6ZVwiIHwgXCJtb2RlXCI+KSB7XG4gIGNvbnN0IHByb2dyZXNzID0gdXNlTWVtbygoKSA9PiB7XG4gICAgY29uc3QgcHJvZ3Jlc3NWYWwgPSBjdXJyZW50IC0gbWluO1xuICAgIGNvbnN0IG1heFZhbCA9IG1heCAtIG1pbjtcblxuICAgIGNvbnN0IGN1cnJQcm9ncmVzcyA9IChwcm9ncmVzc1ZhbCAqIDEwMCkgLyBtYXhWYWw7XG5cbiAgICByZXR1cm4gY3VyclByb2dyZXNzO1xuICB9LCBbbWluLCBtYXgsIGN1cnJlbnRdKTtcblxuICByZXR1cm4gPFByb2dyZXNzQmFyIHNpemU9e3NpemV9IHByb2dyZXNzPXtwcm9ncmVzc30gbW9kZT17bW9kZX0gLz47XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHVCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxrQkFBQSxHQUFBQyxzQkFBQSxDQUFBRixPQUFBO0FBQStDLFNBQUFFLHVCQUFBQyxHQUFBLFdBQUFBLEdBQUEsSUFBQUEsR0FBQSxDQUFBQyxVQUFBLEdBQUFELEdBQUEsS0FBQUUsT0FBQSxFQUFBRixHQUFBO0FBQUEsU0FBQUcseUJBQUFDLFdBQUEsZUFBQUMsT0FBQSxrQ0FBQUMsaUJBQUEsT0FBQUQsT0FBQSxRQUFBRSxnQkFBQSxPQUFBRixPQUFBLFlBQUFGLHdCQUFBLFlBQUFBLENBQUFDLFdBQUEsV0FBQUEsV0FBQSxHQUFBRyxnQkFBQSxHQUFBRCxpQkFBQSxLQUFBRixXQUFBO0FBQUEsU0FBQVIsd0JBQUFJLEdBQUEsRUFBQUksV0FBQSxTQUFBQSxXQUFBLElBQUFKLEdBQUEsSUFBQUEsR0FBQSxDQUFBQyxVQUFBLFdBQUFELEdBQUEsUUFBQUEsR0FBQSxvQkFBQUEsR0FBQSx3QkFBQUEsR0FBQSw0QkFBQUUsT0FBQSxFQUFBRixHQUFBLFVBQUFRLEtBQUEsR0FBQUwsd0JBQUEsQ0FBQUMsV0FBQSxPQUFBSSxLQUFBLElBQUFBLEtBQUEsQ0FBQUMsR0FBQSxDQUFBVCxHQUFBLFlBQUFRLEtBQUEsQ0FBQUUsR0FBQSxDQUFBVixHQUFBLFNBQUFXLE1BQUEsV0FBQUMscUJBQUEsR0FBQUMsTUFBQSxDQUFBQyxjQUFBLElBQUFELE1BQUEsQ0FBQUUsd0JBQUEsV0FBQUMsR0FBQSxJQUFBaEIsR0FBQSxRQUFBZ0IsR0FBQSxrQkFBQUgsTUFBQSxDQUFBSSxTQUFBLENBQUFDLGNBQUEsQ0FBQUMsSUFBQSxDQUFBbkIsR0FBQSxFQUFBZ0IsR0FBQSxTQUFBSSxJQUFBLEdBQUFSLHFCQUFBLEdBQUFDLE1BQUEsQ0FBQUUsd0JBQUEsQ0FBQWYsR0FBQSxFQUFBZ0IsR0FBQSxjQUFBSSxJQUFBLEtBQUFBLElBQUEsQ0FBQVYsR0FBQSxJQUFBVSxJQUFBLENBQUFDLEdBQUEsS0FBQVIsTUFBQSxDQUFBQyxjQUFBLENBQUFILE1BQUEsRUFBQUssR0FBQSxFQUFBSSxJQUFBLFlBQUFULE1BQUEsQ0FBQUssR0FBQSxJQUFBaEIsR0FBQSxDQUFBZ0IsR0FBQSxTQUFBTCxNQUFBLENBQUFULE9BQUEsR0FBQUYsR0FBQSxNQUFBUSxLQUFBLElBQUFBLEtBQUEsQ0FBQWEsR0FBQSxDQUFBckIsR0FBQSxFQUFBVyxNQUFBLFlBQUFBLE1BQUE7QUFFL0M7QUFDQTtBQUNBO0FBQ2UsU0FBU1csV0FBV0EsQ0FBQUMsSUFBQSxFQWVoQztFQUFBLElBZmlDO0lBQ2xDQyxJQUFJO0lBQ0pDLFFBQVE7SUFDUkMsSUFBSSxHQUFHO0VBWVQsQ0FBQyxHQUFBSCxJQUFBO0VBQ0Msb0JBQ0U1QixNQUFBLENBQUFPLE9BQUEsQ0FBQXlCLGFBQUE7SUFDRUMsU0FBUyxFQUFHLEdBQUVDLDBCQUFNLENBQUNDLFNBQVUsSUFBR0QsMEJBQU0sQ0FBQ0gsSUFBSSxDQUFFLElBQzdDRCxRQUFRLEtBQUssR0FBRyxHQUFHSSwwQkFBTSxDQUFDRSxTQUFTLEdBQUcsRUFDdkMsRUFBRTtJQUNIQyxLQUFLLEVBQUU7TUFBRUMsUUFBUSxFQUFFVDtJQUFLO0VBQUUsZ0JBRTFCN0IsTUFBQSxDQUFBTyxPQUFBLENBQUF5QixhQUFBO0lBQU1LLEtBQUssRUFBRTtNQUFFRSxLQUFLLEVBQUcsR0FBRVQsUUFBUztJQUFHO0VBQUUsQ0FBRSxDQUFDLEVBQ3pDQyxJQUFJLEtBQUssT0FBTyxpQkFBSS9CLE1BQUEsQ0FBQU8sT0FBQSxDQUFBeUIsYUFBQTtJQUFNSyxLQUFLLEVBQUU7TUFBRUcsSUFBSSxFQUFHLEdBQUVWLFFBQVM7SUFBRztFQUFFLENBQUUsQ0FDMUQsQ0FBQztBQUVWO0FBRU8sU0FBU1csbUJBQW1CQSxDQUFBQyxLQUFBLEVBVTRCO0VBQUEsSUFWM0I7SUFDbENDLEdBQUc7SUFDSEMsR0FBRztJQUNIQyxPQUFPO0lBQ1BoQixJQUFJO0lBQ0pFO0VBSzBELENBQUMsR0FBQVcsS0FBQTtFQUMzRCxNQUFNWixRQUFRLEdBQUcsSUFBQWdCLGNBQU8sRUFBQyxNQUFNO0lBQzdCLE1BQU1DLFdBQVcsR0FBR0YsT0FBTyxHQUFHRixHQUFHO0lBQ2pDLE1BQU1LLE1BQU0sR0FBR0osR0FBRyxHQUFHRCxHQUFHO0lBRXhCLE1BQU1NLFlBQVksR0FBSUYsV0FBVyxHQUFHLEdBQUcsR0FBSUMsTUFBTTtJQUVqRCxPQUFPQyxZQUFZO0VBQ3JCLENBQUMsRUFBRSxDQUFDTixHQUFHLEVBQUVDLEdBQUcsRUFBRUMsT0FBTyxDQUFDLENBQUM7RUFFdkIsb0JBQU83QyxNQUFBLENBQUFPLE9BQUEsQ0FBQXlCLGFBQUEsQ0FBQ0wsV0FBVztJQUFDRSxJQUFJLEVBQUVBLElBQUs7SUFBQ0MsUUFBUSxFQUFFQSxRQUFTO0lBQUNDLElBQUksRUFBRUE7RUFBSyxDQUFFLENBQUM7QUFDcEUifQ==
104
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_ProgressBarModule","_interopRequireDefault","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","ProgressBar","_ref","progress","props","mode","ref","useRef","strokeID","useMemo","Math","random","toFixed","height","size","width","setWidth","useState","dashWidth","sections","spacing","useEffect","current","clientWidth","createElement","viewBox","preserveAspectRatio","id","x1","y1","x2","y2","gradientUnits","offset","stroke","className","Styles","container","completed","style","fontSize","left","BalancedProgressBar","_ref2","min","max","progressVal","maxVal","currProgress"],"sources":["../../../src/components/ProgressBar/ProgressBar.tsx"],"sourcesContent":["import React, {\n  ComponentProps,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport Styles from \"./ProgressBar.module.scss\";\n\n/**\n * Shows a progress bar\n **/\nexport default function ProgressBar({\n  progress,\n  ...props\n}: {\n  /**\n   * Given in percent\n   */\n  progress: number;\n} & (\n  | {\n      /**\n       * Given as css font size\n       */\n      size: number | string;\n      mode?: \"gauge\" | \"guide\";\n    }\n  | {\n      /**\n       * Given as pixels\n       */\n      size: number;\n      mode?: \"sections\";\n      /** The number of sections to split */\n      sections: number;\n    }\n)) {\n  if (props.mode === \"sections\") {\n    const ref = useRef<SVGSVGElement>(null);\n    const strokeID = useMemo(\n      () => `stroke-${(Math.random() * 100000).toFixed(0)}`,\n      []\n    );\n    const height = props.size;\n    const [width, setWidth] = useState(0);\n    const dashWidth = width / props.sections;\n    const spacing = dashWidth * 0.2;\n    useEffect(() => {\n      setWidth(ref.current!.clientWidth);\n    }, []);\n    return (\n      <svg\n        ref={ref}\n        viewBox={`${-height / 2} 0 ${width + height - spacing} ${height}`}\n        preserveAspectRatio=\"none\"\n        width={\"100%\"}\n        height={`${height}px`}\n      >\n        <defs>\n          <linearGradient\n            id={`${strokeID}`}\n            x1=\"0%\"\n            y1=\"0%\"\n            x2=\"100%\"\n            y2=\"0%\"\n            gradientUnits=\"userSpaceOnUse\"\n          >\n            <stop offset=\"0%\" stop-color=\"blue\" />\n            <stop offset={`${progress}%`} stop-color=\"blue\" />\n            <stop offset={`${progress}%`} stop-color=\"green\" />\n            <stop offset=\"100%\" stop-color=\"green\" />\n          </linearGradient>\n        </defs>\n        <line\n          x1=\"0\"\n          y1={height / 2}\n          x2={width}\n          y2={height / 2}\n          stroke={`url(#${strokeID})`}\n          stroke-width={height}\n          stroke-dasharray={`${dashWidth - spacing},${spacing}`}\n          stroke-linecap=\"round\"\n        />\n      </svg>\n    );\n  }\n  const mode = props.mode || \"guide\";\n  const size = props.size;\n  return (\n    <div\n      className={`${Styles.container} ${Styles[mode]} ${\n        progress === 100 ? Styles.completed : \"\"\n      }`}\n      style={{ fontSize: size }}\n    >\n      <span style={{ width: `${progress}%` }} />\n      {mode === \"guide\" && <span style={{ left: `${progress}%` }} />}\n    </div>\n  );\n}\n\nexport function BalancedProgressBar({\n  min,\n  max,\n  current,\n  size,\n  ...props\n}: {\n  min: number;\n  max: number;\n  current: number;\n} & Omit<ComponentProps<typeof ProgressBar>, \"progress\">) {\n  const progress = useMemo(() => {\n    const progressVal = current - min;\n    const maxVal = max - min;\n\n    const currProgress = (progressVal * 100) / maxVal;\n\n    return currProgress;\n  }, [min, max, current]);\n\n  return <ProgressBar size={size} progress={progress} {...props as any} />;\n}\n"],"mappings":"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"}
@@ -8,6 +8,9 @@
8
8
  &.gauge {
9
9
  margin: 0em;
10
10
  }
11
+ &.sections {
12
+ width: 100%;
13
+ }
11
14
  height: 0.25em;
12
15
  background-color: red;
13
16
  position: relative;
@@ -44,7 +44,7 @@ function usePaginationControls(containerRef) {
44
44
  behavior: "smooth"
45
45
  });
46
46
  } else {
47
- const rest = containerRef.current.scrollLeft % containerRef.current.clientWidth;
47
+ const rest = Math.round(containerRef.current.scrollLeft) % containerRef.current.clientWidth;
48
48
  const snapOffset = snapToPage ? direction === "l" ? rest ? containerRef.current.clientWidth - rest : 0 : rest : 0;
49
49
  containerRef.current.scrollBy({
50
50
  left: (containerRef.current.clientWidth - snapOffset) * (direction === "l" ? -1 : 1),
@@ -127,4 +127,4 @@ function usePaginationControls(containerRef) {
127
127
  checkControlsRequirement
128
128
  };
129
129
  }
130
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_throttle","_interopRequireDefault","require","_react","_interopRequireWildcard","_FadeIn","_OneUIProvider","_usePaginationControlsModule","_html","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","usePaginationControls","containerRef","snapToPage","baseWidth","snapToCutElement","_snapToCutElement","props","arguments","length","undefined","controlsState","setControls","useState","leftControl","rightControl","LeftControl","useOneUIConfig","RightControl","className","move","direction","childBaseWidth","current","firstElementChild","clientWidth","howMuchDoesTheScrollAddsUpTo","scrollLeft","Math","floor","howMuchElementsFitOnAPage","howMuchElementsFullyFitOnAPage","directionScale","howMuchOfTheRemainingElementIsShown","howMuchToScroll","scrollBy","left","behavior","rest","snapOffset","checkControlsRequirement","updateFunc","next","prev","el","shouldHaveAnyControl","scrollWidth","shouldHaveRightControl","shouldHaveLeftControl","useEffect","throttledCheck","throttle","startingX","lastX","onTouchStart","_ref","touches","e","isSameTarget","pageX","item","onTouchMove","_ref2","touch","onTouchEnd","dir","addEventListener","passive","removeEventListener","controls","createElement","active","Styles","control","onClick","right"],"sources":["../../../src/hooks/ui/usePaginationControls.tsx"],"sourcesContent":["import throttle from \"lodash/throttle\";\nimport React, { RefObject, useEffect, useState } from \"react\";\nimport Fade from \"../../components/FadeIn\";\nimport { useOneUIConfig } from \"../../context/OneUIProvider\";\nimport Styles from \"./usePaginationControls.module.scss\";\nimport { isSameTarget } from \"../../utils/html.utils\";\n\n/**\n * This hook handles the display of pagination controls for the user to move to another page\n */\nexport default function usePaginationControls(\n  containerRef: RefObject<HTMLDivElement>,\n  {\n    snapToPage,\n    baseWidth,\n    snapToCutElement: _snapToCutElement,\n    ...props\n  }: {\n    snapToPage?: boolean;\n    baseWidth?: number;\n    /** This will scroll only until the partially visible element is at the border, instead of scrolling all the container */\n    snapToCutElement?: boolean;\n    \"data-testid\"?: [left: string, right: string];\n  } = {}\n) {\n  const [controlsState, setControls] = useState<\n    [leftControl: boolean, rightControl: boolean]\n  >([false, false]);\n  const [leftControl, rightControl] = controlsState;\n  const LeftControl = useOneUIConfig(\n    \"hook.ui.usePaginationControls.LeftControl\"\n  );\n  const RightControl = useOneUIConfig(\n    \"hook.ui.usePaginationControls.RightControl\"\n  );\n  const className = useOneUIConfig(\n    \"hook.ui.usePaginationControls.className\",\n    \"\"\n  );\n  function move(direction: \"l\" | \"r\", snapToCutElement = _snapToCutElement) {\n    return () => {\n      if (snapToCutElement ?? false) {\n        const childBaseWidth =\n          baseWidth! || containerRef.current!.firstElementChild!.clientWidth;\n        const howMuchDoesTheScrollAddsUpTo =\n          containerRef.current!.scrollLeft / childBaseWidth -\n          Math.floor(\n            (containerRef.current!.scrollLeft + (direction === \"l\" ? -1 : 0)) /\n              childBaseWidth\n          );\n        const howMuchElementsFitOnAPage =\n          containerRef.current!.clientWidth / childBaseWidth;\n\n        const howMuchElementsFullyFitOnAPage =\n          Math.floor(howMuchElementsFitOnAPage) || 1;\n\n        const directionScale =\n          direction === \"l\"\n            ? 1 - howMuchDoesTheScrollAddsUpTo\n            : howMuchDoesTheScrollAddsUpTo;\n\n        const howMuchOfTheRemainingElementIsShown =\n          howMuchElementsFitOnAPage +\n          directionScale -\n          howMuchElementsFullyFitOnAPage;\n\n        const howMuchToScroll =\n          (containerRef.current!.clientWidth -\n            childBaseWidth * howMuchOfTheRemainingElementIsShown) *\n          (direction === \"l\" ? -1 : 1);\n\n        containerRef.current!.scrollBy({\n          left: howMuchToScroll,\n          behavior: \"smooth\",\n        });\n      } else {\n        const rest =\n          containerRef.current!.scrollLeft % containerRef.current!.clientWidth;\n        const snapOffset = snapToPage\n          ? direction === \"l\"\n            ? rest\n              ? containerRef.current!.clientWidth - rest\n              : 0\n            : rest\n          : 0;\n        containerRef.current!.scrollBy({\n          left:\n            (containerRef.current!.clientWidth - snapOffset) *\n            (direction === \"l\" ? -1 : 1),\n          behavior: \"smooth\",\n        });\n      }\n    };\n  }\n\n  function checkControlsRequirement() {\n    const updateFunc =\n      (next: typeof controlsState) => (prev: typeof controlsState) => {\n        if (prev[0] !== next[0] || prev[1] !== next[1]) return next;\n        return prev;\n      };\n    const el = containerRef.current;\n    if (!el) return;\n    const shouldHaveAnyControl = el.scrollWidth > el.clientWidth;\n    if (!shouldHaveAnyControl) setControls(updateFunc([false, false]));\n    else {\n      const shouldHaveRightControl =\n        el.scrollLeft < el.scrollWidth - el.clientWidth;\n      const shouldHaveLeftControl = el.scrollLeft > 0;\n\n      setControls(updateFunc([shouldHaveLeftControl, shouldHaveRightControl]));\n    }\n  }\n  useEffect(() => {\n    const el = containerRef.current!;\n    const throttledCheck = throttle(checkControlsRequirement, 1000 / 4);\n    checkControlsRequirement();\n    let startingX: number | undefined;\n    let lastX: number | undefined;\n\n    const onTouchStart = ({ touches, ...e }: TouchEvent) => {\n      if (!isSameTarget(e)) return;\n      const { pageX } = touches.item(0)!;\n      startingX = pageX;\n    };\n    const onTouchMove = ({ touches, ...e }: TouchEvent) => {\n      if (!isSameTarget(e)) return;\n      const touch = touches.item(0);\n\n      lastX = touch!.pageX;\n    };\n    const onTouchEnd = (e: Event) => {\n      if (!lastX) return;\n      const dir = lastX > startingX! ? \"l\" : \"r\";\n      move(dir, true)();\n      startingX = undefined;\n    };\n    el.addEventListener(\"scroll\", throttledCheck, {\n      passive: true,\n    });\n    el.addEventListener(\"touchstart\", onTouchStart);\n    el.addEventListener(\"touchend\", onTouchEnd);\n    el.addEventListener(\"touchmove\", onTouchMove);\n    return () => {\n      el.removeEventListener(\"scroll\", throttledCheck);\n      el.removeEventListener(\"touchstart\", onTouchStart);\n      el.removeEventListener(\"touchend\", onTouchEnd);\n      el.removeEventListener(\"touchend\", onTouchEnd);\n    };\n  }, []);\n\n  return {\n    controls: [\n      <Fade\n        key={\"l\"}\n        active={leftControl}\n        className={`${Styles.left} ${Styles.control} ${className}`}\n        data-testid={props[\"data-testid\"]?.[0]}\n        onClick={move(\"l\")}\n      >\n        {leftControl && <LeftControl />}\n      </Fade>,\n      <Fade\n        key={\"r\"}\n        active={rightControl}\n        className={`${Styles.right} ${Styles.control} ${className}`}\n        data-testid={props[\"data-testid\"]?.[1]}\n        onClick={move(\"r\")}\n      >\n        {rightControl && <RightControl />}\n      </Fade>,\n    ],\n    checkControlsRequirement,\n  };\n}\n"],"mappings":"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"}
130
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_throttle","_interopRequireDefault","require","_react","_interopRequireWildcard","_FadeIn","_OneUIProvider","_usePaginationControlsModule","_html","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","usePaginationControls","containerRef","snapToPage","baseWidth","snapToCutElement","_snapToCutElement","props","arguments","length","undefined","controlsState","setControls","useState","leftControl","rightControl","LeftControl","useOneUIConfig","RightControl","className","move","direction","childBaseWidth","current","firstElementChild","clientWidth","howMuchDoesTheScrollAddsUpTo","scrollLeft","Math","floor","howMuchElementsFitOnAPage","howMuchElementsFullyFitOnAPage","directionScale","howMuchOfTheRemainingElementIsShown","howMuchToScroll","scrollBy","left","behavior","rest","round","snapOffset","checkControlsRequirement","updateFunc","next","prev","el","shouldHaveAnyControl","scrollWidth","shouldHaveRightControl","shouldHaveLeftControl","useEffect","throttledCheck","throttle","startingX","lastX","onTouchStart","_ref","touches","e","isSameTarget","pageX","item","onTouchMove","_ref2","touch","onTouchEnd","dir","addEventListener","passive","removeEventListener","controls","createElement","active","Styles","control","onClick","right"],"sources":["../../../src/hooks/ui/usePaginationControls.tsx"],"sourcesContent":["import throttle from \"lodash/throttle\";\nimport React, { RefObject, useEffect, useState } from \"react\";\nimport Fade from \"../../components/FadeIn\";\nimport { useOneUIConfig } from \"../../context/OneUIProvider\";\nimport Styles from \"./usePaginationControls.module.scss\";\nimport { isSameTarget } from \"../../utils/html.utils\";\n\n/**\n * This hook handles the display of pagination controls for the user to move to another page\n */\nexport default function usePaginationControls(\n  containerRef: RefObject<HTMLDivElement>,\n  {\n    snapToPage,\n    baseWidth,\n    snapToCutElement: _snapToCutElement,\n    ...props\n  }: {\n    snapToPage?: boolean;\n    baseWidth?: number;\n    /** This will scroll only until the partially visible element is at the border, instead of scrolling all the container */\n    snapToCutElement?: boolean;\n    \"data-testid\"?: [left: string, right: string];\n  } = {}\n) {\n  const [controlsState, setControls] = useState<\n    [leftControl: boolean, rightControl: boolean]\n  >([false, false]);\n  const [leftControl, rightControl] = controlsState;\n  const LeftControl = useOneUIConfig(\n    \"hook.ui.usePaginationControls.LeftControl\"\n  );\n  const RightControl = useOneUIConfig(\n    \"hook.ui.usePaginationControls.RightControl\"\n  );\n  const className = useOneUIConfig(\n    \"hook.ui.usePaginationControls.className\",\n    \"\"\n  );\n  function move(direction: \"l\" | \"r\", snapToCutElement = _snapToCutElement) {\n    return () => {\n      if (snapToCutElement ?? false) {\n        const childBaseWidth =\n          baseWidth! || containerRef.current!.firstElementChild!.clientWidth;\n        const howMuchDoesTheScrollAddsUpTo =\n          containerRef.current!.scrollLeft / childBaseWidth -\n          Math.floor(\n            (containerRef.current!.scrollLeft + (direction === \"l\" ? -1 : 0)) /\n              childBaseWidth\n          );\n        const howMuchElementsFitOnAPage =\n          containerRef.current!.clientWidth / childBaseWidth;\n\n        const howMuchElementsFullyFitOnAPage =\n          Math.floor(howMuchElementsFitOnAPage) || 1;\n\n        const directionScale =\n          direction === \"l\"\n            ? 1 - howMuchDoesTheScrollAddsUpTo\n            : howMuchDoesTheScrollAddsUpTo;\n\n        const howMuchOfTheRemainingElementIsShown =\n          howMuchElementsFitOnAPage +\n          directionScale -\n          howMuchElementsFullyFitOnAPage;\n\n        const howMuchToScroll =\n          (containerRef.current!.clientWidth -\n            childBaseWidth * howMuchOfTheRemainingElementIsShown) *\n          (direction === \"l\" ? -1 : 1);\n\n        containerRef.current!.scrollBy({\n          left: howMuchToScroll,\n          behavior: \"smooth\",\n        });\n      } else {\n        const rest =\n          Math.round(containerRef.current!.scrollLeft) %\n          containerRef.current!.clientWidth;\n        const snapOffset = snapToPage\n          ? direction === \"l\"\n            ? rest\n              ? containerRef.current!.clientWidth - rest\n              : 0\n            : rest\n          : 0;\n        containerRef.current!.scrollBy({\n          left:\n            (containerRef.current!.clientWidth - snapOffset) *\n            (direction === \"l\" ? -1 : 1),\n          behavior: \"smooth\",\n        });\n      }\n    };\n  }\n\n  function checkControlsRequirement() {\n    const updateFunc =\n      (next: typeof controlsState) => (prev: typeof controlsState) => {\n        if (prev[0] !== next[0] || prev[1] !== next[1]) return next;\n        return prev;\n      };\n    const el = containerRef.current;\n    if (!el) return;\n    const shouldHaveAnyControl = el.scrollWidth > el.clientWidth;\n    if (!shouldHaveAnyControl) setControls(updateFunc([false, false]));\n    else {\n      const shouldHaveRightControl =\n        el.scrollLeft < el.scrollWidth - el.clientWidth;\n      const shouldHaveLeftControl = el.scrollLeft > 0;\n\n      setControls(updateFunc([shouldHaveLeftControl, shouldHaveRightControl]));\n    }\n  }\n  useEffect(() => {\n    const el = containerRef.current!;\n    const throttledCheck = throttle(checkControlsRequirement, 1000 / 4);\n    checkControlsRequirement();\n    let startingX: number | undefined;\n    let lastX: number | undefined;\n\n    const onTouchStart = ({ touches, ...e }: TouchEvent) => {\n      if (!isSameTarget(e)) return;\n      const { pageX } = touches.item(0)!;\n      startingX = pageX;\n    };\n    const onTouchMove = ({ touches, ...e }: TouchEvent) => {\n      if (!isSameTarget(e)) return;\n      const touch = touches.item(0);\n\n      lastX = touch!.pageX;\n    };\n    const onTouchEnd = (e: Event) => {\n      if (!lastX) return;\n      const dir = lastX > startingX! ? \"l\" : \"r\";\n      move(dir, true)();\n      startingX = undefined;\n    };\n    el.addEventListener(\"scroll\", throttledCheck, {\n      passive: true,\n    });\n    el.addEventListener(\"touchstart\", onTouchStart);\n    el.addEventListener(\"touchend\", onTouchEnd);\n    el.addEventListener(\"touchmove\", onTouchMove);\n    return () => {\n      el.removeEventListener(\"scroll\", throttledCheck);\n      el.removeEventListener(\"touchstart\", onTouchStart);\n      el.removeEventListener(\"touchend\", onTouchEnd);\n      el.removeEventListener(\"touchend\", onTouchEnd);\n    };\n  }, []);\n\n  return {\n    controls: [\n      <Fade\n        key={\"l\"}\n        active={leftControl}\n        className={`${Styles.left} ${Styles.control} ${className}`}\n        data-testid={props[\"data-testid\"]?.[0]}\n        onClick={move(\"l\")}\n      >\n        {leftControl && <LeftControl />}\n      </Fade>,\n      <Fade\n        key={\"r\"}\n        active={rightControl}\n        className={`${Styles.right} ${Styles.control} ${className}`}\n        data-testid={props[\"data-testid\"]?.[1]}\n        onClick={move(\"r\")}\n      >\n        {rightControl && <RightControl />}\n      </Fade>,\n    ],\n    checkControlsRequirement,\n  };\n}\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@onepercentio/one-ui",
3
- "version": "0.27.0",
3
+ "version": "0.27.2",
4
4
  "description": "A set of reusable components created through the development of Onepercent projects",
5
5
  "repository": "git@github.com:onepercentio/one-ui.git",
6
6
  "author": "Murilo Oliveira de Araujo <murilo.araujo@onepercent.io>",