@onepercentio/one-ui 0.26.2 → 0.26.4

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.
@@ -66,6 +66,7 @@ $duration: 1s;
66
66
  transition: max-height math.div($duration, 2) $duration * 0.2;
67
67
  min-height: initial;
68
68
  align-items: flex-start !important;
69
+ flex-shrink: 0;
69
70
  > * {
70
71
  justify-content: flex-start !important;
71
72
  }
@@ -50,7 +50,7 @@ function Select(_ref) {
50
50
  (0, _react.useLayoutEffect)(() => {
51
51
  if (open) setFilterTerm("");
52
52
  }, [open]);
53
- const dropdownClassNames = _drop ? {
53
+ const selectClasses = _drop ? {
54
54
  dropdown: _drop
55
55
  } : (0, _OneUIProvider.useOneUIConfig)("component.select.className", {});
56
56
  (0, _react.useEffect)(() => {
@@ -64,7 +64,7 @@ function Select(_ref) {
64
64
  }, [open]);
65
65
  return /*#__PURE__*/_react.default.createElement(_Collapsable.default, {
66
66
  title: /*#__PURE__*/_react.default.createElement(_Input.default, _extends({}, otherProps, {
67
- className: `${_SelectModule.default.input} ${!items.length ? _SelectModule.default.empty : ""}`,
67
+ className: `${_SelectModule.default.input} ${selectClasses.input} ${!items.length ? _SelectModule.default.empty : ""}`,
68
68
  value: _selected ? "labelStr" in _selected ? _selected.labelStr : _selected.label : label || "",
69
69
  disabled: true,
70
70
  Icon: /*#__PURE__*/_react.default.createElement("div", {
@@ -80,7 +80,7 @@ function Select(_ref) {
80
80
  if (items.length) setOpen(open);
81
81
  },
82
82
  className: `${otherProps.disabled ? "disabled" : ""} ${rootClassName}`,
83
- contentClassName: `${_SelectModule.default.optionsContainer} ${dropdownClassNames.dropdown}`,
83
+ contentClassName: `${_SelectModule.default.optionsContainer} ${selectClasses.dropdown}`,
84
84
  alignTo: alignTo,
85
85
  ref: collapsableRef,
86
86
  anchorTo: _AnchoredTooltip.AnchoredTooltipAnchor.BOTTOM
@@ -110,10 +110,10 @@ function Select(_ref) {
110
110
  })), filteredItems.map(i => /*#__PURE__*/_react.default.createElement(_Text.default, _extends({
111
111
  type: "caption",
112
112
  key: i.value,
113
- className: `${i === _selected ? `${_SelectModule.default.selected} ${dropdownClassNames.selectedItem}` : ""} ${dropdownClassNames.item || ""}`,
113
+ className: `${i === _selected ? `${_SelectModule.default.selected} ${selectClasses.selectedItem}` : ""} ${selectClasses.item || ""}`,
114
114
  onClick: () => onClick(i)
115
115
  }, i), i.label))));
116
116
  }
117
117
  var _default = Select;
118
118
  exports.default = _default;
119
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Collapsable","_interopRequireDefault","_Text","_SelectModule","_Input","_Loader","_OneUIProvider","_AnchoredTooltip","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","Select","_ref","items","selected","label","onClick","loading","rootClassName","dropdownClassName","_drop","alignTo","AnchoredTooltipAlignment","CENTER","filter","otherProps","StateIndicator","useOneUIContext","component","select","collapsableRef","useRef","_selected","useMemo","find","a","value","open","setOpen","useState","filterTerm","setFilterTerm","filteredItems","item","useEffect","current","redimension","useLayoutEffect","dropdownClassNames","dropdown","useOneUIConfig","close","window","addEventListener","removeEventListener","createElement","title","className","Styles","input","empty","labelStr","disabled","Icon","indicator","id","undefined","mode","onToggleOpen","contentClassName","optionsContainer","ref","anchorTo","AnchoredTooltipAnchor","BOTTOM","e","stopPropagation","searchInput","onChange","_ref2","decoration","containerProps","border","map","type","selectedItem","_default","exports"],"sources":["../../../src/components/Select/Select.tsx"],"sourcesContent":["import React, {\n  ComponentProps,\n  DetailedHTMLProps,\n  ElementRef,\n  HTMLAttributes,\n  ReactElement,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport Collapsable from \"../Collapsable\";\nimport Text from \"../Text\";\nimport Styles from \"./Select.module.scss\";\nimport Input from \"../Input\";\nimport Loader from \"../Loader\";\nimport {\n  OneUIContextSpecs,\n  useOneUIConfig,\n  useOneUIContext,\n} from \"../../context/OneUIProvider\";\nimport {\n  AnchoredTooltipAlignment,\n  AnchoredTooltipAnchor,\n} from \"../AnchoredTooltip/AnchoredTooltip\";\n\nexport type SelectItem = (\n  | {\n      label: string;\n      value: string;\n    }\n  | {\n      label: ReactElement;\n      labelStr: string;\n      value: string;\n    }\n) &\n  Omit<DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLElement>, \"ref\" | \"color\">;\n\n/**\n * A dropdown select\n **/\nfunction Select<I extends SelectItem>({\n  items,\n  selected,\n  label,\n  onClick,\n  loading,\n  rootClassName = \"\",\n  dropdownClassName: _drop = \"\",\n  alignTo = AnchoredTooltipAlignment.CENTER,\n  filter,\n  ...otherProps\n}: {\n  loading?: boolean;\n  items: Readonly<I[]>;\n  onClick: (i: I) => void;\n  rootClassName?: string;\n  dropdownClassName?: string;\n  alignTo?: AnchoredTooltipAlignment;\n  filter?: (item: I, term: string) => boolean;\n} & (\n  | {\n      selected?: I[\"value\"];\n      label: string;\n    }\n  | {\n      selected: I[\"value\"];\n      label?: string;\n    }\n) &\n  Omit<ComponentProps<typeof Input>, \"selected\" | \"onClick\">) {\n  const { StateIndicator } = useOneUIContext().component.select;\n  const collapsableRef = useRef<ElementRef<typeof Collapsable>>(null);\n\n  const _selected = useMemo(() => {\n    return items.find((a) => a.value === selected);\n  }, [selected, items]);\n\n  const [open, setOpen] = useState(false);\n  const [filterTerm, setFilterTerm] = useState(\"\");\n\n  const filteredItems = useMemo(() => {\n    if (filter && filterTerm)\n      return items.filter((item) => filter(item, filterTerm));\n    else return items;\n  }, [filterTerm, items]);\n\n  useEffect(() => {\n    collapsableRef.current!.redimension();\n  }, [filteredItems.length]);\n\n  useLayoutEffect(() => {\n    if (open) setFilterTerm(\"\");\n  }, [open]);\n\n  const dropdownClassNames = _drop\n    ? ({\n        dropdown: _drop,\n      } as NonNullable<OneUIContextSpecs[\"component\"][\"select\"][\"className\"]>)\n    : useOneUIConfig(\"component.select.className\", {});\n\n  useEffect(() => {\n    if (open) {\n      const close = () => {\n        setOpen(false);\n      };\n      window.addEventListener(\"click\", close);\n      return () => window.removeEventListener(\"click\", close);\n    }\n  }, [open]);\n\n  return (\n    <Collapsable\n      title={\n        <Input\n          {...otherProps}\n          className={`${Styles.input} ${!items.length ? Styles.empty : \"\"}`}\n          value={\n            _selected\n              ? \"labelStr\" in _selected\n                ? _selected.labelStr\n                : _selected.label\n              : label || \"\"\n          }\n          disabled\n          Icon={\n            <div className={`${Styles.indicator}`}>\n              {loading ? <Loader /> : <StateIndicator open={!!open} />}\n            </div>\n          }\n        />\n      }\n      id={undefined}\n      mode=\"float\"\n      open={open}\n      onToggleOpen={(open) => {\n        if (items.length) setOpen(open);\n      }}\n      className={`${otherProps.disabled ? \"disabled\" : \"\"} ${rootClassName}`}\n      contentClassName={`${Styles.optionsContainer} ${dropdownClassNames.dropdown}`}\n      alignTo={alignTo}\n      ref={collapsableRef}\n      anchorTo={AnchoredTooltipAnchor.BOTTOM}\n    >\n      <div\n        className={Styles.items}\n        onClick={(e) => {\n          e.stopPropagation();\n          setOpen(false);\n        }}\n      >\n        {filter && (\n          <div className={Styles.searchInput}>\n            <Input\n              onChange={({ target: { value } }) => setFilterTerm(value)}\n              decoration={<span>🔎&nbsp;</span>}\n              containerProps={{\n                onClick: (e) => e.stopPropagation(),\n              }}\n              border={false}\n              value={filterTerm}\n            />\n          </div>\n        )}\n        {filteredItems.map((i) => (\n          <Text\n            type=\"caption\"\n            key={i.value}\n            className={`${\n              i === _selected\n                ? `${Styles.selected} ${dropdownClassNames.selectedItem}`\n                : \"\"\n            } ${dropdownClassNames.item || \"\"}`}\n            onClick={() => onClick(i)}\n            {...i}\n          >\n            {i.label}\n          </Text>\n        ))}\n      </div>\n    </Collapsable>\n  );\n}\n\nexport default Select;\n"],"mappings":"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"}
119
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Collapsable","_interopRequireDefault","_Text","_SelectModule","_Input","_Loader","_OneUIProvider","_AnchoredTooltip","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","Select","_ref","items","selected","label","onClick","loading","rootClassName","dropdownClassName","_drop","alignTo","AnchoredTooltipAlignment","CENTER","filter","otherProps","StateIndicator","useOneUIContext","component","select","collapsableRef","useRef","_selected","useMemo","find","a","value","open","setOpen","useState","filterTerm","setFilterTerm","filteredItems","item","useEffect","current","redimension","useLayoutEffect","selectClasses","dropdown","useOneUIConfig","close","window","addEventListener","removeEventListener","createElement","title","className","Styles","input","empty","labelStr","disabled","Icon","indicator","id","undefined","mode","onToggleOpen","contentClassName","optionsContainer","ref","anchorTo","AnchoredTooltipAnchor","BOTTOM","e","stopPropagation","searchInput","onChange","_ref2","decoration","containerProps","border","map","type","selectedItem","_default","exports"],"sources":["../../../src/components/Select/Select.tsx"],"sourcesContent":["import React, {\n  ComponentProps,\n  DetailedHTMLProps,\n  ElementRef,\n  HTMLAttributes,\n  ReactElement,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport Collapsable from \"../Collapsable\";\nimport Text from \"../Text\";\nimport Styles from \"./Select.module.scss\";\nimport Input from \"../Input\";\nimport Loader from \"../Loader\";\nimport {\n  OneUIContextSpecs,\n  useOneUIConfig,\n  useOneUIContext,\n} from \"../../context/OneUIProvider\";\nimport {\n  AnchoredTooltipAlignment,\n  AnchoredTooltipAnchor,\n} from \"../AnchoredTooltip/AnchoredTooltip\";\n\nexport type SelectItem = (\n  | {\n      label: string;\n      value: string;\n    }\n  | {\n      label: ReactElement;\n      labelStr: string;\n      value: string;\n    }\n) &\n  Omit<\n    DetailedHTMLProps<HTMLAttributes<HTMLDivElement>, HTMLElement>,\n    \"ref\" | \"color\"\n  >;\n\n/**\n * A dropdown select\n **/\nfunction Select<I extends SelectItem>({\n  items,\n  selected,\n  label,\n  onClick,\n  loading,\n  rootClassName = \"\",\n  dropdownClassName: _drop = \"\",\n  alignTo = AnchoredTooltipAlignment.CENTER,\n  filter,\n  ...otherProps\n}: {\n  loading?: boolean;\n  items: Readonly<I[]>;\n  onClick: (i: I) => void;\n  rootClassName?: string;\n  dropdownClassName?: string;\n  alignTo?: AnchoredTooltipAlignment;\n  filter?: (item: I, term: string) => boolean;\n} & (\n  | {\n      selected?: I[\"value\"];\n      label: string;\n    }\n  | {\n      selected: I[\"value\"];\n      label?: string;\n    }\n) &\n  Omit<ComponentProps<typeof Input>, \"selected\" | \"onClick\">) {\n  const { StateIndicator } = useOneUIContext().component.select;\n  const collapsableRef = useRef<ElementRef<typeof Collapsable>>(null);\n\n  const _selected = useMemo(() => {\n    return items.find((a) => a.value === selected);\n  }, [selected, items]);\n\n  const [open, setOpen] = useState(false);\n  const [filterTerm, setFilterTerm] = useState(\"\");\n\n  const filteredItems = useMemo(() => {\n    if (filter && filterTerm)\n      return items.filter((item) => filter(item, filterTerm));\n    else return items;\n  }, [filterTerm, items]);\n\n  useEffect(() => {\n    collapsableRef.current!.redimension();\n  }, [filteredItems.length]);\n\n  useLayoutEffect(() => {\n    if (open) setFilterTerm(\"\");\n  }, [open]);\n\n  const selectClasses = _drop\n    ? ({\n        dropdown: _drop,\n      } as NonNullable<OneUIContextSpecs[\"component\"][\"select\"][\"className\"]>)\n    : useOneUIConfig(\"component.select.className\", {});\n\n  useEffect(() => {\n    if (open) {\n      const close = () => {\n        setOpen(false);\n      };\n      window.addEventListener(\"click\", close);\n      return () => window.removeEventListener(\"click\", close);\n    }\n  }, [open]);\n\n  return (\n    <Collapsable\n      title={\n        <Input\n          {...otherProps}\n          className={`${Styles.input} ${selectClasses.input} ${\n            !items.length ? Styles.empty : \"\"\n          }`}\n          value={\n            _selected\n              ? \"labelStr\" in _selected\n                ? _selected.labelStr\n                : _selected.label\n              : label || \"\"\n          }\n          disabled\n          Icon={\n            <div className={`${Styles.indicator}`}>\n              {loading ? <Loader /> : <StateIndicator open={!!open} />}\n            </div>\n          }\n        />\n      }\n      id={undefined}\n      mode=\"float\"\n      open={open}\n      onToggleOpen={(open) => {\n        if (items.length) setOpen(open);\n      }}\n      className={`${otherProps.disabled ? \"disabled\" : \"\"} ${rootClassName}`}\n      contentClassName={`${Styles.optionsContainer} ${selectClasses.dropdown}`}\n      alignTo={alignTo}\n      ref={collapsableRef}\n      anchorTo={AnchoredTooltipAnchor.BOTTOM}\n    >\n      <div\n        className={Styles.items}\n        onClick={(e) => {\n          e.stopPropagation();\n          setOpen(false);\n        }}\n      >\n        {filter && (\n          <div className={Styles.searchInput}>\n            <Input\n              onChange={({ target: { value } }) => setFilterTerm(value)}\n              decoration={<span>🔎&nbsp;</span>}\n              containerProps={{\n                onClick: (e) => e.stopPropagation(),\n              }}\n              border={false}\n              value={filterTerm}\n            />\n          </div>\n        )}\n        {filteredItems.map((i) => (\n          <Text\n            type=\"caption\"\n            key={i.value}\n            className={`${\n              i === _selected\n                ? `${Styles.selected} ${selectClasses.selectedItem}`\n                : \"\"\n            } ${selectClasses.item || \"\"}`}\n            onClick={() => onClick(i)}\n            {...i}\n          >\n            {i.label}\n          </Text>\n        ))}\n      </div>\n    </Collapsable>\n  );\n}\n\nexport default Select;\n"],"mappings":"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"}
@@ -89,6 +89,7 @@ export type OneUIContextSpecs = {
89
89
  dropdown?: string;
90
90
  item?: string;
91
91
  selectedItem?: string;
92
+ input?: string;
92
93
  };
93
94
  };
94
95
  header: {
@@ -117,4 +117,4 @@ function useCurrentImageScale() {
117
117
  const context = (0, _react.useContext)(Context);
118
118
  return context.state.imageScale;
119
119
  }
120
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_get","_interopRequireDefault","require","_merge","_cloneDeep","_react","_interopRequireWildcard","_useAdaptiveImage","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Context","createContext","OneUIProvider","_ref","children","config","prevCtx","useContext","scale","useAdaptiveImage","mergedConfig","useMemo","merge","clone","state","imageScale","createElement","Provider","value","_default","exports","pathToJson","path","exampleConfig","arguments","length","undefined","split","slice","replace","concat","reduce","result","idx","arr","r","k","ErrorWrapper","originalObject","Proxy","_target","Symbol","toPrimitive","filter","Boolean","join","e","pathJson","Error","JSON","stringify","useOneUIContext","context","process","env","NODE_ENV","useOneUIView","oneuiConfigPath","componentName","providedValue","useOneUIConfig","prop","defaultValue","val","endsWith","useCurrentImageScale"],"sources":["../../src/context/OneUIProvider.tsx"],"sourcesContent":["import get from \"lodash/get\";\nimport merge from \"lodash/merge\";\nimport clone from \"lodash/cloneDeep\";\nimport { Get } from \"type-fest\";\nimport React, { ComponentProps, ReactElement, ReactNode, useMemo } from \"react\";\nimport { createContext, PropsWithChildren, useContext } from \"react\";\nimport { FieldPath } from \"../type-utils\";\nimport useAdaptiveImage from \"../hooks/ui/useAdaptiveImage\";\nimport { ImageScales } from \"@muritavo/webpack-microfrontend-scripts/bin/types/ImageScales\";\nimport Button from \"../components/Button\";\nimport CheckBox from \"../components/CheckBox\";\nimport Radio from \"../components/Radio/Radio\";\nimport { FileInputViewProps } from \"../components/FileInput/View/View.types\";\nimport {\n  AnswerByField,\n  GenericFormFieldProps,\n} from \"../components/Form/v2/FormField/FormField.types\";\nimport { UploadTask } from \"firebase/storage\";\nimport { BaseQuestion } from \"../components/Form/v2/Form.types\";\n\ntype DeepPartial<T> = {\n  [P in keyof T]?: NonNullable<T[P]> extends Function\n    ? T[P]\n    : DeepPartial<T[P]>;\n};\n\nexport type OneUIContextSpecs = {\n  component: {\n    spacing: {\n      variants: {\n        [k in OnepercentUtility.UIElements.SpacingVariants]: string;\n      };\n    };\n    collapsable: {\n      className: string;\n    };\n    form: {\n      titleVariant: OnepercentUtility.UIElements.TextVariants;\n      labelVariant: OnepercentUtility.UIElements.TextVariants;\n      /** Label shown when a field is optional */\n      optionalLabel: string;\n\n      /** Label shown when a required field was not provided */\n      requiredLabel: string;\n\n      onFileUpload(questionId: string, file: File): UploadTask;\n\n      extensions?: {\n        [K in OnepercentUtility.UIElements.FormExtension[\"fields\"][\"type\"]]: {\n          Input: (props: GenericFormFieldProps<K>) => ReactElement;\n          validator: (\n            answer: AnswerByField<{ type: K }>,\n            question: BaseQuestion &\n              (OnepercentUtility.UIElements.FormExtension[\"fields\"] & {\n                type: K;\n              })\n          ) => {\n            isValid: boolean;\n            error?: string;\n          };\n        };\n      };\n    };\n    text?: {\n      className?: {\n        [k in React.ComponentProps<\n          typeof import(\"../components/Text\")[\"default\"]\n        >[\"type\"]]?: string;\n      };\n      htmlTag?: {\n        [k in React.ComponentProps<\n          typeof import(\"../components/Text\")[\"default\"]\n        >[\"type\"]]?: \"p\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\";\n      };\n    };\n    button?: {\n      className?: {\n        [k in NonNullable<\n          React.ComponentProps<\n            typeof import(\"../components/Button\")[\"default\"]\n          >[\"variant\"]\n        >]?: string;\n      };\n      Component?: (props: ComponentProps<typeof Button>) => ReactElement;\n    };\n    input: {\n      className: string;\n      border: boolean;\n    };\n    fileInput: {\n      View: (props: FileInputViewProps) => ReactElement;\n    };\n    passwordInput: {\n      iconSrc: {\n        passwordHidden: string;\n        passwordVisible: string;\n      };\n    };\n    asyncWrapper: {\n      LoadingComponent?: () => JSX.Element;\n      messages: {\n        error: {\n          title: string;\n          retryBtn: string;\n        };\n      };\n    };\n    select: {\n      StateIndicator: (props: { open: boolean }) => JSX.Element;\n      className?: {\n        dropdown?: string;\n        item?: string;\n        selectedItem?: string;\n      };\n    };\n    header: {\n      LogoImage: () => JSX.Element;\n      MoreOptions: ({ open }: { open: boolean }) => JSX.Element;\n    };\n    table: {\n      controls: {\n        PrevPage: ({ disabled }: { disabled: boolean }) => JSX.Element;\n        NextPage: ({ disabled }: { disabled: boolean }) => JSX.Element;\n      };\n    };\n    tooltip: {\n      className?: string;\n    };\n    adaptiveDialog: {\n      dialogClassName: string;\n      backdropClassName: string;\n      variant: {\n        [k in OnepercentUtility.UIElements.AdaptiveDialogVariants]: string;\n      };\n    };\n    adaptiveSidebar: {\n      className: string;\n      controlClassName: string;\n    };\n    checkbox: {\n      Component?: (props: ComponentProps<typeof CheckBox>) => ReactElement;\n    };\n    radio: {\n      Component?: (props: ComponentProps<typeof Radio>) => ReactElement;\n    };\n  };\n  hook: {\n    ui: {\n      usePaginationControls: {\n        LeftControl: () => ReactElement;\n        RightControl: () => ReactElement;\n        className?: string;\n      };\n    };\n  };\n  state: {\n    imageScale: ImageScales;\n  };\n};\n\ntype ContextConfigSpecs = DeepPartial<OneUIContextSpecs>;\n\nconst Context = createContext<ContextConfigSpecs>(null as any);\n\nfunction OneUIProvider({\n  children,\n  config,\n}: PropsWithChildren<{ config: ContextConfigSpecs }>) {\n  const prevCtx = useContext(Context);\n  const scale = useAdaptiveImage();\n  const mergedConfig = useMemo(() => {\n    return merge(clone(prevCtx), config, {\n      state: {\n        imageScale: scale,\n      },\n    });\n  }, [prevCtx, config, scale]);\n\n  return <Context.Provider value={mergedConfig}>{children}</Context.Provider>;\n}\n\nexport default OneUIProvider\n\nfunction pathToJson(\n  path: string,\n  key?: string | Symbol,\n  exampleConfig = \"THE_MISSING_CONFIG\"\n) {\n  if (!key) {\n    key = path.split(\".\").slice(-1)[0];\n    path = path.replace(`.${key}`, \"\");\n  }\n\n  return path\n    .split(\".\")\n    .concat(key as string)\n    .reduce((result, key, idx, arr) => {\n      (arr.slice(0, idx).reduce((r, k) => (r as any)[k], result) as any)[key] =\n        idx === arr.length - 1 ? exampleConfig : {};\n      return result;\n    }, {});\n}\n\nfunction ErrorWrapper(\n  originalObject: any,\n  path: string = \"config\"\n): typeof Proxy {\n  return new Proxy(\n    typeof originalObject !== \"object\" ? {} : originalObject || {},\n    {\n      get(_target, key) {\n        if (key === Symbol.toPrimitive) {\n          return () => _target[key];\n        }\n        try {\n          const value = originalObject[key];\n          if (typeof value === \"undefined\") return undefined;\n          if (typeof value === \"object\")\n            return ErrorWrapper(value, [path, key].filter(Boolean).join(\".\"));\n          return value;\n        } catch (e) {\n          const pathJson = pathToJson(path, key);\n          throw new Error(\n            `A component is using the UI config ${[path, key].join(\".\")}.\n\nPlease define it using:\nimport OneUIProvider from \"@onepercent/one-ui/dist/context/OneUIProvider\";\n\n  ...\n${`<OneUIProvider config={${JSON.stringify(pathJson, null, 4)}}>\n...\n</OneUIProvider>`.replace(/[ ]/g, \"-\")}`\n          );\n        }\n      },\n    }\n  );\n}\n\nexport function useOneUIContext() {\n  const context = useContext(Context);\n\n  if (process.env.NODE_ENV === \"development\")\n    return ErrorWrapper(context) as unknown as OneUIContextSpecs;\n\n  return context as OneUIContextSpecs;\n}\n\nexport function useOneUIView<P extends FieldPath<OneUIContextSpecs>>(\n  oneuiConfigPath: P,\n  componentName: string\n) {\n  const providedValue = useOneUIConfig(oneuiConfigPath);\n  if (!providedValue) {\n    throw new Error(`The component ${componentName} requires a view to be set on OneUI initialization\n\nViews ready for use with this component shall be available at:\nimport SomeView from \"@onepercentio/one-ui/dist/components/${componentName}/View/SomeView\";\n    \nPlease define it using:\nimport OneUIProvider from \"@onepercentio/one-ui/dist/context/OneUIProvider\";\n\n  ...\n${`<OneUIProvider config={${JSON.stringify(\n  pathToJson(oneuiConfigPath, undefined, \"SomeView\"),\n  null,\n  4\n)}}>\n...\n</OneUIProvider>`.replace(/[ ]/g, \"-\")}`);\n  }\n\n  return providedValue;\n}\n\nexport function useOneUIConfig<\n  P extends FieldPath<OneUIContextSpecs>,\n  T extends Get<OneUIContextSpecs, P>\n>(prop: P, defaultValue?: T): NonNullable<Get<OneUIContextSpecs, P>> {\n  const context = useContext(Context);\n  if (process.env.NODE_ENV === \"development\") {\n    const val = useMemo(() => {\n      return get(context, prop);\n    }, [context, prop]);\n    if (\n      typeof val === \"string\" ||\n      typeof val === \"function\" ||\n      prop.endsWith(\".Component\") ||\n      prop.endsWith(\".View\")\n    )\n      return (val as any) || defaultValue;\n\n    if (typeof val === \"boolean\") return val as any;\n    return ErrorWrapper(val || defaultValue) as unknown as NonNullable<T>;\n  }\n  const value = useMemo(() => {\n    return get(context, prop);\n  }, [context, prop]);\n  return value || defaultValue;\n}\n\nexport function useCurrentImageScale() {\n  const context = useContext(Context);\n\n  return context.state!.imageScale!;\n}\n"],"mappings":";;;;;;;;;;AAAA,IAAAA,IAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,UAAA,GAAAH,sBAAA,CAAAC,OAAA;AAEA,IAAAG,MAAA,GAAAC,uBAAA,CAAAJ,OAAA;AAGA,IAAAK,iBAAA,GAAAN,sBAAA,CAAAC,OAAA;AAA4D,SAAAM,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAH,wBAAAO,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,oBAAAA,GAAA,wBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAG,KAAA,GAAAR,wBAAA,CAAAC,WAAA,OAAAO,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAJ,GAAA,YAAAG,KAAA,CAAAE,GAAA,CAAAL,GAAA,SAAAM,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAX,GAAA,QAAAW,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAd,GAAA,EAAAW,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAV,GAAA,EAAAW,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAX,GAAA,CAAAW,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAF,GAAA,MAAAG,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAhB,GAAA,EAAAM,MAAA,YAAAA,MAAA;AAAA,SAAAlB,uBAAAY,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AA2J5D,MAAMiB,OAAO,gBAAG,IAAAC,oBAAa,EAAqB,IAAW,CAAC;AAE9D,SAASC,aAAaA,CAAAC,IAAA,EAGgC;EAAA,IAH/B;IACrBC,QAAQ;IACRC;EACiD,CAAC,GAAAF,IAAA;EAClD,MAAMG,OAAO,GAAG,IAAAC,iBAAU,EAACP,OAAO,CAAC;EACnC,MAAMQ,KAAK,GAAG,IAAAC,yBAAgB,EAAC,CAAC;EAChC,MAAMC,YAAY,GAAG,IAAAC,cAAO,EAAC,MAAM;IACjC,OAAO,IAAAC,cAAK,EAAC,IAAAC,kBAAK,EAACP,OAAO,CAAC,EAAED,MAAM,EAAE;MACnCS,KAAK,EAAE;QACLC,UAAU,EAAEP;MACd;IACF,CAAC,CAAC;EACJ,CAAC,EAAE,CAACF,OAAO,EAAED,MAAM,EAAEG,KAAK,CAAC,CAAC;EAE5B,oBAAOjC,MAAA,CAAAU,OAAA,CAAA+B,aAAA,CAAChB,OAAO,CAACiB,QAAQ;IAACC,KAAK,EAAER;EAAa,GAAEN,QAA2B,CAAC;AAC7E;AAAC,IAAAe,QAAA,GAEcjB,aAAa;AAAAkB,OAAA,CAAAnC,OAAA,GAAAkC,QAAA;AAE5B,SAASE,UAAUA,CACjBC,IAAY,EACZ5B,GAAqB,EAErB;EAAA,IADA6B,aAAa,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,oBAAoB;EAEpC,IAAI,CAAC9B,GAAG,EAAE;IACRA,GAAG,GAAG4B,IAAI,CAACK,KAAK,CAAC,GAAG,CAAC,CAACC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAClCN,IAAI,GAAGA,IAAI,CAACO,OAAO,CAAE,IAAGnC,GAAI,EAAC,EAAE,EAAE,CAAC;EACpC;EAEA,OAAO4B,IAAI,CACRK,KAAK,CAAC,GAAG,CAAC,CACVG,MAAM,CAACpC,GAAa,CAAC,CACrBqC,MAAM,CAAC,CAACC,MAAM,EAAEtC,GAAG,EAAEuC,GAAG,EAAEC,GAAG,KAAK;IAChCA,GAAG,CAACN,KAAK,CAAC,CAAC,EAAEK,GAAG,CAAC,CAACF,MAAM,CAAC,CAACI,CAAC,EAAEC,CAAC,KAAMD,CAAC,CAASC,CAAC,CAAC,EAAEJ,MAAM,CAAC,CAAStC,GAAG,CAAC,GACrEuC,GAAG,KAAKC,GAAG,CAACT,MAAM,GAAG,CAAC,GAAGF,aAAa,GAAG,CAAC,CAAC;IAC7C,OAAOS,MAAM;EACf,CAAC,EAAE,CAAC,CAAC,CAAC;AACV;AAEA,SAASK,YAAYA,CACnBC,cAAmB,EAEL;EAAA,IADdhB,IAAY,GAAAE,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,QAAQ;EAEvB,OAAO,IAAIe,KAAK,CACd,OAAOD,cAAc,KAAK,QAAQ,GAAG,CAAC,CAAC,GAAGA,cAAc,IAAI,CAAC,CAAC,EAC9D;IACElD,GAAGA,CAACoD,OAAO,EAAE9C,GAAG,EAAE;MAChB,IAAIA,GAAG,KAAK+C,MAAM,CAACC,WAAW,EAAE;QAC9B,OAAO,MAAMF,OAAO,CAAC9C,GAAG,CAAC;MAC3B;MACA,IAAI;QACF,MAAMwB,KAAK,GAAGoB,cAAc,CAAC5C,GAAG,CAAC;QACjC,IAAI,OAAOwB,KAAK,KAAK,WAAW,EAAE,OAAOQ,SAAS;QAClD,IAAI,OAAOR,KAAK,KAAK,QAAQ,EAC3B,OAAOmB,YAAY,CAACnB,KAAK,EAAE,CAACI,IAAI,EAAE5B,GAAG,CAAC,CAACiD,MAAM,CAACC,OAAO,CAAC,CAACC,IAAI,CAAC,GAAG,CAAC,CAAC;QACnE,OAAO3B,KAAK;MACd,CAAC,CAAC,OAAO4B,CAAC,EAAE;QACV,MAAMC,QAAQ,GAAG1B,UAAU,CAACC,IAAI,EAAE5B,GAAG,CAAC;QACtC,MAAM,IAAIsD,KAAK,CACZ,sCAAqC,CAAC1B,IAAI,EAAE5B,GAAG,CAAC,CAACmD,IAAI,CAAC,GAAG,CAAE;AACxE;AACA;AACA;AACA;AACA;AACA,EAAG,0BAAyBI,IAAI,CAACC,SAAS,CAACH,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAE;AAC9D;AACA,iBAAiB,CAAClB,OAAO,CAAC,MAAM,EAAE,GAAG,CAAE,EAC7B,CAAC;MACH;IACF;EACF,CACF,CAAC;AACH;AAEO,SAASsB,eAAeA,CAAA,EAAG;EAChC,MAAMC,OAAO,GAAG,IAAA7C,iBAAU,EAACP,OAAO,CAAC;EAEnC,IAAIqD,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,aAAa,EACxC,OAAOlB,YAAY,CAACe,OAAO,CAAC;EAE9B,OAAOA,OAAO;AAChB;AAEO,SAASI,YAAYA,CAC1BC,eAAkB,EAClBC,aAAqB,EACrB;EACA,MAAMC,aAAa,GAAGC,cAAc,CAACH,eAAe,CAAC;EACrD,IAAI,CAACE,aAAa,EAAE;IAClB,MAAM,IAAIX,KAAK,CAAE,iBAAgBU,aAAc;AACnD;AACA;AACA,6DAA6DA,aAAc;AAC3E;AACA;AACA;AACA;AACA;AACA,EAAG,0BAAyBT,IAAI,CAACC,SAAS,CACxC7B,UAAU,CAACoC,eAAe,EAAE/B,SAAS,EAAE,UAAU,CAAC,EAClD,IAAI,EACJ,CACF,CAAE;AACF;AACA,iBAAiB,CAACG,OAAO,CAAC,MAAM,EAAE,GAAG,CAAE,EAAC,CAAC;EACvC;EAEA,OAAO8B,aAAa;AACtB;AAEO,SAASC,cAAcA,CAG5BC,IAAO,EAAEC,YAAgB,EAA0C;EACnE,MAAMV,OAAO,GAAG,IAAA7C,iBAAU,EAACP,OAAO,CAAC;EACnC,IAAIqD,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,aAAa,EAAE;IAC1C,MAAMQ,GAAG,GAAG,IAAApD,cAAO,EAAC,MAAM;MACxB,OAAO,IAAAvB,YAAG,EAACgE,OAAO,EAAES,IAAI,CAAC;IAC3B,CAAC,EAAE,CAACT,OAAO,EAAES,IAAI,CAAC,CAAC;IACnB,IACE,OAAOE,GAAG,KAAK,QAAQ,IACvB,OAAOA,GAAG,KAAK,UAAU,IACzBF,IAAI,CAACG,QAAQ,CAAC,YAAY,CAAC,IAC3BH,IAAI,CAACG,QAAQ,CAAC,OAAO,CAAC,EAEtB,OAAQD,GAAG,IAAYD,YAAY;IAErC,IAAI,OAAOC,GAAG,KAAK,SAAS,EAAE,OAAOA,GAAG;IACxC,OAAO1B,YAAY,CAAC0B,GAAG,IAAID,YAAY,CAAC;EAC1C;EACA,MAAM5C,KAAK,GAAG,IAAAP,cAAO,EAAC,MAAM;IAC1B,OAAO,IAAAvB,YAAG,EAACgE,OAAO,EAAES,IAAI,CAAC;EAC3B,CAAC,EAAE,CAACT,OAAO,EAAES,IAAI,CAAC,CAAC;EACnB,OAAO3C,KAAK,IAAI4C,YAAY;AAC9B;AAEO,SAASG,oBAAoBA,CAAA,EAAG;EACrC,MAAMb,OAAO,GAAG,IAAA7C,iBAAU,EAACP,OAAO,CAAC;EAEnC,OAAOoD,OAAO,CAACtC,KAAK,CAAEC,UAAU;AAClC"}
120
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_get","_interopRequireDefault","require","_merge","_cloneDeep","_react","_interopRequireWildcard","_useAdaptiveImage","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Context","createContext","OneUIProvider","_ref","children","config","prevCtx","useContext","scale","useAdaptiveImage","mergedConfig","useMemo","merge","clone","state","imageScale","createElement","Provider","value","_default","exports","pathToJson","path","exampleConfig","arguments","length","undefined","split","slice","replace","concat","reduce","result","idx","arr","r","k","ErrorWrapper","originalObject","Proxy","_target","Symbol","toPrimitive","filter","Boolean","join","e","pathJson","Error","JSON","stringify","useOneUIContext","context","process","env","NODE_ENV","useOneUIView","oneuiConfigPath","componentName","providedValue","useOneUIConfig","prop","defaultValue","val","endsWith","useCurrentImageScale"],"sources":["../../src/context/OneUIProvider.tsx"],"sourcesContent":["import get from \"lodash/get\";\nimport merge from \"lodash/merge\";\nimport clone from \"lodash/cloneDeep\";\nimport { Get } from \"type-fest\";\nimport React, { ComponentProps, ReactElement, ReactNode, useMemo } from \"react\";\nimport { createContext, PropsWithChildren, useContext } from \"react\";\nimport { FieldPath } from \"../type-utils\";\nimport useAdaptiveImage from \"../hooks/ui/useAdaptiveImage\";\nimport { ImageScales } from \"@muritavo/webpack-microfrontend-scripts/bin/types/ImageScales\";\nimport Button from \"../components/Button\";\nimport CheckBox from \"../components/CheckBox\";\nimport Radio from \"../components/Radio/Radio\";\nimport { FileInputViewProps } from \"../components/FileInput/View/View.types\";\nimport {\n  AnswerByField,\n  GenericFormFieldProps,\n} from \"../components/Form/v2/FormField/FormField.types\";\nimport { UploadTask } from \"firebase/storage\";\nimport { BaseQuestion } from \"../components/Form/v2/Form.types\";\n\ntype DeepPartial<T> = {\n  [P in keyof T]?: NonNullable<T[P]> extends Function\n    ? T[P]\n    : DeepPartial<T[P]>;\n};\n\nexport type OneUIContextSpecs = {\n  component: {\n    spacing: {\n      variants: {\n        [k in OnepercentUtility.UIElements.SpacingVariants]: string;\n      };\n    };\n    collapsable: {\n      className: string;\n    };\n    form: {\n      titleVariant: OnepercentUtility.UIElements.TextVariants;\n      labelVariant: OnepercentUtility.UIElements.TextVariants;\n      /** Label shown when a field is optional */\n      optionalLabel: string;\n\n      /** Label shown when a required field was not provided */\n      requiredLabel: string;\n\n      onFileUpload(questionId: string, file: File): UploadTask;\n\n      extensions?: {\n        [K in OnepercentUtility.UIElements.FormExtension[\"fields\"][\"type\"]]: {\n          Input: (props: GenericFormFieldProps<K>) => ReactElement;\n          validator: (\n            answer: AnswerByField<{ type: K }>,\n            question: BaseQuestion &\n              (OnepercentUtility.UIElements.FormExtension[\"fields\"] & {\n                type: K;\n              })\n          ) => {\n            isValid: boolean;\n            error?: string;\n          };\n        };\n      };\n    };\n    text?: {\n      className?: {\n        [k in React.ComponentProps<\n          typeof import(\"../components/Text\")[\"default\"]\n        >[\"type\"]]?: string;\n      };\n      htmlTag?: {\n        [k in React.ComponentProps<\n          typeof import(\"../components/Text\")[\"default\"]\n        >[\"type\"]]?: \"p\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\";\n      };\n    };\n    button?: {\n      className?: {\n        [k in NonNullable<\n          React.ComponentProps<\n            typeof import(\"../components/Button\")[\"default\"]\n          >[\"variant\"]\n        >]?: string;\n      };\n      Component?: (props: ComponentProps<typeof Button>) => ReactElement;\n    };\n    input: {\n      className: string;\n      border: boolean;\n    };\n    fileInput: {\n      View: (props: FileInputViewProps) => ReactElement;\n    };\n    passwordInput: {\n      iconSrc: {\n        passwordHidden: string;\n        passwordVisible: string;\n      };\n    };\n    asyncWrapper: {\n      LoadingComponent?: () => JSX.Element;\n      messages: {\n        error: {\n          title: string;\n          retryBtn: string;\n        };\n      };\n    };\n    select: {\n      StateIndicator: (props: { open: boolean }) => JSX.Element;\n      className?: {\n        dropdown?: string;\n        item?: string;\n        selectedItem?: string;\n        input?: string;\n      };\n    };\n    header: {\n      LogoImage: () => JSX.Element;\n      MoreOptions: ({ open }: { open: boolean }) => JSX.Element;\n    };\n    table: {\n      controls: {\n        PrevPage: ({ disabled }: { disabled: boolean }) => JSX.Element;\n        NextPage: ({ disabled }: { disabled: boolean }) => JSX.Element;\n      };\n    };\n    tooltip: {\n      className?: string;\n    };\n    adaptiveDialog: {\n      dialogClassName: string;\n      backdropClassName: string;\n      variant: {\n        [k in OnepercentUtility.UIElements.AdaptiveDialogVariants]: string;\n      };\n    };\n    adaptiveSidebar: {\n      className: string;\n      controlClassName: string;\n    };\n    checkbox: {\n      Component?: (props: ComponentProps<typeof CheckBox>) => ReactElement;\n    };\n    radio: {\n      Component?: (props: ComponentProps<typeof Radio>) => ReactElement;\n    };\n  };\n  hook: {\n    ui: {\n      usePaginationControls: {\n        LeftControl: () => ReactElement;\n        RightControl: () => ReactElement;\n        className?: string;\n      };\n    };\n  };\n  state: {\n    imageScale: ImageScales;\n  };\n};\n\ntype ContextConfigSpecs = DeepPartial<OneUIContextSpecs>;\n\nconst Context = createContext<ContextConfigSpecs>(null as any);\n\nfunction OneUIProvider({\n  children,\n  config,\n}: PropsWithChildren<{ config: ContextConfigSpecs }>) {\n  const prevCtx = useContext(Context);\n  const scale = useAdaptiveImage();\n  const mergedConfig = useMemo(() => {\n    return merge(clone(prevCtx), config, {\n      state: {\n        imageScale: scale,\n      },\n    });\n  }, [prevCtx, config, scale]);\n\n  return <Context.Provider value={mergedConfig}>{children}</Context.Provider>;\n}\n\nexport default OneUIProvider;\n\nfunction pathToJson(\n  path: string,\n  key?: string | Symbol,\n  exampleConfig = \"THE_MISSING_CONFIG\"\n) {\n  if (!key) {\n    key = path.split(\".\").slice(-1)[0];\n    path = path.replace(`.${key}`, \"\");\n  }\n\n  return path\n    .split(\".\")\n    .concat(key as string)\n    .reduce((result, key, idx, arr) => {\n      (arr.slice(0, idx).reduce((r, k) => (r as any)[k], result) as any)[key] =\n        idx === arr.length - 1 ? exampleConfig : {};\n      return result;\n    }, {});\n}\n\nfunction ErrorWrapper(\n  originalObject: any,\n  path: string = \"config\"\n): typeof Proxy {\n  return new Proxy(\n    typeof originalObject !== \"object\" ? {} : originalObject || {},\n    {\n      get(_target, key) {\n        if (key === Symbol.toPrimitive) {\n          return () => _target[key];\n        }\n        try {\n          const value = originalObject[key];\n          if (typeof value === \"undefined\") return undefined;\n          if (typeof value === \"object\")\n            return ErrorWrapper(value, [path, key].filter(Boolean).join(\".\"));\n          return value;\n        } catch (e) {\n          const pathJson = pathToJson(path, key);\n          throw new Error(\n            `A component is using the UI config ${[path, key].join(\".\")}.\n\nPlease define it using:\nimport OneUIProvider from \"@onepercent/one-ui/dist/context/OneUIProvider\";\n\n  ...\n${`<OneUIProvider config={${JSON.stringify(pathJson, null, 4)}}>\n...\n</OneUIProvider>`.replace(/[ ]/g, \"-\")}`\n          );\n        }\n      },\n    }\n  );\n}\n\nexport function useOneUIContext() {\n  const context = useContext(Context);\n\n  if (process.env.NODE_ENV === \"development\")\n    return ErrorWrapper(context) as unknown as OneUIContextSpecs;\n\n  return context as OneUIContextSpecs;\n}\n\nexport function useOneUIView<P extends FieldPath<OneUIContextSpecs>>(\n  oneuiConfigPath: P,\n  componentName: string\n) {\n  const providedValue = useOneUIConfig(oneuiConfigPath);\n  if (!providedValue) {\n    throw new Error(`The component ${componentName} requires a view to be set on OneUI initialization\n\nViews ready for use with this component shall be available at:\nimport SomeView from \"@onepercentio/one-ui/dist/components/${componentName}/View/SomeView\";\n    \nPlease define it using:\nimport OneUIProvider from \"@onepercentio/one-ui/dist/context/OneUIProvider\";\n\n  ...\n${`<OneUIProvider config={${JSON.stringify(\n  pathToJson(oneuiConfigPath, undefined, \"SomeView\"),\n  null,\n  4\n)}}>\n...\n</OneUIProvider>`.replace(/[ ]/g, \"-\")}`);\n  }\n\n  return providedValue;\n}\n\nexport function useOneUIConfig<\n  P extends FieldPath<OneUIContextSpecs>,\n  T extends Get<OneUIContextSpecs, P>\n>(prop: P, defaultValue?: T): NonNullable<Get<OneUIContextSpecs, P>> {\n  const context = useContext(Context);\n  if (process.env.NODE_ENV === \"development\") {\n    const val = useMemo(() => {\n      return get(context, prop);\n    }, [context, prop]);\n    if (\n      typeof val === \"string\" ||\n      typeof val === \"function\" ||\n      prop.endsWith(\".Component\") ||\n      prop.endsWith(\".View\")\n    )\n      return (val as any) || defaultValue;\n\n    if (typeof val === \"boolean\") return val as any;\n    return ErrorWrapper(val || defaultValue) as unknown as NonNullable<T>;\n  }\n  const value = useMemo(() => {\n    return get(context, prop);\n  }, [context, prop]);\n  return value || defaultValue;\n}\n\nexport function useCurrentImageScale() {\n  const context = useContext(Context);\n\n  return context.state!.imageScale!;\n}\n"],"mappings":"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"}
@@ -26,7 +26,7 @@ export type LocalPaginable<I extends any, E extends any = any> = Paginable<I, E>
26
26
  * This returns a ref to be bound to an elements so it can be able to detect when a pagination whould occur
