@onepercentio/one-ui 0.21.3 → 0.21.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (172) hide show
  1. package/ai/components/UncontrolledTransition/UncontrolledTransition.ai.d.ts +15 -0
  2. package/ai/components/UncontrolledTransition/UncontrolledTransition.ai.js +37 -0
  3. package/ai/components/UncontrolledTransition/UncontrolledTransition.ai.js.map +1 -0
  4. package/ai/hooks/ui/useAlternating.ai.d.ts +9 -0
  5. package/ai/hooks/ui/useAlternating.ai.js +17 -0
  6. package/ai/hooks/ui/useAlternating.ai.js.map +1 -0
  7. package/ai/hooks/useHero.ai.d.ts +9 -0
  8. package/ai/hooks/useHero.ai.js +21 -0
  9. package/ai/hooks/useHero.ai.js.map +1 -0
  10. package/ai/types.d.ts +9 -0
  11. package/ai/types.js +3 -0
  12. package/ai/types.js.map +1 -0
  13. package/dist/assets/styles/variables.scss +0 -5
  14. package/dist/components/AdaptiveButton/AdaptiveButton.d.ts +2 -2
  15. package/dist/components/AdaptiveContainer/AdaptiveContainer.d.ts +2 -2
  16. package/dist/components/AdaptiveDialog/AdaptiveDialog.d.ts +4 -3
  17. package/dist/components/AdaptiveDialog/AdaptiveDialog.js +6 -3
  18. package/dist/components/AdaptiveSidebar/AdaptiveSidebar.d.ts +3 -0
  19. package/dist/components/AdaptiveSidebar/AdaptiveSidebar.js +7 -6
  20. package/dist/components/AdaptiveSidebar/AdaptiveSidebar.sample.d.ts +2 -0
  21. package/dist/components/AdaptiveSidebar/AdaptiveSidebar.sample.js +13 -0
  22. package/dist/components/AnchoredTooltip/AnchoredTooltip.d.ts +3 -0
  23. package/dist/components/AnchoredTooltip/AnchoredTooltip.js +5 -5
  24. package/dist/components/AnimatedEntrance/AnimatedEntrance.d.ts +3 -3
  25. package/dist/components/AsyncWrapper/AsyncWrapper.d.ts +2 -2
  26. package/dist/components/Avatar/Avatar.d.ts +2 -1
  27. package/dist/components/BucketFill/BucketFill.d.ts +3 -3
  28. package/dist/components/Button/Button.d.ts +2 -2
  29. package/dist/components/Button/Button.js +5 -4
  30. package/dist/components/Button/Button.module.scss +5 -2
  31. package/dist/components/Card/Card.d.ts +2 -2
  32. package/dist/components/Chart/Chart.logic.d.ts +3 -1
  33. package/dist/components/Chart/Chart.logic.js +2 -1
  34. package/dist/components/Chart/Chart.view.d.ts +2 -1
  35. package/dist/components/CheckBox/CheckBox.d.ts +1 -1
  36. package/dist/components/CodeInput/CodeInput.d.ts +9 -0
  37. package/dist/components/CodeInput/CodeInput.js +85 -0
  38. package/dist/components/CodeInput/CodeInput.module.scss +5 -0
  39. package/dist/components/CodeInput/index.d.ts +1 -0
  40. package/dist/components/CodeInput/index.js +14 -0
  41. package/dist/components/Collapsable/Collapsable.d.ts +5 -2
  42. package/dist/components/Collapsable/Collapsable.js +22 -7
  43. package/dist/components/Countdown/Countdown.d.ts +2 -1
  44. package/dist/components/Divider/Divider.d.ts +2 -1
  45. package/dist/components/EmailInput/EmailInput.d.ts +3 -0
  46. package/dist/components/EmailInput/EmailInput.js +5 -5
  47. package/dist/components/FadeIn/FadeIn.d.ts +3 -0
  48. package/dist/components/FadeIn/FadeIn.js +5 -4
  49. package/dist/components/FileInput/FileInput.d.ts +1 -1
  50. package/dist/components/FileInput/View/BigFactory/BigFactory.d.ts +2 -2
  51. package/dist/components/FileInput/View/Compact/Compact.d.ts +2 -1
  52. package/dist/components/FlowController/FlowController.d.ts +2 -2
  53. package/dist/components/Form/v2/Form.d.ts +18 -0
  54. package/dist/components/Form/v2/Form.hook.d.ts +21 -0
  55. package/dist/components/Form/v2/Form.hook.js +214 -0
  56. package/dist/components/Form/v2/Form.js +69 -0
  57. package/dist/components/Form/v2/Form.module.scss +0 -0
  58. package/dist/components/Form/v2/Form.types.d.ts +97 -0
  59. package/dist/components/Form/v2/Form.types.js +45 -0
  60. package/dist/components/Form/v2/FormField/Extensions/DateField/DateField.d.ts +12 -0
  61. package/dist/components/Form/v2/FormField/Extensions/DateField/DateField.js +74 -0
  62. package/dist/components/Form/v2/FormField/Extensions/DateField/DateField.module.scss +0 -0
  63. package/dist/components/Form/v2/FormField/Extensions/DateField/index.d.ts +1 -0
  64. package/dist/components/Form/v2/FormField/Extensions/DateField/index.js +14 -0
  65. package/dist/components/Form/v2/FormField/Extensions/PhoneField/PhoneField.d.ts +10 -0
  66. package/dist/components/Form/v2/FormField/Extensions/PhoneField/PhoneField.js +92 -0
  67. package/dist/components/Form/v2/FormField/Extensions/PhoneField/PhoneField.module.scss +0 -0
  68. package/dist/components/Form/v2/FormField/Extensions/PhoneField/index.d.ts +1 -0
  69. package/dist/components/Form/v2/FormField/Extensions/PhoneField/index.js +14 -0
  70. package/dist/components/Form/v2/FormField/FormField.d.ts +6 -0
  71. package/dist/components/Form/v2/FormField/FormField.js +309 -0
  72. package/dist/components/Form/v2/FormField/FormField.module.scss +0 -0
  73. package/dist/components/Form/v2/FormField/FormField.types.d.ts +83 -0
  74. package/dist/components/Form/v2/FormField/FormField.types.js +13 -0
  75. package/dist/components/Form/v2/FormField/index.d.ts +1 -0
  76. package/dist/components/Form/v2/FormField/index.js +14 -0
  77. package/dist/components/Form/v2/index.d.ts +1 -0
  78. package/dist/components/Form/v2/index.js +14 -0
  79. package/dist/components/HSForms/HSForms.d.ts +2 -1
  80. package/dist/components/Header/Header.d.ts +2 -2
  81. package/dist/components/HeaderCloseBtn/HeaderCloseBtn.d.ts +2 -1
  82. package/dist/components/InfinityScroll/InfinityScroll.d.ts +3 -0
  83. package/dist/components/InfinityScroll/InfinityScroll.js +5 -5
  84. package/dist/components/Input/Input.d.ts +3 -0
  85. package/dist/components/Input/Input.js +4 -4
  86. package/dist/components/InstantCounter/InstantCounter.d.ts +3 -0
  87. package/dist/components/InstantCounter/InstantCounter.js +5 -4
  88. package/dist/components/LavaLamp/LavaLamp.d.ts +2 -2
  89. package/dist/components/LavaLamp/LavaLamp.js +1 -1
  90. package/dist/components/LavaLamp/v2/LavaLamp.d.ts +2 -2
  91. package/dist/components/LinkToId/LinkToId.d.ts +2 -2
  92. package/dist/components/Loader/Loader.d.ts +1 -1
  93. package/dist/components/LoaderDotsIndicator/LoaderDotsIndicator.d.ts +5 -2
  94. package/dist/components/LoaderDotsIndicator/LoaderDotsIndicator.js +9 -3
  95. package/dist/components/LoopableVideo/LoopableVideo.d.ts +2 -2
  96. package/dist/components/MainGrid/MainGrid.d.ts +3 -0
  97. package/dist/components/MainGrid/MainGrid.js +5 -4
  98. package/dist/components/MutableHamburgerButton/MutableHamburgerButton.d.ts +1 -1
  99. package/dist/components/NodesNavigator/NodesNavigator.d.ts +17 -0
  100. package/dist/components/NodesNavigator/NodesNavigator.js +108 -0
  101. package/dist/components/NodesNavigator/NodesNavigator.module.scss +19 -0
  102. package/dist/components/NodesNavigator/index.d.ts +1 -0
  103. package/dist/components/NodesNavigator/index.js +14 -0
  104. package/dist/components/Notification/Notification.d.ts +2 -2
  105. package/dist/components/OrderableList/OrderableList.d.ts +1 -1
  106. package/dist/components/PaginationIndicator/PaginationIndicator.d.ts +9 -6
  107. package/dist/components/PaginationIndicator/PaginationIndicator.js +49 -11
  108. package/dist/components/Parallax/Parallax.d.ts +3 -0
  109. package/dist/components/Parallax/Parallax.js +5 -4
  110. package/dist/components/PasswordInput/PasswordInput.d.ts +3 -0
  111. package/dist/components/PasswordInput/PasswordInput.js +5 -5
  112. package/dist/components/PingPongText/PingPongText.d.ts +2 -2
  113. package/dist/components/PixelatedScan/PixelatedScan.d.ts +2 -1
  114. package/dist/components/Portal/Portal.d.ts +1 -1
  115. package/dist/components/ProgressBar/ProgressBar.d.ts +3 -3
  116. package/dist/components/ProgressTexts/ProgressTexts.d.ts +1 -1
  117. package/dist/components/Radio/Radio.d.ts +1 -1
  118. package/dist/components/SectionContainer/SectionContainer.d.ts +3 -0
  119. package/dist/components/SectionContainer/SectionContainer.js +5 -4
  120. package/dist/components/Select/Select.d.ts +3 -3
  121. package/dist/components/Select/Select.js +1 -1
  122. package/dist/components/Skeleton/Skeleton.d.ts +2 -1
  123. package/dist/components/Spacing/Spacing.d.ts +2 -1
  124. package/dist/components/StaticScroller/StaticScroller.d.ts +3 -0
  125. package/dist/components/StaticScroller/StaticScroller.js +5 -4
  126. package/dist/components/Switch/Switch.d.ts +2 -2
  127. package/dist/components/Table/Table.d.ts +2 -1
  128. package/dist/components/Tabs/Tabs.d.ts +2 -2
  129. package/dist/components/Text/Text.d.ts +7 -5
  130. package/dist/components/Text/Text.js +5 -4
  131. package/dist/components/Text/Text.module.scss +4 -0
  132. package/dist/components/Transition/Transition.d.ts +8 -5
  133. package/dist/components/Transition/Transition.js +18 -16
  134. package/dist/components/Transition/Transition.module.scss +1 -1
  135. package/dist/components/UncontrolledTransition/UncontrolledTransition.d.ts +3 -0
  136. package/dist/components/UncontrolledTransition/UncontrolledTransition.js +25 -13
  137. package/dist/components/UncontrolledTransition/UncontrolledTransition.sample.d.ts +2 -0
  138. package/dist/components/UncontrolledTransition/UncontrolledTransition.sample.js +44 -0
  139. package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.d.ts +6 -3
  140. package/dist/components/WalletConnectionWrapper/WalletConnectionWrapper.js +14 -7
  141. package/dist/components/utilitary/ScrollAndFocusLock/ScrollAndFocusLock.d.ts +2 -2
  142. package/dist/context/AsyncProcess.d.ts +2 -1
  143. package/dist/context/ContextAsyncControl.d.ts +24 -0
  144. package/dist/context/ContextAsyncControl.js +101 -0
  145. package/dist/context/CustomBrowserRouter.d.ts +2 -2
  146. package/dist/context/OneUIProvider.d.ts +29 -1
  147. package/dist/context/OneUIProvider.js +1 -1
  148. package/dist/hooks/persistence/useLocalStorage.d.ts +1 -1
  149. package/dist/hooks/persistence/useLocalStorage.js +5 -1
  150. package/dist/hooks/ui/useAlternating.d.ts +4 -0
  151. package/dist/hooks/ui/useAlternating.js +34 -0
  152. package/dist/hooks/ui/usePaginationControls.d.ts +2 -2
  153. package/dist/hooks/useAsyncControl.d.ts +15 -3
  154. package/dist/hooks/useAsyncControl.js +24 -20
  155. package/dist/hooks/useHero.d.ts +4 -2
  156. package/dist/hooks/useHero.js +39 -15
  157. package/dist/hooks/useHero.module.scss +1 -1
  158. package/dist/hooks/useShortIntl.d.ts +1 -1
  159. package/dist/hooks/useShortIntl.js +1 -1
  160. package/dist/models/GenericContract.d.ts +3 -3
  161. package/dist/models/GenericContract.js +5 -3
  162. package/dist/storybookUtils/index.d.ts +2 -2
  163. package/dist/type-utils.d.ts +5 -0
  164. package/dist/type-utils.js +1 -1
  165. package/dist/utility.d.js +1 -1
  166. package/package.json +19 -4
  167. package/src_ai/components/UncontrolledTransition/UncontrolledTransition.ai.ts +35 -0
  168. package/src_ai/hooks/ui/useAlternating.ai.ts +15 -0
  169. package/src_ai/hooks/useHero.ai.ts +18 -0
  170. package/src_ai/types.ts +10 -0
  171. package/tsconfig-ai.json +9 -0
  172. package/tsconfig.vite.json +109 -0
