@onepercentio/one-ui 0.28.4 → 0.28.6

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.
@@ -42,6 +42,7 @@ const CONFIGS_BY_ENTRANCE_TYPE = {
42
42
  }
43
43
  };
44
44
  function AnimatedEntranceItem(_ref) {
45
+ var _children$key;
45
46
  let {
46
47
  children,
47
48
  noEntranceAnimation,
@@ -52,6 +53,7 @@ function AnimatedEntranceItem(_ref) {
52
53
  const [screen, setScreen] = (0, _react.useState)(noEntranceAnimation ? children : /*#__PURE__*/_react.default.createElement(_react.Fragment, {
53
54
  key: "null"
54
55
  }));
56
+ console.log(screen, children.key);
55
57
  (0, _react.useLayoutEffect)(() => {
56
58
  if (String(children.key).includes("-nullated") && uncontRef.current) {
57
59
  uncontRef.current.setOrientation("backward");
@@ -109,7 +111,9 @@ function AnimatedEntranceItem(_ref) {
109
111
  config: CONFIGS_BY_ENTRANCE_TYPE[entranceType]
110
112
  }, screen === null ? /*#__PURE__*/_react.default.createElement(_react.Fragment, {
111
113
  key: "null"
112
- }) : typeof screen === "string" ? children : screen);
114
+ }) : typeof screen === "string" ? (_children$key = children.key) !== null && _children$key !== void 0 && _children$key.endsWith("-nullated") && screen.endsWith("-nullated") ? /*#__PURE__*/_react.default.createElement(_react.Fragment, {
115
+ key: children.key + "-null"
116
+ }) : children : screen);
113
117
  }
114
118
 
115
119
  /**
@@ -135,7 +139,7 @@ function AnimatedEntrance(_ref3) {
135
139
  // If not, toggle to null to animate exit
136
140
  _react.default.createElement(_react.Fragment, {
137
141
  key: String(c.key).includes("-nullated") ? c.key : `${c.key}-nullated`
138
- });
142
+ }, prevChildren.current.find(a => a.key === c.key));
139
143
  });
140
144
  for (let child of newChildren) {
141
145
  var _children;
@@ -149,11 +153,14 @@ function AnimatedEntrance(_ref3) {
149
153
  return filteredOutChildren;
150
154
  }, [children]);
151
155
  prevChildren.current = childrenDelayed;
156
+ console.log(childrenDelayed.map(a => a.key));
152
157
  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, childrenDelayed.map(child => /*#__PURE__*/_react.default.createElement(AnimatedEntranceItem, {
153
158
  key: String(child.key).replace("-nullated", ""),
154
159
  noEntranceAnimation: firstRef.current,
155
160
  entranceType: entranceType,
156
- onRemoveChildren: k => prevChildren.current = prevChildren.current.filter(a => a.key !== String(k) + "-nullated")
161
+ onRemoveChildren: k => {
162
+ prevChildren.current = prevChildren.current.filter(a => a.key !== String(k) + "-nullated");
163
+ }
157
164
  }, children.find(c => c.key === child.key) || child)));
158
165
  }
