@onepercentio/one-ui 1.2.1 → 1.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -5,7 +5,18 @@ process.env.NODE_ENV =
5
5
  : "production");
6
6
  const { resolveFromMainContext } = require("./workarounds");
7
7
  require("./monkeypatch");
8
+ const chalk = require("chalk");
8
9
  const { join, relative, resolve } = require("path");
10
+ try {
11
+ require(resolveFromMainContext("html-webpack-plugin"));
12
+ } catch (error) {
13
+ throw new Error(
14
+ chalk.white(
15
+ `There was a problem loading the module ${chalk.red(chalk.bold("html-webpack-plugin"))} (Check the error above).
16
+ Make sure it's installed as it is important for generating the final HTML files.`,
17
+ ),
18
+ );
19
+ }
9
20
  const HTMLPlugin = require(resolveFromMainContext("html-webpack-plugin"));
10
21
  const {
11
22
  writeFileSync,
@@ -17,7 +28,6 @@ const {
17
28
  } = require("fs");
18
29
  const lodash = require("lodash");
19
30
  const { findPathDeep } = require("deepdash")(lodash);
20
- const chalk = require("chalk");
21
31
 
22
32
  function findAllStaticGeneration() {
23
33
  const glob = require("glob");
@@ -49,11 +59,12 @@ async function loadGenerator() {
49
59
  })();
50
60
  return await (configGenerator.default || configGenerator)(
51
61
  resolve("."),
52
- process.env.NODE_ENV
62
+ process.env.NODE_ENV,
53
63
  );
54
64
  } catch (e) {
55
65
  switch (e.code) {
56
66
  case "MODULE_NOT_FOUND":
67
+ case "ERR_MODULE_NOT_FOUND":
57
68
  if (e.message.split("\n")[0].includes("config-factory")) {
58
69
  const ans = await require("inquirer").prompt([
59
70
  {
@@ -74,14 +85,14 @@ async function loadGenerator() {
74
85
  config,
75
86
  mainHtml
76
87
  }
77
- }`
88
+ }`,
78
89
  );
79
90
  console.log(require("chalk").green("File created"));
80
91
  } else {
81
92
  console.log(
82
93
  require("chalk").yellow(
83
- "This command will only work when there is a valid configuration"
84
- )
94
+ "This command will only work when there is a valid configuration",
95
+ ),
85
96
  );
86
97
  }
87
98
  process.exit(0);
@@ -104,11 +115,11 @@ function findFirstBabelLoaderConfigPath(config) {
104
115
  function prerenderRequire() {
105
116
  try {
106
117
  return resolveFromMainContext(
107
- "@nettoolkit/prerender-loader" // This supports webpack 5
118
+ "@nettoolkit/prerender-loader", // This supports webpack 5
108
119
  );
109
120
  } catch (e) {
110
121
  return resolveFromMainContext(
111
- "prerender-loader" // This doesn't
122
+ "prerender-loader", // This doesn't
112
123
  );
113
124
  }
114
125
  }
@@ -126,11 +137,11 @@ async function createConfig(
126
137
  /** @type {number} */
127
138
  maxParallelTasks,
128
139
  /** @type {() => Promise<string[]>} */
129
- filterResults = async (results) => results
140
+ filterResults = async (results) => results,
130
141
  ) {
131
142
  if (!process.env.EMAIL_TEMPLATES_BASE_DOMAIN)
132
143
  throw new Error(
133
- `The env variable "EMAIL_TEMPLATES_BASE_DOMAIN" is not set (ex: https://localhost:3000). It's required for pointing to the image resources correctly`
144
+ `The env variable "EMAIL_TEMPLATES_BASE_DOMAIN" is not set (ex: https://localhost:3000). It's required for pointing to the image resources correctly`,
134
145
  );
135
146
  if (!existsSync(outputDir)) mkdirSync(outputDir, { recursive: true });
136
147
 
@@ -140,7 +151,7 @@ async function createConfig(
140
151
  const onlyHTMLs = !outputFolderFiles.some(
141
152
  (file) =>
142
153
  lstatSync(join(outputDir, file)).isDirectory() ||
143
- !file.endsWith(".html")
154
+ !file.endsWith(".html"),
144
155
  );
145
156
  if (onlyHTMLs) {
146
157
  rmSync(outputDir, {
@@ -158,8 +169,8 @@ async function createConfig(
158
169
  baseConfig.plugins = baseConfig.plugins.filter(
159
170
  (a) =>
160
171
  !["ManifestPlugin", "MiniCss"].find((pattern) =>
161
- a.constructor.name.includes(pattern)
162
- )
172
+ a.constructor.name.includes(pattern),
173
+ ),
163
174
  );
164
175
  /** @type {import("webpack").WebpackPluginInstance} */
165
176
  const LogPlugin = {
@@ -168,7 +179,7 @@ async function createConfig(
168
179
  compiler.hooks.afterEmit.tap("Logger", (compilation) => {
169
180
  console.log(chalk.green("Output successfull"));
170
181
  const htmls = Object.keys(compilation.assets).filter((a) =>
171
- a.endsWith(".html")
182
+ a.endsWith(".html"),
172
183
  );
173
184
  const lazyFindPort = process.argv.find((a) => a === "--port");
174
185
  const port = process.argv[process.argv.indexOf(lazyFindPort) + 1];
@@ -190,7 +201,7 @@ async function createConfig(
190
201
  ? baseConfig.module.rules
191
202
  : lodash.get(
192
203
  baseConfig.module.rules,
193
- babelLoaderPath.slice(0, indexOfOneOf + 5)
204
+ babelLoaderPath.slice(0, indexOfOneOf + 5),
194
205
  );
195
206
 
196
207
  whereToPlaceTheNewLoaderPath.splice(1, 0, {
@@ -315,7 +326,7 @@ async function createConfig(
315
326
 
316
327
  if (!baseConfig.resolve.alias) baseConfig.resolve.alias = {};
317
328
  baseConfig.resolve.alias.CSSInliner = require.resolve(
318
- join(__dirname, "scripts", "css-inliner.ts")
329
+ join(__dirname, "scripts", "css-inliner.ts"),
319
330
  );
320
331
 
321
332
  baseConfig.output.filename = `[name].js`;
@@ -326,12 +337,12 @@ async function createConfig(
326
337
  baseConfig.plugins = baseConfig.plugins.filter(
327
338
  (a) =>
328
339
  !["ModuleFederationPlugin", "SourceMapDevToolPlugin"].includes(
329
- a.constructor.name
330
- )
340
+ a.constructor.name,
341
+ ),
331
342
  );
332
343
 
333
344
  const providePlugin = baseConfig.plugins.find(
334
- (a) => a.constructor.name === "ProvidePlugin"
345
+ (a) => a.constructor.name === "ProvidePlugin",
335
346
  );
336
347
 
337
348
  if (providePlugin) delete providePlugin.definitions.process;
@@ -344,9 +355,9 @@ function checkTemplatesCount(webpackEntry) {
344
355
  console.log(
345
356
  chalk.green(
346
357
  `No templates were found. If you want to create a static template, please create a file with name ${chalk.white(
347
- "{htmlName}.static.tsx"
348
- )} (ex: some-template.static.tsx)`
349
- )
358
+ "{htmlName}.static.tsx",
359
+ )} (ex: some-template.static.tsx)`,
360
+ ),
350
361
  );
351
362
  process.exit(0);
352
363
  }
@@ -370,7 +381,7 @@ module.exports = async function initEmailWebpack() {
370
381
  outputDir,
371
382
  resourcesOnly,
372
383
  maxParallelTasks,
373
- templatesFilter
384
+ templatesFilter,
374
385
  );
375
386
  checkTemplatesCount(config.entry);
376
387
  return config;
@@ -6,15 +6,22 @@ module.exports = function (content) {
6
6
  } = getOptions(this);
7
7
  content = content.replace("export default ", "");
8
8
  const [_, functionName] = /function ([a-zA-Z0-9]+)\(/.exec(content);
9
- content = `import { render } from 'react-dom';
9
+ content = `import * as DOM from 'react-dom';
10
+ import * as ClientDOM from 'react-dom/client';
10
11
  import React from 'react';
11
12
  import InlineCSS from "CSSInliner";
12
13
  window.PRERENDER = window.PRERENDER || true
13
-
14
+ const { render } = DOM;
15
+ const { createRoot } = ClientDOM;
14
16
  ${content}
15
17
  export default function Load() {
16
18
  return new Promise((r) => {
17
- render(<${functionName}/>, document.body);
19
+ if (!!createRoot) {
20
+ createRoot(document.body).render(<${functionName}/>)
21
+ } else {
22
+ render(<${functionName}/>, document.body);
23
+ }
24
+
18
25
  ${inlineCSS ? `InlineCSS();` : ""}
19
26
  r();
20
27
  })
@@ -49,10 +49,16 @@ function _Input(_ref, ref) {
49
49
  }
50
50
  }, [autoFocus]);
51
51
  const Component = multiline ? "textarea" : "input";
52
+ const containerRef = (0, _react.useRef)(null);
53
+ const maxWidth = (0, _react.useMemo)(() => {
54
+ var _containerRef$current;
55
+ return (_containerRef$current = containerRef.current) === null || _containerRef$current === void 0 ? void 0 : _containerRef$current.getBoundingClientRect().width;
56
+ }, [error, disclaimer]);
52
57
  return /*#__PURE__*/_react.default.createElement("div", {
53
58
  className: "".concat(className.container, " ").concat(localClassName)
54
59
  }, /*#__PURE__*/_react.default.createElement("div", _extends({
55
- className: "".concat(_InputModule.default.inputContainer, " ").concat(false ? _InputModule.default.withIcon : "")
60
+ className: "".concat(_InputModule.default.inputContainer, " ").concat(false ? _InputModule.default.withIcon : ""),
61
+ ref: containerRef
56
62
  }, containerProps), decoration, /*#__PURE__*/_react.default.createElement(Component, _extends({
57
63
  ref: inputRef,
58
64
  placeholder: placeholder,
@@ -72,7 +78,10 @@ function _Input(_ref, ref) {
72
78
  }, Icon), icon && /*#__PURE__*/_react.default.createElement("img", _extends({
73
79
  className: _InputModule.default.icon
74
80
  }, icon))), /*#__PURE__*/_react.default.createElement(_AdaptiveContainer.default, {
75
- direction: "v"
81
+ direction: "v",
82
+ style: {
83
+ maxWidth: maxWidth
84
+ }
76
85
  }, error && shouldShowError ? /*#__PURE__*/_react.default.createElement(_Text.default, {
77
86
  key: "error",
78
87
  title: typeof error === "string" ? error : "",
@@ -91,4 +100,4 @@ function _Input(_ref, ref) {
91
100
  **/
92
101
  const Input = /*#__PURE__*/(0, _react.forwardRef)(_Input);
93
102
  var _default = exports.default = Input;
94
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_OneUIProvider","_Text","_interopRequireDefault","_InputModule","_AdaptiveContainer","_excluded","e","__esModule","default","t","WeakMap","r","n","o","i","f","__proto__","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","_extends","assign","bind","arguments","length","apply","_objectWithoutProperties","_objectWithoutPropertiesLoose","getOwnPropertySymbols","indexOf","propertyIsEnumerable","_Input","_ref","ref","_variants$error","_variants$disclaimer","error","placeholder","hideError","icon","Icon","autoFocus","disclaimer","multiline","decoration","containerProps","className","localClassName","otherProps","useOneUIConfig","variants","focused","setFocused","useState","inputRef","useRef","useImperativeHandle","current","shouldShowError","useMemo","useEffect","setTimeout","focus","clearTimeout","Component","createElement","concat","container","Styles","inputContainer","withIcon","rows","input","onFocus","onBlur","direction","key","title","type","Fragment","Input","forwardRef","_default","exports"],"sources":["../../../src/components/Input/Input.tsx"],"sourcesContent":["import React, {\n  ChangeEventHandler,\n  DetailedHTMLProps,\n  ForwardedRef,\n  forwardRef,\n  Fragment,\n  ReactElement,\n  useEffect,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { useOneUIConfig } from \"../../context/OneUIProvider\";\nimport Text from \"../Text\";\nimport Styles from \"./Input.module.scss\";\nimport AdaptiveContainer from \"../AdaptiveContainer\";\n\nexport type InputProps = {\n  decoration?: React.ReactElement | null;\n  error?: string | ReactElement;\n  hideError?: \"onfocus\";\n  placeholder?: string;\n  disclaimer?: string | ReactElement;\n  multiline?: number;\n  icon?: {\n    onClick?: () => void;\n  } & DetailedHTMLProps<React.ImgHTMLAttributes<HTMLImageElement>, any>;\n  Icon?: React.ReactElement;\n  onChange?: ChangeEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n  containerProps?: Omit<React.HTMLProps<HTMLDivElement>, \"ref\">;\n  value?: string;\n  \"data-testid\"?: string;\n} & Omit<\n  React.HTMLProps<HTMLInputElement | HTMLTextAreaElement>,\n  \"ref\" | \"onChange\" | \"value\"\n>;\nfunction _Input(\n  {\n    error,\n    placeholder = \" \",\n    hideError,\n    icon,\n    Icon,\n    autoFocus,\n    disclaimer,\n    multiline,\n    decoration = null,\n    containerProps,\n    className: localClassName,\n    ...otherProps\n  }: InputProps,\n  ref: ForwardedRef<any>,\n) {\n  const className = useOneUIConfig(\"component.input.className\", {});\n  const variants = useOneUIConfig(\"component.input.labelVariants\", {});\n  const [focused, setFocused] = useState(false);\n  const inputRef = useRef<HTMLInputElement | HTMLTextAreaElement>(null);\n  useImperativeHandle(ref, () => inputRef.current, []);\n  const shouldShowError = useMemo(() => {\n    if (hideError === \"onfocus\") return !focused;\n    return !!error;\n  }, [focused, error, hideError]);\n  useEffect(() => {\n    if (autoFocus) {\n      const t = setTimeout(() => {\n        inputRef.current!.focus();\n      }, 500);\n      return () => clearTimeout(t);\n    }\n  }, [autoFocus]);\n  const Component = multiline ? \"textarea\" : \"input\";\n  return (\n    <div className={`${className.container} ${localClassName}`}>\n      <div\n        className={`${Styles.inputContainer} ${false ? Styles.withIcon : \"\"}`}\n        {...containerProps}\n      >\n        {decoration}\n        <Component\n          ref={inputRef as any}\n          placeholder={placeholder}\n          rows={multiline}\n          className={className.input}\n          {...otherProps}\n          onFocus={(e) => {\n            setFocused(true);\n            if (otherProps.onFocus) otherProps.onFocus(e);\n          }}\n          onBlur={(e) => {\n            setFocused(false);\n            if (otherProps.onBlur) otherProps.onBlur(e);\n          }}\n        />\n        {Icon && <div className={Styles.icon}>{Icon}</div>}\n        {icon && <img className={Styles.icon} {...icon} />}\n      </div>\n      <AdaptiveContainer direction=\"v\">\n        {error && shouldShowError ? (\n          <Text\n            key={\"error\"}\n            title={typeof error === \"string\" ? error : \"\"}\n            type={variants.error ?? \"error\"}\n          >\n            {error}\n          </Text>\n        ) : disclaimer ? (\n          <Text\n            key={\"t\"}\n            title={typeof disclaimer === \"string\" ? disclaimer : \"\"}\n            type={variants.disclaimer ?? \"caption\"}\n          >\n            {disclaimer}\n          </Text>\n        ) : (\n          <Fragment key={\"e\"} />\n        )}\n      </AdaptiveContainer>\n    </div>\n  );\n}\n\n/**\n * A transparent input with some prebuilt states common to the application\n **/\nconst Input = forwardRef(_Input);\nexport default Input;\n"],"mappings":"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","ignoreList":[]}
103
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_OneUIProvider","_Text","_interopRequireDefault","_InputModule","_AdaptiveContainer","_excluded","e","__esModule","default","t","WeakMap","r","n","o","i","f","__proto__","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","_extends","assign","bind","arguments","length","apply","_objectWithoutProperties","_objectWithoutPropertiesLoose","getOwnPropertySymbols","indexOf","propertyIsEnumerable","_Input","_ref","ref","_variants$error","_variants$disclaimer","error","placeholder","hideError","icon","Icon","autoFocus","disclaimer","multiline","decoration","containerProps","className","localClassName","otherProps","useOneUIConfig","variants","focused","setFocused","useState","inputRef","useRef","useImperativeHandle","current","shouldShowError","useMemo","useEffect","setTimeout","focus","clearTimeout","Component","containerRef","maxWidth","_containerRef$current","getBoundingClientRect","width","createElement","concat","container","Styles","inputContainer","withIcon","rows","input","onFocus","onBlur","direction","style","key","title","type","Fragment","Input","forwardRef","_default","exports"],"sources":["../../../src/components/Input/Input.tsx"],"sourcesContent":["import React, {\n  ChangeEventHandler,\n  ComponentRef,\n  DetailedHTMLProps,\n  ForwardedRef,\n  forwardRef,\n  Fragment,\n  ReactElement,\n  useEffect,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { useOneUIConfig } from \"../../context/OneUIProvider\";\nimport Text from \"../Text\";\nimport Styles from \"./Input.module.scss\";\nimport AdaptiveContainer from \"../AdaptiveContainer\";\n\nexport type InputProps = {\n  decoration?: React.ReactElement | null;\n  error?: string | ReactElement;\n  hideError?: \"onfocus\";\n  placeholder?: string;\n  disclaimer?: string | ReactElement;\n  multiline?: number;\n  icon?: {\n    onClick?: () => void;\n  } & DetailedHTMLProps<React.ImgHTMLAttributes<HTMLImageElement>, any>;\n  Icon?: React.ReactElement;\n  onChange?: ChangeEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n  containerProps?: Omit<React.HTMLProps<HTMLDivElement>, \"ref\">;\n  value?: string;\n  \"data-testid\"?: string;\n} & Omit<\n  React.HTMLProps<HTMLInputElement | HTMLTextAreaElement>,\n  \"ref\" | \"onChange\" | \"value\"\n>;\nfunction _Input(\n  {\n    error,\n    placeholder = \" \",\n    hideError,\n    icon,\n    Icon,\n    autoFocus,\n    disclaimer,\n    multiline,\n    decoration = null,\n    containerProps,\n    className: localClassName,\n    ...otherProps\n  }: InputProps,\n  ref: ForwardedRef<any>,\n) {\n  const className = useOneUIConfig(\"component.input.className\", {});\n  const variants = useOneUIConfig(\"component.input.labelVariants\", {});\n  const [focused, setFocused] = useState(false);\n  const inputRef = useRef<HTMLInputElement | HTMLTextAreaElement>(null);\n  useImperativeHandle(ref, () => inputRef.current, []);\n  const shouldShowError = useMemo(() => {\n    if (hideError === \"onfocus\") return !focused;\n    return !!error;\n  }, [focused, error, hideError]);\n  useEffect(() => {\n    if (autoFocus) {\n      const t = setTimeout(() => {\n        inputRef.current!.focus();\n      }, 500);\n      return () => clearTimeout(t);\n    }\n  }, [autoFocus]);\n  const Component = multiline ? \"textarea\" : \"input\";\n  const containerRef = useRef<ComponentRef<\"div\">>(null);\n  const maxWidth = useMemo(\n    () => containerRef.current?.getBoundingClientRect().width,\n    [error, disclaimer],\n  );\n  return (\n    <div className={`${className.container} ${localClassName}`}>\n      <div\n        className={`${Styles.inputContainer} ${false ? Styles.withIcon : \"\"}`}\n        ref={containerRef}\n        {...containerProps}\n      >\n        {decoration}\n        <Component\n          ref={inputRef as any}\n          placeholder={placeholder}\n          rows={multiline}\n          className={className.input}\n          {...otherProps}\n          onFocus={(e) => {\n            setFocused(true);\n            if (otherProps.onFocus) otherProps.onFocus(e);\n          }}\n          onBlur={(e) => {\n            setFocused(false);\n            if (otherProps.onBlur) otherProps.onBlur(e);\n          }}\n        />\n        {Icon && <div className={Styles.icon}>{Icon}</div>}\n        {icon && <img className={Styles.icon} {...icon} />}\n      </div>\n      <AdaptiveContainer direction=\"v\" style={{ maxWidth: maxWidth }}>\n        {error && shouldShowError ? (\n          <Text\n            key={\"error\"}\n            title={typeof error === \"string\" ? error : \"\"}\n            type={variants.error ?? \"error\"}\n          >\n            {error}\n          </Text>\n        ) : disclaimer ? (\n          <Text\n            key={\"t\"}\n            title={typeof disclaimer === \"string\" ? disclaimer : \"\"}\n            type={variants.disclaimer ?? \"caption\"}\n          >\n            {disclaimer}\n          </Text>\n        ) : (\n          <Fragment key={\"e\"} />\n        )}\n      </AdaptiveContainer>\n    </div>\n  );\n}\n\n/**\n * A transparent input with some prebuilt states common to the application\n **/\nconst Input = forwardRef(_Input);\nexport default Input;\n"],"mappings":"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","ignoreList":[]}
@@ -10,7 +10,7 @@ import CheckBox from "../components/CheckBox";
10
10
  import Radio from "../components/Radio/Radio";
11
11
  import { FileInputViewProps } from "../components/FileInput/View/View.types";
12
12
  import { AnswerByField, FormField, GenericFormFieldProps } from "../components/Form/FormField/FormField.types";
13
- import { BaseQuestion, FormMode } from "../components/Form/Form.types";
13
+ import { FormMode } from "../components/Form/Form.types";
14
14
  type DeepPartial<T> = {
15
15
  [P in keyof T]?: NonNullable<T[P]> extends Function ? T[P] : DeepPartial<T[P]>;
16
16
  };
@@ -47,7 +47,7 @@ export type OneUIContextSpecs = {
47
47
  Input: (props: GenericFormFieldProps<K>) => ReactElement;
48
48
  validator: (answer: AnswerByField<{
49
49
  type: K;
50
- }> | undefined, question: BaseQuestion & (FromOnePercentUtility<"UIElements.FormExtension">["fields"] & {
50
+ }> | undefined, question: FormField & (FromOnePercentUtility<"UIElements.FormExtension">["fields"] & {
51
51
  type: K;
52
52
  })) => {
53
53
  isValid: boolean;
@@ -96,4 +96,4 @@ function useCurrentImageScale() {
96
96
  const context = (0, _react.useContext)(Context);
97
97
  return context.state.imageScale;
98
98
  }
99
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_get","_interopRequireDefault","require","_merge","_cloneDeep","_react","_interopRequireWildcard","_useAdaptiveImage","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","Context","createContext","OneUIProvider","_ref","children","config","prevCtx","useContext","scale","useAdaptiveImage","mergedConfig","useMemo","merge","clone","state","imageScale","createElement","Provider","value","_default","exports","pathToJson","path","key","exampleConfig","arguments","length","undefined","split","slice","replace","concat","reduce","result","idx","arr","k","ErrorWrapper","originalObject","Proxy","_target","Symbol","toPrimitive","filter","Boolean","join","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 { JSX } from \"react\";\nimport 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 { ImageScales } from \"@muritavo/webpack-microfrontend-scripts/bin/types/ImageScales\";\nimport { UploadTask } from \"firebase/storage\";\nimport {\n  FieldPath,\n  FromOnePercentUtility,\n  NamespaceAccessors,\n  Path,\n  PathObject,\n} from \"../type-utils\";\nimport useAdaptiveImage from \"../hooks/ui/useAdaptiveImage\";\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  FormField,\n  GenericFormFieldProps,\n} from \"../components/Form/FormField/FormField.types\";\nimport { BaseQuestion, FormMode } from \"../components/Form/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\ntype IfUtilityHas<N extends NamespaceAccessors, Declare> =\n  FromOnePercentUtility<N> extends `To define this property you need to set OnepercentUtility.${string} globally`\n    ? undefined\n    : Declare;\n\nexport type OneUIContextSpecs = {\n  component: {\n    asyncTriggerContainer: {\n      LoadingComponent: () => ReactElement;\n    };\n    spacing: {\n      variants: {\n        [k in FromOnePercentUtility<\"UIElements.SpacingVariants\">]: string;\n      };\n    };\n    collapsable: {\n      className: string;\n    };\n    form: {\n      fieldWrapper: {\n        [k in `${keyof typeof FormMode}-${FormField[\"type\"]}`]:\n          | string\n          | ((p: PropsWithChildren<FormField & { value: any }>) => ReactNode);\n      };\n      titleVariant: FromOnePercentUtility<\"UIElements.TextVariants\">;\n      labelVariant: FromOnePercentUtility<\"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: IfUtilityHas<\n        \"UIElements.FormExtension\",\n        {\n          [K in FromOnePercentUtility<\"UIElements.FormExtension\">[\"fields\"][\"type\"]]: {\n            ReadOnly?: (\n              props: Omit<GenericFormFieldProps<K>, \"onAnswer\" | \"error\">,\n            ) => ReactElement;\n            Input: (props: GenericFormFieldProps<K>) => ReactElement;\n            validator: (\n              answer: AnswerByField<{ type: K }> | undefined,\n              question: BaseQuestion &\n                (FromOnePercentUtility<\"UIElements.FormExtension\">[\"fields\"] & {\n                  type: K;\n                }),\n            ) => {\n              isValid: boolean;\n              error?: string;\n            };\n          };\n        }\n      >;\n    };\n    text: IfUtilityHas<\n      \"UIElements.TextVariants\",\n      {\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    >;\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: {\n        /** The wrapper around input tag & caption element (used for error and caption) */\n        container: string;\n        /** The input html tag */\n        input: string;\n      };\n      labelVariants: {\n        error?: FromOnePercentUtility<\"UIElements.TextVariants\">;\n        disclaimer?: FromOnePercentUtility<\"UIElements.TextVariants\">;\n      };\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 FromOnePercentUtility<\"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    tabs: {\n      item: string;\n      container: string;\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\nexport type ContextConfigSpecs = DeepPartial<OneUIContextSpecs> &\n  PathObject<OneUIContextSpecs, \"component.text\">;\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 || key === \"$$typeof\") {\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<P extends FieldPath<OneUIContextSpecs>>(\n  prop: P,\n): Get<OneUIContextSpecs, P>;\nexport function useOneUIConfig<\n  P extends FieldPath<OneUIContextSpecs>,\n  T extends DeepPartial<Get<OneUIContextSpecs, P>>,\n>(prop: P, defaultValue: T): NonNullable<Get<OneUIContextSpecs, P>>;\nexport function useOneUIConfig<\n  P extends FieldPath<OneUIContextSpecs>,\n  T extends Get<OneUIContextSpecs, P>,\n>(prop: P, defaultValue?: T): Get<OneUIContextSpecs, P> | T {\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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","ignoreList":[]}
99
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_get","_interopRequireDefault","require","_merge","_cloneDeep","_react","_interopRequireWildcard","_useAdaptiveImage","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","Context","createContext","OneUIProvider","_ref","children","config","prevCtx","useContext","scale","useAdaptiveImage","mergedConfig","useMemo","merge","clone","state","imageScale","createElement","Provider","value","_default","exports","pathToJson","path","key","exampleConfig","arguments","length","undefined","split","slice","replace","concat","reduce","result","idx","arr","k","ErrorWrapper","originalObject","Proxy","_target","Symbol","toPrimitive","filter","Boolean","join","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 { JSX } from \"react\";\nimport 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 { ImageScales } from \"@muritavo/webpack-microfrontend-scripts/bin/types/ImageScales\";\nimport { UploadTask } from \"firebase/storage\";\nimport {\n  FieldPath,\n  FromOnePercentUtility,\n  NamespaceAccessors,\n  Path,\n  PathObject,\n} from \"../type-utils\";\nimport useAdaptiveImage from \"../hooks/ui/useAdaptiveImage\";\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  FormField,\n  GenericFormFieldProps,\n} from \"../components/Form/FormField/FormField.types\";\nimport { BaseQuestion, FormMode } from \"../components/Form/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\ntype IfUtilityHas<N extends NamespaceAccessors, Declare> =\n  FromOnePercentUtility<N> extends `To define this property you need to set OnepercentUtility.${string} globally`\n    ? undefined\n    : Declare;\n\nexport type OneUIContextSpecs = {\n  component: {\n    asyncTriggerContainer: {\n      LoadingComponent: () => ReactElement;\n    };\n    spacing: {\n      variants: {\n        [k in FromOnePercentUtility<\"UIElements.SpacingVariants\">]: string;\n      };\n    };\n    collapsable: {\n      className: string;\n    };\n    form: {\n      fieldWrapper: {\n        [k in `${keyof typeof FormMode}-${FormField[\"type\"]}`]:\n          | string\n          | ((p: PropsWithChildren<FormField & { value: any }>) => ReactNode);\n      };\n      titleVariant: FromOnePercentUtility<\"UIElements.TextVariants\">;\n      labelVariant: FromOnePercentUtility<\"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: IfUtilityHas<\n        \"UIElements.FormExtension\",\n        {\n          [K in FromOnePercentUtility<\"UIElements.FormExtension\">[\"fields\"][\"type\"]]: {\n            ReadOnly?: (\n              props: Omit<GenericFormFieldProps<K>, \"onAnswer\" | \"error\">,\n            ) => ReactElement;\n            Input: (props: GenericFormFieldProps<K>) => ReactElement;\n            validator: (\n              answer: AnswerByField<{ type: K }> | undefined,\n              question: FormField &\n                (FromOnePercentUtility<\"UIElements.FormExtension\">[\"fields\"] & {\n                  type: K;\n                }),\n            ) => {\n              isValid: boolean;\n              error?: string;\n            };\n          };\n        }\n      >;\n    };\n    text: IfUtilityHas<\n      \"UIElements.TextVariants\",\n      {\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    >;\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: {\n        /** The wrapper around input tag & caption element (used for error and caption) */\n        container: string;\n        /** The input html tag */\n        input: string;\n      };\n      labelVariants: {\n        error?: FromOnePercentUtility<\"UIElements.TextVariants\">;\n        disclaimer?: FromOnePercentUtility<\"UIElements.TextVariants\">;\n      };\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 FromOnePercentUtility<\"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    tabs: {\n      item: string;\n      container: string;\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\nexport type ContextConfigSpecs = DeepPartial<OneUIContextSpecs> &\n  PathObject<OneUIContextSpecs, \"component.text\">;\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 || key === \"$$typeof\") {\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<P extends FieldPath<OneUIContextSpecs>>(\n  prop: P,\n): Get<OneUIContextSpecs, P>;\nexport function useOneUIConfig<\n  P extends FieldPath<OneUIContextSpecs>,\n  T extends DeepPartial<Get<OneUIContextSpecs, P>>,\n>(prop: P, defaultValue: T): NonNullable<Get<OneUIContextSpecs, P>>;\nexport function useOneUIConfig<\n  P extends FieldPath<OneUIContextSpecs>,\n  T extends Get<OneUIContextSpecs, P>,\n>(prop: P, defaultValue?: T): Get<OneUIContextSpecs, P> | T {\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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","ignoreList":[]}
@@ -24,7 +24,9 @@ function _Input({ error, placeholder = " ", hideError, icon, Icon, autoFocus, di
24
24
  }
25
25
  }, [autoFocus]);
26
26
  const Component = multiline ? "textarea" : "input";
27
- return (_jsxs("div", { className: `${className.container} ${localClassName}`, children: [_jsxs("div", { className: `${Styles.inputContainer} ${false ? Styles.withIcon : ""}`, ...containerProps, children: [decoration, _jsx(Component, { ref: inputRef, placeholder: placeholder, rows: multiline, className: className.input, ...otherProps, onFocus: (e) => {
27
+ const containerRef = useRef(null);
28
+ const maxWidth = useMemo(() => containerRef.current?.getBoundingClientRect().width, [error, disclaimer]);
29
+ return (_jsxs("div", { className: `${className.container} ${localClassName}`, children: [_jsxs("div", { className: `${Styles.inputContainer} ${false ? Styles.withIcon : ""}`, ref: containerRef, ...containerProps, children: [decoration, _jsx(Component, { ref: inputRef, placeholder: placeholder, rows: multiline, className: className.input, ...otherProps, onFocus: (e) => {
28
30
  setFocused(true);
29
31
  if (otherProps.onFocus)
30
32
  otherProps.onFocus(e);
@@ -32,7 +34,7 @@ function _Input({ error, placeholder = " ", hideError, icon, Icon, autoFocus, di
32
34
  setFocused(false);
33
35
  if (otherProps.onBlur)
34
36
  otherProps.onBlur(e);
35
- } }), Icon && _jsx("div", { className: Styles.icon, children: Icon }), icon && _jsx("img", { className: Styles.icon, ...icon })] }), _jsx(AdaptiveContainer, { direction: "v", children: error && shouldShowError ? (_jsx(Text, { title: typeof error === "string" ? error : "", type: variants.error ?? "error", children: error }, "error")) : disclaimer ? (_jsx(Text, { title: typeof disclaimer === "string" ? disclaimer : "", type: variants.disclaimer ?? "caption", children: disclaimer }, "t")) : (_jsx(Fragment, {}, "e")) })] }));
37
+ } }), Icon && _jsx("div", { className: Styles.icon, children: Icon }), icon && _jsx("img", { className: Styles.icon, ...icon })] }), _jsx(AdaptiveContainer, { direction: "v", style: { maxWidth: maxWidth }, children: error && shouldShowError ? (_jsx(Text, { title: typeof error === "string" ? error : "", type: variants.error ?? "error", children: error }, "error")) : disclaimer ? (_jsx(Text, { title: typeof disclaimer === "string" ? disclaimer : "", type: variants.disclaimer ?? "caption", children: disclaimer }, "t")) : (_jsx(Fragment, {}, "e")) })] }));
36
38
  }
37
39
  /**
38
40
  * A transparent input with some prebuilt states common to the application
@@ -1 +1 @@
1
- {"version":3,"file":"Input.js","sourceRoot":"","sources":["../../../src/components/Input/Input.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Input.js","sourceRoot":"","sources":["../../../src/components/Input/Input.tsx"],"names":[],"mappings":";AAAA,OAAc,EAKZ,UAAU,EACV,QAAQ,EAER,SAAS,EACT,mBAAmB,EACnB,OAAO,EACP,MAAM,EACN,QAAQ,GACT,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,IAAI,MAAM,SAAS,CAAC;AAC3B,OAAO,MAAM,MAAM,qBAAqB,CAAC;AACzC,OAAO,iBAAiB,MAAM,sBAAsB,CAAC;AAqBrD,SAAS,MAAM,CACb,EACE,KAAK,EACL,WAAW,GAAG,GAAG,EACjB,SAAS,EACT,IAAI,EACJ,IAAI,EACJ,SAAS,EACT,UAAU,EACV,SAAS,EACT,UAAU,GAAG,IAAI,EACjB,cAAc,EACd,SAAS,EAAE,cAAc,EACzB,GAAG,UAAU,EACF,EACb,GAAsB;IAEtB,MAAM,SAAS,GAAG,cAAc,CAAC,2BAA2B,EAAE,EAAE,CAAC,CAAC;IAClE,MAAM,QAAQ,GAAG,cAAc,CAAC,+BAA+B,EAAE,EAAE,CAAC,CAAC;IACrE,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC9C,MAAM,QAAQ,GAAG,MAAM,CAAyC,IAAI,CAAC,CAAC;IACtE,mBAAmB,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;IACrD,MAAM,eAAe,GAAG,OAAO,CAAC,GAAG,EAAE;QACnC,IAAI,SAAS,KAAK,SAAS;YAAE,OAAO,CAAC,OAAO,CAAC;QAC7C,OAAO,CAAC,CAAC,KAAK,CAAC;IACjB,CAAC,EAAE,CAAC,OAAO,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC,CAAC;IAChC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,SAAS,EAAE,CAAC;YACd,MAAM,CAAC,GAAG,UAAU,CAAC,GAAG,EAAE;gBACxB,QAAQ,CAAC,OAAQ,CAAC,KAAK,EAAE,CAAC;YAC5B,CAAC,EAAE,GAAG,CAAC,CAAC;YACR,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC/B,CAAC;IACH,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IAChB,MAAM,SAAS,GAAG,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC;IACnD,MAAM,YAAY,GAAG,MAAM,CAAsB,IAAI,CAAC,CAAC;IACvD,MAAM,QAAQ,GAAG,OAAO,CACtB,GAAG,EAAE,CAAC,YAAY,CAAC,OAAO,EAAE,qBAAqB,EAAE,CAAC,KAAK,EACzD,CAAC,KAAK,EAAE,UAAU,CAAC,CACpB,CAAC;IACF,OAAO,CACL,eAAK,SAAS,EAAE,GAAG,SAAS,CAAC,SAAS,IAAI,cAAc,EAAE,aACxD,eACE,SAAS,EAAE,GAAG,MAAM,CAAC,cAAc,IAAI,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,EACrE,GAAG,EAAE,YAAY,KACb,cAAc,aAEjB,UAAU,EACX,KAAC,SAAS,IACR,GAAG,EAAE,QAAe,EACpB,WAAW,EAAE,WAAW,EACxB,IAAI,EAAE,SAAS,EACf,SAAS,EAAE,SAAS,CAAC,KAAK,KACtB,UAAU,EACd,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE;4BACb,UAAU,CAAC,IAAI,CAAC,CAAC;4BACjB,IAAI,UAAU,CAAC,OAAO;gCAAE,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;wBAChD,CAAC,EACD,MAAM,EAAE,CAAC,CAAC,EAAE,EAAE;4BACZ,UAAU,CAAC,KAAK,CAAC,CAAC;4BAClB,IAAI,UAAU,CAAC,MAAM;gCAAE,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;wBAC9C,CAAC,GACD,EACD,IAAI,IAAI,cAAK,SAAS,EAAE,MAAM,CAAC,IAAI,YAAG,IAAI,GAAO,EACjD,IAAI,IAAI,cAAK,SAAS,EAAE,MAAM,CAAC,IAAI,KAAM,IAAI,GAAI,IAC9C,EACN,KAAC,iBAAiB,IAAC,SAAS,EAAC,GAAG,EAAC,KAAK,EAAE,EAAE,QAAQ,EAAE,QAAQ,EAAE,YAC3D,KAAK,IAAI,eAAe,CAAC,CAAC,CAAC,CAC1B,KAAC,IAAI,IAEH,KAAK,EAAE,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAC7C,IAAI,EAAE,QAAQ,CAAC,KAAK,IAAI,OAAO,YAE9B,KAAK,IAJD,OAAO,CAKP,CACR,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CACf,KAAC,IAAI,IAEH,KAAK,EAAE,OAAO,UAAU,KAAK,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,EACvD,IAAI,EAAE,QAAQ,CAAC,UAAU,IAAI,SAAS,YAErC,UAAU,IAJN,GAAG,CAKH,CACR,CAAC,CAAC,CAAC,CACF,KAAC,QAAQ,MAAM,GAAG,CAAI,CACvB,GACiB,IAChB,CACP,CAAC;AACJ,CAAC;AAED;;IAEI;AACJ,MAAM,KAAK,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC;AACjC,eAAe,KAAK,CAAC"}
@@ -10,7 +10,7 @@ import CheckBox from "../components/CheckBox";
10
10
  import Radio from "../components/Radio/Radio";
11
11
  import { FileInputViewProps } from "../components/FileInput/View/View.types";
12
12
  import { AnswerByField, FormField, GenericFormFieldProps } from "../components/Form/FormField/FormField.types";
13
- import { BaseQuestion, FormMode } from "../components/Form/Form.types";
13
+ import { FormMode } from "../components/Form/Form.types";
14
14
  type DeepPartial<T> = {
15
15
  [P in keyof T]?: NonNullable<T[P]> extends Function ? T[P] : DeepPartial<T[P]>;
16
16
  };
@@ -47,7 +47,7 @@ export type OneUIContextSpecs = {
47
47
  Input: (props: GenericFormFieldProps<K>) => ReactElement;
48
48
  validator: (answer: AnswerByField<{
49
49
  type: K;
50
- }> | undefined, question: BaseQuestion & (FromOnePercentUtility<"UIElements.FormExtension">["fields"] & {
50
+ }> | undefined, question: FormField & (FromOnePercentUtility<"UIElements.FormExtension">["fields"] & {
51
51
  type: K;
52
52
  })) => {
53
53
  isValid: boolean;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@onepercentio/one-ui",
3
- "version": "1.2.1",
3
+ "version": "1.2.2",
4
4
  "description": "A set of reusable components created through the development of Onepercent projects",
5
5
  "repository": "git@github.com:onepercentio/one-ui.git",
6
6
  "author": "Murilo Oliveira de Araujo <murilo.araujo@onepercent.io>",