@@ -0,0 +1,108 @@
1
+ "use strict";
2
+
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.calculateTargetIndex = calculateTargetIndex;
8
+ exports.default = NodesNavigator;
9
+ var _react = _interopRequireWildcard(require("react"));
10
+ var _NodesNavigatorModule = _interopRequireDefault(require("./NodesNavigator.module.scss"));
11
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
12
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
13
+ 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; }
14
+ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
15
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
16
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
17
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
18
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
19
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
20
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
21
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
22
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
23
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
24
+ function calculateTargetIndex(nodesPosition, center, clickedAt) {
25
+ const counterClickedAt = [center[1] - clickedAt[1], center[0] - clickedAt[0]];
26
+ const slope = (counterClickedAt[1] - center[1]) / (counterClickedAt[0] - center[0]);
27
+ const inverseTan = Math.atan(slope);
28
+ return [Math.sin(inverseTan), Math.cos(inverseTan)];
29
+ }
30
+
31
+ /**
32
+ * Distributes circles representing the nodes and allows the user to navigate to said nodes through clicking
33
+ **/
34
+ function NodesNavigator(_ref) {
35
+ let nodes = _ref.nodes,
36
+ currentNode = _ref.currentNode,
37
+ onClickNode = _ref.onClickNode;
38
+ const rootRef = (0, _react.useRef)(null);
39
+ (0, _react.useEffect)(function () {
40
+ if (!currentNode) return;
41
+ const currentNodeEl = rootRef.current.children[nodes.indexOf(currentNode)];
42
+ const style = currentNodeEl.style;
43
+ style.transform = "translateX(0em) translateY(0em)";
44
+ }, [currentNode]);
45
+ const _useState = (0, _react.useState)(function () {
46
+ return nodes.filter(function (n) {
47
+ return n !== currentNode;
48
+ });
49
+ }),
50
+ _useState2 = _slicedToArray(_useState, 2),
51
+ otherNodes = _useState2[0],
52
+ setOtherNodes = _useState2[1];
53
+ const _useState3 = (0, _react.useState)([]),
54
+ _useState4 = _slicedToArray(_useState3, 2),
55
+ nodesPosition = _useState4[0],
56
+ setNodesPosition = _useState4[1];
57
+ (0, _react.useEffect)(function () {
58
+ setNodesPosition(otherNodes.map(function (n, index) {
59
+ var angle = index * Math.PI / 3;
60
+ return [Math.sin(angle), Math.cos(angle)];
61
+ }));
62
+ }, [otherNodes]);
63
+ (0, _react.useEffect)(function () {
64
+ if (otherNodes.length !== nodesPosition.length) return;
65
+ const elements = rootRef.current.children;
66
+ for (let node of otherNodes) {
67
+ const idx = otherNodes.indexOf(node);
68
+ const pos = nodesPosition[idx];
69
+ const el = elements[idx];
70
+ el.style.transform = "translateX(".concat(pos[0] + "em", ") translateY(").concat(pos[1] + "em", ")");
71
+ }
72
+ }, [nodesPosition]);
73
+ console.log(nodesPosition);
74
+ return /*#__PURE__*/_react.default.createElement("div", {
75
+ className: _NodesNavigatorModule.default.root,
76
+ ref: rootRef
77
+ }, otherNodes.map(function (n) {
78
+ return /*#__PURE__*/_react.default.createElement("div", {
79
+ key: nodes.indexOf(n),
80
+ className: _NodesNavigatorModule.default.node,
81
+ onClick: function onClick(_ref2) {
82
+ let clientX = _ref2.clientX,
83
+ clientY = _ref2.clientY;
84
+ const root = rootRef.current.getBoundingClientRect();
85
+ const center = [root.left + root.width / 2, root.top + root.height / 2];
86
+ const click = [clientX, clientY];
87
+ const angle = 3 + Math.atan2(click[1] - center[1], click[0] - center[0]);
88
+ const futureIndex = Math.round(angle / Math.PI * 3 - 1);
89
+ console.log(futureIndex);
90
+ setOtherNodes(function (prev) {
91
+ prev.splice(futureIndex + 1, 0, currentNode);
92
+ return _toConsumableArray(prev.filter(function (a) {
93
+ return a !== n;
94
+ }));
95
+ });
96
+ // console.log(angle);
97
+ onClickNode === null || onClickNode === void 0 ? void 0 : onClickNode(n);
98
+ }
99
+ }, otherNodes.indexOf(n));
100
+ }), currentNode && /*#__PURE__*/_react.default.createElement("div", {
101
+ key: nodes.indexOf(currentNode),
102
+ className: _NodesNavigatorModule.default.node,
103
+ onClick: function onClick() {
104
+ onClickNode === null || onClickNode === void 0 ? void 0 : onClickNode(currentNode);
105
+ }
106
+ }, "C"));
107
+ }
108
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_NodesNavigatorModule","_interopRequireDefault","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","_typeof","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_toConsumableArray","arr","_arrayWithoutHoles","_iterableToArray","_unsupportedIterableToArray","_nonIterableSpread","TypeError","iter","Symbol","iterator","Array","from","isArray","_arrayLikeToArray","_slicedToArray","i","_arrayWithHoles","_iterableToArrayLimit","_nonIterableRest","o","minLen","n","toString","slice","constructor","name","test","len","length","arr2","_i","_s","_e","_x","_r","_arr","_n","_d","next","done","push","value","err","return","calculateTargetIndex","nodesPosition","center","clickedAt","counterClickedAt","slope","inverseTan","Math","atan","sin","cos","NodesNavigator","_ref","nodes","currentNode","onClickNode","rootRef","useRef","useEffect","currentNodeEl","current","children","indexOf","style","transform","_useState","useState","filter","_useState2","otherNodes","setOtherNodes","_useState3","_useState4","setNodesPosition","map","index","angle","PI","elements","node","idx","pos","el","concat","console","log","createElement","className","Styles","root","ref","onClick","_ref2","clientX","clientY","getBoundingClientRect","left","width","top","height","click","atan2","futureIndex","round","prev","splice","a"],"sources":["../../../src/components/NodesNavigator/NodesNavigator.tsx"],"sourcesContent":["import React, {\n  ReactElement,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport Styles from \"./NodesNavigator.module.scss\";\n\ntype Node = {\n  /** Indicates how much that node should increase in relation to other nodes */\n  grandeour: number;\n\n  /** What to show on that node */\n  cover: ReactElement;\n};\n\nexport function calculateTargetIndex(\n  nodesPosition: [x: number, y: number][],\n  center: [x: number, y: number],\n  clickedAt: [x: number, y: number]\n) {\n  const counterClickedAt = [center[1] - clickedAt[1], center[0] - clickedAt[0]];\n  const slope =\n    (counterClickedAt[1] - center[1]) / (counterClickedAt[0] - center[0]);\n\n  const inverseTan = Math.atan(slope);\n  return [Math.sin(inverseTan), Math.cos(inverseTan)];\n}\n\n/**\n * Distributes circles representing the nodes and allows the user to navigate to said nodes through clicking\n **/\nexport default function NodesNavigator({\n  nodes,\n  currentNode,\n  onClickNode,\n}: {\n  nodes: Node[];\n  currentNode: Node | null;\n  onClickNode?: (n: Node) => void;\n}) {\n  const rootRef = useRef<HTMLDivElement>(null);\n\n  useEffect(() => {\n    if (!currentNode) return;\n    const currentNodeEl = rootRef.current!.children[\n      nodes.indexOf(currentNode)\n    ] as HTMLDivElement;\n    const style = currentNodeEl.style;\n\n    style.transform = `translateX(0em) translateY(0em)`;\n  }, [currentNode]);\n\n  const [otherNodes, setOtherNodes] = useState(() => {\n    return nodes.filter((n) => n !== currentNode);\n  });\n  const [nodesPosition, setNodesPosition] = useState<\n    [tX: number, tY: number][]\n  >([]);\n\n  useEffect(() => {\n    setNodesPosition(\n      otherNodes.map((n, index) => {\n        var angle = (index * Math.PI) / 3;\n        return [Math.sin(angle), Math.cos(angle)];\n      })\n    );\n  }, [otherNodes]);\n\n  useEffect(() => {\n    if (otherNodes.length !== nodesPosition.length) return;\n    const elements = rootRef.current!.children;\n    for (let node of otherNodes) {\n      const idx = otherNodes.indexOf(node);\n      const pos = nodesPosition[idx];\n      const el = elements[idx] as HTMLDivElement;\n      el.style.transform = `translateX(${pos[0] + \"em\"}) translateY(${\n        pos[1] + \"em\"\n      })`;\n    }\n  }, [nodesPosition]);\n\n  console.log(nodesPosition)\n\n  return (\n    <div className={Styles.root} ref={rootRef}>\n      {otherNodes.map((n) => (\n        <div\n          key={nodes.indexOf(n)}\n          className={Styles.node}\n          onClick={({ clientX, clientY }) => {\n            const root = rootRef.current!.getBoundingClientRect();\n            const center = [\n              root.left + root.width / 2,\n              root.top + root.height / 2,\n            ];\n            const click = [clientX, clientY];\n            const angle =\n              3 + Math.atan2(click[1] - center[1], click[0] - center[0]);\n\n            const futureIndex = Math.round((angle / Math.PI) * 3 - 1);\n            console.log(futureIndex);\n            setOtherNodes((prev) => {\n              prev.splice(futureIndex + 1, 0, currentNode!);\n              return [...prev.filter((a) => a !== n)];\n            });\n            // console.log(angle);\n            onClickNode?.(n);\n          }}\n        >\n          {/* {n.cover} */}\n          {otherNodes.indexOf(n)}\n        </div>\n      ))}\n      {currentNode && (\n        <div\n          key={nodes.indexOf(currentNode)}\n          className={Styles.node}\n          onClick={() => {\n            onClickNode?.(currentNode!);\n          }}\n        >\n          {/* {n.cover} */}C\n        </div>\n      )}\n    </div>\n  );\n}\n"],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ .root {
2
+ background-color: red;
3
+ width: 100%;
4
+ height: 100%;
5
+ position: relative;
6
+ font-size: 72px;
7
+ display: flex;
8
+ align-items: center;
9
+ justify-content: center;
10
+ }
11
+
12
+ .node {
13
+ height: 1em;
14
+ width: 1em;
15
+ border-radius: 0.5em;
16
+ overflow: hidden;
17
+ position: absolute;
18
+ transition: transform linear 2s;
19
+ }
@@ -0,0 +1 @@
1
+ export { default } from './NodesNavigator';
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ Object.defineProperty(exports, "default", {
7
+ enumerable: true,
8
+ get: function get() {
9
+ return _NodesNavigator.default;
10
+ }
11
+ });
12
+ var _NodesNavigator = _interopRequireDefault(require("./NodesNavigator"));
13
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
14
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfTm9kZXNOYXZpZ2F0b3IiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIm9iaiIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0Il0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvTm9kZXNOYXZpZ2F0b3IvaW5kZXgudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IGRlZmF1bHQgfSBmcm9tICcuL05vZGVzTmF2aWdhdG9yJztcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFBQSxJQUFBQSxlQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFBMkMsU0FBQUQsdUJBQUFFLEdBQUEsV0FBQUEsR0FBQSxJQUFBQSxHQUFBLENBQUFDLFVBQUEsR0FBQUQsR0FBQSxLQUFBRSxPQUFBLEVBQUFGLEdBQUEifQ==
@@ -1,7 +1,7 @@
1
- import { PropsWithChildren } from "react";
1
+ import React, { PropsWithChildren } from "react";
2
2
  /**
3
3
  * A layout for the notification card
4
4
  **/