159
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Transition","_UncontrolledTransition","_interopRequireDefault","_AnimatedEntranceModule","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","EntranceType","exports","CONFIGS_BY_ENTRANCE_TYPE","SLIDE_AND_EXPAND","forward","elementEntering","Styles","elementExiting","backward","elementEnteringReverse","elementExitingReverse","EXPAND","elementExpanding","elementShrinking","elementExpandingReverse","elementShrinkingReverse","AnimatedEntranceItem","_ref","children","noEntranceAnimation","onRemoveChildren","entranceType","uncontRef","useRef","screen","setScreen","useState","createElement","Fragment","useLayoutEffect","String","includes","current","setOrientation","useEffect","x","setTimeout","sectionRef","style","maxHeight","scrollHeight","restoreAutoHeight","_ref2","target","currentTarget","removeProperty","classList","remove","removeEventListener","addEventListener","clearTimeout","firstRenderClass","useMemo","ref","transitionType","TransitionAnimationTypes","CUSTOM","className","resetHeight","lockTransitionWidth","replace","onDiscardStep","k","config","AnimatedEntrance","_ref3","firstRef","prevChildren","childrenDelayed","newChildren","filter","c","find","a","filteredOutChildren","map","child","_children","previousChildKey","indexOf","splice","findIndex","unshift"],"sources":["../../../src/components/AnimatedEntrance/AnimatedEntrance.tsx"],"sourcesContent":["import React, {\n  ElementRef,\n  Fragment,\n  Key,\n  ReactElement,\n  TransitionEvent,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { TransitionAnimationTypes } from \"../Transition\";\nimport UncontrolledTransition from \"../UncontrolledTransition\";\nimport Styles from \"./AnimatedEntrance.module.scss\";\n\nexport enum EntranceType {\n  SLIDE_AND_EXPAND,\n  EXPAND,\n}\n\nconst CONFIGS_BY_ENTRANCE_TYPE = {\n  [EntranceType.SLIDE_AND_EXPAND]: {\n    forward: {\n      elementEntering: Styles.elementEntering,\n      elementExiting: Styles.elementExiting,\n    },\n    backward: {\n      elementEntering: Styles.elementEnteringReverse,\n      elementExiting: Styles.elementExitingReverse,\n    },\n  },\n  [EntranceType.EXPAND]: {\n    forward: {\n      elementEntering: Styles.elementExpanding,\n      elementExiting: Styles.elementShrinking,\n    },\n    backward: {\n      elementEntering: Styles.elementExpandingReverse,\n      elementExiting: Styles.elementShrinkingReverse,\n    },\n  },\n};\n\nexport function AnimatedEntranceItem({\n  children,\n  noEntranceAnimation,\n  onRemoveChildren,\n  entranceType,\n}: {\n  children: ReactElement;\n  noEntranceAnimation: boolean;\n  onRemoveChildren: (key: Key) => void;\n  entranceType: EntranceType;\n}) {\n  const uncontRef = useRef<ElementRef<typeof UncontrolledTransition>>(null);\n  const [screen, setScreen] = useState<ReactElement | string | null>(\n    noEntranceAnimation ? children : <Fragment key={\"null\"} />\n  );\n  useLayoutEffect(() => {\n    if (String(children.key).includes(\"-nullated\") && uncontRef.current) {\n      uncontRef.current!.setOrientation(\"backward\");\n    }\n  }, [children.key]);\n\n  useEffect(() => {\n    setScreen(String(children.key));\n  }, [children.key]);\n\n  useEffect(() => {\n    if (screen === null) return;\n    const x = setTimeout(() => {\n      const key = String(typeof screen === \"string\" ? screen : screen.key!);\n      if (key === \"null\" || key.includes(\"-nullated\")) {\n        uncontRef.current!.sectionRef.current!.style.maxHeight = `${\n          uncontRef.current!.sectionRef.current!.scrollHeight\n        }px`;\n        setTimeout(() => {\n          uncontRef.current!.sectionRef.current!.style.maxHeight = `0px`;\n        }, 100);\n      } else {\n        uncontRef.current!.sectionRef.current!.style.maxHeight = `${\n          uncontRef.current!.sectionRef.current!.scrollHeight\n        }px`;\n        if (!noEntranceAnimation) {\n          const restoreAutoHeight = ({\n            target,\n            currentTarget,\n          }: TransitionEvent<HTMLDivElement>) => {\n            if (target !== currentTarget) return;\n            uncontRef.current!.sectionRef.current!.style.removeProperty(\n              \"max-height\"\n            );\n            uncontRef.current!.sectionRef.current!.classList.remove(\n              Styles.maxHeight\n            );\n            uncontRef.current!.sectionRef.current!.removeEventListener(\n              \"transitionend\",\n              restoreAutoHeight as any\n            );\n          };\n          uncontRef.current!.sectionRef.current!.addEventListener(\n            \"transitionend\",\n            restoreAutoHeight as any\n          );\n        } else {\n          uncontRef.current!.sectionRef.current!.style.removeProperty(\n            \"max-height\"\n          );\n          uncontRef.current!.sectionRef.current!.classList.remove(\n            Styles.maxHeight\n          );\n        }\n      }\n    }, 100);\n    return () => {\n      clearTimeout(x);\n    };\n  }, [typeof screen === \"object\" ? screen?.key : screen]);\n\n  const firstRenderClass = useMemo(\n    () => (noEntranceAnimation ? \"\" : Styles.maxHeight),\n    [screen === null]\n  );\n\n  return (\n    <UncontrolledTransition\n      ref={uncontRef}\n      transitionType={TransitionAnimationTypes.CUSTOM}\n      className={`${Styles.resetHeight} ${firstRenderClass}`}\n      lockTransitionWidth\n      key={String(children.key).replace(\"-nullated\", \"\")}\n      onDiscardStep={(k) => {\n        if (k !== \"null\") {\n          onRemoveChildren(k!);\n          setScreen(null);\n        }\n      }}\n      config={CONFIGS_BY_ENTRANCE_TYPE[entranceType]}\n    >\n      {screen === null ? (\n        <Fragment key={\"null\"} />\n      ) : typeof screen === \"string\" ? (\n        children\n      ) : (\n        screen\n      )}\n    </UncontrolledTransition>\n  );\n}\n\n/**\n * Animates the entrance and exit of a component\n **/\nexport default function AnimatedEntrance({\n  children,\n  entranceType = EntranceType.SLIDE_AND_EXPAND,\n}: {\n  children: ReactElement[];\n  entranceType?: EntranceType;\n}) {\n  const firstRef = useRef(true);\n  useEffect(() => {\n    firstRef.current = false;\n  }, []);\n  const prevChildren = useRef([] as typeof children);\n  const childrenDelayed = useMemo(() => {\n    const newChildren = children.filter(\n      (c) => !prevChildren.current.find((a) => a.key === c.key)\n    );\n    const filteredOutChildren = prevChildren.current.map((c) => {\n      return children.find((a) => a.key === c.key) ? ( // If the previous child still exists, mantain\n        c\n      ) : (\n        // If not, toggle to null to animate exit\n        <Fragment\n          key={\n            String(c.key).includes(\"-nullated\") ? c.key : `${c.key}-nullated`\n          }\n        />\n      );\n    });\n\n    for (let child of newChildren) {\n      const previousChildKey = children[children.indexOf(child) - 1]?.key;\n      if (previousChildKey) {\n        filteredOutChildren.splice(\n          filteredOutChildren.findIndex((a) => a.key === previousChildKey) + 1,\n          0,\n          child\n        );\n      } else {\n        filteredOutChildren.unshift(child);\n      }\n    }\n\n    return filteredOutChildren;\n  }, [children]);\n  prevChildren.current = childrenDelayed;\n\n  return (\n    <>\n      {childrenDelayed.map((child) => (\n        <AnimatedEntranceItem\n          key={String(child.key!).replace(\"-nullated\", \"\")}\n          noEntranceAnimation={firstRef.current}\n          entranceType={entranceType}\n          onRemoveChildren={(k) =>\n            (prevChildren.current = prevChildren.current.filter(\n              (a) => a.key !== String(k) + \"-nullated\"\n            ))\n          }\n        >\n          {children.find((c) => c.key === child.key) || child}\n        </AnimatedEntranceItem>\n      ))}\n    </>\n  );\n}\n"],"mappings":"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"}
166
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Transition","_UncontrolledTransition","_interopRequireDefault","_AnimatedEntranceModule","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","EntranceType","exports","CONFIGS_BY_ENTRANCE_TYPE","SLIDE_AND_EXPAND","forward","elementEntering","Styles","elementExiting","backward","elementEnteringReverse","elementExitingReverse","EXPAND","elementExpanding","elementShrinking","elementExpandingReverse","elementShrinkingReverse","AnimatedEntranceItem","_ref","_children$key","children","noEntranceAnimation","onRemoveChildren","entranceType","uncontRef","useRef","screen","setScreen","useState","createElement","Fragment","console","log","useLayoutEffect","String","includes","current","setOrientation","useEffect","x","setTimeout","sectionRef","style","maxHeight","scrollHeight","restoreAutoHeight","_ref2","target","currentTarget","removeProperty","classList","remove","removeEventListener","addEventListener","clearTimeout","firstRenderClass","useMemo","ref","transitionType","TransitionAnimationTypes","CUSTOM","className","resetHeight","lockTransitionWidth","replace","onDiscardStep","k","config","endsWith","AnimatedEntrance","_ref3","firstRef","prevChildren","childrenDelayed","newChildren","filter","c","find","a","filteredOutChildren","map","child","_children","previousChildKey","indexOf","splice","findIndex","unshift"],"sources":["../../../src/components/AnimatedEntrance/AnimatedEntrance.tsx"],"sourcesContent":["import React, {\n  ElementRef,\n  Fragment,\n  Key,\n  ReactElement,\n  TransitionEvent,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { TransitionAnimationTypes } from \"../Transition\";\nimport UncontrolledTransition from \"../UncontrolledTransition\";\nimport Styles from \"./AnimatedEntrance.module.scss\";\n\nexport enum EntranceType {\n  SLIDE_AND_EXPAND,\n  EXPAND,\n}\n\nconst CONFIGS_BY_ENTRANCE_TYPE = {\n  [EntranceType.SLIDE_AND_EXPAND]: {\n    forward: {\n      elementEntering: Styles.elementEntering,\n      elementExiting: Styles.elementExiting,\n    },\n    backward: {\n      elementEntering: Styles.elementEnteringReverse,\n      elementExiting: Styles.elementExitingReverse,\n    },\n  },\n  [EntranceType.EXPAND]: {\n    forward: {\n      elementEntering: Styles.elementExpanding,\n      elementExiting: Styles.elementShrinking,\n    },\n    backward: {\n      elementEntering: Styles.elementExpandingReverse,\n      elementExiting: Styles.elementShrinkingReverse,\n    },\n  },\n};\n\nexport function AnimatedEntranceItem({\n  children,\n  noEntranceAnimation,\n  onRemoveChildren,\n  entranceType,\n}: {\n  children: ReactElement;\n  noEntranceAnimation: boolean;\n  onRemoveChildren: (key: Key) => void;\n  entranceType: EntranceType;\n}) {\n  const uncontRef = useRef<ElementRef<typeof UncontrolledTransition>>(null);\n  const [screen, setScreen] = useState<ReactElement | string | null>(\n    noEntranceAnimation ? children : <Fragment key={\"null\"} />\n  );\n  console.log(screen, children.key)\n  useLayoutEffect(() => {\n    if (String(children.key).includes(\"-nullated\") && uncontRef.current) {\n      uncontRef.current!.setOrientation(\"backward\");\n    }\n  }, [children.key]);\n\n  useEffect(() => {\n    setScreen(String(children.key));\n  }, [children.key]);\n\n  useEffect(() => {\n    if (screen === null) return;\n    const x = setTimeout(() => {\n      const key = String(typeof screen === \"string\" ? screen : screen.key!);\n      if (key === \"null\" || key.includes(\"-nullated\")) {\n        uncontRef.current!.sectionRef.current!.style.maxHeight = `${uncontRef.current!.sectionRef.current!.scrollHeight\n          }px`;\n        setTimeout(() => {\n          uncontRef.current!.sectionRef.current!.style.maxHeight = `0px`;\n        }, 100);\n      } else {\n        uncontRef.current!.sectionRef.current!.style.maxHeight = `${uncontRef.current!.sectionRef.current!.scrollHeight\n          }px`;\n        if (!noEntranceAnimation) {\n          const restoreAutoHeight = ({\n            target,\n            currentTarget,\n          }: TransitionEvent<HTMLDivElement>) => {\n            if (target !== currentTarget) return;\n            uncontRef.current!.sectionRef.current!.style.removeProperty(\n              \"max-height\"\n            );\n            uncontRef.current!.sectionRef.current!.classList.remove(\n              Styles.maxHeight\n            );\n            uncontRef.current!.sectionRef.current!.removeEventListener(\n              \"transitionend\",\n              restoreAutoHeight as any\n            );\n          };\n          uncontRef.current!.sectionRef.current!.addEventListener(\n            \"transitionend\",\n            restoreAutoHeight as any\n          );\n        } else {\n          uncontRef.current!.sectionRef.current!.style.removeProperty(\n            \"max-height\"\n          );\n          uncontRef.current!.sectionRef.current!.classList.remove(\n            Styles.maxHeight\n          );\n        }\n      }\n    }, 100);\n    return () => {\n      clearTimeout(x);\n    };\n  }, [typeof screen === \"object\" ? screen?.key : screen]);\n\n  const firstRenderClass = useMemo(\n    () => (noEntranceAnimation ? \"\" : Styles.maxHeight),\n    [screen === null]\n  );\n\n  return (\n    <UncontrolledTransition\n      ref={uncontRef}\n      transitionType={TransitionAnimationTypes.CUSTOM}\n      className={`${Styles.resetHeight} ${firstRenderClass}`}\n      lockTransitionWidth\n      key={String(children.key).replace(\"-nullated\", \"\")}\n      onDiscardStep={(k) => {\n        if (k !== \"null\") {\n          onRemoveChildren(k!);\n          setScreen(null);\n        }\n      }}\n      config={CONFIGS_BY_ENTRANCE_TYPE[entranceType]}\n    >\n      {screen === null ? (\n        <Fragment key={\"null\"} />\n      ) : typeof screen === \"string\" ? (\n        (children.key?.endsWith(\"-nullated\") && screen.endsWith(\"-nullated\"))\n          ? <Fragment key={children.key + \"-null\"} />\n          : children\n      ) : (\n        screen\n      )}\n    </UncontrolledTransition>\n  );\n}\n\n/**\n * Animates the entrance and exit of a component\n **/\nexport default function AnimatedEntrance({\n  children,\n  entranceType = EntranceType.SLIDE_AND_EXPAND,\n}: {\n  children: ReactElement[];\n  entranceType?: EntranceType;\n}) {\n  const firstRef = useRef(true);\n  useEffect(() => {\n    firstRef.current = false;\n  }, []);\n  const prevChildren = useRef([] as typeof children);\n  const childrenDelayed = useMemo(() => {\n    const newChildren = children.filter(\n      (c) => !prevChildren.current.find((a) => a.key === c.key)\n    );\n    const filteredOutChildren = prevChildren.current.map((c) => {\n      return children.find((a) => a.key === c.key) ? ( // If the previous child still exists, mantain\n        c\n      ) : (\n        // If not, toggle to null to animate exit\n        <Fragment\n          key={\n            String(c.key).includes(\"-nullated\") ? c.key : `${c.key}-nullated`\n          }\n        >\n          {prevChildren.current.find(a => a.key === c.key)}\n        </Fragment>\n      );\n    });\n\n    for (let child of newChildren) {\n      const previousChildKey = children[children.indexOf(child) - 1]?.key;\n      if (previousChildKey) {\n        filteredOutChildren.splice(\n          filteredOutChildren.findIndex((a) => a.key === previousChildKey) + 1,\n          0,\n          child\n        );\n      } else {\n        filteredOutChildren.unshift(child);\n      }\n    }\n\n    return filteredOutChildren;\n  }, [children]);\n  prevChildren.current = childrenDelayed;\n\n  console.log(childrenDelayed.map(a => a.key));\n\n\n  return (\n    <>\n      {childrenDelayed.map((child) => (\n        <AnimatedEntranceItem\n          key={String(child.key!).replace(\"-nullated\", \"\")}\n          noEntranceAnimation={firstRef.current}\n          entranceType={entranceType}\n          onRemoveChildren={(k) => {\n\n            (prevChildren.current = prevChildren.current.filter(\n              (a) => a.key !== String(k) + \"-nullated\"\n            ))\n          }\n          }\n        >\n          {children.find((c) => c.key === child.key) || child}\n        </AnimatedEntranceItem>\n      ))}\n    </>\n  );\n}\n"],"mappings":"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"}
@@ -82,16 +82,18 @@ function _UncontrolledTransition(_ref, ref) {
82
82
  className: className,
83
83
  step: predictedStep,
84
84
  onDiscardStep: (discardedKey, animatedAt) => {
85
- if (onDiscardStep) onDiscardStep(discardedKey);
86
- orientation.current = "forward";
87
- setChildStack(prev => {
88
- return {
89
- childStack: prev.childStack.filter(a => {
90
- return a.key !== discardedKey || a.createdAt > animatedAt;
91
- }),
92
- offset: prev.offset === 1 ? 1 : prev.offset - 1
93
- };
94
- });
85
+ setTimeout(() => {
86
+ if (onDiscardStep) onDiscardStep(discardedKey);
87
+ orientation.current = "forward";
88
+ setChildStack(prev => {
89
+ return {
90
+ childStack: prev.childStack.filter(a => {
91
+ return a.key !== discardedKey || a.createdAt > animatedAt;
92
+ }),
93
+ offset: prev.offset === 1 ? 1 : prev.offset - 1
94
+ };
95
+ });
96
+ }, 0);
95
97
  },
96
98
  lockTransitionWidth: lockTransitionWidth,
97
99
  lockTransitionHeight: lockTransitionHeight,
@@ -106,4 +108,4 @@ const UncontrolledTransition = /*#__PURE__*/(0, _react.forwardRef)(_Uncontrolled
106
108
  exports.UncontrolledTransition = UncontrolledTransition;
107
109
  var _default = UncontrolledTransition;
108
110
  exports.default = _default;
109
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Transition","_interopRequireDefault","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_UncontrolledTransition","_ref","ref","className","contentClassName","children","createElement","Fragment","lockTransitionWidth","lockTransitionHeight","contentStyle","onDiscardStep","props","sectionRef","useRef","childStack","offset","setChildStack","useState","createdAt","Date","now","orientation","setOrientation","a","current","useImperativeHandle","useLayoutEffect","process","env","NODE_ENV","Error","p","useEffect","prev","forEach","arr","predictedStep","step","discardedKey","animatedAt","filter","UncontrolledTransition","forwardRef","exports","_default"],"sources":["../../../src/components/UncontrolledTransition/UncontrolledTransition.tsx"],"sourcesContent":["import React, {\n  DetailedHTMLProps,\n  ForwardedRef,\n  forwardRef,\n  Key,\n  RefObject,\n  useEffect,\n  useImperativeHandle,\n  useLayoutEffect,\n  useRef,\n  useState,\n} from \"react\";\nimport Transition from \"../Transition\";\nimport {\n  TransitionProps,\n  TransitionTypeDefinitions,\n} from \"../Transition/Transition\";\n\nfunction _UncontrolledTransition(\n  {\n    className = \"\",\n    contentClassName,\n    children = <React.Fragment key=\"default\"></React.Fragment>,\n    lockTransitionWidth = true,\n    lockTransitionHeight = false,\n    contentStyle,\n    onDiscardStep,\n    ...props\n  }: {\n    className?: string;\n    contentClassName?: string;\n    children?: React.ReactElement;\n    lockTransitionWidth?: boolean;\n    lockTransitionHeight?: boolean;\n    onDiscardStep?: (key: Key) => void;\n  } & Pick<TransitionProps, \"contentStyle\"> &\n    TransitionTypeDefinitions &\n    Omit<\n      DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, any>,\n      \"className\" | \"children\" | \"ref\"\n    >,\n  ref: ForwardedRef<{\n    setOrientation: (orientation: \"forward\" | \"backward\") => void;\n    sectionRef: RefObject<HTMLDivElement | null>;\n  }>\n) {\n  const sectionRef = useRef<HTMLDivElement>(null);\n  const [{ childStack, offset }, setChildStack] = useState<{\n    childStack: (React.ReactElement & { createdAt: number })[];\n    offset: number;\n  }>(() => ({\n    childStack: [{ ...children, createdAt: Date.now() }],\n    offset: 1,\n  }));\n  const orientation = useRef<\"forward\" | \"backward\">(\"forward\");\n  function setOrientation(a: typeof orientation.current) {\n    orientation.current = a;\n  }\n\n  useImperativeHandle(\n    ref,\n    () => ({\n      setOrientation,\n      sectionRef,\n    }),\n    []\n  );\n\n  useLayoutEffect(() => {\n    if (process.env.NODE_ENV !== \"production\" && !children.key)\n      throw new Error(\n        \"The provided child should have a key property, please provide it\"\n      );\n    if (childStack.length === 1 && childStack[0].key === children.key) return;\n    if (orientation.current === \"forward\")\n      setChildStack((p) => ({\n        ...p,\n        childStack: [...p.childStack, { ...children, createdAt: Date.now() }],\n      }));\n    else\n      setChildStack((p) => ({\n        ...p,\n        childStack: [{ ...children, createdAt: Date.now() }, ...p.childStack],\n      }));\n  }, [children.key]);\n\n  useEffect(() => {\n    if (orientation.current === \"backward\") {\n      setChildStack((prev) => {\n        return {\n          ...prev,\n          offset: prev.childStack.length,\n        };\n      });\n    }\n  }, [childStack.length]);\n\n  childStack.forEach((a, i, arr) => {\n    if (a.key === children.key)\n      arr[i] = { ...children, createdAt: a.createdAt };\n  });\n\n  const predictedStep = childStack.length - offset;\n\n  return (\n    <>\n      {childStack.length ? (\n        <Transition\n          ref={sectionRef}\n          contentStyle={contentStyle}\n          className={className}\n          step={predictedStep}\n          onDiscardStep={(discardedKey, animatedAt) => {\n            if (onDiscardStep) onDiscardStep(discardedKey);\n            orientation.current = \"forward\";\n            setChildStack((prev) => {\n              return {\n                childStack: prev.childStack.filter((a) => {\n                  return a.key !== discardedKey || a.createdAt > animatedAt;\n                }),\n                offset: prev.offset === 1 ? 1 : prev.offset - 1,\n              };\n            });\n          }}\n          lockTransitionWidth={lockTransitionWidth}\n          lockTransitionHeight={lockTransitionHeight}\n          contentClassName={contentClassName}\n          {...props}\n        >\n          {childStack}\n        </Transition>\n      ) : null}\n    </>\n  );\n}\n\n/**\n * This component receives child with key and applies a transition when the key changes, allowing to swap elements with a fine transition.\n **/\nexport const UncontrolledTransition = forwardRef(_UncontrolledTransition);\nexport default UncontrolledTransition;\n"],"mappings":"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"}
111
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Transition","_interopRequireDefault","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_UncontrolledTransition","_ref","ref","className","contentClassName","children","createElement","Fragment","lockTransitionWidth","lockTransitionHeight","contentStyle","onDiscardStep","props","sectionRef","useRef","childStack","offset","setChildStack","useState","createdAt","Date","now","orientation","setOrientation","a","current","useImperativeHandle","useLayoutEffect","process","env","NODE_ENV","Error","p","useEffect","prev","forEach","arr","predictedStep","step","discardedKey","animatedAt","setTimeout","filter","UncontrolledTransition","forwardRef","exports","_default"],"sources":["../../../src/components/UncontrolledTransition/UncontrolledTransition.tsx"],"sourcesContent":["import React, {\n  DetailedHTMLProps,\n  ForwardedRef,\n  forwardRef,\n  Key,\n  RefObject,\n  useEffect,\n  useImperativeHandle,\n  useLayoutEffect,\n  useRef,\n  useState,\n} from \"react\";\nimport Transition from \"../Transition\";\nimport {\n  TransitionProps,\n  TransitionTypeDefinitions,\n} from \"../Transition/Transition\";\n\nfunction _UncontrolledTransition(\n  {\n    className = \"\",\n    contentClassName,\n    children = <React.Fragment key=\"default\"></React.Fragment>,\n    lockTransitionWidth = true,\n    lockTransitionHeight = false,\n    contentStyle,\n    onDiscardStep,\n    ...props\n  }: {\n    className?: string;\n    contentClassName?: string;\n    children?: React.ReactElement;\n    lockTransitionWidth?: boolean;\n    lockTransitionHeight?: boolean;\n    onDiscardStep?: (key: Key) => void;\n  } & Pick<TransitionProps, \"contentStyle\"> &\n    TransitionTypeDefinitions &\n    Omit<\n      DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, any>,\n      \"className\" | \"children\" | \"ref\"\n    >,\n  ref: ForwardedRef<{\n    setOrientation: (orientation: \"forward\" | \"backward\") => void;\n    sectionRef: RefObject<HTMLDivElement | null>;\n  }>\n) {\n  const sectionRef = useRef<HTMLDivElement>(null);\n  const [{ childStack, offset }, setChildStack] = useState<{\n    childStack: (React.ReactElement & { createdAt: number })[];\n    offset: number;\n  }>(() => ({\n    childStack: [{ ...children, createdAt: Date.now() }],\n    offset: 1,\n  }));\n  const orientation = useRef<\"forward\" | \"backward\">(\"forward\");\n  function setOrientation(a: typeof orientation.current) {\n    orientation.current = a;\n  }\n\n  useImperativeHandle(\n    ref,\n    () => ({\n      setOrientation,\n      sectionRef,\n    }),\n    []\n  );\n\n  useLayoutEffect(() => {\n    if (process.env.NODE_ENV !== \"production\" && !children.key)\n      throw new Error(\n        \"The provided child should have a key property, please provide it\"\n      );\n    if (childStack.length === 1 && childStack[0].key === children.key) return;\n    if (orientation.current === \"forward\")\n      setChildStack((p) => ({\n        ...p,\n        childStack: [...p.childStack, { ...children, createdAt: Date.now() }],\n      }));\n    else\n      setChildStack((p) => ({\n        ...p,\n        childStack: [{ ...children, createdAt: Date.now() }, ...p.childStack],\n      }));\n  }, [children.key]);\n\n  useEffect(() => {\n    if (orientation.current === \"backward\") {\n      setChildStack((prev) => {\n        return {\n          ...prev,\n          offset: prev.childStack.length,\n        };\n      });\n    }\n  }, [childStack.length]);\n\n  childStack.forEach((a, i, arr) => {\n    if (a.key === children.key)\n      arr[i] = { ...children, createdAt: a.createdAt };\n  });\n\n  const predictedStep = childStack.length - offset;\n\n  return (\n    <>\n      {childStack.length ? (\n        <Transition\n          ref={sectionRef}\n          contentStyle={contentStyle}\n          className={className}\n          step={predictedStep}\n          onDiscardStep={(discardedKey, animatedAt) => {\n            setTimeout(() => {\n              if (onDiscardStep) onDiscardStep(discardedKey);\n              orientation.current = \"forward\";\n              setChildStack((prev) => {\n                return {\n                  childStack: prev.childStack.filter((a) => {\n                    return a.key !== discardedKey || a.createdAt > animatedAt;\n                  }),\n                  offset: prev.offset === 1 ? 1 : prev.offset - 1,\n                };\n              });\n            }, 0)\n          }}\n          lockTransitionWidth={lockTransitionWidth}\n          lockTransitionHeight={lockTransitionHeight}\n          contentClassName={contentClassName}\n          {...props}\n        >\n          {childStack}\n        </Transition>\n      ) : null}\n    </>\n  );\n}\n\n/**\n * This component receives child with key and applies a transition when the key changes, allowing to swap elements with a fine transition.\n **/\nexport const UncontrolledTransition = forwardRef(_UncontrolledTransition);\nexport default UncontrolledTransition;\n"],"mappings":"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"}
@@ -2,4 +2,4 @@
2
2
  * This hook pipes a data and when it is set to a falsy value ("", undefined, null, 0),
