@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.
- package/WebpackConfigs/email-templates.js +33 -22
- package/WebpackConfigs/loaders/static-loader.js +10 -3
- package/dist/components/Input/Input.js +12 -3
- package/dist/context/OneUIProvider.d.ts +2 -2
- package/dist/context/OneUIProvider.js +1 -1
- package/dist-ts/components/Input/Input.js +4 -2
- package/dist-ts/components/Input/Input.js.map +1 -1
- package/dist-ts/context/OneUIProvider.d.ts +2 -2
- package/package.json +1 -1
|
@@ -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
|
|
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
|
-
|
|
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":";;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AAcA,IAAAC,cAAA,GAAAD,OAAA;AACA,IAAAE,KAAA,GAAAC,sBAAA,CAAAH,OAAA;AACA,IAAAI,YAAA,GAAAD,sBAAA,CAAAH,OAAA;AACA,IAAAK,kBAAA,GAAAF,sBAAA,CAAAH,OAAA;AAAqD,MAAAM,SAAA;AAAA,SAAAH,uBAAAI,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAAA,SAAAR,wBAAAQ,CAAA,EAAAG,CAAA,6BAAAC,OAAA,MAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAZ,uBAAA,YAAAA,CAAAQ,CAAA,EAAAG,CAAA,SAAAA,CAAA,IAAAH,CAAA,IAAAA,CAAA,CAAAC,UAAA,SAAAD,CAAA,MAAAO,CAAA,EAAAC,CAAA,EAAAC,CAAA,KAAAC,SAAA,QAAAR,OAAA,EAAAF,CAAA,iBAAAA,CAAA,uBAAAA,CAAA,yBAAAA,CAAA,SAAAS,CAAA,MAAAF,CAAA,GAAAJ,CAAA,GAAAG,CAAA,GAAAD,CAAA,QAAAE,CAAA,CAAAI,GAAA,CAAAX,CAAA,UAAAO,CAAA,CAAAK,GAAA,CAAAZ,CAAA,GAAAO,CAAA,CAAAM,GAAA,CAAAb,CAAA,EAAAS,CAAA,gBAAAN,CAAA,IAAAH,CAAA,gBAAAG,CAAA,OAAAW,cAAA,CAAAC,IAAA,CAAAf,CAAA,EAAAG,CAAA,OAAAK,CAAA,IAAAD,CAAA,GAAAS,MAAA,CAAAC,cAAA,KAAAD,MAAA,CAAAE,wBAAA,CAAAlB,CAAA,EAAAG,CAAA,OAAAK,CAAA,CAAAI,GAAA,IAAAJ,CAAA,CAAAK,GAAA,IAAAN,CAAA,CAAAE,CAAA,EAAAN,CAAA,EAAAK,CAAA,IAAAC,CAAA,CAAAN,CAAA,IAAAH,CAAA,CAAAG,CAAA,WAAAM,CAAA,KAAAT,CAAA,EAAAG,CAAA;AAAA,SAAAgB,SAAA,WAAAA,QAAA,GAAAH,MAAA,CAAAI,MAAA,GAAAJ,MAAA,CAAAI,MAAA,CAAAC,IAAA,eAAAf,CAAA,aAAAN,CAAA,MAAAA,CAAA,GAAAsB,SAAA,CAAAC,MAAA,EAAAvB,CAAA,UAAAG,CAAA,GAAAmB,SAAA,CAAAtB,CAAA,YAAAK,CAAA,IAAAF,CAAA,OAAAW,cAAA,CAAAC,IAAA,CAAAZ,CAAA,EAAAE,CAAA,MAAAC,CAAA,CAAAD,CAAA,IAAAF,CAAA,CAAAE,CAAA,aAAAC,CAAA,KAAAa,QAAA,CAAAK,KAAA,OAAAF,SAAA;AAAA,SAAAG,yBAAAzB,CAAA,EAAAG,CAAA,gBAAAH,CAAA,iBAAAO,CAAA,EAAAF,CAAA,EAAAG,CAAA,GAAAkB,6BAAA,CAAA1B,CAAA,EAAAG,CAAA,OAAAa,MAAA,CAAAW,qBAAA,QAAArB,CAAA,GAAAU,MAAA,CAAAW,qBAAA,CAAA3B,CAAA,QAAAK,CAAA,MAAAA,CAAA,GAAAC,CAAA,CAAAiB,MAAA,EAAAlB,CAAA,IAAAE,CAAA,GAAAD,CAAA,CAAAD,CAAA,UAAAF,CAAA,CAAAyB,OAAA,CAAArB,CAAA,QAAAsB,oBAAA,CAAAd,IAAA,CAAAf,CAAA,EAAAO,CAAA,MAAAC,CAAA,CAAAD,CAAA,IAAAP,CAAA,CAAAO,CAAA,aAAAC,CAAA;AAAA,SAAAkB,8BAAArB,CAAA,EAAAL,CAAA,gBAAAK,CAAA,iBAAAF,CAAA,gBAAAG,CAAA,IAAAD,CAAA,SAAAS,cAAA,CAAAC,IAAA,CAAAV,CAAA,EAAAC,CAAA,gBAAAN,CAAA,CAAA4B,OAAA,CAAAtB,CAAA,aAAAH,CAAA,CAAAG,CAAA,IAAAD,CAAA,CAAAC,CAAA,YAAAH,CAAA;AAqBrD,SAAS2B,MAAMA,CAAAC,IAAA,EAebC,GAAsB,EACtB;EAAA,IAAAC,eAAA,EAAAC,oBAAA;EAAA,IAfA;MACEC,KAAK;MACLC,WAAW,GAAG,GAAG;MACjBC,SAAS;MACTC,IAAI;MACJC,IAAI;MACJC,SAAS;MACTC,UAAU;MACVC,SAAS;MACTC,UAAU,GAAG,IAAI;MACjBC,cAAc;MACdC,SAAS,EAAEC;IAED,CAAC,GAAAf,IAAA;IADRgB,UAAU,GAAAtB,wBAAA,CAAAM,IAAA,EAAAhC,SAAA;EAIf,MAAM8C,SAAS,GAAG,IAAAG,6BAAc,EAAC,2BAA2B,EAAE,CAAC,CAAC,CAAC;EACjE,MAAMC,QAAQ,GAAG,IAAAD,6BAAc,EAAC,+BAA+B,EAAE,CAAC,CAAC,CAAC;EACpE,MAAM,CAACE,OAAO,EAAEC,UAAU,CAAC,GAAG,IAAAC,eAAQ,EAAC,KAAK,CAAC;EAC7C,MAAMC,QAAQ,GAAG,IAAAC,aAAM,EAAyC,IAAI,CAAC;EACrE,IAAAC,0BAAmB,EAACvB,GAAG,EAAE,MAAMqB,QAAQ,CAACG,OAAO,EAAE,EAAE,CAAC;EACpD,MAAMC,eAAe,GAAG,IAAAC,cAAO,EAAC,MAAM;IACpC,IAAIrB,SAAS,KAAK,SAAS,EAAE,OAAO,CAACa,OAAO;IAC5C,OAAO,CAAC,CAACf,KAAK;EAChB,CAAC,EAAE,CAACe,OAAO,EAAEf,KAAK,EAAEE,SAAS,CAAC,CAAC;EAC/B,IAAAsB,gBAAS,EAAC,MAAM;IACd,IAAInB,SAAS,EAAE;MACb,MAAMrC,CAAC,GAAGyD,UAAU,CAAC,MAAM;QACzBP,QAAQ,CAACG,OAAO,CAAEK,KAAK,CAAC,CAAC;MAC3B,CAAC,EAAE,GAAG,CAAC;MACP,OAAO,MAAMC,YAAY,CAAC3D,CAAC,CAAC;IAC9B;EACF,CAAC,EAAE,CAACqC,SAAS,CAAC,CAAC;EACf,MAAMuB,SAAS,GAAGrB,SAAS,GAAG,UAAU,GAAG,OAAO;EAClD,MAAMsB,YAAY,GAAG,IAAAV,aAAM,EAAsB,IAAI,CAAC;EACtD,MAAMW,QAAQ,GAAG,IAAAP,cAAO,EACtB;IAAA,IAAAQ,qBAAA;IAAA,QAAAA,qBAAA,GAAMF,YAAY,CAACR,OAAO,cAAAU,qBAAA,uBAApBA,qBAAA,CAAsBC,qBAAqB,CAAC,CAAC,CAACC,KAAK;EAAA,GACzD,CAACjC,KAAK,EAAEM,UAAU,CACpB,CAAC;EACD,oBACElD,MAAA,CAAAW,OAAA,CAAAmE,aAAA;IAAKxB,SAAS,KAAAyB,MAAA,CAAKzB,SAAS,CAAC0B,SAAS,OAAAD,MAAA,CAAIxB,cAAc;EAAG,gBACzDvD,MAAA,CAAAW,OAAA,CAAAmE,aAAA,QAAAlD,QAAA;IACE0B,SAAS,KAAAyB,MAAA,CAAKE,oBAAM,CAACC,cAAc,OAAAH,MAAA,CAAI,KAAK,GAAGE,oBAAM,CAACE,QAAQ,GAAG,EAAE,CAAG;IACtE1C,GAAG,EAAEgC;EAAa,GACdpB,cAAc,GAEjBD,UAAU,eACXpD,MAAA,CAAAW,OAAA,CAAAmE,aAAA,CAACN,SAAS,EAAA5C,QAAA;IACRa,GAAG,EAAEqB,QAAgB;IACrBjB,WAAW,EAAEA,WAAY;IACzBuC,IAAI,EAAEjC,SAAU;IAChBG,SAAS,EAAEA,SAAS,CAAC+B;EAAM,GACvB7B,UAAU;IACd8B,OAAO,EAAG7E,CAAC,IAAK;MACdmD,UAAU,CAAC,IAAI,CAAC;MAChB,IAAIJ,UAAU,CAAC8B,OAAO,EAAE9B,UAAU,CAAC8B,OAAO,CAAC7E,CAAC,CAAC;IAC/C,CAAE;IACF8E,MAAM,EAAG9E,CAAC,IAAK;MACbmD,UAAU,CAAC,KAAK,CAAC;MACjB,IAAIJ,UAAU,CAAC+B,MAAM,EAAE/B,UAAU,CAAC+B,MAAM,CAAC9E,CAAC,CAAC;IAC7C;EAAE,EACH,CAAC,EACDuC,IAAI,iBAAIhD,MAAA,CAAAW,OAAA,CAAAmE,aAAA;IAAKxB,SAAS,EAAE2B,oBAAM,CAAClC;EAAK,GAAEC,IAAU,CAAC,EACjDD,IAAI,iBAAI/C,MAAA,CAAAW,OAAA,CAAAmE,aAAA,QAAAlD,QAAA;IAAK0B,SAAS,EAAE2B,oBAAM,CAAClC;EAAK,GAAKA,IAAI,CAAG,CAC9C,CAAC,eACN/C,MAAA,CAAAW,OAAA,CAAAmE,aAAA,CAACvE,kBAAA,CAAAI,OAAiB;IAAC6E,SAAS,EAAC,GAAG;IAACC,KAAK,EAAE;MAAEf,QAAQ,EAAEA;IAAS;EAAE,GAC5D9B,KAAK,IAAIsB,eAAe,gBACvBlE,MAAA,CAAAW,OAAA,CAAAmE,aAAA,CAAC1E,KAAA,CAAAO,OAAI;IACH+E,GAAG,EAAE,OAAQ;IACbC,KAAK,EAAE,OAAO/C,KAAK,KAAK,QAAQ,GAAGA,KAAK,GAAG,EAAG;IAC9CgD,IAAI,GAAAlD,eAAA,GAAEgB,QAAQ,CAACd,KAAK,cAAAF,eAAA,cAAAA,eAAA,GAAI;EAAQ,GAE/BE,KACG,CAAC,GACLM,UAAU,gBACZlD,MAAA,CAAAW,OAAA,CAAAmE,aAAA,CAAC1E,KAAA,CAAAO,OAAI;IACH+E,GAAG,EAAE,GAAI;IACTC,KAAK,EAAE,OAAOzC,UAAU,KAAK,QAAQ,GAAGA,UAAU,GAAG,EAAG;IACxD0C,IAAI,GAAAjD,oBAAA,GAAEe,QAAQ,CAACR,UAAU,cAAAP,oBAAA,cAAAA,oBAAA,GAAI;EAAU,GAEtCO,UACG,CAAC,gBAEPlD,MAAA,CAAAW,OAAA,CAAAmE,aAAA,CAAC9E,MAAA,CAAA6F,QAAQ;IAACH,GAAG,EAAE;EAAI,CAAE,CAEN,CAChB,CAAC;AAEV;;AAEA;AACA;AACA;AACA,MAAMI,KAAK,gBAAG,IAAAC,iBAAU,EAACxD,MAAM,CAAC;AAAC,IAAAyD,QAAA,GAAAC,OAAA,CAAAtF,OAAA,GAClBmF,KAAK","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 {
|
|
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:
|
|
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
|
-
|
|
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":";AAAA,OAAc,
|
|
1
|
+
{"version":3,"file":"Input.js","sourceRoot":"","sources":["../../../src/components/Input/Input.tsx"],"names":[],"mappings":"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"}
|
|
@@ -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 {
|
|
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:
|
|
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.
|
|
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>",
|