5
5
  export default function Notification({ type, children }: PropsWithChildren<{
6
6
  type: "success";
7
- }>): JSX.Element;
7
+ }>): React.JSX.Element;
@@ -28,7 +28,7 @@ export default function OrderableList({ children, className, mode, shrinkToOnOrd
28
28
  onChangeKeyOrder: (newOrder: string[]) => void;
29
29
  } | {
30
30
  currentOrder?: string[];
31
- }) & DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement>): JSX.Element;
31
+ }) & DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement>): React.JSX.Element;
32
32
  export declare function useOrderableListAnchor(): {
33
33
  anchorRef: React.MutableRefObject<HTMLDivElement> | undefined;
34
34
  };
@@ -1,21 +1,24 @@
1
- import React, { RefObject } from "react";
1
+ import React, { ComponentProps, RefObject } from "react";
2
2
  export declare enum PaginationIndicatorMode {
3
3
  /** This will make the guide ball be kept on center */
4
4
  CENTERED = 0,
5
5
  /** This will make the guide ball move, while the indicator balls keep in place */
6
6
  START = 1
7
7
  }
8
- /**
9
- * A cool component to indicate how many pages are
10
- **/
11
8
  export declare function PaginationIndicatorView({ size, page: currentPage, pages: decimalPages, className, onClickPage, mode, }: {
12
9
  size: number;
13
10
  page: number;
14
11
  pages: number;
15
- className: string;
12
+ className?: string;
16
13
  onClickPage?: (page: number) => void;
17
14
  mode?: PaginationIndicatorMode;
18
- }): JSX.Element;
15
+ }): React.JSX.Element;
16
+ export declare function AnimatedPaginationIndicator(props: ComponentProps<typeof PaginationIndicatorView> & {
17
+ duration: number;
18
+ }): React.JSX.Element;
19
+ /**
20
+ * A cool component to indicate how many pages are
21
+ **/
19
22
  declare const PaginationIndicator: React.ForwardRefExoticComponent<{
20
23
  scrollableRef: RefObject<HTMLDivElement>;
21
24
  estimatedWidth?: number | undefined;
@@ -4,12 +4,14 @@ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" =
4
4
  Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
+ exports.AnimatedPaginationIndicator = AnimatedPaginationIndicator;
7
8
  exports.PaginationIndicatorMode = void 0;
8
9
  exports.PaginationIndicatorView = PaginationIndicatorView;
9
10
  exports.default = void 0;
10
11
  var _react = _interopRequireWildcard(require("react"));
11
12
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
12
13
  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; }