27
27
  */
28
28
  export declare function useContainerPagination(cb: (pageSize: number) => void, pageSize: number, direction?: "h" | "v"): {
29
- scrollableRef: import("react").RefObject<HTMLDivElement>;
29
+ scrollableRef: import("react").MutableRefObject<HTMLDivElement | undefined>;
30
30
  customOptionsRef: import("react").MutableRefObject<(() => {
31
31
  offsetBottom?: number;
32
32
  offsetLeft?: number;
@@ -85,7 +85,7 @@ function usePagination(request) {
85
85
  */
86
86
  function useContainerPagination(cb, pageSize) {
87
87
  let direction = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : "v";
88
- const scrollableRef = (0, _react.useRef)(null);
88
+ const scrollableRef = (0, _react.useRef)();
89
89
  const customOptionsRef = (0, _react.useRef)();
90
90
  (0, _react.useEffect)(() => {
91
91
  const el = scrollableRef.current;
@@ -146,4 +146,4 @@ function useLocalPagination(items) {
146
146
  src: pagSrc
147
147
  };
148
148
  }
149
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_useAsyncControl","_interopRequireDefault","_throttle","obj","__esModule","default","usePagination","request","paginationId","arguments","length","undefined","startingItems","paginationDataRef","useRef","current","paginationData","paginationIdFactory","useMemo","randId","Math","random","toString","Array","isArray","items","setItems","useState","id","setId","useEffect","process","control","useAsyncControl","updateItems","cb","prev","derivateCurrentPage","pageSize","currentPage","floor","_requestPage","useCallback","page","_paginationData$id","finished","result","slice","totalItems","getNextPage","getPage","getAll","refreshCurrentPage","_paginationData$pagin","loading","error","setError","useContainerPagination","direction","scrollableRef","customOptionsRef","el","scrollElement","scrollingElement","calculateIfReachedLimit","throttle","e","_customOptionsRef$cur","target","offsetBottom","offsetLeft","call","offsetLimit","scrollHeight","clientHeight","scrollWidth","clientWidth","offset","scrollTop","scrollLeft","leading","trailing","addEventListener","passive","removeEventListener","useLocalPagination","instanceID","Date","now","currItems","Promise","resolve","from","newArray","pagination","pagSrc","src"],"sources":["../../src/hooks/usePagination.ts"],"sourcesContent":["import {\n  useCallback,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport useAsyncControl from \"./useAsyncControl\";\nimport throttle from \"lodash/throttle\";\n\ntype UpdateEvent<I extends any> = {\n  finished: boolean;\n  items: I[];\n  totalItems: number;\n};\n\nexport default function usePagination<I extends any>(\n  request: (\n    page: number,\n    pageSize: number | \"all\",\n    currItems?: I[]\n  ) => Promise<UpdateEvent<I>>,\n  paginationId: object | any[] | (() => string) = () => \"default\",\n  startingItems?: I[]\n): Paginable<I> {\n  const paginationDataRef = useRef<{\n    [d: string]:\n      | {\n          finished: boolean;\n          totalItems: number;\n        }\n      | undefined;\n  }>({});\n  const { current: paginationData } = paginationDataRef;\n  const paginationIdFactory = useMemo(\n    () => {\n      if (typeof paginationId === \"object\") {\n        const randId = Math.random();\n        return () => randId.toString();\n      } else return paginationId;\n    },\n    Array.isArray(paginationId) ? paginationId : [paginationId]\n  );\n\n  const [items, setItems] =\n    useState<[paginationId: string, items: I[]] | undefined>();\n\n  const [id, setId] = useState(() => paginationIdFactory());\n\n  useEffect(() => {\n    setId(paginationIdFactory());\n    if (startingItems) setItems([paginationIdFactory(), startingItems]);\n    else setItems(undefined);\n  }, [paginationIdFactory()]);\n\n  const { process, ...control } = useAsyncControl();\n\n  function updateItems(cb: (prevItems?: I) => UpdateEvent<I>[\"items\"]) {\n    setItems((prev) => [prev![0], cb()]);\n  }\n\n  const derivateCurrentPage = (pageSize: number) => {\n    if (items === undefined) return 0;\n    const currentPage = Math.floor((items?.[1].length ?? 0) / pageSize) - 1;\n    return currentPage;\n  };\n\n  const _requestPage = useCallback(\n    function (page: number, pageSize: number | \"all\") {\n      const id = paginationIdFactory();\n      if (paginationData[id]?.finished) return;\n      process(async () => {\n        const result = await request(\n          page,\n          pageSize,\n          items?.[0] === id && page !== 0\n            ? pageSize === \"all\"\n              ? undefined\n              : items?.[1].slice(0, page * pageSize)\n            : undefined\n        );\n        paginationData[id] = {\n          finished: result.finished,\n          totalItems: result.totalItems,\n        };\n        setItems((prev) => {\n          if (page === 0) return [id, result.items];\n          else if (!prev || id === prev[0]) return [id, result.items];\n          return prev;\n        });\n      });\n    },\n    [items, request]\n  );\n\n  return {\n    updateItems,\n    getNextPage: (pageSize: number) => {\n      _requestPage(derivateCurrentPage(pageSize) + 1, pageSize);\n    },\n    getPage: _requestPage,\n    getAll: () => {\n      _requestPage(0, \"all\");\n    },\n    refreshCurrentPage: (pageSize: number) => {\n      _requestPage(derivateCurrentPage(pageSize), pageSize);\n    },\n    totalItems: () => paginationData[paginationIdFactory()]?.totalItems,\n    id: () => id,\n    loading: control.loading,\n    error: control.error,\n    items: items?.[1],\n    setError: control.setError,\n  };\n}\n\nexport type Paginable<I extends any, E extends any = any> = {\n  updateItems: (cb: (prevItems?: I) => UpdateEvent<I>[\"items\"]) => void;\n  getNextPage: (pageSize: number) => void;\n  refreshCurrentPage: (pageSize: number) => void;\n  getPage: (page: number, pageSize: number) => void;\n  getAll: () => void;\n  totalItems: () => number | undefined;\n  loading: boolean;\n  error: E | Error | undefined;\n  items: I[] | undefined;\n  setError: ReturnType<typeof useAsyncControl>[\"setError\"];\n  id: () => string;\n};\n\nexport type LocalPaginable<I extends any, E extends any = any> = Paginable<\n  I,\n  E\n> & {\n  src: I;\n};\n\n/**\n * This returns a ref to be bound to an elements so it can be able to detect when a pagination whould occur\n */\nexport function useContainerPagination(\n  cb: (pageSize: number) => void,\n  pageSize: number,\n  direction: \"h\" | \"v\" = \"v\"\n) {\n  const scrollableRef = useRef<HTMLDivElement>(null);\n  const customOptionsRef =\n    useRef<() => { offsetBottom?: number; offsetLeft?: number }>();\n\n  useEffect(() => {\n    const el = scrollableRef.current!;\n    const scrollElement =\n      (el as unknown as typeof window.document).scrollingElement || el;\n    const calculateIfReachedLimit = throttle(\n      (e: Event) => {\n        if (e.target !== el) return;\n        const { offsetBottom = 0, offsetLeft = 0 } =\n          customOptionsRef.current?.() || {};\n        const offsetLimit =\n          direction === \"v\"\n            ? scrollElement.scrollHeight -\n              offsetBottom -\n              scrollElement.clientHeight * 0.6\n            : scrollElement.scrollWidth -\n              offsetLeft -\n              scrollElement.clientWidth * 0.6;\n        const offset =\n          direction === \"v\"\n            ? scrollElement.clientHeight + scrollElement.scrollTop\n            : scrollElement.clientWidth + scrollElement.scrollLeft;\n        if (offset >= offsetLimit) {\n          cb(pageSize);\n        }\n      },\n      250,\n      {\n        leading: false,\n        trailing: true,\n      }\n    );\n\n    el.addEventListener(\"scroll\", calculateIfReachedLimit, {\n      passive: true,\n    });\n    return () => el.removeEventListener(\"scroll\", calculateIfReachedLimit);\n  }, [cb, pageSize]);\n\n  return {\n    scrollableRef,\n    customOptionsRef,\n  };\n}\n\n/**\n * This function receives an amount of local instances and paginates it\n */\nexport function useLocalPagination<L>(items: L[] | undefined) {\n  const instanceID = useMemo(() => Date.now(), [items]);\n  const cb = useCallback(\n    (page: number, pageSize: number | \"all\", currItems: L[] = []) => {\n      if (!items)\n        return Promise.resolve({\n          finished: false,\n          totalItems: 0,\n          items: [],\n        });\n      if (pageSize === \"all\") pageSize = items.length;\n      const from = pageSize * page;\n      const newArray = [...currItems, ...items.slice(from, from + pageSize)];\n\n      return Promise.resolve({\n        finished: newArray.length === items.length,\n        totalItems: items.length,\n        items: newArray,\n      });\n    },\n    [items]\n  );\n  const pagination = usePagination<L>(cb, () => `${instanceID}`);\n  const pagSrc = useMemo(() => items, [pagination.items]);\n\n  return {\n    ...pagination,\n    loading: items === undefined,\n    src: pagSrc,\n  };\n}\n"],"mappings":"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"}
149
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_useAsyncControl","_interopRequireDefault","_throttle","obj","__esModule","default","usePagination","request","paginationId","arguments","length","undefined","startingItems","paginationDataRef","useRef","current","paginationData","paginationIdFactory","useMemo","randId","Math","random","toString","Array","isArray","items","setItems","useState","id","setId","useEffect","process","control","useAsyncControl","updateItems","cb","prev","derivateCurrentPage","pageSize","currentPage","floor","_requestPage","useCallback","page","_paginationData$id","finished","result","slice","totalItems","getNextPage","getPage","getAll","refreshCurrentPage","_paginationData$pagin","loading","error","setError","useContainerPagination","direction","scrollableRef","customOptionsRef","el","scrollElement","scrollingElement","calculateIfReachedLimit","throttle","e","_customOptionsRef$cur","target","offsetBottom","offsetLeft","call","offsetLimit","scrollHeight","clientHeight","scrollWidth","clientWidth","offset","scrollTop","scrollLeft","leading","trailing","addEventListener","passive","removeEventListener","useLocalPagination","instanceID","Date","now","currItems","Promise","resolve","from","newArray","pagination","pagSrc","src"],"sources":["../../src/hooks/usePagination.ts"],"sourcesContent":["import {\n  useCallback,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport useAsyncControl from \"./useAsyncControl\";\nimport throttle from \"lodash/throttle\";\n\ntype UpdateEvent<I extends any> = {\n  finished: boolean;\n  items: I[];\n  totalItems: number;\n};\n\nexport default function usePagination<I extends any>(\n  request: (\n    page: number,\n    pageSize: number | \"all\",\n    currItems?: I[]\n  ) => Promise<UpdateEvent<I>>,\n  paginationId: object | any[] | (() => string) = () => \"default\",\n  startingItems?: I[]\n): Paginable<I> {\n  const paginationDataRef = useRef<{\n    [d: string]:\n      | {\n          finished: boolean;\n          totalItems: number;\n        }\n      | undefined;\n  }>({});\n  const { current: paginationData } = paginationDataRef;\n  const paginationIdFactory = useMemo(\n    () => {\n      if (typeof paginationId === \"object\") {\n        const randId = Math.random();\n        return () => randId.toString();\n      } else return paginationId;\n    },\n    Array.isArray(paginationId) ? paginationId : [paginationId]\n  );\n\n  const [items, setItems] =\n    useState<[paginationId: string, items: I[]] | undefined>();\n\n  const [id, setId] = useState(() => paginationIdFactory());\n\n  useEffect(() => {\n    setId(paginationIdFactory());\n    if (startingItems) setItems([paginationIdFactory(), startingItems]);\n    else setItems(undefined);\n  }, [paginationIdFactory()]);\n\n  const { process, ...control } = useAsyncControl();\n\n  function updateItems(cb: (prevItems?: I) => UpdateEvent<I>[\"items\"]) {\n    setItems((prev) => [prev![0], cb()]);\n  }\n\n  const derivateCurrentPage = (pageSize: number) => {\n    if (items === undefined) return 0;\n    const currentPage = Math.floor((items?.[1].length ?? 0) / pageSize) - 1;\n    return currentPage;\n  };\n\n  const _requestPage = useCallback(\n    function (page: number, pageSize: number | \"all\") {\n      const id = paginationIdFactory();\n      if (paginationData[id]?.finished) return;\n      process(async () => {\n        const result = await request(\n          page,\n          pageSize,\n          items?.[0] === id && page !== 0\n            ? pageSize === \"all\"\n              ? undefined\n              : items?.[1].slice(0, page * pageSize)\n            : undefined\n        );\n        paginationData[id] = {\n          finished: result.finished,\n          totalItems: result.totalItems,\n        };\n        setItems((prev) => {\n          if (page === 0) return [id, result.items];\n          else if (!prev || id === prev[0]) return [id, result.items];\n          return prev;\n        });\n      });\n    },\n    [items, request]\n  );\n\n  return {\n    updateItems,\n    getNextPage: (pageSize: number) => {\n      _requestPage(derivateCurrentPage(pageSize) + 1, pageSize);\n    },\n    getPage: _requestPage,\n    getAll: () => {\n      _requestPage(0, \"all\");\n    },\n    refreshCurrentPage: (pageSize: number) => {\n      _requestPage(derivateCurrentPage(pageSize), pageSize);\n    },\n    totalItems: () => paginationData[paginationIdFactory()]?.totalItems,\n    id: () => id,\n    loading: control.loading,\n    error: control.error,\n    items: items?.[1],\n    setError: control.setError,\n  };\n}\n\nexport type Paginable<I extends any, E extends any = any> = {\n  updateItems: (cb: (prevItems?: I) => UpdateEvent<I>[\"items\"]) => void;\n  getNextPage: (pageSize: number) => void;\n  refreshCurrentPage: (pageSize: number) => void;\n  getPage: (page: number, pageSize: number) => void;\n  getAll: () => void;\n  totalItems: () => number | undefined;\n  loading: boolean;\n  error: E | Error | undefined;\n  items: I[] | undefined;\n  setError: ReturnType<typeof useAsyncControl>[\"setError\"];\n  id: () => string;\n};\n\nexport type LocalPaginable<I extends any, E extends any = any> = Paginable<\n  I,\n  E\n> & {\n  src: I;\n};\n\n/**\n * This returns a ref to be bound to an elements so it can be able to detect when a pagination whould occur\n */\nexport function useContainerPagination(\n  cb: (pageSize: number) => void,\n  pageSize: number,\n  direction: \"h\" | \"v\" = \"v\"\n) {\n  const scrollableRef = useRef<HTMLDivElement>();\n  const customOptionsRef =\n    useRef<() => { offsetBottom?: number; offsetLeft?: number }>();\n\n  useEffect(() => {\n    const el = scrollableRef.current!;\n    const scrollElement =\n      (el as unknown as typeof window.document).scrollingElement || el;\n    const calculateIfReachedLimit = throttle(\n      (e: Event) => {\n        if (e.target !== el) return;\n        const { offsetBottom = 0, offsetLeft = 0 } =\n          customOptionsRef.current?.() || {};\n        const offsetLimit =\n          direction === \"v\"\n            ? scrollElement.scrollHeight -\n              offsetBottom -\n              scrollElement.clientHeight * 0.6\n            : scrollElement.scrollWidth -\n              offsetLeft -\n              scrollElement.clientWidth * 0.6;\n        const offset =\n          direction === \"v\"\n            ? scrollElement.clientHeight + scrollElement.scrollTop\n            : scrollElement.clientWidth + scrollElement.scrollLeft;\n        if (offset >= offsetLimit) {\n          cb(pageSize);\n        }\n      },\n      250,\n      {\n        leading: false,\n        trailing: true,\n      }\n    );\n\n    el.addEventListener(\"scroll\", calculateIfReachedLimit, {\n      passive: true,\n    });\n    return () => el.removeEventListener(\"scroll\", calculateIfReachedLimit);\n  }, [cb, pageSize]);\n\n  return {\n    scrollableRef,\n    customOptionsRef,\n  };\n}\n\n/**\n * This function receives an amount of local instances and paginates it\n */\nexport function useLocalPagination<L>(items: L[] | undefined) {\n  const instanceID = useMemo(() => Date.now(), [items]);\n  const cb = useCallback(\n    (page: number, pageSize: number | \"all\", currItems: L[] = []) => {\n      if (!items)\n        return Promise.resolve({\n          finished: false,\n          totalItems: 0,\n          items: [],\n        });\n      if (pageSize === \"all\") pageSize = items.length;\n      const from = pageSize * page;\n      const newArray = [...currItems, ...items.slice(from, from + pageSize)];\n\n      return Promise.resolve({\n        finished: newArray.length === items.length,\n        totalItems: items.length,\n        items: newArray,\n      });\n    },\n    [items]\n  );\n  const pagination = usePagination<L>(cb, () => `${instanceID}`);\n  const pagSrc = useMemo(() => items, [pagination.items]);\n\n  return {\n    ...pagination,\n    loading: items === undefined,\n    src: pagSrc,\n  };\n}\n"],"mappings":"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"}
@@ -9,12 +9,12 @@ var _ContextAsyncControl = require("../../context/ContextAsyncControl");
9
9
  function useUniqueEffect(id, effect, deps) {
10
10
  const lockId = (0, _react.useMemo)(() => Math.random(), []);
11
11
  const [currLock, setCurrLock] = (0, _ContextAsyncControl.useShareState)("unique-effect", id);
12
- (0, _react.useInsertionEffect)(() => {
12
+ (0, _react.useLayoutEffect)(() => {
13
13
  if (currLock === lockId) effect();
14
14
  }, [...deps, currLock]);
15
- (0, _react.useInsertionEffect)(() => {
15
+ (0, _react.useLayoutEffect)(() => {
16
16
  if (currLock === undefined) setCurrLock(lockId);
17
17
  if (currLock === lockId) return () => setCurrLock(undefined);
18
18
  }, [currLock]);
19
19
  }
20
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJyZXF1aXJlIiwiX0NvbnRleHRBc3luY0NvbnRyb2wiLCJ1c2VVbmlxdWVFZmZlY3QiLCJpZCIsImVmZmVjdCIsImRlcHMiLCJsb2NrSWQiLCJ1c2VNZW1vIiwiTWF0aCIsInJhbmRvbSIsImN1cnJMb2NrIiwic2V0Q3VyckxvY2siLCJ1c2VTaGFyZVN0YXRlIiwidXNlSW5zZXJ0aW9uRWZmZWN0IiwidW5kZWZpbmVkIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2hvb2tzL3V0aWxpdHkvdXNlVW5pcXVlRWZmZWN0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZUVmZmVjdCwgdXNlSW5zZXJ0aW9uRWZmZWN0LCB1c2VNZW1vIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgeyB1c2VTaGFyZVN0YXRlIH0gZnJvbSBcIi4uLy4uL2NvbnRleHQvQ29udGV4dEFzeW5jQ29udHJvbFwiO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiB1c2VVbmlxdWVFZmZlY3QoXG4gIGlkOiBzdHJpbmcsXG4gIGVmZmVjdDogKCkgPT4gdm9pZCxcbiAgZGVwczogYW55W11cbikge1xuICBjb25zdCBsb2NrSWQgPSB1c2VNZW1vKCgpID0+IE1hdGgucmFuZG9tKCksIFtdKTtcbiAgY29uc3QgW2N1cnJMb2NrLCBzZXRDdXJyTG9ja10gPSB1c2VTaGFyZVN0YXRlPG51bWJlciB8IHVuZGVmaW5lZD4oXG4gICAgXCJ1bmlxdWUtZWZmZWN0XCIsXG4gICAgaWRcbiAgKTtcbiAgdXNlSW5zZXJ0aW9uRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoY3VyckxvY2sgPT09IGxvY2tJZCkgZWZmZWN0KCk7XG4gIH0sIFsuLi5kZXBzLCBjdXJyTG9ja10pO1xuXG4gIHVzZUluc2VydGlvbkVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKGN1cnJMb2NrID09PSB1bmRlZmluZWQpIHNldEN1cnJMb2NrKGxvY2tJZCk7XG4gICAgaWYgKGN1cnJMb2NrID09PSBsb2NrSWQpIHJldHVybiAoKSA9PiBzZXRDdXJyTG9jayh1bmRlZmluZWQpO1xuICB9LCBbY3VyckxvY2tdKTtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxPQUFBO0FBQ0EsSUFBQUMsb0JBQUEsR0FBQUQsT0FBQTtBQUVlLFNBQVNFLGVBQWVBLENBQ3JDQyxFQUFVLEVBQ1ZDLE1BQWtCLEVBQ2xCQyxJQUFXLEVBQ1g7RUFDQSxNQUFNQyxNQUFNLEdBQUcsSUFBQUMsY0FBTyxFQUFDLE1BQU1DLElBQUksQ0FBQ0MsTUFBTSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUM7RUFDL0MsTUFBTSxDQUFDQyxRQUFRLEVBQUVDLFdBQVcsQ0FBQyxHQUFHLElBQUFDLGtDQUFhLEVBQzNDLGVBQWUsRUFDZlQsRUFDRixDQUFDO0VBQ0QsSUFBQVUseUJBQWtCLEVBQUMsTUFBTTtJQUN2QixJQUFJSCxRQUFRLEtBQUtKLE1BQU0sRUFBRUYsTUFBTSxDQUFDLENBQUM7RUFDbkMsQ0FBQyxFQUFFLENBQUMsR0FBR0MsSUFBSSxFQUFFSyxRQUFRLENBQUMsQ0FBQztFQUV2QixJQUFBRyx5QkFBa0IsRUFBQyxNQUFNO0lBQ3ZCLElBQUlILFFBQVEsS0FBS0ksU0FBUyxFQUFFSCxXQUFXLENBQUNMLE1BQU0sQ0FBQztJQUMvQyxJQUFJSSxRQUFRLEtBQUtKLE1BQU0sRUFBRSxPQUFPLE1BQU1LLFdBQVcsQ0FBQ0csU0FBUyxDQUFDO0VBQzlELENBQUMsRUFBRSxDQUFDSixRQUFRLENBQUMsQ0FBQztBQUNoQiJ9
20
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJyZXF1aXJlIiwiX0NvbnRleHRBc3luY0NvbnRyb2wiLCJ1c2VVbmlxdWVFZmZlY3QiLCJpZCIsImVmZmVjdCIsImRlcHMiLCJsb2NrSWQiLCJ1c2VNZW1vIiwiTWF0aCIsInJhbmRvbSIsImN1cnJMb2NrIiwic2V0Q3VyckxvY2siLCJ1c2VTaGFyZVN0YXRlIiwidXNlTGF5b3V0RWZmZWN0IiwidW5kZWZpbmVkIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2hvb2tzL3V0aWxpdHkvdXNlVW5pcXVlRWZmZWN0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZUxheW91dEVmZmVjdCwgdXNlTWVtbyB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHsgdXNlU2hhcmVTdGF0ZSB9IGZyb20gXCIuLi8uLi9jb250ZXh0L0NvbnRleHRBc3luY0NvbnRyb2xcIjtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gdXNlVW5pcXVlRWZmZWN0KFxuICBpZDogc3RyaW5nLFxuICBlZmZlY3Q6ICgpID0+IHZvaWQsXG4gIGRlcHM6IGFueVtdXG4pIHtcbiAgY29uc3QgbG9ja0lkID0gdXNlTWVtbygoKSA9PiBNYXRoLnJhbmRvbSgpLCBbXSk7XG4gIGNvbnN0IFtjdXJyTG9jaywgc2V0Q3VyckxvY2tdID0gdXNlU2hhcmVTdGF0ZTxudW1iZXIgfCB1bmRlZmluZWQ+KFxuICAgIFwidW5pcXVlLWVmZmVjdFwiLFxuICAgIGlkXG4gICk7XG4gIHVzZUxheW91dEVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKGN1cnJMb2NrID09PSBsb2NrSWQpIGVmZmVjdCgpO1xuICB9LCBbLi4uZGVwcywgY3VyckxvY2tdKTtcblxuICB1c2VMYXlvdXRFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChjdXJyTG9jayA9PT0gdW5kZWZpbmVkKSBzZXRDdXJyTG9jayhsb2NrSWQpO1xuICAgIGlmIChjdXJyTG9jayA9PT0gbG9ja0lkKSByZXR1cm4gKCkgPT4gc2V0Q3VyckxvY2sodW5kZWZpbmVkKTtcbiAgfSwgW2N1cnJMb2NrXSk7XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsT0FBQTtBQUNBLElBQUFDLG9CQUFBLEdBQUFELE9BQUE7QUFFZSxTQUFTRSxlQUFlQSxDQUNyQ0MsRUFBVSxFQUNWQyxNQUFrQixFQUNsQkMsSUFBVyxFQUNYO0VBQ0EsTUFBTUMsTUFBTSxHQUFHLElBQUFDLGNBQU8sRUFBQyxNQUFNQyxJQUFJLENBQUNDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDO0VBQy9DLE1BQU0sQ0FBQ0MsUUFBUSxFQUFFQyxXQUFXLENBQUMsR0FBRyxJQUFBQyxrQ0FBYSxFQUMzQyxlQUFlLEVBQ2ZULEVBQ0YsQ0FBQztFQUNELElBQUFVLHNCQUFlLEVBQUMsTUFBTTtJQUNwQixJQUFJSCxRQUFRLEtBQUtKLE1BQU0sRUFBRUYsTUFBTSxDQUFDLENBQUM7RUFDbkMsQ0FBQyxFQUFFLENBQUMsR0FBR0MsSUFBSSxFQUFFSyxRQUFRLENBQUMsQ0FBQztFQUV2QixJQUFBRyxzQkFBZSxFQUFDLE1BQU07SUFDcEIsSUFBSUgsUUFBUSxLQUFLSSxTQUFTLEVBQUVILFdBQVcsQ0FBQ0wsTUFBTSxDQUFDO0lBQy9DLElBQUlJLFFBQVEsS0FBS0osTUFBTSxFQUFFLE9BQU8sTUFBTUssV0FBVyxDQUFDRyxTQUFTLENBQUM7RUFDOUQsQ0FBQyxFQUFFLENBQUNKLFFBQVEsQ0FBQyxDQUFDO0FBQ2hCIn0=
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@onepercentio/one-ui",
3
- "version": "0.26.2",
3
+ "version": "0.26.4",
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>",