3
3
  * it returns the previous valid value
4
4
  */
5
- export default function useFreeze<T>(something: T): NonNullable<T> | null;
5
+ export default function useFreeze<T>(something: T): T | undefined;
@@ -6,12 +6,12 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports.default = useFreeze;
7
7
  var _react = require("react");
8
8
  /**
9
- * This hook pipes a data and when it is set to a falsy value ("", undefined, null, 0),
9
+ * This hook pipes a data and when it is set to a falsy value ("", undefined, null, 0),
10
10
  * it returns the previous valid value
11
11
  */
12
12
  function useFreeze(something) {
13
13
  const currChildOrPrev = (0, _react.useRef)(undefined);
14
- currChildOrPrev.current = something || currChildOrPrev.current;
15
- return currChildOrPrev.current || null;
14
+ currChildOrPrev.current = something === undefined ? currChildOrPrev.current : something;
15
+ return currChildOrPrev.current;
16
16
  }
17
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJyZXF1aXJlIiwidXNlRnJlZXplIiwic29tZXRoaW5nIiwiY3VyckNoaWxkT3JQcmV2IiwidXNlUmVmIiwidW5kZWZpbmVkIiwiY3VycmVudCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ob29rcy91c2VGcmVlemUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlUmVmIH0gZnJvbSBcInJlYWN0XCI7XG5cbi8qKlxuICogVGhpcyBob29rIHBpcGVzIGEgZGF0YSBhbmQgd2hlbiBpdCBpcyBzZXQgdG8gYSBmYWxzeSB2YWx1ZSAoXCJcIiwgdW5kZWZpbmVkLCBudWxsLCAwKSwgXG4gKiBpdCByZXR1cm5zIHRoZSBwcmV2aW91cyB2YWxpZCB2YWx1ZVxuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiB1c2VGcmVlemU8VD4oc29tZXRoaW5nOiBUKSB7XG4gICAgY29uc3QgY3VyckNoaWxkT3JQcmV2ID0gdXNlUmVmPFQ+KHVuZGVmaW5lZCk7XG4gICAgY3VyckNoaWxkT3JQcmV2LmN1cnJlbnQgPSBzb21ldGhpbmcgfHwgY3VyckNoaWxkT3JQcmV2LmN1cnJlbnQ7XG4gICAgcmV0dXJuIGN1cnJDaGlsZE9yUHJldi5jdXJyZW50IHx8IG51bGw7XG59Il0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLE9BQUE7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNlLFNBQVNDLFNBQVNBLENBQUlDLFNBQVksRUFBRTtFQUMvQyxNQUFNQyxlQUFlLEdBQUcsSUFBQUMsYUFBTSxFQUFJQyxTQUFTLENBQUM7RUFDNUNGLGVBQWUsQ0FBQ0csT0FBTyxHQUFHSixTQUFTLElBQUlDLGVBQWUsQ0FBQ0csT0FBTztFQUM5RCxPQUFPSCxlQUFlLENBQUNHLE9BQU8sSUFBSSxJQUFJO0FBQzFDIn0=
17
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJyZXF1aXJlIiwidXNlRnJlZXplIiwic29tZXRoaW5nIiwiY3VyckNoaWxkT3JQcmV2IiwidXNlUmVmIiwidW5kZWZpbmVkIiwiY3VycmVudCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ob29rcy91c2VGcmVlemUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlUmVmIH0gZnJvbSBcInJlYWN0XCI7XG5cbi8qKlxuICogVGhpcyBob29rIHBpcGVzIGEgZGF0YSBhbmQgd2hlbiBpdCBpcyBzZXQgdG8gYSBmYWxzeSB2YWx1ZSAoXCJcIiwgdW5kZWZpbmVkLCBudWxsLCAwKSxcbiAqIGl0IHJldHVybnMgdGhlIHByZXZpb3VzIHZhbGlkIHZhbHVlXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIHVzZUZyZWV6ZTxUPihzb21ldGhpbmc6IFQpIHtcbiAgY29uc3QgY3VyckNoaWxkT3JQcmV2ID0gdXNlUmVmPFQ+KHVuZGVmaW5lZCk7XG4gIGN1cnJDaGlsZE9yUHJldi5jdXJyZW50ID1cbiAgICBzb21ldGhpbmcgPT09IHVuZGVmaW5lZCA/IGN1cnJDaGlsZE9yUHJldi5jdXJyZW50IDogc29tZXRoaW5nO1xuICByZXR1cm4gY3VyckNoaWxkT3JQcmV2LmN1cnJlbnQ7XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsT0FBQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ2UsU0FBU0MsU0FBU0EsQ0FBSUMsU0FBWSxFQUFFO0VBQ2pELE1BQU1DLGVBQWUsR0FBRyxJQUFBQyxhQUFNLEVBQUlDLFNBQVMsQ0FBQztFQUM1Q0YsZUFBZSxDQUFDRyxPQUFPLEdBQ3JCSixTQUFTLEtBQUtHLFNBQVMsR0FBR0YsZUFBZSxDQUFDRyxPQUFPLEdBQUdKLFNBQVM7RUFDL0QsT0FBT0MsZUFBZSxDQUFDRyxPQUFPO0FBQ2hDIn0=
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@onepercentio/one-ui",
3
- "version": "0.28.4",
3
+ "version": "0.28.6",
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>",