14
+ 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
15
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
14
16
  function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
15
17
  function _toArray(arr) { return _arrayWithHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableRest(); }
@@ -26,9 +28,6 @@ let PaginationIndicatorMode = /*#__PURE__*/function (PaginationIndicatorMode) {
26
28
  PaginationIndicatorMode[PaginationIndicatorMode["START"] = 1] = "START";
27
29
  return PaginationIndicatorMode;
28
30
  }({});
29
- /**
30
- * A cool component to indicate how many pages are
31
- **/
32
31
  exports.PaginationIndicatorMode = PaginationIndicatorMode;
33
32
  function PaginationIndicatorView(_ref) {
34
33
  let size = _ref.size,
@@ -171,6 +170,41 @@ function PaginationIndicatorView(_ref) {
171
170
  }
172
171
  }, pageBalls));
173
172
  }
173
+ function AnimatedPaginationIndicator(props) {
174
+ const prevPage = (0, _react.useRef)(props.page);
175
+ const _useState = (0, _react.useState)(props.page),
176
+ _useState2 = _slicedToArray(_useState, 2),
177
+ pageProgress = _useState2[0],
178
+ setPageProgress = _useState2[1];
179
+ (0, _react.useEffect)(function () {
180
+ const diff = props.page - prevPage.current;
181
+ const diffPerStep = diff / 60;
182
+ const interval = setInterval(function () {
183
+ setPageProgress(function (prev) {
184
+ const next = prev + diffPerStep;
185
+ if (diff < 0) {
186
+ if (next <= props.page) {
187
+ clearInterval(interval);
188
+ return props.page;
189
+ }
190
+ } else {
191
+ if (next >= props.page) {
192
+ clearInterval(interval);
193
+ return props.page;
194
+ }
195
+ }
196
+ return Number(next.toFixed(2));
197
+ });
198
+ }, props.duration / 60);
199
+ return function () {
200
+ prevPage.current = props.page;
201
+ clearInterval(interval);
202
+ };
203
+ }, [props.page]);
204
+ return /*#__PURE__*/_react.default.createElement(PaginationIndicatorView, _extends({}, props, {
205
+ page: pageProgress
206
+ }));
207
+ }
174
208
  function _PaginationIndicator(_ref3, ref) {
175
209
  let scrollableRef = _ref3.scrollableRef,
176
210
  estimatedWidth = _ref3.estimatedWidth,
@@ -178,14 +212,14 @@ function _PaginationIndicator(_ref3, ref) {
178
212
  _ref3$className = _ref3.className,
179
213
  className = _ref3$className === void 0 ? "" : _ref3$className,
180
214
  onClickPage = _ref3.onClickPage;
181
- const _useState = (0, _react.useState)(1),
182
- _useState2 = _slicedToArray(_useState, 2),
183
- currentPage = _useState2[0],
184
- setCurrentPage = _useState2[1];
185
- const _useState3 = (0, _react.useState)(),
215
+ const _useState3 = (0, _react.useState)(1),
186
216
  _useState4 = _slicedToArray(_useState3, 2),
187
- defs = _useState4[0],
188
- setDefs = _useState4[1];
217
+ currentPage = _useState4[0],
218
+ setCurrentPage = _useState4[1];
219
+ const _useState5 = (0, _react.useState)(),
220
+ _useState6 = _slicedToArray(_useState5, 2),
221
+ defs = _useState6[0],
222
+ setDefs = _useState6[1];
189
223
  const refreshPages = (0, _react.useCallback)(function () {
190
224
  if (!scrollableRef.current) return;
191
225
  const maxWidth = estimatedWidth === undefined ? scrollableRef.current.scrollWidth : estimatedWidth;
@@ -237,7 +271,11 @@ function _PaginationIndicator(_ref3, ref) {
237
271
  onClickPage: onClickPage
238
272
  });
239
273
  }
274
+
275
+ /**
276
+ * A cool component to indicate how many pages are
277
+ **/
240
278
  const PaginationIndicator = /*#__PURE__*/(0, _react.forwardRef)(_PaginationIndicator);
241
279
  var _default = PaginationIndicator;
242
280
  exports.default = _default;
243
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_slicedToArray","arr","i","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","_i","Symbol","iterator","_s","_e","_x","_r","_arr","_n","_d","next","done","push","value","length","err","return","_toArray","_iterableToArray","TypeError","o","minLen","_arrayLikeToArray","n","toString","slice","constructor","name","Array","from","test","len","arr2","iter","isArray","MAX_BALLS","eachBallWidthEm","CENTER_GUIDE_BALL","PaginationIndicatorMode","exports","PaginationIndicatorView","_ref","size","currentPage","page","decimalPages","pages","className","onClickPage","_ref$mode","mode","CENTERED","useMemo","floor","Math","modulus","currentFloorModulus","equivalent","rand","random","pageIndex","ceil","numBalls","indexForTheBallsCenter","balls","indexForLastPages","isCenterPage","resetPageIndex","left","_ref2","pushBallsToRightBy","min","pushBallsToLeftBy","pushGuideToRightBy","pushToLeft","fill","undefined","map","_","isLastBall","isFirstBall","diameter","padding","createElement","width","concat","height","x","y","rx","ballSize","START","onClick","pageClicked","round","_balls$reverse","reverse","_balls$reverse2","guideBall","pageBalls","version","xmlns","style","minWidth","fontSize","id","in","result","stdDeviation","values","in2","filter","mask","opacity","cursor","_PaginationIndicator","_ref3","ref","scrollableRef","estimatedWidth","_ref3$className","_useState","useState","_useState2","setCurrentPage","_useState3","_useState4","defs","setDefs","refreshPages","useCallback","current","maxWidth","scrollWidth","clientWidth","useEffect","updatePageIndicators","target","eachPageWidth","scrollLeft","lastPageProgress","maximumProgress","diffToMax","currentProgressOnDiff","useImperativeHandle","el","onScroll","e","currentTarget","addEventListener","passive","removeEventListener","PaginationIndicator","forwardRef","_default"],"sources":["../../../src/components/PaginationIndicator/PaginationIndicator.tsx"],"sourcesContent":["import React, {\n  ForwardedRef,\n  forwardRef,\n  RefObject,\n  useCallback,\n  useEffect,\n  useImperativeHandle,\n  useMemo,\n  useState,\n} from \"react\";\n\nconst MAX_BALLS = 7;\nconst eachBallWidthEm = 1.2;\n\nconst CENTER_GUIDE_BALL = 1;\n\nexport enum PaginationIndicatorMode {\n  /** This will make the guide ball be kept on center  */\n  CENTERED,\n\n  /** This will make the guide ball move, while the indicator balls keep in place */\n  START,\n}\n\n/**\n * A cool component to indicate how many pages are\n **/\nexport function PaginationIndicatorView({\n  size,\n  page: currentPage,\n  pages: decimalPages,\n  className,\n  onClickPage,\n  mode = PaginationIndicatorMode.CENTERED,\n}: {\n  size: number;\n  page: number;\n  pages: number;\n  className: string;\n  onClickPage?: (page: number) => void;\n  mode?: PaginationIndicatorMode;\n}) {\n  const page = useMemo(() => {\n    const floor = Math.floor(decimalPages);\n    const modulus = decimalPages % floor;\n\n    if (currentPage > floor) {\n      const currentFloorModulus = currentPage % floor;\n      const equivalent = (currentFloorModulus * 100) / modulus;\n\n      return floor + equivalent / 100;\n    } else {\n      return currentPage;\n    }\n  }, [currentPage, decimalPages]);\n  const rand = useMemo(() => Math.random().toString(), []);\n  const pageIndex = page - 1;\n  const pages = useMemo(() => Math.ceil(decimalPages), [decimalPages]);\n  const numBalls = useMemo(() => {\n    const numBalls = pages >= MAX_BALLS ? MAX_BALLS : Math.ceil(pages);\n\n    return numBalls;\n  }, [pages]);\n\n  const indexForTheBallsCenter = useMemo(() => (numBalls - 1) / 2, [numBalls]);\n  const balls = useMemo(() => {\n    const indexForLastPages = pages + 1 - indexForTheBallsCenter;\n    /**\n     * Is the page index (position of the center)\n     * after the first pages and\n     * before the last pages */\n    const isCenterPage =\n      numBalls >= MAX_BALLS &&\n      pageIndex > indexForTheBallsCenter &&\n      pageIndex < indexForLastPages - 1;\n    let modulus =\n      pageIndex %\n      (1 + (indexForTheBallsCenter - Math.floor(indexForTheBallsCenter)));\n    const resetPageIndex = isCenterPage\n      ? indexForTheBallsCenter + modulus\n      : pages < MAX_BALLS\n      ? pageIndex\n      : pageIndex >= indexForLastPages - 1\n      ? numBalls - (pages - pageIndex)\n      : pageIndex;\n    const left = eachBallWidthEm * resetPageIndex;\n    const { pushBallsToRightBy, pushBallsToLeftBy, pushGuideToRightBy } =\n      mode === PaginationIndicatorMode.CENTERED\n        ? {\n            pushBallsToRightBy: Math.min(pages, MAX_BALLS) * eachBallWidthEm,\n            pushBallsToLeftBy: left,\n            pushGuideToRightBy: 0,\n          }\n        : {\n            pushBallsToRightBy: (eachBallWidthEm - 0.5) / 2,\n            pushBallsToLeftBy: 0,\n            pushGuideToRightBy: left,\n          };\n    let pushToLeft: number = 0;\n    return new Array(CENTER_GUIDE_BALL + numBalls)\n      .fill(undefined)\n      .map((_, i) => {\n        const isLastBall = i === numBalls - 1;\n        const isFirstBall = i === 0;\n\n        if (i === numBalls) {\n          const diameter = 0.45 * 2;\n          const padding = (eachBallWidthEm - diameter) / 2;\n          return (\n            <rect\n              fill=\"#fff\"\n              width={`${diameter}em`}\n              height={`${diameter}em`}\n              x={`${\n                pushBallsToRightBy - padding + pushGuideToRightBy - pushToLeft\n              }em`}\n              y={`${padding}em`}\n              rx={`${diameter / 2}em`}\n            />\n          );\n        }\n\n        const ballSize =\n          numBalls < MAX_BALLS\n            ? 0.5\n            : page <= indexForTheBallsCenter + 1 && isLastBall\n            ? 0\n            : pageIndex >= indexForLastPages - 1 && isFirstBall\n            ? 0\n            : isCenterPage\n            ? isFirstBall\n              ? 0.5 - modulus * 0.5\n              : isLastBall\n              ? modulus * 0.5\n              : 0.5\n            : 0.5;\n\n        if (i === 0 && mode === PaginationIndicatorMode.START)\n          pushToLeft = (0.5 - ballSize) * 2.4;\n\n        return (\n          <rect\n            key={`guide-${i}`}\n            width={`${ballSize * 1.2}em`}\n            height={`${ballSize * 1.2}em`}\n            x={`${\n              pushBallsToRightBy +\n              i * eachBallWidthEm -\n              pushBallsToLeftBy -\n              pushToLeft\n            }em`}\n            y={`${(eachBallWidthEm - ballSize * 1.2) / 2}em`}\n            rx={`${(ballSize * 1.2) / 2}em`}\n            onClick={() => {\n              if (onClickPage) {\n                const pageClicked =\n                  (!isCenterPage\n                    ? pageIndex >= indexForLastPages - 1\n                      ? Math.floor(page) - resetPageIndex - 1\n                      : 0\n                    : Math.floor(page) - (indexForTheBallsCenter + 1)) +\n                  1 +\n                  i;\n                onClickPage(Math.round(pageClicked));\n              }\n            }}\n          />\n        );\n      });\n  }, [indexForTheBallsCenter, pageIndex, pages]);\n  const [guideBall, ...pageBalls] = balls.reverse();\n  let width = eachBallWidthEm * Math.min(pages, MAX_BALLS) * 2;\n  if (mode === PaginationIndicatorMode.START) width /= 2;\n\n  return (\n    <svg\n      version=\"1.1\"\n      xmlns=\"http://www.w3.org/2000/svg\"\n      className={className}\n      style={{\n        width: `${width}em`,\n        minWidth: `${width}em`,\n        height: \"1.2em\",\n        fontSize: `${size}px`,\n      }}\n    >\n      <filter id={`goo-${rand}`}>\n        <feGaussianBlur in=\"SourceGraphic\" result=\"blur\" stdDeviation=\"5\" />\n        <feColorMatrix\n          in=\"blur\"\n          mode=\"matrix\"\n          values=\"1 0 0 0 0  0 1 0 0 0  0 0 1 0 0  0 0 0 18 -7\"\n          result=\"goo\"\n        />\n        <feBlend in2=\"goo\" in=\"SourceGraphic\" result=\"mix\" />\n      </filter>\n      <mask id={`mask-${rand}`}>\n        <g filter={`url(#${`goo-${rand}`})`} fill=\"#fff\">\n          {[pageBalls]}\n          {guideBall}\n        </g>\n      </mask>\n      <rect\n        x=\"0\"\n        y=\"0\"\n        mask={`url(#${`mask-${rand}`})`}\n        width=\"100%\"\n        height=\"100%\"\n        style={{ fill: \"var(--digital-blue)\" }}\n      ></rect>\n      {onClickPage && (\n        <g opacity={0} style={{ cursor: \"pointer\" }}>\n          {pageBalls}\n        </g>\n      )}\n    </svg>\n  );\n}\n\nfunction _PaginationIndicator(\n  {\n    scrollableRef,\n    estimatedWidth,\n    size,\n    className = \"\",\n    onClickPage,\n  }: {\n    scrollableRef: RefObject<HTMLDivElement>;\n    estimatedWidth?: number;\n    size: number;\n    className?: string;\n    onClickPage?: (page: number) => void;\n  },\n  ref: ForwardedRef<{\n    refreshPages: () => void;\n  }>\n) {\n  const [currentPage, setCurrentPage] = useState(1);\n\n  const [defs, setDefs] =\n    useState<{\n      pages: number;\n    }>();\n\n  const refreshPages = useCallback(() => {\n    if (!scrollableRef.current) return;\n    const maxWidth =\n      estimatedWidth === undefined\n        ? scrollableRef.current!.scrollWidth\n        : estimatedWidth;\n\n    const pages = maxWidth / scrollableRef.current!.clientWidth;\n    if (pages > 1)\n      setDefs({\n        pages,\n      });\n  }, [estimatedWidth]);\n\n  useEffect(() => refreshPages(), [refreshPages]);\n\n  const updatePageIndicators = useCallback(\n    (target: HTMLDivElement, pages: number) => {\n      if (!scrollableRef.current) return;\n      const eachPageWidth = scrollableRef.current!.clientWidth;\n      const page = 1 + target.scrollLeft / eachPageWidth;\n      const lastPageProgress = Math.floor(pages) + 1;\n      const maximumProgress = pages + 1;\n\n      const diffToMax = maximumProgress - lastPageProgress;\n      const currentProgressOnDiff = page - lastPageProgress;\n\n      if (page > lastPageProgress)\n        setCurrentPage(lastPageProgress + currentProgressOnDiff / diffToMax);\n      else setCurrentPage(page);\n    },\n    []\n  );\n\n  useImperativeHandle(\n    ref,\n    () => ({\n      refreshPages,\n    }),\n    []\n  );\n\n  useEffect(() => {\n    if (!defs) return;\n    const el = scrollableRef.current!;\n    const onScroll = (e: Event) =>\n      updatePageIndicators(e.currentTarget as HTMLDivElement, defs.pages);\n    updatePageIndicators(el, defs.pages);\n    el.addEventListener(\"scroll\", onScroll, {\n      passive: true\n    });\n    return () => {\n      el.removeEventListener(\"scroll\", onScroll);\n    };\n  }, [defs]);\n\n  const pages = useMemo(() => (defs ? defs.pages : undefined), [defs]);\n\n  return !pages ? null : (\n    <PaginationIndicatorView\n      pages={pages}\n      page={currentPage}\n      size={size}\n      className={className}\n      onClickPage={onClickPage}\n    />\n  );\n}\n\nconst PaginationIndicator = forwardRef(_PaginationIndicator);\nexport default PaginationIndicator;\n\n"],"mappings":"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"}
281
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_slicedToArray","arr","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","_i","Symbol","iterator","_s","_e","_x","_r","_arr","_n","_d","next","done","push","value","err","return","_toArray","_iterableToArray","TypeError","o","minLen","_arrayLikeToArray","n","toString","slice","constructor","name","Array","from","test","len","arr2","iter","isArray","MAX_BALLS","eachBallWidthEm","CENTER_GUIDE_BALL","PaginationIndicatorMode","exports","PaginationIndicatorView","_ref","size","currentPage","page","decimalPages","pages","className","onClickPage","_ref$mode","mode","CENTERED","useMemo","floor","Math","modulus","currentFloorModulus","equivalent","rand","random","pageIndex","ceil","numBalls","indexForTheBallsCenter","balls","indexForLastPages","isCenterPage","resetPageIndex","left","_ref2","pushBallsToRightBy","min","pushBallsToLeftBy","pushGuideToRightBy","pushToLeft","fill","undefined","map","_","isLastBall","isFirstBall","diameter","padding","createElement","width","concat","height","x","y","rx","ballSize","START","onClick","pageClicked","round","_balls$reverse","reverse","_balls$reverse2","guideBall","pageBalls","version","xmlns","style","minWidth","fontSize","id","in","result","stdDeviation","values","in2","filter","mask","opacity","cursor","AnimatedPaginationIndicator","props","prevPage","useRef","_useState","useState","_useState2","pageProgress","setPageProgress","useEffect","diff","current","diffPerStep","interval","setInterval","prev","clearInterval","Number","toFixed","duration","_PaginationIndicator","_ref3","ref","scrollableRef","estimatedWidth","_ref3$className","_useState3","_useState4","setCurrentPage","_useState5","_useState6","defs","setDefs","refreshPages","useCallback","maxWidth","scrollWidth","clientWidth","updatePageIndicators","eachPageWidth","scrollLeft","lastPageProgress","maximumProgress","diffToMax","currentProgressOnDiff","useImperativeHandle","el","onScroll","e","currentTarget","addEventListener","passive","removeEventListener","PaginationIndicator","forwardRef","_default"],"sources":["../../../src/components/PaginationIndicator/PaginationIndicator.tsx"],"sourcesContent":["import React, {\n  ComponentProps,\n  ForwardedRef,\n  forwardRef,\n  RefObject,\n  useCallback,\n  useEffect,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\n\nconst MAX_BALLS = 7;\nconst eachBallWidthEm = 1.2;\n\nconst CENTER_GUIDE_BALL = 1;\n\nexport enum PaginationIndicatorMode {\n  /** This will make the guide ball be kept on center  */\n  CENTERED,\n\n  /** This will make the guide ball move, while the indicator balls keep in place */\n  START,\n}\nexport function PaginationIndicatorView({\n  size,\n  page: currentPage,\n  pages: decimalPages,\n  className,\n  onClickPage,\n  mode = PaginationIndicatorMode.CENTERED,\n}: {\n  size: number;\n  page: number;\n  pages: number;\n  className?: string;\n  onClickPage?: (page: number) => void;\n  mode?: PaginationIndicatorMode;\n}) {\n  const page = useMemo(() => {\n    const floor = Math.floor(decimalPages);\n    const modulus = decimalPages % floor;\n\n    if (currentPage > floor) {\n      const currentFloorModulus = currentPage % floor;\n      const equivalent = (currentFloorModulus * 100) / modulus;\n\n      return floor + equivalent / 100;\n    } else {\n      return currentPage;\n    }\n  }, [currentPage, decimalPages]);\n  const rand = useMemo(() => Math.random().toString(), []);\n  const pageIndex = page - 1;\n  const pages = useMemo(() => Math.ceil(decimalPages), [decimalPages]);\n  const numBalls = useMemo(() => {\n    const numBalls = pages >= MAX_BALLS ? MAX_BALLS : Math.ceil(pages);\n\n    return numBalls;\n  }, [pages]);\n\n  const indexForTheBallsCenter = useMemo(() => (numBalls - 1) / 2, [numBalls]);\n  const balls = useMemo(() => {\n    const indexForLastPages = pages + 1 - indexForTheBallsCenter;\n    /**\n     * Is the page index (position of the center)\n     * after the first pages and\n     * before the last pages */\n    const isCenterPage =\n      numBalls >= MAX_BALLS &&\n      pageIndex > indexForTheBallsCenter &&\n      pageIndex < indexForLastPages - 1;\n    let modulus =\n      pageIndex %\n      (1 + (indexForTheBallsCenter - Math.floor(indexForTheBallsCenter)));\n    const resetPageIndex = isCenterPage\n      ? indexForTheBallsCenter + modulus\n      : pages < MAX_BALLS\n      ? pageIndex\n      : pageIndex >= indexForLastPages - 1\n      ? numBalls - (pages - pageIndex)\n      : pageIndex;\n    const left = eachBallWidthEm * resetPageIndex;\n    const { pushBallsToRightBy, pushBallsToLeftBy, pushGuideToRightBy } =\n      mode === PaginationIndicatorMode.CENTERED\n        ? {\n            pushBallsToRightBy: Math.min(pages, MAX_BALLS) * eachBallWidthEm,\n            pushBallsToLeftBy: left,\n            pushGuideToRightBy: 0,\n          }\n        : {\n            pushBallsToRightBy: (eachBallWidthEm - 0.5) / 2,\n            pushBallsToLeftBy: 0,\n            pushGuideToRightBy: left,\n          };\n    let pushToLeft: number = 0;\n    return new Array(CENTER_GUIDE_BALL + numBalls)\n      .fill(undefined)\n      .map((_, i) => {\n        const isLastBall = i === numBalls - 1;\n        const isFirstBall = i === 0;\n\n        if (i === numBalls) {\n          const diameter = 0.45 * 2;\n          const padding = (eachBallWidthEm - diameter) / 2;\n          return (\n            <rect\n              fill=\"#fff\"\n              width={`${diameter}em`}\n              height={`${diameter}em`}\n              x={`${\n                pushBallsToRightBy - padding + pushGuideToRightBy - pushToLeft\n              }em`}\n              y={`${padding}em`}\n              rx={`${diameter / 2}em`}\n            />\n          );\n        }\n\n        const ballSize =\n          numBalls < MAX_BALLS\n            ? 0.5\n            : page <= indexForTheBallsCenter + 1 && isLastBall\n            ? 0\n            : pageIndex >= indexForLastPages - 1 && isFirstBall\n            ? 0\n            : isCenterPage\n            ? isFirstBall\n              ? 0.5 - modulus * 0.5\n              : isLastBall\n              ? modulus * 0.5\n              : 0.5\n            : 0.5;\n\n        if (i === 0 && mode === PaginationIndicatorMode.START)\n          pushToLeft = (0.5 - ballSize) * 2.4;\n\n        return (\n          <rect\n            key={`guide-${i}`}\n            width={`${ballSize * 1.2}em`}\n            height={`${ballSize * 1.2}em`}\n            x={`${\n              pushBallsToRightBy +\n              i * eachBallWidthEm -\n              pushBallsToLeftBy -\n              pushToLeft\n            }em`}\n            y={`${(eachBallWidthEm - ballSize * 1.2) / 2}em`}\n            rx={`${(ballSize * 1.2) / 2}em`}\n            onClick={() => {\n              if (onClickPage) {\n                const pageClicked =\n                  (!isCenterPage\n                    ? pageIndex >= indexForLastPages - 1\n                      ? Math.floor(page) - resetPageIndex - 1\n                      : 0\n                    : Math.floor(page) - (indexForTheBallsCenter + 1)) +\n                  1 +\n                  i;\n                onClickPage(Math.round(pageClicked));\n              }\n            }}\n          />\n        );\n      });\n  }, [indexForTheBallsCenter, pageIndex, pages]);\n  const [guideBall, ...pageBalls] = balls.reverse();\n  let width = eachBallWidthEm * Math.min(pages, MAX_BALLS) * 2;\n  if (mode === PaginationIndicatorMode.START) width /= 2;\n\n  return (\n    <svg\n      version=\"1.1\"\n      xmlns=\"http://www.w3.org/2000/svg\"\n      className={className}\n      style={{\n        width: `${width}em`,\n        minWidth: `${width}em`,\n        height: \"1.2em\",\n        fontSize: `${size}px`,\n      }}\n    >\n      <filter id={`goo-${rand}`}>\n        <feGaussianBlur in=\"SourceGraphic\" result=\"blur\" stdDeviation=\"5\" />\n        <feColorMatrix\n          in=\"blur\"\n          mode=\"matrix\"\n          values=\"1 0 0 0 0  0 1 0 0 0  0 0 1 0 0  0 0 0 18 -7\"\n          result=\"goo\"\n        />\n        <feBlend in2=\"goo\" in=\"SourceGraphic\" result=\"mix\" />\n      </filter>\n      <mask id={`mask-${rand}`}>\n        <g filter={`url(#${`goo-${rand}`})`} fill=\"#fff\">\n          {[pageBalls]}\n          {guideBall}\n        </g>\n      </mask>\n      <rect\n        x=\"0\"\n        y=\"0\"\n        mask={`url(#${`mask-${rand}`})`}\n        width=\"100%\"\n        height=\"100%\"\n        style={{ fill: \"var(--digital-blue)\" }}\n      ></rect>\n      {onClickPage && (\n        <g opacity={0} style={{ cursor: \"pointer\" }}>\n          {pageBalls}\n        </g>\n      )}\n    </svg>\n  );\n}\n\nexport function AnimatedPaginationIndicator(\n  props: ComponentProps<typeof PaginationIndicatorView> & {\n    duration: number;\n  }\n) {\n  const prevPage = useRef(props.page);\n  const [pageProgress, setPageProgress] = useState(props.page);\n  useEffect(() => {\n    const diff = props.page - prevPage.current;\n    const diffPerStep = diff / 60;\n\n    const interval = setInterval(() => {\n      setPageProgress((prev) => {\n        const next = prev + diffPerStep;\n        if (diff < 0) {\n          if (next <= props.page) {\n            clearInterval(interval);\n            return props.page;\n          }\n        } else {\n          if (next >= props.page) {\n            clearInterval(interval);\n            return props.page;\n          }\n        }\n        return Number(next.toFixed(2));\n      });\n    }, props.duration / 60);\n\n    return () => {\n      prevPage.current = props.page;\n      clearInterval(interval)\n    };\n  }, [props.page]);\n\n  return <PaginationIndicatorView {...props} page={pageProgress} />;\n}\n\nfunction _PaginationIndicator(\n  {\n    scrollableRef,\n    estimatedWidth,\n    size,\n    className = \"\",\n    onClickPage,\n  }: {\n    scrollableRef: RefObject<HTMLDivElement>;\n    estimatedWidth?: number;\n    size: number;\n    className?: string;\n    onClickPage?: (page: number) => void;\n  },\n  ref: ForwardedRef<{\n    refreshPages: () => void;\n  }>\n) {\n  const [currentPage, setCurrentPage] = useState(1);\n\n  const [defs, setDefs] =\n    useState<{\n      pages: number;\n    }>();\n\n  const refreshPages = useCallback(() => {\n    if (!scrollableRef.current) return;\n    const maxWidth =\n      estimatedWidth === undefined\n        ? scrollableRef.current!.scrollWidth\n        : estimatedWidth;\n\n    const pages = maxWidth / scrollableRef.current!.clientWidth;\n    if (pages > 1)\n      setDefs({\n        pages,\n      });\n  }, [estimatedWidth]);\n\n  useEffect(() => refreshPages(), [refreshPages]);\n\n  const updatePageIndicators = useCallback(\n    (target: HTMLDivElement, pages: number) => {\n      if (!scrollableRef.current) return;\n      const eachPageWidth = scrollableRef.current!.clientWidth;\n      const page = 1 + target.scrollLeft / eachPageWidth;\n      const lastPageProgress = Math.floor(pages) + 1;\n      const maximumProgress = pages + 1;\n\n      const diffToMax = maximumProgress - lastPageProgress;\n      const currentProgressOnDiff = page - lastPageProgress;\n\n      if (page > lastPageProgress)\n        setCurrentPage(lastPageProgress + currentProgressOnDiff / diffToMax);\n      else setCurrentPage(page);\n    },\n    []\n  );\n\n  useImperativeHandle(\n    ref,\n    () => ({\n      refreshPages,\n    }),\n    []\n  );\n\n  useEffect(() => {\n    if (!defs) return;\n    const el = scrollableRef.current!;\n    const onScroll = (e: Event) =>\n      updatePageIndicators(e.currentTarget as HTMLDivElement, defs.pages);\n    updatePageIndicators(el, defs.pages);\n    el.addEventListener(\"scroll\", onScroll, {\n      passive: true,\n    });\n    return () => {\n      el.removeEventListener(\"scroll\", onScroll);\n    };\n  }, [defs]);\n\n  const pages = useMemo(() => (defs ? defs.pages : undefined), [defs]);\n\n  return !pages ? null : (\n    <PaginationIndicatorView\n      pages={pages}\n      page={currentPage}\n      size={size}\n      className={className}\n      onClickPage={onClickPage}\n    />\n  );\n}\n\n/**\n * A cool component to indicate how many pages are\n **/\nconst PaginationIndicator = forwardRef(_PaginationIndicator);\nexport default PaginationIndicator;\n"],"mappings":"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"}
@@ -11,5 +11,8 @@ declare type Props = PropsWithChildren<{
11
11
  y: number;
12
12
  };
13
13
  }> & DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLDivElement>;
14
+ /**
15
+ * It holds a children and animates a tilt effect relative to mouse position
16
+ **/
14
17
  declare const Parallax: React.ForwardRefExoticComponent<Omit<Props, "ref"> & React.RefAttributes<HTMLDivElement>>;
15
18
  export default Parallax;