@onepercentio/one-ui 0.25.8 → 0.26.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/AdaptiveDialog/AdaptiveDialog.d.ts +5 -1
- package/dist/components/AdaptiveDialog/AdaptiveDialog.js +6 -4
- package/dist/components/Collapsable/Collapsable.module.scss +3 -0
- package/dist/components/FileInput/FileInput.d.ts +3 -3
- package/dist/components/FileInput/FileInput.js +1 -1
- package/dist/hooks/ui/usePaginationControls.js +9 -4
- package/dist/hooks/useElementFit.d.ts +3 -1
- package/dist/hooks/useElementFit.js +4 -3
- package/dist/hooks/usePagination.js +5 -4
- package/dist/hooks/utility/useDepChange.d.ts +1 -0
- package/dist/hooks/utility/useDepChange.js +17 -0
- package/package.json +1 -1
|
@@ -2,11 +2,15 @@ import { PropsWithChildren } from "react";
|
|
|
2
2
|
/**
|
|
3
3
|
* This component implements a generic drawer that displays it as a drawer on mobile and as a modal on desktop
|
|
4
4
|
**/
|
|
5
|
-
export default function AdaptiveDialog({ variant, onClose, open, className, onClickOut, children, onClosed, }: PropsWithChildren<{
|
|
5
|
+
export default function AdaptiveDialog({ variant, onClose, open, className, onClickOut, children, onClosed, inline, }: PropsWithChildren<{
|
|
6
6
|
variant?: OnepercentUtility.UIElements.AdaptiveDialogVariants;
|
|
7
7
|
className?: string;
|
|
8
8
|
open: boolean;
|
|
9
9
|
onClose?: () => void;
|
|
10
10
|
onClickOut?: () => void;
|
|
11
11
|
onClosed?: () => void;
|
|
12
|
+
/**
|
|
13
|
+
* Indicates this rendering will write the html inside the current position on dom.
|
|
14
|
+
* If omitted or false, it will render on the document body, to prevent style bleeding */
|
|
15
|
+
inline?: boolean;
|
|
12
16
|
}>): import("react/jsx-runtime").JSX.Element | null;
|
|
@@ -24,7 +24,8 @@ function AdaptiveDialog(_ref) {
|
|
|
24
24
|
className = "",
|
|
25
25
|
onClickOut,
|
|
26
26
|
children,
|
|
27
|
-
onClosed
|
|
27
|
+
onClosed,
|
|
28
|
+
inline = false
|
|
28
29
|
} = _ref;
|
|
29
30
|
const rootDivRef = (0, _react.useRef)(null);
|
|
30
31
|
const [isVisible, setIsVisible] = (0, _react.useState)(open);
|
|
@@ -47,7 +48,7 @@ function AdaptiveDialog(_ref) {
|
|
|
47
48
|
backdrop: (0, _OneUIProvider.useOneUIConfig)("component.adaptiveDialog.backdropClassName", ""),
|
|
48
49
|
dialog: (0, _OneUIProvider.useOneUIConfig)("component.adaptiveDialog.dialogClassName", "")
|
|
49
50
|
};
|
|
50
|
-
|
|
51
|
+
const content = /*#__PURE__*/_react.default.createElement("div", {
|
|
51
52
|
ref: rootDivRef,
|
|
52
53
|
className: `${_AdaptiveDialogModule.default.backdrop} ${open ? _AdaptiveDialogModule.default.open : _AdaptiveDialogModule.default.close} ${expanded ? _AdaptiveDialogModule.default.expanded : ""} ${globalClassName.backdrop} ${variantClass}`,
|
|
53
54
|
onClick: onClickOut,
|
|
@@ -71,6 +72,7 @@ function AdaptiveDialog(_ref) {
|
|
|
71
72
|
size: 24
|
|
72
73
|
})), /*#__PURE__*/_react.default.createElement("div", {
|
|
73
74
|
onClick: () => setExpanded(p => !p)
|
|
74
|
-
}), children)))
|
|
75
|
+
}), children)));
|
|
76
|
+
return isVisible || open ? inline ? content : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_reactDom.default.createPortal(content, document.body)) : null;
|
|
75
77
|
}
|
|
76
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_AdaptiveDialogModule","_interopRequireDefault","_MutableHamburgerButton","_ScrollAndFocusLock","_reactDom","_OneUIProvider","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","AdaptiveDialog","_ref","variant","onClose","open","className","onClickOut","children","onClosed","rootDivRef","useRef","isVisible","setIsVisible","useState","expanded","setExpanded","variantClass","useOneUIConfig","useEffect","toggleVisbility","e","animationName","Styles","backdropDismiss","target","removeEventListener","current","addEventListener","globalClassName","backdrop","dialog","createElement","Fragment","ReactDOM","createPortal","ref","close","onClick","onAnimationEnd","_ref2","currentTarget","style","pointerEvents","container","stopPropagation","closeBtn","state","size","p","document","body"],"sources":["../../../src/components/AdaptiveDialog/AdaptiveDialog.tsx"],"sourcesContent":["import React, { PropsWithChildren, useEffect, useRef, useState } from \"react\";\nimport Styles from \"./AdaptiveDialog.module.scss\";\nimport MutableHamburgerButton from \"../MutableHamburgerButton\";\nimport ScrollAndFocusLock from \"../utilitary/ScrollAndFocusLock\";\nimport ReactDOM from \"react-dom\";\nimport { useOneUIConfig } from \"../../context/OneUIProvider\";\n\n/**\n * This component implements a generic drawer that displays it as a drawer on mobile and as a modal on desktop\n **/\nexport default function AdaptiveDialog({\n  variant = \"default\",\n  onClose,\n  open = false,\n  className = \"\",\n  onClickOut,\n  children,\n  onClosed,\n}: PropsWithChildren<{\n  variant?: OnepercentUtility.UIElements.AdaptiveDialogVariants;\n  className?: string;\n  open: boolean;\n  onClose?: () => void;\n  onClickOut?: () => void;\n  onClosed?: () => void;\n}>) {\n  const rootDivRef = useRef<HTMLDivElement>(null);\n  const [isVisible, setIsVisible] = useState(open);\n  const [expanded, setExpanded] = useState(false);\n  const variantClass = useOneUIConfig(\n    `component.adaptiveDialog.variant.${variant}`,\n    \"\"\n  );\n\n  useEffect(() => {\n    if (open) {\n      setIsVisible(true);\n      const toggleVisbility = (e: AnimationEvent) => {\n        if (e.animationName === Styles.backdropDismiss) {\n          onClosed?.();\n          setIsVisible(false);\n          (e.target! as HTMLDivElement).removeEventListener(\n            \"animationend\",\n            toggleVisbility\n          );\n        }\n      };\n      rootDivRef.current!.addEventListener(\"animationend\", toggleVisbility);\n    }\n  }, [open]);\n\n  const globalClassName = {\n    backdrop: useOneUIConfig(\"component.adaptiveDialog.backdropClassName\", \"\"),\n    dialog: useOneUIConfig(\"component.adaptiveDialog.dialogClassName\", \"\"),\n  };\n\n  return isVisible || open ? (\n    <>\n      {ReactDOM.createPortal(\n        <div\n          ref={rootDivRef}\n          className={`${Styles.backdrop} ${open ? Styles.open : Styles.close} ${\n            expanded ? Styles.expanded : \"\"\n          } ${globalClassName.backdrop} ${variantClass}`}\n          onClick={onClickOut}\n          onAnimationEnd={({ target, currentTarget }) => {\n            if (target === currentTarget)\n              (target as HTMLDivElement).style.pointerEvents = \"initial\";\n          }}\n        >\n          <div\n            className={`${Styles.container} ${className} ${globalClassName.dialog}`}\n            onClick={(e) => e.stopPropagation()}\n          >\n            <ScrollAndFocusLock open={open}>\n              {onClose && (\n                <button className={Styles.closeBtn} onClick={onClose}>\n                  <MutableHamburgerButton state=\"closed\" size={24} />\n                </button>\n              )}\n              <div onClick={() => setExpanded((p) => !p)} />\n              {children}\n            </ScrollAndFocusLock>\n          </div>\n        </div>,\n        document.body\n      )}\n    </>\n  ) : null;\n}\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,qBAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,uBAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,mBAAA,GAAAF,sBAAA,CAAAF,OAAA;AACA,IAAAK,SAAA,GAAAH,sBAAA,CAAAF,OAAA;AACA,IAAAM,cAAA,GAAAN,OAAA;AAA6D,SAAAE,uBAAAK,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAAA,SAAAG,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAZ,wBAAAQ,GAAA,EAAAI,WAAA,SAAAA,WAAA,IAAAJ,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,oBAAAA,GAAA,wBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAQ,KAAA,GAAAL,wBAAA,CAAAC,WAAA,OAAAI,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAT,GAAA,YAAAQ,KAAA,CAAAE,GAAA,CAAAV,GAAA,SAAAW,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAhB,GAAA,QAAAgB,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAnB,GAAA,EAAAgB,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAf,GAAA,EAAAgB,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAhB,GAAA,CAAAgB,GAAA,SAAAL,MAAA,CAAAT,OAAA,GAAAF,GAAA,MAAAQ,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAArB,GAAA,EAAAW,MAAA,YAAAA,MAAA;AAE7D;AACA;AACA;AACe,SAASW,cAAcA,CAAAC,IAAA,EAelC;EAAA,IAfmC;IACrCC,OAAO,GAAG,SAAS;IACnBC,OAAO;IACPC,IAAI,GAAG,KAAK;IACZC,SAAS,GAAG,EAAE;IACdC,UAAU;IACVC,QAAQ;IACRC;EAQD,CAAC,GAAAP,IAAA;EACA,MAAMQ,UAAU,GAAG,IAAAC,aAAM,EAAiB,IAAI,CAAC;EAC/C,MAAM,CAACC,SAAS,EAAEC,YAAY,CAAC,GAAG,IAAAC,eAAQ,EAACT,IAAI,CAAC;EAChD,MAAM,CAACU,QAAQ,EAAEC,WAAW,CAAC,GAAG,IAAAF,eAAQ,EAAC,KAAK,CAAC;EAC/C,MAAMG,YAAY,GAAG,IAAAC,6BAAc,EAChC,oCAAmCf,OAAQ,EAAC,EAC7C,EACF,CAAC;EAED,IAAAgB,gBAAS,EAAC,MAAM;IACd,IAAId,IAAI,EAAE;MACRQ,YAAY,CAAC,IAAI,CAAC;MAClB,MAAMO,eAAe,GAAIC,CAAiB,IAAK;QAC7C,IAAIA,CAAC,CAACC,aAAa,KAAKC,6BAAM,CAACC,eAAe,EAAE;UAC9Cf,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAG,CAAC;UACZI,YAAY,CAAC,KAAK,CAAC;UAClBQ,CAAC,CAACI,MAAM,CAAqBC,mBAAmB,CAC/C,cAAc,EACdN,eACF,CAAC;QACH;MACF,CAAC;MACDV,UAAU,CAACiB,OAAO,CAAEC,gBAAgB,CAAC,cAAc,EAAER,eAAe,CAAC;IACvE;EACF,CAAC,EAAE,CAACf,IAAI,CAAC,CAAC;EAEV,MAAMwB,eAAe,GAAG;IACtBC,QAAQ,EAAE,IAAAZ,6BAAc,EAAC,4CAA4C,EAAE,EAAE,CAAC;IAC1Ea,MAAM,EAAE,IAAAb,6BAAc,EAAC,0CAA0C,EAAE,EAAE;EACvE,CAAC;EAED,OAAON,SAAS,IAAIP,IAAI,gBACtBnC,MAAA,CAAAW,OAAA,CAAAmD,aAAA,CAAA9D,MAAA,CAAAW,OAAA,CAAAoD,QAAA,qBACGC,iBAAQ,CAACC,YAAY,eACpBjE,MAAA,CAAAW,OAAA,CAAAmD,aAAA;IACEI,GAAG,EAAE1B,UAAW;IAChBJ,SAAS,EAAG,GAAEiB,6BAAM,CAACO,QAAS,IAAGzB,IAAI,GAAGkB,6BAAM,CAAClB,IAAI,GAAGkB,6BAAM,CAACc,KAAM,IACjEtB,QAAQ,GAAGQ,6BAAM,CAACR,QAAQ,GAAG,EAC9B,IAAGc,eAAe,CAACC,QAAS,IAAGb,YAAa,EAAE;IAC/CqB,OAAO,EAAE/B,UAAW;IACpBgC,cAAc,EAAEC,KAAA,IAA+B;MAAA,IAA9B;QAAEf,MAAM;QAAEgB;MAAc,CAAC,GAAAD,KAAA;MACxC,IAAIf,MAAM,KAAKgB,aAAa,EACzBhB,MAAM,CAAoBiB,KAAK,CAACC,aAAa,GAAG,SAAS;IAC9D;EAAE,gBAEFzE,MAAA,CAAAW,OAAA,CAAAmD,aAAA;IACE1B,SAAS,EAAG,GAAEiB,6BAAM,CAACqB,SAAU,IAAGtC,SAAU,IAAGuB,eAAe,CAACE,MAAO,EAAE;IACxEO,OAAO,EAAGjB,CAAC,IAAKA,CAAC,CAACwB,eAAe,CAAC;EAAE,gBAEpC3E,MAAA,CAAAW,OAAA,CAAAmD,aAAA,CAACxD,mBAAA,CAAAK,OAAkB;IAACwB,IAAI,EAAEA;EAAK,GAC5BD,OAAO,iBACNlC,MAAA,CAAAW,OAAA,CAAAmD,aAAA;IAAQ1B,SAAS,EAAEiB,6BAAM,CAACuB,QAAS;IAACR,OAAO,EAAElC;EAAQ,gBACnDlC,MAAA,CAAAW,OAAA,CAAAmD,aAAA,CAACzD,uBAAA,CAAAM,OAAsB;IAACkE,KAAK,EAAC,QAAQ;IAACC,IAAI,EAAE;EAAG,CAAE,CAC5C,CACT,eACD9E,MAAA,CAAAW,OAAA,CAAAmD,aAAA;IAAKM,OAAO,EAAEA,CAAA,KAAMtB,WAAW,CAAEiC,CAAC,IAAK,CAACA,CAAC;EAAE,CAAE,CAAC,EAC7CzC,QACiB,CACjB,CACF,CAAC,EACN0C,QAAQ,CAACC,IACX,CACA,CAAC,GACD,IAAI;AACV"}
|
|
78
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_AdaptiveDialogModule","_interopRequireDefault","_MutableHamburgerButton","_ScrollAndFocusLock","_reactDom","_OneUIProvider","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","AdaptiveDialog","_ref","variant","onClose","open","className","onClickOut","children","onClosed","inline","rootDivRef","useRef","isVisible","setIsVisible","useState","expanded","setExpanded","variantClass","useOneUIConfig","useEffect","toggleVisbility","e","animationName","Styles","backdropDismiss","target","removeEventListener","current","addEventListener","globalClassName","backdrop","dialog","content","createElement","ref","close","onClick","onAnimationEnd","_ref2","currentTarget","style","pointerEvents","container","stopPropagation","closeBtn","state","size","p","Fragment","ReactDOM","createPortal","document","body"],"sources":["../../../src/components/AdaptiveDialog/AdaptiveDialog.tsx"],"sourcesContent":["import React, { PropsWithChildren, useEffect, useRef, useState } from \"react\";\nimport Styles from \"./AdaptiveDialog.module.scss\";\nimport MutableHamburgerButton from \"../MutableHamburgerButton\";\nimport ScrollAndFocusLock from \"../utilitary/ScrollAndFocusLock\";\nimport ReactDOM from \"react-dom\";\nimport { useOneUIConfig } from \"../../context/OneUIProvider\";\n\n/**\n * This component implements a generic drawer that displays it as a drawer on mobile and as a modal on desktop\n **/\nexport default function AdaptiveDialog({\n  variant = \"default\",\n  onClose,\n  open = false,\n  className = \"\",\n  onClickOut,\n  children,\n  onClosed,\n  inline = false,\n}: PropsWithChildren<{\n  variant?: OnepercentUtility.UIElements.AdaptiveDialogVariants;\n  className?: string;\n  open: boolean;\n  onClose?: () => void;\n  onClickOut?: () => void;\n  onClosed?: () => void;\n  /**\n   * Indicates this rendering will write the html inside the current position on dom.\n   * If omitted or false, it will render on the document body, to prevent style bleeding */\n  inline?: boolean;\n}>) {\n  const rootDivRef = useRef<HTMLDivElement>(null);\n  const [isVisible, setIsVisible] = useState(open);\n  const [expanded, setExpanded] = useState(false);\n  const variantClass = useOneUIConfig(\n    `component.adaptiveDialog.variant.${variant}`,\n    \"\"\n  );\n\n  useEffect(() => {\n    if (open) {\n      setIsVisible(true);\n      const toggleVisbility = (e: AnimationEvent) => {\n        if (e.animationName === Styles.backdropDismiss) {\n          onClosed?.();\n          setIsVisible(false);\n          (e.target! as HTMLDivElement).removeEventListener(\n            \"animationend\",\n            toggleVisbility\n          );\n        }\n      };\n      rootDivRef.current!.addEventListener(\"animationend\", toggleVisbility);\n    }\n  }, [open]);\n\n  const globalClassName = {\n    backdrop: useOneUIConfig(\"component.adaptiveDialog.backdropClassName\", \"\"),\n    dialog: useOneUIConfig(\"component.adaptiveDialog.dialogClassName\", \"\"),\n  };\n  const content = (\n    <div\n      ref={rootDivRef}\n      className={`${Styles.backdrop} ${open ? Styles.open : Styles.close} ${\n        expanded ? Styles.expanded : \"\"\n      } ${globalClassName.backdrop} ${variantClass}`}\n      onClick={onClickOut}\n      onAnimationEnd={({ target, currentTarget }) => {\n        if (target === currentTarget)\n          (target as HTMLDivElement).style.pointerEvents = \"initial\";\n      }}\n    >\n      <div\n        className={`${Styles.container} ${className} ${globalClassName.dialog}`}\n        onClick={(e) => e.stopPropagation()}\n      >\n        <ScrollAndFocusLock open={open}>\n          {onClose && (\n            <button className={Styles.closeBtn} onClick={onClose}>\n              <MutableHamburgerButton state=\"closed\" size={24} />\n            </button>\n          )}\n          <div onClick={() => setExpanded((p) => !p)} />\n          {children}\n        </ScrollAndFocusLock>\n      </div>\n    </div>\n  );\n\n  return isVisible || open ? (\n    inline ? (\n      content\n    ) : (\n      <>{ReactDOM.createPortal(content, document.body)}</>\n    )\n  ) : null;\n}\n"],"mappings":"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"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import React from "react";
|
|
1
|
+
import React, { ReactElement } from "react";
|
|
2
2
|
export type FileInputProps = {
|
|
3
3
|
states: {
|
|
4
4
|
waitingFile: {
|
|
5
5
|
/** The reason why this file is being requested */
|
|
6
|
-
title: string;
|
|
6
|
+
title: string | ReactElement;
|
|
7
7
|
/** Shown below the title */
|
|
8
8
|
description?: string;
|
|
9
9
|
/** The label to show on the button */
|
|
@@ -11,7 +11,7 @@ export type FileInputProps = {
|
|
|
11
11
|
};
|
|
12
12
|
fileProvided: {
|
|
13
13
|
/** Text show when the file has been provided */
|
|
14
|
-
title: string;
|
|
14
|
+
title: string | ReactElement;
|
|
15
15
|
/** Shown below the title */
|
|
16
16
|
description?: string;
|
|
17
17
|
/** Shown on the button to remove the file */
|
|
@@ -44,4 +44,4 @@ function FileInput(_ref) {
|
|
|
44
44
|
}
|
|
45
45
|
var _default = FileInput;
|
|
46
46
|
exports.default = _default;
|
|
47
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfT25lVUlQcm92aWRlciIsIl9GaWxlSW5wdXRNb2R1bGUiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0Iiwib2JqIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJfZ2V0UmVxdWlyZVdpbGRjYXJkQ2FjaGUiLCJub2RlSW50ZXJvcCIsIldlYWtNYXAiLCJjYWNoZUJhYmVsSW50ZXJvcCIsImNhY2hlTm9kZUludGVyb3AiLCJjYWNoZSIsImhhcyIsImdldCIsIm5ld09iaiIsImhhc1Byb3BlcnR5RGVzY3JpcHRvciIsIk9iamVjdCIsImRlZmluZVByb3BlcnR5IiwiZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yIiwia2V5IiwicHJvdG90eXBlIiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwiZGVzYyIsInNldCIsIl9leHRlbmRzIiwiYXNzaWduIiwiYmluZCIsInRhcmdldCIsImkiLCJhcmd1bWVudHMiLCJsZW5ndGgiLCJzb3VyY2UiLCJhcHBseSIsIkZpbGVJbnB1dCIsIl9yZWYiLCJvbkZpbGUiLCJwcm9wcyIsIlZpZXciLCJ1c2VPbmVVSVZpZXciLCJpbnB1dFJlZiIsInVzZVJlZiIsIm9uRmlsZVNlbGVjdGVkIiwidXNlQ2FsbGJhY2siLCJlIiwiZmlsZSIsImZpbGVzIiwiaXRlbSIsInVuZGVmaW5lZCIsImNyZWF0ZUVsZW1lbnQiLCJvbkFjdGlvbiIsImN1cnJlbnQiLCJ2YWx1ZSIsImNsaWNrIiwiaW5wdXRFbCIsInJlZiIsIm9uQ2hhbmdlIiwidHlwZSIsImNsYXNzTmFtZSIsIlN0eWxlcyIsImhpZGRlbiIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0ZpbGVJbnB1dC9GaWxlSW5wdXQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwge1xuICBDaGFuZ2VFdmVudEhhbmRsZXIsXG4gIFJlYWN0RWxlbWVudCxcbiAgdXNlQ2FsbGJhY2ssXG4gIHVzZVJlZixcbn0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgeyB1c2VPbmVVSVZpZXcgfSBmcm9tIFwiLi4vLi4vY29udGV4dC9PbmVVSVByb3ZpZGVyXCI7XG5pbXBvcnQgU3R5bGVzIGZyb20gXCIuL0ZpbGVJbnB1dC5tb2R1bGUuc2Nzc1wiO1xuXG5leHBvcnQgdHlwZSBGaWxlSW5wdXRQcm9wcyA9IHtcbiAgc3RhdGVzOiB7XG4gICAgd2FpdGluZ0ZpbGU6IHtcbiAgICAgIC8qKiBUaGUgcmVhc29uIHdoeSB0aGlzIGZpbGUgaXMgYmVpbmcgcmVxdWVzdGVkICovXG4gICAgICB0aXRsZTogc3RyaW5nIHwgUmVhY3RFbGVtZW50O1xuICAgICAgLyoqIFNob3duIGJlbG93IHRoZSB0aXRsZSAqL1xuICAgICAgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG4gICAgICAvKiogVGhlIGxhYmVsIHRvIHNob3cgb24gdGhlIGJ1dHRvbiAqL1xuICAgICAgYnV0dG9uPzogc3RyaW5nO1xuICAgIH07XG4gICAgZmlsZVByb3ZpZGVkOiB7XG4gICAgICAvKiogVGV4dCBzaG93IHdoZW4gdGhlIGZpbGUgaGFzIGJlZW4gcHJvdmlkZWQgKi9cbiAgICAgIHRpdGxlOiBzdHJpbmcgfCBSZWFjdEVsZW1lbnQ7XG4gICAgICAvKiogU2hvd24gYmVsb3cgdGhlIHRpdGxlICovXG4gICAgICBkZXNjcmlwdGlvbj86IHN0cmluZztcbiAgICAgIC8qKiBTaG93biBvbiB0aGUgYnV0dG9uIHRvIHJlbW92ZSB0aGUgZmlsZSAqL1xuICAgICAgYnV0dG9uPzogc3RyaW5nO1xuICAgIH07XG4gIH07XG4gIGZvb3Rlcjogc3RyaW5nO1xuICBmaWxlPzogRmlsZTtcbiAgb25GaWxlOiAoZmlsZTogRmlsZSB8IHVuZGVmaW5lZCkgPT4gdm9pZDtcbiAgcHJvZ3Jlc3M/OiBudW1iZXI7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbn0gJiBSZWFjdC5IVE1MUHJvcHM8SFRNTElucHV0RWxlbWVudD47XG5cbi8qKlxuICogQSBjb21wb25lbnQgdG8gcHJvdmlkZSB0aGUgdXBsb2FkIG9mIGEgZmlsZVxuICoqL1xuZnVuY3Rpb24gRmlsZUlucHV0KHsgb25GaWxlLCAuLi5wcm9wcyB9OiBGaWxlSW5wdXRQcm9wcykge1xuICBjb25zdCBWaWV3ID0gdXNlT25lVUlWaWV3KFwiY29tcG9uZW50LmZpbGVJbnB1dC5WaWV3XCIsIFwiRmlsZUlucHV0XCIpO1xuICBjb25zdCBpbnB1dFJlZiA9IHVzZVJlZjxIVE1MSW5wdXRFbGVtZW50PihudWxsKTtcblxuICBjb25zdCBvbkZpbGVTZWxlY3RlZCA9IHVzZUNhbGxiYWNrKFxuICAgICgoZSkgPT4ge1xuICAgICAgY29uc3QgZmlsZSA9IGUudGFyZ2V0LmZpbGVzIS5pdGVtKDApO1xuICAgICAgb25GaWxlKGZpbGUgfHwgdW5kZWZpbmVkKTtcbiAgICB9KSBhcyBDaGFuZ2VFdmVudEhhbmRsZXI8SFRNTElucHV0RWxlbWVudD4sXG4gICAgW11cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxWaWV3XG4gICAgICB7Li4ucHJvcHN9XG4gICAgICBvbkFjdGlvbj17KCkgPT4ge1xuICAgICAgICBpZiAocHJvcHMuZmlsZSkge1xuICAgICAgICAgIGlucHV0UmVmLmN1cnJlbnQhLnZhbHVlID0gXCJcIjtcbiAgICAgICAgICBvbkZpbGUodW5kZWZpbmVkKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBpbnB1dFJlZi5jdXJyZW50IS5jbGljaygpO1xuICAgICAgICB9XG4gICAgICB9fVxuICAgICAgaW5wdXRFbD17XG4gICAgICAgIDxpbnB1dFxuICAgICAgICAgIHsuLi5wcm9wc31cbiAgICAgICAgICByZWY9e2lucHV0UmVmfVxuICAgICAgICAgIG9uQ2hhbmdlPXtvbkZpbGVTZWxlY3RlZH1cbiAgICAgICAgICB0eXBlPXtcImZpbGVcIn1cbiAgICAgICAgICBjbGFzc05hbWU9e1N0eWxlcy5oaWRkZW59XG4gICAgICAgIC8+XG4gICAgICB9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
|
|
@@ -23,7 +23,8 @@ function usePaginationControls(containerRef) {
|
|
|
23
23
|
snapToCutElement: _snapToCutElement,
|
|
24
24
|
...props
|
|
25
25
|
} = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
26
|
-
const [
|
|
26
|
+
const [controlsState, setControls] = (0, _react.useState)([false, false]);
|
|
27
|
+
const [leftControl, rightControl] = controlsState;
|
|
27
28
|
const LeftControl = (0, _OneUIProvider.useOneUIConfig)("hook.ui.usePaginationControls.LeftControl");
|
|
28
29
|
const RightControl = (0, _OneUIProvider.useOneUIConfig)("hook.ui.usePaginationControls.RightControl");
|
|
29
30
|
const className = (0, _OneUIProvider.useOneUIConfig)("hook.ui.usePaginationControls.className", "");
|
|
@@ -53,12 +54,16 @@ function usePaginationControls(containerRef) {
|
|
|
53
54
|
};
|
|
54
55
|
}
|
|
55
56
|
function checkControlsRequirement() {
|
|
57
|
+
const updateFunc = next => prev => {
|
|
58
|
+
if (prev[0] !== next[0] || prev[1] !== next[1]) return next;
|
|
59
|
+
return prev;
|
|
60
|
+
};
|
|
56
61
|
const el = containerRef.current;
|
|
57
62
|
const shouldHaveAnyControl = el.scrollWidth > el.clientWidth;
|
|
58
|
-
if (!shouldHaveAnyControl) setControls([false, false]);else {
|
|
63
|
+
if (!shouldHaveAnyControl) setControls(updateFunc([false, false]));else {
|
|
59
64
|
const shouldHaveRightControl = el.scrollLeft < el.scrollWidth - el.clientWidth;
|
|
60
65
|
const shouldHaveLeftControl = el.scrollLeft > 0;
|
|
61
|
-
setControls([shouldHaveLeftControl, shouldHaveRightControl]);
|
|
66
|
+
setControls(updateFunc([shouldHaveLeftControl, shouldHaveRightControl]));
|
|
62
67
|
}
|
|
63
68
|
}
|
|
64
69
|
(0, _react.useEffect)(() => {
|
|
@@ -121,4 +126,4 @@ function usePaginationControls(containerRef) {
|
|
|
121
126
|
checkControlsRequirement
|
|
122
127
|
};
|
|
123
128
|
}
|
|
124
|
-
//# 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","leftControl","rightControl","setControls","useState","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","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 [[leftControl, rightControl], setControls] = useState<\n    [leftControl: boolean, rightControl: boolean]\n  >([false, false]);\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 el = containerRef.current!;\n    const shouldHaveAnyControl = el.scrollWidth > el.clientWidth;\n    if (!shouldHaveAnyControl) setControls([false, false]);\n    else {\n      const shouldHaveRightControl =\n        el.scrollLeft < el.scrollWidth - el.clientWidth;\n      const shouldHaveLeftControl = el.scrollLeft > 0;\n\n      setControls([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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"}
|
|
129
|
+
//# 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    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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"}
|
|
@@ -6,7 +6,9 @@ import { RefObject } from "react";
|
|
|
6
6
|
*/
|
|
7
7
|
export default function useElementFit(baseWidth: number, baseHeight?: number): {
|
|
8
8
|
/** The amount of items that are able to fit in the available width */
|
|
9
|
-
|
|
9
|
+
howManyItemsFit?: number;
|
|
10
|
+
/** How many items until it overflows width */
|
|
11
|
+
anItemMore?: number;
|
|
10
12
|
/** The ref to be sent to the element that will receive the items */
|
|
11
13
|
ref: RefObject<HTMLDivElement>;
|
|
12
14
|
};
|
|
@@ -16,7 +16,7 @@ function useElementFit(baseWidth, baseHeight) {
|
|
|
16
16
|
var _ref$current, _ref$current2;
|
|
17
17
|
function howManyItemsStackVertically() {
|
|
18
18
|
if (!ref.current || baseHeight === undefined) return 1;
|
|
19
|
-
return Math.
|
|
19
|
+
return Math.floor(ref.current.clientHeight / baseHeight);
|
|
20
20
|
}
|
|
21
21
|
if (window.PRERENDER) return 4;
|
|
22
22
|
const width = ((_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.clientWidth) || window.visualViewport.width;
|
|
@@ -36,8 +36,9 @@ function useElementFit(baseWidth, baseHeight) {
|
|
|
36
36
|
};
|
|
37
37
|
}, []);
|
|
38
38
|
return {
|
|
39
|
-
itemsToShow,
|
|
39
|
+
howManyItemsFit: itemsToShow,
|
|
40
|
+
anItemMore: itemsToShow ? itemsToShow + 1 : undefined,
|
|
40
41
|
ref
|
|
41
42
|
};
|
|
42
43
|
}
|
|
43
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJyZXF1aXJlIiwidXNlRWxlbWVudEZpdCIsImJhc2VXaWR0aCIsImJhc2VIZWlnaHQiLCJyZWYiLCJ1c2VSZWYiLCJjYWxjdWxhdGVEaW1lbnNpb24iLCJfcmVmJGN1cnJlbnQiLCJfcmVmJGN1cnJlbnQyIiwiaG93TWFueUl0ZW1zU3RhY2tWZXJ0aWNhbGx5IiwiY3VycmVudCIsInVuZGVmaW5lZCIsIk1hdGgiLCJmbG9vciIsImNsaWVudEhlaWdodCIsIndpbmRvdyIsIlBSRVJFTkRFUiIsIndpZHRoIiwiY2xpZW50V2lkdGgiLCJ2aXN1YWxWaWV3cG9ydCIsIm1heEl0ZW1zSG9yaXpvbnRhbGx5IiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiZGVmYXVsdCIsIm5hbWUiLCJpdGVtc1RvU2hvdyIsInNldEl0ZW1zVG9TaG93IiwidXNlU3RhdGUiLCJ1c2VFZmZlY3QiLCJvblJlc2l6ZSIsImFkZEV2ZW50TGlzdGVuZXIiLCJyZW1vdmVFdmVudExpc3RlbmVyIiwiaG93TWFueUl0ZW1zRml0IiwiYW5JdGVtTW9yZSJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ob29rcy91c2VFbGVtZW50Rml0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJlZk9iamVjdCwgdXNlRWZmZWN0LCB1c2VMYXlvdXRFZmZlY3QsIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tIFwicmVhY3RcIjtcblxuLyoqXG4gKiBUaGlzIGhvb2sgcmVjZWl2ZXMgYSBiYXNlIHdpZHRoIG9mIGFuIGVsZW1lbnQgYW5kIHJldHVybnMgaG93IG11Y2ggaXRlbXMgZml0ICoqdmVydGljYWxseSoqIGluc2lkZSB0aGUgcmVmZXJlbmNlZCBodG1sIGVsZW1lbnRcbiAqXG4gKiBAcGFyYW0gYmFzZVdpZHRoIFRoZSBiYXNlIHdpZHRoIG9mIGVhY2ggZWxlbWVudFxuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiB1c2VFbGVtZW50Rml0KFxuICBiYXNlV2lkdGg6IG51bWJlcixcbiAgYmFzZUhlaWdodD86IG51bWJlclxuKToge1xuICAvKiogVGhlIGFtb3VudCBvZiBpdGVtcyB0aGF0IGFyZSBhYmxlIHRvIGZpdCBpbiB0aGUgYXZhaWxhYmxlIHdpZHRoICovXG4gIGhvd01hbnlJdGVtc0ZpdD86IG51bWJlcjtcbiAgLyoqIEhvdyBtYW55IGl0ZW1zIHVudGlsIGl0IG92ZXJmbG93cyB3aWR0aCAqL1xuICBhbkl0ZW1Nb3JlPzogbnVtYmVyO1xuXG4gIC8qKiBUaGUgcmVmIHRvIGJlIHNlbnQgdG8gdGhlIGVsZW1lbnQgdGhhdCB3aWxsIHJlY2VpdmUgdGhlIGl0ZW1zICovXG4gIHJlZjogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50Pjtcbn0ge1xuICBjb25zdCByZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQ+KG51bGwpO1xuICBmdW5jdGlvbiBjYWxjdWxhdGVEaW1lbnNpb24oKSB7XG4gICAgZnVuY3Rpb24gaG93TWFueUl0ZW1zU3RhY2tWZXJ0aWNhbGx5KCkge1xuICAgICAgaWYgKCFyZWYuY3VycmVudCB8fCBiYXNlSGVpZ2h0ID09PSB1bmRlZmluZWQpIHJldHVybiAxO1xuICAgICAgcmV0dXJuIE1hdGguZmxvb3IocmVmLmN1cnJlbnQhLmNsaWVudEhlaWdodCAvIGJhc2VIZWlnaHQpO1xuICAgIH1cbiAgICBpZiAoKHdpbmRvdyBhcyBhbnkpLlBSRVJFTkRFUikgcmV0dXJuIDQ7XG5cbiAgICBjb25zdCB3aWR0aCA9IHJlZi5jdXJyZW50Py5jbGllbnRXaWR0aCB8fCB3aW5kb3cudmlzdWFsVmlld3BvcnQhLndpZHRoO1xuICAgIGNvbnN0IG1heEl0ZW1zSG9yaXpvbnRhbGx5ID0gTWF0aC5mbG9vcih3aWR0aCAvIGJhc2VXaWR0aCkgfHwgMTtcblxuICAgIGlmIChwcm9jZXNzLmVudi5OT0RFX0VOViA9PT0gXCJkZXZlbG9wbWVudFwiKVxuICAgICAgcmVxdWlyZShcIi4uL21vZGVscy9EZWJ1Z0xvZ2dlclwiKS5kZWZhdWx0KFxuICAgICAgICBgJHt1c2VFbGVtZW50Rml0Lm5hbWV9OmNsaWVudFdpZHRoYCxcbiAgICAgICAgcmVmLmN1cnJlbnQ/LmNsaWVudFdpZHRoXG4gICAgICApO1xuICAgIHJldHVybiBtYXhJdGVtc0hvcml6b250YWxseSAqIGhvd01hbnlJdGVtc1N0YWNrVmVydGljYWxseSgpO1xuICB9XG4gIGNvbnN0IFtpdGVtc1RvU2hvdywgc2V0SXRlbXNUb1Nob3ddID0gdXNlU3RhdGUoXG4gICAgKHdpbmRvdyBhcyBhbnkpLlBSRVJFTkRFUiA/IDQgOiB1bmRlZmluZWRcbiAgKTtcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBzZXRJdGVtc1RvU2hvdyhjYWxjdWxhdGVEaW1lbnNpb24oKSk7XG4gICAgZnVuY3Rpb24gb25SZXNpemUoKSB7XG4gICAgICBzZXRJdGVtc1RvU2hvdyhjYWxjdWxhdGVEaW1lbnNpb24oKSk7XG4gICAgfVxuICAgIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKFwicmVzaXplXCIsIG9uUmVzaXplKTtcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgd2luZG93LnJlbW92ZUV2ZW50TGlzdGVuZXIoXCJyZXNpemVcIiwgb25SZXNpemUpO1xuICAgIH07XG4gIH0sIFtdKTtcblxuICByZXR1cm4ge1xuICAgIGhvd01hbnlJdGVtc0ZpdDogaXRlbXNUb1Nob3csXG4gICAgYW5JdGVtTW9yZTogaXRlbXNUb1Nob3cgPyBpdGVtc1RvU2hvdyArIDEgOiB1bmRlZmluZWQsXG4gICAgcmVmLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLE9BQUE7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ2UsU0FBU0MsYUFBYUEsQ0FDbkNDLFNBQWlCLEVBQ2pCQyxVQUFtQixFQVNuQjtFQUNBLE1BQU1DLEdBQUcsR0FBRyxJQUFBQyxhQUFNLEVBQWlCLElBQUksQ0FBQztFQUN4QyxTQUFTQyxrQkFBa0JBLENBQUEsRUFBRztJQUFBLElBQUFDLFlBQUEsRUFBQUMsYUFBQTtJQUM1QixTQUFTQywyQkFBMkJBLENBQUEsRUFBRztNQUNyQyxJQUFJLENBQUNMLEdBQUcsQ0FBQ00sT0FBTyxJQUFJUCxVQUFVLEtBQUtRLFNBQVMsRUFBRSxPQUFPLENBQUM7TUFDdEQsT0FBT0MsSUFBSSxDQUFDQyxLQUFLLENBQUNULEdBQUcsQ0FBQ00sT0FBTyxDQUFFSSxZQUFZLEdBQUdYLFVBQVUsQ0FBQztJQUMzRDtJQUNBLElBQUtZLE1BQU0sQ0FBU0MsU0FBUyxFQUFFLE9BQU8sQ0FBQztJQUV2QyxNQUFNQyxLQUFLLEdBQUcsRUFBQVYsWUFBQSxHQUFBSCxHQUFHLENBQUNNLE9BQU8sY0FBQUgsWUFBQSx1QkFBWEEsWUFBQSxDQUFhVyxXQUFXLEtBQUlILE1BQU0sQ0FBQ0ksY0FBYyxDQUFFRixLQUFLO0lBQ3RFLE1BQU1HLG9CQUFvQixHQUFHUixJQUFJLENBQUNDLEtBQUssQ0FBQ0ksS0FBSyxHQUFHZixTQUFTLENBQUMsSUFBSSxDQUFDO0lBRS9ELElBQUltQixPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLGFBQWEsRUFDeEN2QixPQUFPLENBQUMsdUJBQXVCLENBQUMsQ0FBQ3dCLE9BQU8sQ0FDckMsR0FBRXZCLGFBQWEsQ0FBQ3dCLElBQUssY0FBYSxHQUFBakIsYUFBQSxHQUNuQ0osR0FBRyxDQUFDTSxPQUFPLGNBQUFGLGFBQUEsdUJBQVhBLGFBQUEsQ0FBYVUsV0FDZixDQUFDO0lBQ0gsT0FBT0Usb0JBQW9CLEdBQUdYLDJCQUEyQixDQUFDLENBQUM7RUFDN0Q7RUFDQSxNQUFNLENBQUNpQixXQUFXLEVBQUVDLGNBQWMsQ0FBQyxHQUFHLElBQUFDLGVBQVEsRUFDM0NiLE1BQU0sQ0FBU0MsU0FBUyxHQUFHLENBQUMsR0FBR0wsU0FDbEMsQ0FBQztFQUNELElBQUFrQixnQkFBUyxFQUFDLE1BQU07SUFDZEYsY0FBYyxDQUFDckIsa0JBQWtCLENBQUMsQ0FBQyxDQUFDO0lBQ3BDLFNBQVN3QixRQUFRQSxDQUFBLEVBQUc7TUFDbEJILGNBQWMsQ0FBQ3JCLGtCQUFrQixDQUFDLENBQUMsQ0FBQztJQUN0QztJQUNBUyxNQUFNLENBQUNnQixnQkFBZ0IsQ0FBQyxRQUFRLEVBQUVELFFBQVEsQ0FBQztJQUMzQyxPQUFPLE1BQU07TUFDWGYsTUFBTSxDQUFDaUIsbUJBQW1CLENBQUMsUUFBUSxFQUFFRixRQUFRLENBQUM7SUFDaEQsQ0FBQztFQUNILENBQUMsRUFBRSxFQUFFLENBQUM7RUFFTixPQUFPO0lBQ0xHLGVBQWUsRUFBRVAsV0FBVztJQUM1QlEsVUFBVSxFQUFFUixXQUFXLEdBQUdBLFdBQVcsR0FBRyxDQUFDLEdBQUdmLFNBQVM7SUFDckRQO0VBQ0YsQ0FBQztBQUNIIn0=
|
|
@@ -42,10 +42,10 @@ function usePagination(request) {
|
|
|
42
42
|
return currentPage;
|
|
43
43
|
};
|
|
44
44
|
const _requestPage = (0, _react.useCallback)(function (page, pageSize) {
|
|
45
|
+
var _paginationData$id;
|
|
45
46
|
const id = paginationIdFactory();
|
|
47
|
+
if ((_paginationData$id = paginationData[id]) !== null && _paginationData$id !== void 0 && _paginationData$id.finished) return;
|
|
46
48
|
process(async () => {
|
|
47
|
-
var _paginationData$id;
|
|
48
|
-
if ((_paginationData$id = paginationData[id]) !== null && _paginationData$id !== void 0 && _paginationData$id.finished) return;
|
|
49
49
|
const result = await request(page, pageSize, (items === null || items === void 0 ? void 0 : items[0]) === id && page !== 0 ? pageSize === "all" ? undefined : items === null || items === void 0 ? void 0 : items[1].slice(0, page * pageSize) : undefined);
|
|
50
50
|
paginationData[id] = {
|
|
51
51
|
finished: result.finished,
|
|
@@ -90,8 +90,9 @@ function useContainerPagination(cb, pageSize) {
|
|
|
90
90
|
(0, _react.useEffect)(() => {
|
|
91
91
|
const el = scrollableRef.current;
|
|
92
92
|
const scrollElement = el.scrollingElement || el;
|
|
93
|
-
const calculateIfReachedLimit = (0, _throttle.default)(
|
|
93
|
+
const calculateIfReachedLimit = (0, _throttle.default)(e => {
|
|
94
94
|
var _customOptionsRef$cur;
|
|
95
|
+
if (e.target !== el) return;
|
|
95
96
|
const {
|
|
96
97
|
offsetBottom = 0,
|
|
97
98
|
offsetLeft = 0
|
|
@@ -145,4 +146,4 @@ function useLocalPagination(items) {
|
|
|
145
146
|
src: pagSrc
|
|
146
147
|
};
|
|
147
148
|
}
|
|
148
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_useAsyncControl","_interopRequireDefault","_throttle","obj","__esModule","default","usePagination","request","paginationId","arguments","length","undefined","startingItems","paginationDataRef","useRef","current","paginationData","paginationIdFactory","useMemo","randId","Math","random","toString","Array","isArray","items","setItems","useState","id","setId","useEffect","process","control","useAsyncControl","updateItems","cb","prev","derivateCurrentPage","pageSize","currentPage","ceil","_requestPage","useCallback","page","_paginationData$id","finished","result","slice","totalItems","getNextPage","getPage","getAll","refreshCurrentPage","_paginationData$pagin","loading","error","setError","useContainerPagination","direction","scrollableRef","customOptionsRef","el","scrollElement","scrollingElement","calculateIfReachedLimit","throttle","_customOptionsRef$cur","offsetBottom","offsetLeft","call","offsetLimit","scrollHeight","clientHeight","scrollWidth","clientWidth","offset","scrollTop","scrollLeft","leading","trailing","addEventListener","passive","removeEventListener","useLocalPagination","instanceID","Date","now","currItems","Promise","resolve","from","newArray","pagination","pagSrc","src"],"sources":["../../src/hooks/usePagination.ts"],"sourcesContent":["import {\n  useCallback,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport useAsyncControl from \"./useAsyncControl\";\nimport throttle from \"lodash/throttle\";\n\ntype UpdateEvent<I extends any> = {\n  finished: boolean;\n  items: I[];\n  totalItems: number;\n};\n\nexport default function usePagination<I extends any>(\n  request: (\n    page: number,\n    pageSize: number | \"all\",\n    currItems?: I[]\n  ) => Promise<UpdateEvent<I>>,\n  paginationId: object | any[] | (() => string) = () => \"default\",\n  startingItems?: I[]\n): Paginable<I> {\n  const paginationDataRef = useRef<{\n    [d: string]:\n      | {\n          finished: boolean;\n          totalItems: number;\n        }\n      | undefined;\n  }>({});\n  const { current: paginationData } = paginationDataRef;\n  const paginationIdFactory = useMemo(\n    () => {\n      if (typeof paginationId === \"object\") {\n        const randId = Math.random();\n        return () => randId.toString();\n      } else return paginationId;\n    },\n    Array.isArray(paginationId) ? paginationId : [paginationId]\n  );\n\n  const [items, setItems] =\n    useState<[paginationId: string, items: I[]] | undefined>();\n\n  const [id, setId] = useState(() => paginationIdFactory());\n\n  useEffect(() => {\n    setId(paginationIdFactory());\n    if (startingItems) setItems([paginationIdFactory(), startingItems]);\n    else setItems(undefined);\n  }, [paginationIdFactory()]);\n\n  const { process, ...control } = useAsyncControl();\n\n  function updateItems(cb: (prevItems?: I) => UpdateEvent<I>[\"items\"]) {\n    setItems((prev) => [prev![0], cb()]);\n  }\n\n  const derivateCurrentPage = (pageSize: number) => {\n    if (items === undefined) return 0;\n    const currentPage = Math.ceil((items?.[1].length ?? 0) / pageSize) - 1;\n    return currentPage;\n  };\n\n  const _requestPage = useCallback(\n    function (page: number, pageSize: number | \"all\") {\n      const id = paginationIdFactory();\n      process(async () => {\n        if (paginationData[id]?.finished) return;\n        const result = await request(\n          page,\n          pageSize,\n          items?.[0] === id && page !== 0\n            ? pageSize === \"all\"\n              ? undefined\n              : items?.[1].slice(0, page * pageSize)\n            : undefined\n        );\n        paginationData[id] = {\n          finished: result.finished,\n          totalItems: result.totalItems,\n        };\n        setItems((prev) => {\n          if (page === 0) return [id, result.items];\n          else if (!prev || id === prev[0]) return [id, result.items];\n          return prev;\n        });\n      });\n    },\n    [items, request]\n  );\n\n  return {\n    updateItems,\n    getNextPage: (pageSize: number) => {\n      _requestPage(derivateCurrentPage(pageSize) + 1, pageSize);\n    },\n    getPage: _requestPage,\n    getAll: () => {\n      _requestPage(0, \"all\");\n    },\n    refreshCurrentPage: (pageSize: number) => {\n      _requestPage(derivateCurrentPage(pageSize), pageSize);\n    },\n    totalItems: () => paginationData[paginationIdFactory()]?.totalItems,\n    id: () => id,\n    loading: control.loading,\n    error: control.error,\n    items: items?.[1],\n    setError: control.setError,\n  };\n}\n\nexport type Paginable<I extends any, E extends any = any> = {\n  updateItems: (cb: (prevItems?: I) => UpdateEvent<I>[\"items\"]) => void;\n  getNextPage: (pageSize: number) => void;\n  refreshCurrentPage: (pageSize: number) => void;\n  getPage: (page: number, pageSize: number) => void;\n  getAll: () => void;\n  totalItems: () => number | undefined;\n  loading: boolean;\n  error: E | Error | undefined;\n  items: I[] | undefined;\n  setError: ReturnType<typeof useAsyncControl>[\"setError\"];\n  id: () => string;\n};\n\nexport type LocalPaginable<I extends any, E extends any = any> = Paginable<\n  I,\n  E\n> & {\n  src: I;\n};\n\n/**\n * This returns a ref to be bound to an elements so it can be able to detect when a pagination whould occur\n */\nexport function useContainerPagination(\n  cb: (pageSize: number) => void,\n  pageSize: number,\n  direction: \"h\" | \"v\" = \"v\"\n) {\n  const scrollableRef = useRef<HTMLDivElement>(null);\n  const customOptionsRef =\n    useRef<() => { offsetBottom?: number; offsetLeft?: number }>();\n\n  useEffect(() => {\n    const el = scrollableRef.current!;\n    const scrollElement =\n      (el as unknown as typeof window.document).scrollingElement || el;\n    const calculateIfReachedLimit = throttle(\n      () => {\n        const { offsetBottom = 0, offsetLeft = 0 } =\n          customOptionsRef.current?.() || {};\n        const offsetLimit =\n          direction === \"v\"\n            ? scrollElement.scrollHeight -\n              offsetBottom -\n              scrollElement.clientHeight * 0.6\n            : scrollElement.scrollWidth -\n              offsetLeft -\n              scrollElement.clientWidth * 0.6;\n        const offset =\n          direction === \"v\"\n            ? scrollElement.clientHeight + scrollElement.scrollTop\n            : scrollElement.clientWidth + scrollElement.scrollLeft;\n        if (offset >= offsetLimit) {\n          cb(pageSize);\n        }\n      },\n      250,\n      {\n        leading: false,\n        trailing: true,\n      }\n    );\n\n    el.addEventListener(\"scroll\", calculateIfReachedLimit, {\n      passive: true,\n    });\n    return () => el.removeEventListener(\"scroll\", calculateIfReachedLimit);\n  }, [cb, pageSize]);\n\n  return {\n    scrollableRef,\n    customOptionsRef,\n  };\n}\n\n/**\n * This function receives an amount of local instances and paginates it\n */\nexport function useLocalPagination<L>(items: L[] | undefined) {\n  const instanceID = useMemo(() => Date.now(), [items]);\n  const cb = useCallback(\n    (page: number, pageSize: number | \"all\", currItems: L[] = []) => {\n      if (!items)\n        return Promise.resolve({\n          finished: false,\n          totalItems: 0,\n          items: [],\n        });\n      if (pageSize === \"all\") pageSize = items.length;\n      const from = pageSize * page;\n      const newArray = [...currItems, ...items.slice(from, from + pageSize)];\n\n      return Promise.resolve({\n        finished: newArray.length === items.length,\n        totalItems: items.length,\n        items: newArray,\n      });\n    },\n    [items]\n  );\n  const pagination = usePagination<L>(cb, () => `${instanceID}`);\n  const pagSrc = useMemo(() => items, [pagination.items]);\n\n  return {\n    ...pagination,\n    loading: items === undefined,\n    src: pagSrc,\n  };\n}\n"],"mappings":"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"}
|
|
149
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_useAsyncControl","_interopRequireDefault","_throttle","obj","__esModule","default","usePagination","request","paginationId","arguments","length","undefined","startingItems","paginationDataRef","useRef","current","paginationData","paginationIdFactory","useMemo","randId","Math","random","toString","Array","isArray","items","setItems","useState","id","setId","useEffect","process","control","useAsyncControl","updateItems","cb","prev","derivateCurrentPage","pageSize","currentPage","ceil","_requestPage","useCallback","page","_paginationData$id","finished","result","slice","totalItems","getNextPage","getPage","getAll","refreshCurrentPage","_paginationData$pagin","loading","error","setError","useContainerPagination","direction","scrollableRef","customOptionsRef","el","scrollElement","scrollingElement","calculateIfReachedLimit","throttle","e","_customOptionsRef$cur","target","offsetBottom","offsetLeft","call","offsetLimit","scrollHeight","clientHeight","scrollWidth","clientWidth","offset","scrollTop","scrollLeft","leading","trailing","addEventListener","passive","removeEventListener","useLocalPagination","instanceID","Date","now","currItems","Promise","resolve","from","newArray","pagination","pagSrc","src"],"sources":["../../src/hooks/usePagination.ts"],"sourcesContent":["import {\n  useCallback,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport useAsyncControl from \"./useAsyncControl\";\nimport throttle from \"lodash/throttle\";\n\ntype UpdateEvent<I extends any> = {\n  finished: boolean;\n  items: I[];\n  totalItems: number;\n};\n\nexport default function usePagination<I extends any>(\n  request: (\n    page: number,\n    pageSize: number | \"all\",\n    currItems?: I[]\n  ) => Promise<UpdateEvent<I>>,\n  paginationId: object | any[] | (() => string) = () => \"default\",\n  startingItems?: I[]\n): Paginable<I> {\n  const paginationDataRef = useRef<{\n    [d: string]:\n      | {\n          finished: boolean;\n          totalItems: number;\n        }\n      | undefined;\n  }>({});\n  const { current: paginationData } = paginationDataRef;\n  const paginationIdFactory = useMemo(\n    () => {\n      if (typeof paginationId === \"object\") {\n        const randId = Math.random();\n        return () => randId.toString();\n      } else return paginationId;\n    },\n    Array.isArray(paginationId) ? paginationId : [paginationId]\n  );\n\n  const [items, setItems] =\n    useState<[paginationId: string, items: I[]] | undefined>();\n\n  const [id, setId] = useState(() => paginationIdFactory());\n\n  useEffect(() => {\n    setId(paginationIdFactory());\n    if (startingItems) setItems([paginationIdFactory(), startingItems]);\n    else setItems(undefined);\n  }, [paginationIdFactory()]);\n\n  const { process, ...control } = useAsyncControl();\n\n  function updateItems(cb: (prevItems?: I) => UpdateEvent<I>[\"items\"]) {\n    setItems((prev) => [prev![0], cb()]);\n  }\n\n  const derivateCurrentPage = (pageSize: number) => {\n    if (items === undefined) return 0;\n    const currentPage = Math.ceil((items?.[1].length ?? 0) / pageSize) - 1;\n    return currentPage;\n  };\n\n  const _requestPage = useCallback(\n    function (page: number, pageSize: number | \"all\") {\n      const id = paginationIdFactory();\n      if (paginationData[id]?.finished) return;\n      process(async () => {\n        const result = await request(\n          page,\n          pageSize,\n          items?.[0] === id && page !== 0\n            ? pageSize === \"all\"\n              ? undefined\n              : items?.[1].slice(0, page * pageSize)\n            : undefined\n        );\n        paginationData[id] = {\n          finished: result.finished,\n          totalItems: result.totalItems,\n        };\n        setItems((prev) => {\n          if (page === 0) return [id, result.items];\n          else if (!prev || id === prev[0]) return [id, result.items];\n          return prev;\n        });\n      });\n    },\n    [items, request]\n  );\n\n  return {\n    updateItems,\n    getNextPage: (pageSize: number) => {\n      _requestPage(derivateCurrentPage(pageSize) + 1, pageSize);\n    },\n    getPage: _requestPage,\n    getAll: () => {\n      _requestPage(0, \"all\");\n    },\n    refreshCurrentPage: (pageSize: number) => {\n      _requestPage(derivateCurrentPage(pageSize), pageSize);\n    },\n    totalItems: () => paginationData[paginationIdFactory()]?.totalItems,\n    id: () => id,\n    loading: control.loading,\n    error: control.error,\n    items: items?.[1],\n    setError: control.setError,\n  };\n}\n\nexport type Paginable<I extends any, E extends any = any> = {\n  updateItems: (cb: (prevItems?: I) => UpdateEvent<I>[\"items\"]) => void;\n  getNextPage: (pageSize: number) => void;\n  refreshCurrentPage: (pageSize: number) => void;\n  getPage: (page: number, pageSize: number) => void;\n  getAll: () => void;\n  totalItems: () => number | undefined;\n  loading: boolean;\n  error: E | Error | undefined;\n  items: I[] | undefined;\n  setError: ReturnType<typeof useAsyncControl>[\"setError\"];\n  id: () => string;\n};\n\nexport type LocalPaginable<I extends any, E extends any = any> = Paginable<\n  I,\n  E\n> & {\n  src: I;\n};\n\n/**\n * This returns a ref to be bound to an elements so it can be able to detect when a pagination whould occur\n */\nexport function useContainerPagination(\n  cb: (pageSize: number) => void,\n  pageSize: number,\n  direction: \"h\" | \"v\" = \"v\"\n) {\n  const scrollableRef = useRef<HTMLDivElement>(null);\n  const customOptionsRef =\n    useRef<() => { offsetBottom?: number; offsetLeft?: number }>();\n\n  useEffect(() => {\n    const el = scrollableRef.current!;\n    const scrollElement =\n      (el as unknown as typeof window.document).scrollingElement || el;\n    const calculateIfReachedLimit = throttle(\n      (e: Event) => {\n        if (e.target !== el) return;\n        const { offsetBottom = 0, offsetLeft = 0 } =\n          customOptionsRef.current?.() || {};\n        const offsetLimit =\n          direction === \"v\"\n            ? scrollElement.scrollHeight -\n              offsetBottom -\n              scrollElement.clientHeight * 0.6\n            : scrollElement.scrollWidth -\n              offsetLeft -\n              scrollElement.clientWidth * 0.6;\n        const offset =\n          direction === \"v\"\n            ? scrollElement.clientHeight + scrollElement.scrollTop\n            : scrollElement.clientWidth + scrollElement.scrollLeft;\n        if (offset >= offsetLimit) {\n          cb(pageSize);\n        }\n      },\n      250,\n      {\n        leading: false,\n        trailing: true,\n      }\n    );\n\n    el.addEventListener(\"scroll\", calculateIfReachedLimit, {\n      passive: true,\n    });\n    return () => el.removeEventListener(\"scroll\", calculateIfReachedLimit);\n  }, [cb, pageSize]);\n\n  return {\n    scrollableRef,\n    customOptionsRef,\n  };\n}\n\n/**\n * This function receives an amount of local instances and paginates it\n */\nexport function useLocalPagination<L>(items: L[] | undefined) {\n  const instanceID = useMemo(() => Date.now(), [items]);\n  const cb = useCallback(\n    (page: number, pageSize: number | \"all\", currItems: L[] = []) => {\n      if (!items)\n        return Promise.resolve({\n          finished: false,\n          totalItems: 0,\n          items: [],\n        });\n      if (pageSize === \"all\") pageSize = items.length;\n      const from = pageSize * page;\n      const newArray = [...currItems, ...items.slice(from, from + pageSize)];\n\n      return Promise.resolve({\n        finished: newArray.length === items.length,\n        totalItems: items.length,\n        items: newArray,\n      });\n    },\n    [items]\n  );\n  const pagination = usePagination<L>(cb, () => `${instanceID}`);\n  const pagSrc = useMemo(() => items, [pagination.items]);\n\n  return {\n    ...pagination,\n    loading: items === undefined,\n    src: pagSrc,\n  };\n}\n"],"mappings":";;;;;;;;AAAA,IAAAA,MAAA,GAAAC,OAAA;AAQA,IAAAC,gBAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,SAAA,GAAAD,sBAAA,CAAAF,OAAA;AAAuC,SAAAE,uBAAAE,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAQxB,SAASG,aAAaA,CACnCC,OAI4B,EAGd;EAAA,IAFdC,YAA6C,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,MAAM,SAAS;EAAA,IAC/DG,aAAmB,GAAAH,SAAA,CAAAC,MAAA,OAAAD,SAAA,MAAAE,SAAA;EAEnB,MAAME,iBAAiB,GAAG,IAAAC,aAAM,EAO7B,CAAC,CAAC,CAAC;EACN,MAAM;IAAEC,OAAO,EAAEC;EAAe,CAAC,GAAGH,iBAAiB;EACrD,MAAMI,mBAAmB,GAAG,IAAAC,cAAO,EACjC,MAAM;IACJ,IAAI,OAAOV,YAAY,KAAK,QAAQ,EAAE;MACpC,MAAMW,MAAM,GAAGC,IAAI,CAACC,MAAM,CAAC,CAAC;MAC5B,OAAO,MAAMF,MAAM,CAACG,QAAQ,CAAC,CAAC;IAChC,CAAC,MAAM,OAAOd,YAAY;EAC5B,CAAC,EACDe,KAAK,CAACC,OAAO,CAAChB,YAAY,CAAC,GAAGA,YAAY,GAAG,CAACA,YAAY,CAC5D,CAAC;EAED,MAAM,CAACiB,KAAK,EAAEC,QAAQ,CAAC,GACrB,IAAAC,eAAQ,EAAiD,CAAC;EAE5D,MAAM,CAACC,EAAE,EAAEC,KAAK,CAAC,GAAG,IAAAF,eAAQ,EAAC,MAAMV,mBAAmB,CAAC,CAAC,CAAC;EAEzD,IAAAa,gBAAS,EAAC,MAAM;IACdD,KAAK,CAACZ,mBAAmB,CAAC,CAAC,CAAC;IAC5B,IAAIL,aAAa,EAAEc,QAAQ,CAAC,CAACT,mBAAmB,CAAC,CAAC,EAAEL,aAAa,CAAC,CAAC,CAAC,KAC/Dc,QAAQ,CAACf,SAAS,CAAC;EAC1B,CAAC,EAAE,CAACM,mBAAmB,CAAC,CAAC,CAAC,CAAC;EAE3B,MAAM;IAAEc,OAAO;IAAE,GAAGC;EAAQ,CAAC,GAAG,IAAAC,wBAAe,EAAC,CAAC;EAEjD,SAASC,WAAWA,CAACC,EAA8C,EAAE;IACnET,QAAQ,CAAEU,IAAI,IAAK,CAACA,IAAI,CAAE,CAAC,CAAC,EAAED,EAAE,CAAC,CAAC,CAAC,CAAC;EACtC;EAEA,MAAME,mBAAmB,GAAIC,QAAgB,IAAK;IAChD,IAAIb,KAAK,KAAKd,SAAS,EAAE,OAAO,CAAC;IACjC,MAAM4B,WAAW,GAAGnB,IAAI,CAACoB,IAAI,CAAC,CAAC,CAAAf,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAG,CAAC,CAAC,CAACf,MAAM,KAAI,CAAC,IAAI4B,QAAQ,CAAC,GAAG,CAAC;IACtE,OAAOC,WAAW;EACpB,CAAC;EAED,MAAME,YAAY,GAAG,IAAAC,kBAAW,EAC9B,UAAUC,IAAY,EAAEL,QAAwB,EAAE;IAAA,IAAAM,kBAAA;IAChD,MAAMhB,EAAE,GAAGX,mBAAmB,CAAC,CAAC;IAChC,KAAA2B,kBAAA,GAAI5B,cAAc,CAACY,EAAE,CAAC,cAAAgB,kBAAA,eAAlBA,kBAAA,CAAoBC,QAAQ,EAAE;IAClCd,OAAO,CAAC,YAAY;MAClB,MAAMe,MAAM,GAAG,MAAMvC,OAAO,CAC1BoC,IAAI,EACJL,QAAQ,EACR,CAAAb,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAG,CAAC,CAAC,MAAKG,EAAE,IAAIe,IAAI,KAAK,CAAC,GAC3BL,QAAQ,KAAK,KAAK,GAChB3B,SAAS,GACTc,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAG,CAAC,CAAC,CAACsB,KAAK,CAAC,CAAC,EAAEJ,IAAI,GAAGL,QAAQ,CAAC,GACtC3B,SACN,CAAC;MACDK,cAAc,CAACY,EAAE,CAAC,GAAG;QACnBiB,QAAQ,EAAEC,MAAM,CAACD,QAAQ;QACzBG,UAAU,EAAEF,MAAM,CAACE;MACrB,CAAC;MACDtB,QAAQ,CAAEU,IAAI,IAAK;QACjB,IAAIO,IAAI,KAAK,CAAC,EAAE,OAAO,CAACf,EAAE,EAAEkB,MAAM,CAACrB,KAAK,CAAC,CAAC,KACrC,IAAI,CAACW,IAAI,IAAIR,EAAE,KAAKQ,IAAI,CAAC,CAAC,CAAC,EAAE,OAAO,CAACR,EAAE,EAAEkB,MAAM,CAACrB,KAAK,CAAC;QAC3D,OAAOW,IAAI;MACb,CAAC,CAAC;IACJ,CAAC,CAAC;EACJ,CAAC,EACD,CAACX,KAAK,EAAElB,OAAO,CACjB,CAAC;EAED,OAAO;IACL2B,WAAW;IACXe,WAAW,EAAGX,QAAgB,IAAK;MACjCG,YAAY,CAACJ,mBAAmB,CAACC,QAAQ,CAAC,GAAG,CAAC,EAAEA,QAAQ,CAAC;IAC3D,CAAC;IACDY,OAAO,EAAET,YAAY;IACrBU,MAAM,EAAEA,CAAA,KAAM;MACZV,YAAY,CAAC,CAAC,EAAE,KAAK,CAAC;IACxB,CAAC;IACDW,kBAAkB,EAAGd,QAAgB,IAAK;MACxCG,YAAY,CAACJ,mBAAmB,CAACC,QAAQ,CAAC,EAAEA,QAAQ,CAAC;IACvD,CAAC;IACDU,UAAU,EAAEA,CAAA;MAAA,IAAAK,qBAAA;MAAA,QAAAA,qBAAA,GAAMrC,cAAc,CAACC,mBAAmB,CAAC,CAAC,CAAC,cAAAoC,qBAAA,uBAArCA,qBAAA,CAAuCL,UAAU;IAAA;IACnEpB,EAAE,EAAEA,CAAA,KAAMA,EAAE;IACZ0B,OAAO,EAAEtB,OAAO,CAACsB,OAAO;IACxBC,KAAK,EAAEvB,OAAO,CAACuB,KAAK;IACpB9B,KAAK,EAAEA,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAG,CAAC,CAAC;IACjB+B,QAAQ,EAAExB,OAAO,CAACwB;EACpB,CAAC;AACH;AAuBA;AACA;AACA;AACO,SAASC,sBAAsBA,CACpCtB,EAA8B,EAC9BG,QAAgB,EAEhB;EAAA,IADAoB,SAAoB,GAAAjD,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,GAAG;EAE1B,MAAMkD,aAAa,GAAG,IAAA7C,aAAM,EAAiB,IAAI,CAAC;EAClD,MAAM8C,gBAAgB,GACpB,IAAA9C,aAAM,EAAuD,CAAC;EAEhE,IAAAgB,gBAAS,EAAC,MAAM;IACd,MAAM+B,EAAE,GAAGF,aAAa,CAAC5C,OAAQ;IACjC,MAAM+C,aAAa,GAChBD,EAAE,CAAuCE,gBAAgB,IAAIF,EAAE;IAClE,MAAMG,uBAAuB,GAAG,IAAAC,iBAAQ,EACrCC,CAAQ,IAAK;MAAA,IAAAC,qBAAA;MACZ,IAAID,CAAC,CAACE,MAAM,KAAKP,EAAE,EAAE;MACrB,MAAM;QAAEQ,YAAY,GAAG,CAAC;QAAEC,UAAU,GAAG;MAAE,CAAC,GACxC,EAAAH,qBAAA,GAAAP,gBAAgB,CAAC7C,OAAO,cAAAoD,qBAAA,uBAAxBA,qBAAA,CAAAI,IAAA,CAAAX,gBAA2B,CAAC,KAAI,CAAC,CAAC;MACpC,MAAMY,WAAW,GACfd,SAAS,KAAK,GAAG,GACbI,aAAa,CAACW,YAAY,GAC1BJ,YAAY,GACZP,aAAa,CAACY,YAAY,GAAG,GAAG,GAChCZ,aAAa,CAACa,WAAW,GACzBL,UAAU,GACVR,aAAa,CAACc,WAAW,GAAG,GAAG;MACrC,MAAMC,MAAM,GACVnB,SAAS,KAAK,GAAG,GACbI,aAAa,CAACY,YAAY,GAAGZ,aAAa,CAACgB,SAAS,GACpDhB,aAAa,CAACc,WAAW,GAAGd,aAAa,CAACiB,UAAU;MAC1D,IAAIF,MAAM,IAAIL,WAAW,EAAE;QACzBrC,EAAE,CAACG,QAAQ,CAAC;MACd;IACF,CAAC,EACD,GAAG,EACH;MACE0C,OAAO,EAAE,KAAK;MACdC,QAAQ,EAAE;IACZ,CACF,CAAC;IAEDpB,EAAE,CAACqB,gBAAgB,CAAC,QAAQ,EAAElB,uBAAuB,EAAE;MACrDmB,OAAO,EAAE;IACX,CAAC,CAAC;IACF,OAAO,MAAMtB,EAAE,CAACuB,mBAAmB,CAAC,QAAQ,EAAEpB,uBAAuB,CAAC;EACxE,CAAC,EAAE,CAAC7B,EAAE,EAAEG,QAAQ,CAAC,CAAC;EAElB,OAAO;IACLqB,aAAa;IACbC;EACF,CAAC;AACH;;AAEA;AACA;AACA;AACO,SAASyB,kBAAkBA,CAAI5D,KAAsB,EAAE;EAC5D,MAAM6D,UAAU,GAAG,IAAApE,cAAO,EAAC,MAAMqE,IAAI,CAACC,GAAG,CAAC,CAAC,EAAE,CAAC/D,KAAK,CAAC,CAAC;EACrD,MAAMU,EAAE,GAAG,IAAAO,kBAAW,EACpB,UAACC,IAAY,EAAEL,QAAwB,EAA0B;IAAA,IAAxBmD,SAAc,GAAAhF,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,EAAE;IAC1D,IAAI,CAACgB,KAAK,EACR,OAAOiE,OAAO,CAACC,OAAO,CAAC;MACrB9C,QAAQ,EAAE,KAAK;MACfG,UAAU,EAAE,CAAC;MACbvB,KAAK,EAAE;IACT,CAAC,CAAC;IACJ,IAAIa,QAAQ,KAAK,KAAK,EAAEA,QAAQ,GAAGb,KAAK,CAACf,MAAM;IAC/C,MAAMkF,IAAI,GAAGtD,QAAQ,GAAGK,IAAI;IAC5B,MAAMkD,QAAQ,GAAG,CAAC,GAAGJ,SAAS,EAAE,GAAGhE,KAAK,CAACsB,KAAK,CAAC6C,IAAI,EAAEA,IAAI,GAAGtD,QAAQ,CAAC,CAAC;IAEtE,OAAOoD,OAAO,CAACC,OAAO,CAAC;MACrB9C,QAAQ,EAAEgD,QAAQ,CAACnF,MAAM,KAAKe,KAAK,CAACf,MAAM;MAC1CsC,UAAU,EAAEvB,KAAK,CAACf,MAAM;MACxBe,KAAK,EAAEoE;IACT,CAAC,CAAC;EACJ,CAAC,EACD,CAACpE,KAAK,CACR,CAAC;EACD,MAAMqE,UAAU,GAAGxF,aAAa,CAAI6B,EAAE,EAAE,MAAO,GAAEmD,UAAW,EAAC,CAAC;EAC9D,MAAMS,MAAM,GAAG,IAAA7E,cAAO,EAAC,MAAMO,KAAK,EAAE,CAACqE,UAAU,CAACrE,KAAK,CAAC,CAAC;EAEvD,OAAO;IACL,GAAGqE,UAAU;IACbxC,OAAO,EAAE7B,KAAK,KAAKd,SAAS;IAC5BqF,GAAG,EAAED;EACP,CAAC;AACH"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default function useDepChange<T>(callback: (prevDep: T) => void, dep: T): void;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = useDepChange;
|
|
7
|
+
var _react = require("react");
|
|
8
|
+
function useDepChange(callback, dep) {
|
|
9
|
+
const prevStep = (0, _react.useRef)();
|
|
10
|
+
(0, _react.useInsertionEffect)(() => {
|
|
11
|
+
if (prevStep.current) callback(prevStep.current);
|
|
12
|
+
return () => {
|
|
13
|
+
prevStep.current = dep;
|
|
14
|
+
};
|
|
15
|
+
}, [dep]);
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJyZXF1aXJlIiwidXNlRGVwQ2hhbmdlIiwiY2FsbGJhY2siLCJkZXAiLCJwcmV2U3RlcCIsInVzZVJlZiIsInVzZUluc2VydGlvbkVmZmVjdCIsImN1cnJlbnQiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvaG9va3MvdXRpbGl0eS91c2VEZXBDaGFuZ2UudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlSW5zZXJ0aW9uRWZmZWN0LCB1c2VSZWYgfSBmcm9tIFwicmVhY3RcIjtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gdXNlRGVwQ2hhbmdlPFQ+KGNhbGxiYWNrOiAocHJldkRlcDogVCkgPT4gdm9pZCwgZGVwOiBUKSB7XG4gIGNvbnN0IHByZXZTdGVwID0gdXNlUmVmPFQ+KCk7XG4gIHVzZUluc2VydGlvbkVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKHByZXZTdGVwLmN1cnJlbnQpIGNhbGxiYWNrKHByZXZTdGVwLmN1cnJlbnQpO1xuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICBwcmV2U3RlcC5jdXJyZW50ID0gZGVwO1xuICAgIH07XG4gIH0sIFtkZXBdKTtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxPQUFBO0FBRWUsU0FBU0MsWUFBWUEsQ0FBSUMsUUFBOEIsRUFBRUMsR0FBTSxFQUFFO0VBQzlFLE1BQU1DLFFBQVEsR0FBRyxJQUFBQyxhQUFNLEVBQUksQ0FBQztFQUM1QixJQUFBQyx5QkFBa0IsRUFBQyxNQUFNO0lBQ3ZCLElBQUlGLFFBQVEsQ0FBQ0csT0FBTyxFQUFFTCxRQUFRLENBQUNFLFFBQVEsQ0FBQ0csT0FBTyxDQUFDO0lBQ2hELE9BQU8sTUFBTTtNQUNYSCxRQUFRLENBQUNHLE9BQU8sR0FBR0osR0FBRztJQUN4QixDQUFDO0VBQ0gsQ0FBQyxFQUFFLENBQUNBLEdBQUcsQ0FBQyxDQUFDO0FBQ1gifQ==
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@onepercentio/one-ui",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.26.0",
|
|
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>",
|