@onepercentio/one-ui 0.27.5 → 0.27.7

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.
@@ -50,8 +50,8 @@ function getTextNodesIn(elem: HTMLElement): ChildNode[] {
50
50
  return textNodes;
51
51
  }
52
52
 
53
- export default function inlineCSS() {
54
- if (process.env.NODE_ENV === "development") return;
53
+ export default function inlineCSS(force: boolean = false) {
54
+ if (process.env.NODE_ENV === "development" && force === false) return;
55
55
  const allEls = Array.from(document.querySelectorAll("*")) as HTMLElement[];
56
56
  const elstyles: [HTMLElement, string][] = [];
57
57
 
@@ -71,7 +71,9 @@ export default function inlineCSS() {
71
71
  }
72
72
 
73
73
  const inlined = Array.from(styles)
74
- .map((k) => `${k}: ${styles.getPropertyValue(k)}`)
74
+ .map((k) => {
75
+ return `${k}: ${styles.getPropertyValue(k)}`
76
+ })
75
77
  .join("; ")
76
78
  .concat(";");
77
79
  if (inlined !== ";") elstyles.push([el, inlined]);
@@ -82,19 +84,16 @@ export default function inlineCSS() {
82
84
  el.setAttribute("style", s);
83
85
  });
84
86
 
85
- getTextNodesIn(document.body).forEach((n) => {
86
- n.replaceWith(
87
- ...n
88
- .textContent!.split(/\n/g)
89
- .reduce(
90
- (r, txt, i, arr) =>
91
- arr.length - 1 === i
92
- ? [...r, txt]
93
- : [...r, txt, document.createElement("br")],
94
- [] as (Node | string)[]
95
- )
96
- );
97
- });
87
+ if (force === false)
88
+ getTextNodesIn(document.body).forEach((n) => {
89
+ n.replaceWith(
90
+ ...n.textContent!.split(/\n/g).reduce((r, txt, i, arr) => {
91
+ return arr.length - 1 === i
92
+ ? [...r, txt]
93
+ : [...r, txt, document.createElement("br")];
94
+ }, [] as (Node | string)[])
95
+ );
96
+ });
98
97
 
99
98
  if (process.env.NODE_ENV !== "test")
100
99
  document.querySelectorAll("style").forEach((e) => e.remove());
@@ -1,6 +1,6 @@
1
1
  /// <reference types="react" />
2
2
  import { OneUIContextSpecs } from "../../../context/OneUIProvider";
3
- import { AnswerAction, AnswerByField, FormField, FormFieldView, FormMode } from "./FormField/FormField.types";
3
+ import { AnswerAction, AnswerByField, FormField, FormFieldTypes, FormFieldView, FormMode } from "./FormField/FormField.types";
4
4
  import { AnswersMap } from "./Form.types";
5
5
  export declare function useFormAnswers<A extends AnswersMap<any> = AnswersMap>(defaultAnswers: A, mode: FormMode): {
6
6
  answers: A;
@@ -12,7 +12,7 @@ export declare function useFormState(currentQuestions: FormFieldView[], { answer
12
12
  }>;
13
13
  isQuestionsAnswered: boolean;
14
14
  isFilesUploaded: boolean;
15
- onAnswerAction: <T extends "number" | "radio" | "text" | "date" | "select" | "accept" | "phone" | "file" | "check" | "rawcheck">(questionType: T, id: string, answer: AnswerAction<{
15
+ onAnswerAction: <T extends FormFieldTypes>(questionType: T, id: string, answer: AnswerAction<{
16
16
  type: T;
17
17
  }> | undefined) => void;
18
18
  questions: FormFieldView[];
@@ -23,7 +23,7 @@ export declare function useForm(currentQuestions: FormFieldView[], defaultAnswer
23
23
  }>;
24
24
  isQuestionsAnswered: boolean;
25
25
  isFilesUploaded: boolean;
26
- onAnswerAction: <T extends "number" | "radio" | "text" | "date" | "select" | "accept" | "phone" | "file" | "check" | "rawcheck">(questionType: T, id: string, answer: AnswerAction<{
26
+ onAnswerAction: <T extends FormFieldTypes>(questionType: T, id: string, answer: AnswerAction<{
27
27
  type: T;
28
28
  }> | undefined) => void;
29
29
  questions: FormFieldView[];
@@ -33,7 +33,7 @@ export declare function areAllQuestionsAnswered(currentQuestions: FormField[], a
33
33
  isValid: boolean;
34
34
  };
35
35
  export declare const isValidated: (_answer: AnswerByField<{
36
- type: FormField["type"];
36
+ type: FormFieldTypes;
37
37
  }>, isOptional: boolean, validator: ((val: any) => string | boolean) | undefined, requiredFieldLabel: string) => {
38
38
  isValid: any;
39
39
  error: any;
@@ -232,4 +232,4 @@ const isValidated = (_answer, isOptional, validator, requiredFieldLabel) => {
232
232
  };
233
233
  };
234
234
  exports.isValidated = isValidated;
235
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_OneUIProvider","_FormField","useFormAnswers","defaultAnswers","mode","answers","setAnswers","useState","clone","FormMode","READ_ONLY","useFormState","currentQuestions","_ref","formConfig","useOneUIConfig","isValid","isQuestionsAnswered","useMemo","areAllQuestionsAnswered","requiredLabel","extensions","onAnswerAction","questionType","id","answer","onFileUpload","prev","file","isFilesUploaded","useFileUploads","questions","useForm","fileUploadQuestions","filter","a","type","fileUploadStatus","setFileUploadStatus","useLayoutEffect","unsubs","fileQuestion","uploadTask","push","on","r","totalBytes","bytesTransferred","forEach","unsub","areAllFileUploaded","reduce","question","uploadStatus","useFieldErrors","showAllErrors","errorMap","ans","errorsMap","_isValidated","isValidated","optional","validator","updateDefaultError","validation","error","validationResult","extendedSupport","validationResultExtend","currentErrors","Object","entries","_ref2","k","v","undefined","answeredAll","result","checks","accept","_ref3","idx","checkmarks","includes","_answer","isOptional","requiredFieldLabel","Array","isArray","_","exports"],"sources":["../../../../src/components/Form/v2/Form.hook.ts"],"sourcesContent":["import { useLayoutEffect, useMemo, useState } from \"react\";\nimport {\n  OneUIContextSpecs,\n  useOneUIConfig,\n} from \"../../../context/OneUIProvider\";\nimport {\n  AnswerAction,\n  AnswerByField,\n  FormField,\n  FormFieldView,\n  FormMode,\n} from \"./FormField/FormField.types\";\nimport { AnswersMap } from \"./Form.types\";\nimport { UploadTask, UploadTaskSnapshot } from \"firebase/storage\";\n\nexport function useFormAnswers<A extends AnswersMap<any> = AnswersMap>(\n  defaultAnswers: A,\n  mode: FormMode\n) {\n  const [answers, setAnswers] = useState<A>(() => {\n    const clone = {\n      ...defaultAnswers,\n    };\n    if (mode === FormMode.READ_ONLY) return clone;\n    return clone;\n  });\n  return {\n    answers,\n    setAnswers,\n  };\n}\nexport function useFormState(\n  currentQuestions: FormFieldView[],\n  { answers, setAnswers }: ReturnType<typeof useFormAnswers>\n) {\n  const formConfig = useOneUIConfig(\"component.form\");\n\n  const { isValid: isQuestionsAnswered } = useMemo(() => {\n    return areAllQuestionsAnswered(\n      currentQuestions,\n      answers,\n      formConfig.requiredLabel,\n      formConfig.extensions\n    );\n  }, [answers, currentQuestions]);\n\n  const onAnswerAction = <T extends FormField[\"type\"]>(\n    questionType: T,\n    id: string,\n    answer:\n      | AnswerAction<{\n          type: T;\n        }>\n      | undefined\n  ) => {\n    switch (questionType) {\n      case \"file\":\n        const { onFileUpload } = formConfig;\n        setAnswers((prev: any) => {\n          const file = answer as File | undefined;\n          if (file)\n            return {\n              ...prev,\n              [id]: onFileUpload(id, file),\n            };\n          delete prev[id];\n          return { ...prev };\n        });\n        break;\n      default:\n        setAnswers((prev) => ({\n          ...prev,\n          [id]: answer as string,\n        }));\n    }\n  };\n\n  const isFilesUploaded = useFileUploads(currentQuestions, answers);\n\n  return {\n    answers,\n    isQuestionsAnswered,\n    isFilesUploaded,\n    onAnswerAction,\n    questions: currentQuestions,\n  };\n}\n\nexport function useForm(\n  currentQuestions: FormFieldView[],\n  defaultAnswers: AnswersMap,\n  mode: FormMode\n) {\n  const answers = useFormAnswers(defaultAnswers, mode);\n  return useFormState(currentQuestions, answers);\n}\n\nfunction useFileUploads(questions: FormField[], answers: AnswersMap) {\n  const fileUploadQuestions = useMemo(\n    () => questions.filter((a) => a.type === \"file\"),\n    [questions]\n  );\n  const [fileUploadStatus, setFileUploadStatus] = useState<{\n    [questionID: string]: UploadTaskSnapshot[\"state\"];\n  }>({});\n  useLayoutEffect(() => {\n    const unsubs: ReturnType<UploadTask[\"on\"]>[] = [];\n    for (let fileQuestion of fileUploadQuestions) {\n      const uploadTask = answers[fileQuestion.id] as\n        | AnswerByField<{\n            type: \"file\";\n          }>\n        | undefined;\n\n      if (!uploadTask)\n        setFileUploadStatus((prev) => ({\n          ...prev,\n          [fileQuestion.id]: \"running\",\n        }));\n      else if (typeof uploadTask === \"boolean\") {\n        setFileUploadStatus((prev) => ({\n          ...prev,\n          [fileQuestion.id]: \"success\",\n        }));\n      } else\n        unsubs.push(\n          uploadTask.on(\"state_changed\", (r) => {\n            setFileUploadStatus((prev) => ({\n              ...prev,\n              [fileQuestion.id]:\n                r.totalBytes === r.bytesTransferred ? \"success\" : \"running\",\n            }));\n          })\n        );\n    }\n\n    return () => {\n      unsubs.forEach((unsub) => unsub());\n    };\n  }, [answers, fileUploadQuestions]);\n\n  const areAllFileUploaded = useMemo(() => {\n    return fileUploadQuestions.reduce((r, question) => {\n      const uploadStatus = fileUploadStatus[question.id];\n      return r && uploadStatus === \"success\";\n    }, true);\n  }, [fileUploadStatus, fileUploadQuestions]);\n\n  return areAllFileUploaded;\n}\n\nexport function useFieldErrors<\n  Q extends Readonly<\n    Pick<FormField, \"type\" | \"id\" | \"optional\" | \"validator\">[]\n  >\n>(currentQuestions: Q, answers: AnswersMap, showAllErrors: boolean) {\n  const { requiredLabel, extensions } = useOneUIConfig(\"component.form\");\n  const errorMap = useMemo(() => {\n    const ans = <T extends FormFieldView[\"type\"]>(\n      question: Pick<FormField, \"id\"> & {\n        type: T;\n      }\n    ) =>\n      answers[question.id] as AnswerByField<{\n        type: T;\n      }>;\n    const errorsMap: {\n      [questionId: string]: string | undefined;\n    } = {};\n    for (let question of currentQuestions) {\n      const _isValidated = () => {\n        return isValidated(\n          ans(question),\n          !!question.optional,\n          question.validator,\n          requiredLabel\n        );\n      };\n      const updateDefaultError = () => {\n        const validation = _isValidated();\n        errorsMap[question.id] = validation.error;\n      };\n      switch (question.type) {\n        case \"check\":\n        case \"rawcheck\":\n          updateDefaultError();\n          if (question.validator)\n            errorsMap[question.id] = question.validator(\n              ans(question) as any\n            ) as string;\n          break;\n        case \"number\":\n        case \"text\":\n        case \"select\":\n        case \"radio\":\n        case \"file\":\n          updateDefaultError();\n          const validationResult = _isValidated();\n          if (validationResult.error)\n            errorsMap[question.id] = validationResult.error;\n          break;\n        default:\n          const extendedSupport =\n            extensions?.[\n              question.type as OnepercentUtility.UIElements.FormExtension[\"fields\"][\"type\"]\n            ];\n          if (extendedSupport) {\n            const validationResultExtend = extendedSupport.validator(\n              ans(question) as any,\n              question as any\n            );\n            if (validationResultExtend.error)\n              errorsMap[question.id] = validationResultExtend.error;\n          } else {\n            updateDefaultError();\n          }\n      }\n    }\n\n    return errorsMap;\n  }, [currentQuestions, answers]);\n\n  const currentErrors = useMemo(() => {\n    return Object.entries(errorMap).reduce(\n      (r, [k, v]) => ({\n        ...r,\n        [k]: showAllErrors ? v : v !== requiredLabel ? v : undefined,\n      }),\n      {}\n    );\n  }, [showAllErrors, errorMap]);\n\n  return currentErrors as { [k in Q[number][\"id\"]]: string };\n}\n\nexport function areAllQuestionsAnswered(\n  currentQuestions: FormField[],\n  answers: AnswersMap,\n  requiredLabel: string,\n  extensions: OneUIContextSpecs[\"component\"][\"form\"][\"extensions\"]\n) {\n  const isValid = currentQuestions.reduce((answeredAll, question) => {\n    const ans = <T extends FormFieldView[\"type\"]>(\n      question: FormField & {\n        type: T;\n      }\n    ) =>\n      answers[question.id] as unknown as AnswerByField<{\n        type: T;\n      }>;\n\n    const result =\n      answeredAll &&\n      (() => {\n        switch (question.type) {\n          case \"accept\":\n            const checks = ans(question) || [];\n            return question.accept.reduce(\n              (r, { optional }, idx) => r && (optional ? true : checks[idx]),\n              true\n            );\n          case \"check\":\n          case \"rawcheck\":\n            if (question.optional) return true;\n            if (question.validator)\n              return question.validator(ans(question) as any) as boolean;\n            const checkmarks = ans(question) || [];\n            return checkmarks.includes(true);\n          case \"number\":\n          case \"text\":\n          case \"select\":\n          case \"radio\":\n          case \"file\":\n            if (!answers[question.id]) return !!question.optional;\n            const validationResult = isValidated(\n              ans(question),\n              !!question.optional,\n              question.validator,\n              requiredLabel\n            );\n            return validationResult.isValid && answeredAll;\n          default:\n            const extendedSupport =\n              extensions?.[\n                question.type as OnepercentUtility.UIElements.FormExtension[\"fields\"][\"type\"]\n              ];\n            if (extendedSupport) {\n              const validationResultExtend = extendedSupport.validator(\n                ans(question) as any,\n                question as any\n              );\n              return validationResultExtend.isValid;\n            } else\n              return question.validator\n                ? !!question.validator(ans(question) as any)\n                : !!ans(question);\n        }\n      })();\n    return result;\n  }, true);\n\n  return { isValid: !!isValid };\n}\n\nexport const isValidated = (\n    _answer: AnswerByField<{ type: FormField[\"type\"] }>,\n  isOptional: boolean,\n  validator: ((val: any) => string | boolean) | undefined,\n  requiredFieldLabel: string\n) => {\n  const answer = Array.isArray(_answer) ? _answer[0] : _answer;\n  if (!answer && !isOptional)\n    return {\n      isValid: false,\n      error: requiredFieldLabel,\n    };\n  if (!validator)\n    if (Array.isArray(_answer)) {\n      const [_, isValid, error] = _answer;\n      return {\n        isValid,\n        error,\n      };\n    } else {\n      return {\n        isValid: true,\n        error: \"\",\n      };\n    }\n  const validationResult = validator(answer);\n  if (typeof validationResult === \"string\")\n    return {\n      isValid: false,\n      error: validationResult,\n    };\n  return {\n    isValid: validationResult,\n    error: \"\",\n  };\n};\n"],"mappings":";;;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,OAAA;AACA,IAAAC,cAAA,GAAAD,OAAA;AAIA,IAAAE,UAAA,GAAAF,OAAA;AAUO,SAASG,cAAcA,CAC5BC,cAAiB,EACjBC,IAAc,EACd;EACA,MAAM,CAACC,OAAO,EAAEC,UAAU,CAAC,GAAG,IAAAC,eAAQ,EAAI,MAAM;IAC9C,MAAMC,KAAK,GAAG;MACZ,GAAGL;IACL,CAAC;IACD,IAAIC,IAAI,KAAKK,mBAAQ,CAACC,SAAS,EAAE,OAAOF,KAAK;IAC7C,OAAOA,KAAK;EACd,CAAC,CAAC;EACF,OAAO;IACLH,OAAO;IACPC;EACF,CAAC;AACH;AACO,SAASK,YAAYA,CAC1BC,gBAAiC,EAAAC,IAAA,EAEjC;EAAA,IADA;IAAER,OAAO;IAAEC;EAA8C,CAAC,GAAAO,IAAA;EAE1D,MAAMC,UAAU,GAAG,IAAAC,6BAAc,EAAC,gBAAgB,CAAC;EAEnD,MAAM;IAAEC,OAAO,EAAEC;EAAoB,CAAC,GAAG,IAAAC,cAAO,EAAC,MAAM;IACrD,OAAOC,uBAAuB,CAC5BP,gBAAgB,EAChBP,OAAO,EACPS,UAAU,CAACM,aAAa,EACxBN,UAAU,CAACO,UACb,CAAC;EACH,CAAC,EAAE,CAAChB,OAAO,EAAEO,gBAAgB,CAAC,CAAC;EAE/B,MAAMU,cAAc,GAAGA,CACrBC,YAAe,EACfC,EAAU,EACVC,MAIa,KACV;IACH,QAAQF,YAAY;MAClB,KAAK,MAAM;QACT,MAAM;UAAEG;QAAa,CAAC,GAAGZ,UAAU;QACnCR,UAAU,CAAEqB,IAAS,IAAK;UACxB,MAAMC,IAAI,GAAGH,MAA0B;UACvC,IAAIG,IAAI,EACN,OAAO;YACL,GAAGD,IAAI;YACP,CAACH,EAAE,GAAGE,YAAY,CAACF,EAAE,EAAEI,IAAI;UAC7B,CAAC;UACH,OAAOD,IAAI,CAACH,EAAE,CAAC;UACf,OAAO;YAAE,GAAGG;UAAK,CAAC;QACpB,CAAC,CAAC;QACF;MACF;QACErB,UAAU,CAAEqB,IAAI,KAAM;UACpB,GAAGA,IAAI;UACP,CAACH,EAAE,GAAGC;QACR,CAAC,CAAC,CAAC;IACP;EACF,CAAC;EAED,MAAMI,eAAe,GAAGC,cAAc,CAAClB,gBAAgB,EAAEP,OAAO,CAAC;EAEjE,OAAO;IACLA,OAAO;IACPY,mBAAmB;IACnBY,eAAe;IACfP,cAAc;IACdS,SAAS,EAAEnB;EACb,CAAC;AACH;AAEO,SAASoB,OAAOA,CACrBpB,gBAAiC,EACjCT,cAA0B,EAC1BC,IAAc,EACd;EACA,MAAMC,OAAO,GAAGH,cAAc,CAACC,cAAc,EAAEC,IAAI,CAAC;EACpD,OAAOO,YAAY,CAACC,gBAAgB,EAAEP,OAAO,CAAC;AAChD;AAEA,SAASyB,cAAcA,CAACC,SAAsB,EAAE1B,OAAmB,EAAE;EACnE,MAAM4B,mBAAmB,GAAG,IAAAf,cAAO,EACjC,MAAMa,SAAS,CAACG,MAAM,CAAEC,CAAC,IAAKA,CAAC,CAACC,IAAI,KAAK,MAAM,CAAC,EAChD,CAACL,SAAS,CACZ,CAAC;EACD,MAAM,CAACM,gBAAgB,EAAEC,mBAAmB,CAAC,GAAG,IAAA/B,eAAQ,EAErD,CAAC,CAAC,CAAC;EACN,IAAAgC,sBAAe,EAAC,MAAM;IACpB,MAAMC,MAAsC,GAAG,EAAE;IACjD,KAAK,IAAIC,YAAY,IAAIR,mBAAmB,EAAE;MAC5C,MAAMS,UAAU,GAAGrC,OAAO,CAACoC,YAAY,CAACjB,EAAE,CAI7B;MAEb,IAAI,CAACkB,UAAU,EACbJ,mBAAmB,CAAEX,IAAI,KAAM;QAC7B,GAAGA,IAAI;QACP,CAACc,YAAY,CAACjB,EAAE,GAAG;MACrB,CAAC,CAAC,CAAC,CAAC,KACD,IAAI,OAAOkB,UAAU,KAAK,SAAS,EAAE;QACxCJ,mBAAmB,CAAEX,IAAI,KAAM;UAC7B,GAAGA,IAAI;UACP,CAACc,YAAY,CAACjB,EAAE,GAAG;QACrB,CAAC,CAAC,CAAC;MACL,CAAC,MACCgB,MAAM,CAACG,IAAI,CACTD,UAAU,CAACE,EAAE,CAAC,eAAe,EAAGC,CAAC,IAAK;QACpCP,mBAAmB,CAAEX,IAAI,KAAM;UAC7B,GAAGA,IAAI;UACP,CAACc,YAAY,CAACjB,EAAE,GACdqB,CAAC,CAACC,UAAU,KAAKD,CAAC,CAACE,gBAAgB,GAAG,SAAS,GAAG;QACtD,CAAC,CAAC,CAAC;MACL,CAAC,CACH,CAAC;IACL;IAEA,OAAO,MAAM;MACXP,MAAM,CAACQ,OAAO,CAAEC,KAAK,IAAKA,KAAK,CAAC,CAAC,CAAC;IACpC,CAAC;EACH,CAAC,EAAE,CAAC5C,OAAO,EAAE4B,mBAAmB,CAAC,CAAC;EAElC,MAAMiB,kBAAkB,GAAG,IAAAhC,cAAO,EAAC,MAAM;IACvC,OAAOe,mBAAmB,CAACkB,MAAM,CAAC,CAACN,CAAC,EAAEO,QAAQ,KAAK;MACjD,MAAMC,YAAY,GAAGhB,gBAAgB,CAACe,QAAQ,CAAC5B,EAAE,CAAC;MAClD,OAAOqB,CAAC,IAAIQ,YAAY,KAAK,SAAS;IACxC,CAAC,EAAE,IAAI,CAAC;EACV,CAAC,EAAE,CAAChB,gBAAgB,EAAEJ,mBAAmB,CAAC,CAAC;EAE3C,OAAOiB,kBAAkB;AAC3B;AAEO,SAASI,cAAcA,CAI5B1C,gBAAmB,EAAEP,OAAmB,EAAEkD,aAAsB,EAAE;EAClE,MAAM;IAAEnC,aAAa;IAAEC;EAAW,CAAC,GAAG,IAAAN,6BAAc,EAAC,gBAAgB,CAAC;EACtE,MAAMyC,QAAQ,GAAG,IAAAtC,cAAO,EAAC,MAAM;IAC7B,MAAMuC,GAAG,GACPL,QAEC,IAED/C,OAAO,CAAC+C,QAAQ,CAAC5B,EAAE,CAEjB;IACJ,MAAMkC,SAEL,GAAG,CAAC,CAAC;IACN,KAAK,IAAIN,QAAQ,IAAIxC,gBAAgB,EAAE;MACrC,MAAM+C,YAAY,GAAGA,CAAA,KAAM;QACzB,OAAOC,WAAW,CAChBH,GAAG,CAACL,QAAQ,CAAC,EACb,CAAC,CAACA,QAAQ,CAACS,QAAQ,EACnBT,QAAQ,CAACU,SAAS,EAClB1C,aACF,CAAC;MACH,CAAC;MACD,MAAM2C,kBAAkB,GAAGA,CAAA,KAAM;QAC/B,MAAMC,UAAU,GAAGL,YAAY,CAAC,CAAC;QACjCD,SAAS,CAACN,QAAQ,CAAC5B,EAAE,CAAC,GAAGwC,UAAU,CAACC,KAAK;MAC3C,CAAC;MACD,QAAQb,QAAQ,CAAChB,IAAI;QACnB,KAAK,OAAO;QACZ,KAAK,UAAU;UACb2B,kBAAkB,CAAC,CAAC;UACpB,IAAIX,QAAQ,CAACU,SAAS,EACpBJ,SAAS,CAACN,QAAQ,CAAC5B,EAAE,CAAC,GAAG4B,QAAQ,CAACU,SAAS,CACzCL,GAAG,CAACL,QAAQ,CACd,CAAW;UACb;QACF,KAAK,QAAQ;QACb,KAAK,MAAM;QACX,KAAK,QAAQ;QACb,KAAK,OAAO;QACZ,KAAK,MAAM;UACTW,kBAAkB,CAAC,CAAC;UACpB,MAAMG,gBAAgB,GAAGP,YAAY,CAAC,CAAC;UACvC,IAAIO,gBAAgB,CAACD,KAAK,EACxBP,SAAS,CAACN,QAAQ,CAAC5B,EAAE,CAAC,GAAG0C,gBAAgB,CAACD,KAAK;UACjD;QACF;UACE,MAAME,eAAe,GACnB9C,UAAU,aAAVA,UAAU,uBAAVA,UAAU,CACR+B,QAAQ,CAAChB,IAAI,CACd;UACH,IAAI+B,eAAe,EAAE;YACnB,MAAMC,sBAAsB,GAAGD,eAAe,CAACL,SAAS,CACtDL,GAAG,CAACL,QAAQ,CAAC,EACbA,QACF,CAAC;YACD,IAAIgB,sBAAsB,CAACH,KAAK,EAC9BP,SAAS,CAACN,QAAQ,CAAC5B,EAAE,CAAC,GAAG4C,sBAAsB,CAACH,KAAK;UACzD,CAAC,MAAM;YACLF,kBAAkB,CAAC,CAAC;UACtB;MACJ;IACF;IAEA,OAAOL,SAAS;EAClB,CAAC,EAAE,CAAC9C,gBAAgB,EAAEP,OAAO,CAAC,CAAC;EAE/B,MAAMgE,aAAa,GAAG,IAAAnD,cAAO,EAAC,MAAM;IAClC,OAAOoD,MAAM,CAACC,OAAO,CAACf,QAAQ,CAAC,CAACL,MAAM,CACpC,CAACN,CAAC,EAAA2B,KAAA;MAAA,IAAE,CAACC,CAAC,EAAEC,CAAC,CAAC,GAAAF,KAAA;MAAA,OAAM;QACd,GAAG3B,CAAC;QACJ,CAAC4B,CAAC,GAAGlB,aAAa,GAAGmB,CAAC,GAAGA,CAAC,KAAKtD,aAAa,GAAGsD,CAAC,GAAGC;MACrD,CAAC;IAAA,CAAC,EACF,CAAC,CACH,CAAC;EACH,CAAC,EAAE,CAACpB,aAAa,EAAEC,QAAQ,CAAC,CAAC;EAE7B,OAAOa,aAAa;AACtB;AAEO,SAASlD,uBAAuBA,CACrCP,gBAA6B,EAC7BP,OAAmB,EACnBe,aAAqB,EACrBC,UAAgE,EAChE;EACA,MAAML,OAAO,GAAGJ,gBAAgB,CAACuC,MAAM,CAAC,CAACyB,WAAW,EAAExB,QAAQ,KAAK;IACjE,MAAMK,GAAG,GACPL,QAEC,IAED/C,OAAO,CAAC+C,QAAQ,CAAC5B,EAAE,CAEjB;IAEJ,MAAMqD,MAAM,GACVD,WAAW,IACX,CAAC,MAAM;MACL,QAAQxB,QAAQ,CAAChB,IAAI;QACnB,KAAK,QAAQ;UACX,MAAM0C,MAAM,GAAGrB,GAAG,CAACL,QAAQ,CAAC,IAAI,EAAE;UAClC,OAAOA,QAAQ,CAAC2B,MAAM,CAAC5B,MAAM,CAC3B,CAACN,CAAC,EAAAmC,KAAA,EAAgBC,GAAG;YAAA,IAAjB;cAAEpB;YAAS,CAAC,GAAAmB,KAAA;YAAA,OAAUnC,CAAC,KAAKgB,QAAQ,GAAG,IAAI,GAAGiB,MAAM,CAACG,GAAG,CAAC,CAAC;UAAA,GAC9D,IACF,CAAC;QACH,KAAK,OAAO;QACZ,KAAK,UAAU;UACb,IAAI7B,QAAQ,CAACS,QAAQ,EAAE,OAAO,IAAI;UAClC,IAAIT,QAAQ,CAACU,SAAS,EACpB,OAAOV,QAAQ,CAACU,SAAS,CAACL,GAAG,CAACL,QAAQ,CAAQ,CAAC;UACjD,MAAM8B,UAAU,GAAGzB,GAAG,CAACL,QAAQ,CAAC,IAAI,EAAE;UACtC,OAAO8B,UAAU,CAACC,QAAQ,CAAC,IAAI,CAAC;QAClC,KAAK,QAAQ;QACb,KAAK,MAAM;QACX,KAAK,QAAQ;QACb,KAAK,OAAO;QACZ,KAAK,MAAM;UACT,IAAI,CAAC9E,OAAO,CAAC+C,QAAQ,CAAC5B,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC4B,QAAQ,CAACS,QAAQ;UACrD,MAAMK,gBAAgB,GAAGN,WAAW,CAClCH,GAAG,CAACL,QAAQ,CAAC,EACb,CAAC,CAACA,QAAQ,CAACS,QAAQ,EACnBT,QAAQ,CAACU,SAAS,EAClB1C,aACF,CAAC;UACD,OAAO8C,gBAAgB,CAAClD,OAAO,IAAI4D,WAAW;QAChD;UACE,MAAMT,eAAe,GACnB9C,UAAU,aAAVA,UAAU,uBAAVA,UAAU,CACR+B,QAAQ,CAAChB,IAAI,CACd;UACH,IAAI+B,eAAe,EAAE;YACnB,MAAMC,sBAAsB,GAAGD,eAAe,CAACL,SAAS,CACtDL,GAAG,CAACL,QAAQ,CAAC,EACbA,QACF,CAAC;YACD,OAAOgB,sBAAsB,CAACpD,OAAO;UACvC,CAAC,MACC,OAAOoC,QAAQ,CAACU,SAAS,GACrB,CAAC,CAACV,QAAQ,CAACU,SAAS,CAACL,GAAG,CAACL,QAAQ,CAAQ,CAAC,GAC1C,CAAC,CAACK,GAAG,CAACL,QAAQ,CAAC;MACzB;IACF,CAAC,EAAE,CAAC;IACN,OAAOyB,MAAM;EACf,CAAC,EAAE,IAAI,CAAC;EAER,OAAO;IAAE7D,OAAO,EAAE,CAAC,CAACA;EAAQ,CAAC;AAC/B;AAEO,MAAM4C,WAAW,GAAGA,CACvBwB,OAAmD,EACrDC,UAAmB,EACnBvB,SAAuD,EACvDwB,kBAA0B,KACvB;EACH,MAAM7D,MAAM,GAAG8D,KAAK,CAACC,OAAO,CAACJ,OAAO,CAAC,GAAGA,OAAO,CAAC,CAAC,CAAC,GAAGA,OAAO;EAC5D,IAAI,CAAC3D,MAAM,IAAI,CAAC4D,UAAU,EACxB,OAAO;IACLrE,OAAO,EAAE,KAAK;IACdiD,KAAK,EAAEqB;EACT,CAAC;EACH,IAAI,CAACxB,SAAS,EACZ,IAAIyB,KAAK,CAACC,OAAO,CAACJ,OAAO,CAAC,EAAE;IAC1B,MAAM,CAACK,CAAC,EAAEzE,OAAO,EAAEiD,KAAK,CAAC,GAAGmB,OAAO;IACnC,OAAO;MACLpE,OAAO;MACPiD;IACF,CAAC;EACH,CAAC,MAAM;IACL,OAAO;MACLjD,OAAO,EAAE,IAAI;MACbiD,KAAK,EAAE;IACT,CAAC;EACH;EACF,MAAMC,gBAAgB,GAAGJ,SAAS,CAACrC,MAAM,CAAC;EAC1C,IAAI,OAAOyC,gBAAgB,KAAK,QAAQ,EACtC,OAAO;IACLlD,OAAO,EAAE,KAAK;IACdiD,KAAK,EAAEC;EACT,CAAC;EACH,OAAO;IACLlD,OAAO,EAAEkD,gBAAgB;IACzBD,KAAK,EAAE;EACT,CAAC;AACH,CAAC;AAACyB,OAAA,CAAA9B,WAAA,GAAAA,WAAA"}
235
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_OneUIProvider","_FormField","useFormAnswers","defaultAnswers","mode","answers","setAnswers","useState","clone","FormMode","READ_ONLY","useFormState","currentQuestions","_ref","formConfig","useOneUIConfig","isValid","isQuestionsAnswered","useMemo","areAllQuestionsAnswered","requiredLabel","extensions","onAnswerAction","questionType","id","answer","onFileUpload","prev","file","isFilesUploaded","useFileUploads","questions","useForm","fileUploadQuestions","filter","a","type","fileUploadStatus","setFileUploadStatus","useLayoutEffect","unsubs","fileQuestion","uploadTask","push","on","r","totalBytes","bytesTransferred","forEach","unsub","areAllFileUploaded","reduce","question","uploadStatus","useFieldErrors","showAllErrors","errorMap","ans","errorsMap","_isValidated","isValidated","optional","validator","updateDefaultError","validation","error","validationResult","extendedSupport","validationResultExtend","currentErrors","Object","entries","_ref2","k","v","undefined","answeredAll","result","checks","accept","_ref3","idx","checkmarks","includes","_answer","isOptional","requiredFieldLabel","Array","isArray","_","exports"],"sources":["../../../../src/components/Form/v2/Form.hook.ts"],"sourcesContent":["import { useLayoutEffect, useMemo, useState } from \"react\";\nimport {\n  OneUIContextSpecs,\n  useOneUIConfig,\n} from \"../../../context/OneUIProvider\";\nimport {\n  AnswerAction,\n  AnswerByField,\n  FormField,\n  FormFieldTypes,\n  FormFieldView,\n  FormMode,\n} from \"./FormField/FormField.types\";\nimport { AnswersMap } from \"./Form.types\";\nimport { UploadTask, UploadTaskSnapshot } from \"firebase/storage\";\n\nexport function useFormAnswers<A extends AnswersMap<any> = AnswersMap>(\n  defaultAnswers: A,\n  mode: FormMode\n) {\n  const [answers, setAnswers] = useState<A>(() => {\n    const clone = {\n      ...defaultAnswers,\n    };\n    if (mode === FormMode.READ_ONLY) return clone;\n    return clone;\n  });\n  return {\n    answers,\n    setAnswers,\n  };\n}\nexport function useFormState(\n  currentQuestions: FormFieldView[],\n  { answers, setAnswers }: ReturnType<typeof useFormAnswers>\n) {\n  const formConfig = useOneUIConfig(\"component.form\");\n\n  const { isValid: isQuestionsAnswered } = useMemo(() => {\n    return areAllQuestionsAnswered(\n      currentQuestions,\n      answers,\n      formConfig.requiredLabel,\n      formConfig.extensions\n    );\n  }, [answers, currentQuestions]);\n\n  const onAnswerAction = <T extends FormFieldTypes>(\n    questionType: T,\n    id: string,\n    answer:\n      | AnswerAction<{\n          type: T;\n        }>\n      | undefined\n  ) => {\n    switch (questionType) {\n      case \"file\":\n        const { onFileUpload } = formConfig;\n        setAnswers((prev: any) => {\n          const file = answer as File | undefined;\n          if (file)\n            return {\n              ...prev,\n              [id]: onFileUpload(id, file),\n            };\n          delete prev[id];\n          return { ...prev };\n        });\n        break;\n      default:\n        setAnswers((prev) => ({\n          ...prev,\n          [id]: answer as string,\n        }));\n    }\n  };\n\n  const isFilesUploaded = useFileUploads(currentQuestions, answers);\n\n  return {\n    answers,\n    isQuestionsAnswered,\n    isFilesUploaded,\n    onAnswerAction,\n    questions: currentQuestions,\n  };\n}\n\nexport function useForm(\n  currentQuestions: FormFieldView[],\n  defaultAnswers: AnswersMap,\n  mode: FormMode\n) {\n  const answers = useFormAnswers(defaultAnswers, mode);\n  return useFormState(currentQuestions, answers);\n}\n\nfunction useFileUploads(questions: FormField[], answers: AnswersMap) {\n  const fileUploadQuestions = useMemo(\n    () => questions.filter((a) => a.type === \"file\"),\n    [questions]\n  );\n  const [fileUploadStatus, setFileUploadStatus] = useState<{\n    [questionID: string]: UploadTaskSnapshot[\"state\"];\n  }>({});\n  useLayoutEffect(() => {\n    const unsubs: ReturnType<UploadTask[\"on\"]>[] = [];\n    for (let fileQuestion of fileUploadQuestions) {\n      const uploadTask = answers[fileQuestion.id] as\n        | AnswerByField<{\n            type: \"file\";\n          }>\n        | undefined;\n\n      if (!uploadTask)\n        setFileUploadStatus((prev) => ({\n          ...prev,\n          [fileQuestion.id]: \"running\",\n        }));\n      else if (typeof uploadTask === \"boolean\") {\n        setFileUploadStatus((prev) => ({\n          ...prev,\n          [fileQuestion.id]: \"success\",\n        }));\n      } else\n        unsubs.push(\n          uploadTask.on(\"state_changed\", (r) => {\n            setFileUploadStatus((prev) => ({\n              ...prev,\n              [fileQuestion.id]:\n                r.totalBytes === r.bytesTransferred ? \"success\" : \"running\",\n            }));\n          })\n        );\n    }\n\n    return () => {\n      unsubs.forEach((unsub) => unsub());\n    };\n  }, [answers, fileUploadQuestions]);\n\n  const areAllFileUploaded = useMemo(() => {\n    return fileUploadQuestions.reduce((r, question) => {\n      const uploadStatus = fileUploadStatus[question.id];\n      return r && uploadStatus === \"success\";\n    }, true);\n  }, [fileUploadStatus, fileUploadQuestions]);\n\n  return areAllFileUploaded;\n}\n\nexport function useFieldErrors<\n  Q extends Readonly<\n    Pick<FormField, \"type\" | \"id\" | \"optional\" | \"validator\">[]\n  >\n>(currentQuestions: Q, answers: AnswersMap, showAllErrors: boolean) {\n  const { requiredLabel, extensions } = useOneUIConfig(\"component.form\");\n  const errorMap = useMemo(() => {\n    const ans = <T extends FormFieldView[\"type\"]>(\n      question: Pick<FormField, \"id\"> & {\n        type: T;\n      }\n    ) =>\n      answers[question.id] as AnswerByField<{\n        type: T;\n      }>;\n    const errorsMap: {\n      [questionId: string]: string | undefined;\n    } = {};\n    for (let question of currentQuestions) {\n      const _isValidated = () => {\n        return isValidated(\n          ans(question),\n          !!question.optional,\n          question.validator,\n          requiredLabel\n        );\n      };\n      const updateDefaultError = () => {\n        const validation = _isValidated();\n        errorsMap[question.id] = validation.error;\n      };\n      switch (question.type) {\n        case \"check\":\n        case \"rawcheck\":\n          updateDefaultError();\n          if (question.validator)\n            errorsMap[question.id] = question.validator(\n              ans(question) as any\n            ) as string;\n          break;\n        case \"number\":\n        case \"text\":\n        case \"select\":\n        case \"radio\":\n        case \"file\":\n          updateDefaultError();\n          const validationResult = _isValidated();\n          if (validationResult.error)\n            errorsMap[question.id] = validationResult.error;\n          break;\n        default:\n          const extendedSupport =\n            extensions?.[\n              question.type as OnepercentUtility.UIElements.FormExtension[\"fields\"][\"type\"]\n            ];\n          if (extendedSupport) {\n            const validationResultExtend = extendedSupport.validator(\n              ans(question) as any,\n              question as any\n            );\n            if (validationResultExtend.error)\n              errorsMap[question.id] = validationResultExtend.error;\n          } else {\n            updateDefaultError();\n          }\n      }\n    }\n\n    return errorsMap;\n  }, [currentQuestions, answers]);\n\n  const currentErrors = useMemo(() => {\n    return Object.entries(errorMap).reduce(\n      (r, [k, v]) => ({\n        ...r,\n        [k]: showAllErrors ? v : v !== requiredLabel ? v : undefined,\n      }),\n      {}\n    );\n  }, [showAllErrors, errorMap]);\n\n  return currentErrors as { [k in Q[number][\"id\"]]: string };\n}\n\nexport function areAllQuestionsAnswered(\n  currentQuestions: FormField[],\n  answers: AnswersMap,\n  requiredLabel: string,\n  extensions: OneUIContextSpecs[\"component\"][\"form\"][\"extensions\"]\n) {\n  const isValid = currentQuestions.reduce((answeredAll, question) => {\n    const ans = <T extends FormFieldView[\"type\"]>(\n      question: FormField & {\n        type: T;\n      }\n    ) =>\n      answers[question.id] as unknown as AnswerByField<{\n        type: T;\n      }>;\n\n    const result =\n      answeredAll &&\n      (() => {\n        switch (question.type) {\n          case \"accept\":\n            const checks = ans(question) || [];\n            return question.accept.reduce(\n              (r, { optional }, idx) => r && (optional ? true : checks[idx]),\n              true\n            );\n          case \"check\":\n          case \"rawcheck\":\n            if (question.optional) return true;\n            if (question.validator)\n              return question.validator(ans(question) as any) as boolean;\n            const checkmarks = ans(question) || [];\n            return checkmarks.includes(true);\n          case \"number\":\n          case \"text\":\n          case \"select\":\n          case \"radio\":\n          case \"file\":\n            if (!answers[question.id]) return !!question.optional;\n            const validationResult = isValidated(\n              ans(question),\n              !!question.optional,\n              question.validator,\n              requiredLabel\n            );\n            return validationResult.isValid && answeredAll;\n          default:\n            const extendedSupport =\n              extensions?.[\n                question.type as OnepercentUtility.UIElements.FormExtension[\"fields\"][\"type\"]\n              ];\n            if (extendedSupport) {\n              const validationResultExtend = extendedSupport.validator(\n                ans(question) as any,\n                question as any\n              );\n              return validationResultExtend.isValid;\n            } else\n              return question.validator\n                ? !!question.validator(ans(question) as any)\n                : !!ans(question);\n        }\n      })();\n    return result;\n  }, true);\n\n  return { isValid: !!isValid };\n}\n\nexport const isValidated = (\n    _answer: AnswerByField<{ type: FormFieldTypes }>,\n  isOptional: boolean,\n  validator: ((val: any) => string | boolean) | undefined,\n  requiredFieldLabel: string\n) => {\n  const answer = Array.isArray(_answer) ? _answer[0] : _answer;\n  if (!answer && !isOptional)\n    return {\n      isValid: false,\n      error: requiredFieldLabel,\n    };\n  if (!validator)\n    if (Array.isArray(_answer)) {\n      const [_, isValid, error] = _answer;\n      return {\n        isValid,\n        error,\n      };\n    } else {\n      return {\n        isValid: true,\n        error: \"\",\n      };\n    }\n  const validationResult = validator(answer);\n  if (typeof validationResult === \"string\")\n    return {\n      isValid: false,\n      error: validationResult,\n    };\n  return {\n    isValid: validationResult,\n    error: \"\",\n  };\n};\n"],"mappings":"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"}
@@ -84,6 +84,7 @@ export type FormField = {
84
84
  optional?: true;
85
85
  }[];
86
86
  } | UnresolvableOr<OnepercentUtility.UIElements.FormExtension["fields"], {}>>;
87
+ export type FormFieldTypes = FormField['type'] | 'accept';
87
88
  type ExternalQuestionFields = UnresolvableOr<OnepercentUtility.UIElements.FormExtension["fieldAnswer"], {}>;
88
89
  export type AnswerByField<F extends Pick<FormField, "type">> = F["type"] extends "file" ? UploadTask | true : F["type"] extends "accept" | "check" | "rawcheck" ? boolean[] : F["type"] extends "radio" | "text" | "select" | "number" ? string : F["type"] extends keyof ExternalQuestionFields ? OnepercentUtility.UIElements.FormExtension["fieldAnswer"][F["type"]] : unknown;
89
90
  export {};
@@ -10,4 +10,4 @@ let FormMode = /*#__PURE__*/function (FormMode) {
10
10
  return FormMode;
11
11
  }({});
12
12
  exports.FormMode = FormMode;
13
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGb3JtTW9kZSIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Gb3JtL3YyL0Zvcm1GaWVsZC9Gb3JtRmllbGQudHlwZXMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVhY3RFbGVtZW50LCBSZWFjdE5vZGUgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7IFNlbGVjdEl0ZW0gfSBmcm9tIFwiLi4vLi4vLi4vU2VsZWN0L1NlbGVjdFwiO1xuaW1wb3J0IHsgVXBsb2FkVGFzayB9IGZyb20gXCJmaXJlYmFzZS9zdG9yYWdlXCI7XG5pbXBvcnQgeyBVbnJlc29sdmFibGVPciB9IGZyb20gXCIuLi8uLi8uLi8uLi90eXBlLXV0aWxzXCI7XG5cbmV4cG9ydCB0eXBlIEdlbmVyaWNGb3JtRmllbGRQcm9wczxUIGV4dGVuZHMgRm9ybUZpZWxkW1widHlwZVwiXT4gPSB7XG4gIHZhbHVlOiBBbnN3ZXJCeUZpZWxkPHsgdHlwZTogVCB9PjtcbiAgb25BbnN3ZXI6IChGb3JtRmllbGRQcm9wczx7IHR5cGU6IFQgfT4gJiB7XG4gICAgbW9kZTogRm9ybU1vZGUuV1JJVEU7XG4gIH0pW1wib25BbnN3ZXJcIl07XG4gIHF1ZXN0aW9uOiBGb3JtRmllbGRWaWV3ICYgeyB0eXBlOiBUIH07XG4gIGVycm9yPzogc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgRm9ybUZpZWxkUHJvcHM8USBleHRlbmRzIFBpY2s8Rm9ybUZpZWxkVmlldywgXCJ0eXBlXCI+PiA9IHtcbiAgY29uZmlnOiBRO1xuICB2YWx1ZTogQW5zd2VyQnlGaWVsZDxRPjtcbn0gJiAoXG4gIHwge1xuICAgICAgbW9kZTogRm9ybU1vZGUuUkVBRF9PTkxZO1xuICAgIH1cbiAgfCB7XG4gICAgICBtb2RlPzogRm9ybU1vZGUuV1JJVEU7XG4gICAgICBvbkFuc3dlcjogPFQgZXh0ZW5kcyBRW1widHlwZVwiXT4oXG4gICAgICAgIHF1ZXN0aW9uVHlwZTogVCxcbiAgICAgICAgcXVlc3Rpb25JZDogc3RyaW5nLFxuICAgICAgICBhbnN3ZXI6XG4gICAgICAgICAgfCBBbnN3ZXJBY3Rpb248e1xuICAgICAgICAgICAgICB0eXBlOiBUO1xuICAgICAgICAgICAgfT5cbiAgICAgICAgICB8IHVuZGVmaW5lZFxuICAgICAgKSA9PiB2b2lkO1xuICAgICAgZXJyb3I/OiBzdHJpbmcgfCBzdHJpbmdbXTtcbiAgICB9XG4pO1xuXG5leHBvcnQgZW51bSBGb3JtTW9kZSB7XG4gIFJFQURfT05MWSxcbiAgV1JJVEUsXG59XG5leHBvcnQgdHlwZSBGb3JtRmllbGRWaWV3ID0gRm9ybUZpZWxkICYge1xuICB0aXRsZTogc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgQW5zd2VyQWN0aW9uPEYgZXh0ZW5kcyBQaWNrPEZvcm1GaWVsZCwgXCJ0eXBlXCI+PiA9XG4gIEZbXCJ0eXBlXCJdIGV4dGVuZHMgXCJmaWxlXCIgPyBGaWxlIDogQW5zd2VyQnlGaWVsZDxGPjtcblxuZXhwb3J0IHR5cGUgQmFzaWNGb3JtRmllbGRzID1cbiAgfCB7XG4gICAgICB0eXBlOiBcInNlbGVjdFwiO1xuICAgICAgZmlsdGVyPzogKGl0ZW06IFNlbGVjdEl0ZW0sIHRlcm06IHN0cmluZykgPT4gYm9vbGVhbjtcbiAgICAgIG9wdGlvbnM6IFNlbGVjdEl0ZW1bXTtcbiAgICB9XG4gIHwge1xuICAgICAgdHlwZTogXCJ0ZXh0XCI7XG4gICAgICBtdWx0aWxpbmU/OiBudW1iZXI7XG4gICAgfVxuICB8IHtcbiAgICAgIHR5cGU6IFwibnVtYmVyXCI7XG4gICAgfTtcblxudHlwZSBEaXN0cmlidXRlVmFsaWRhdG9yT3ZlclVuaW9uPEZvcm1GaWVsZFR5cGVzIGV4dGVuZHMgeyB0eXBlOiBhbnkgfT4gPVxuICBGb3JtRmllbGRUeXBlcyBleHRlbmRzIGFueVxuICAgID8gRm9ybUZpZWxkVHlwZXMgJiB7XG4gICAgICAgIHZhbGlkYXRvcj86IChcbiAgICAgICAgICB2YWw6IEFuc3dlckFjdGlvbjxGb3JtRmllbGRUeXBlcz4gfCB1bmRlZmluZWRcbiAgICAgICAgKSA9PiBib29sZWFuIHwgc3RyaW5nO1xuICAgICAgfVxuICAgIDogbmV2ZXI7XG5leHBvcnQgdHlwZSBGb3JtRmllbGQgPSB7XG4gIG9wdGlvbmFsPzogYm9vbGVhbjtcbiAgaWQ6IHN0cmluZztcbn0gJiBEaXN0cmlidXRlVmFsaWRhdG9yT3ZlclVuaW9uPFxuICB8IEJhc2ljRm9ybUZpZWxkc1xuICB8IHtcbiAgICAgIHR5cGU6IFwicmFkaW9cIjtcbiAgICAgIG9wdGlvbnM6IFNlbGVjdEl0ZW1bXTtcbiAgICB9XG4gIHwge1xuICAgICAgdHlwZTogXCJjaGVja1wiIHwgXCJyYXdjaGVja1wiO1xuICAgICAgb3B0aW9uczogU2VsZWN0SXRlbVtdO1xuICAgIH1cbiAgfCB7XG4gICAgICB0eXBlOiBcImZpbGVcIjtcbiAgICAgIGZpbGVVc2FnZURlc2NyaXB0aW9uOiBzdHJpbmc7XG4gICAgICBleHRlbnNpb25zOiBzdHJpbmdbXTtcbiAgICAgIGZvb3Rlcjogc3RyaW5nO1xuICAgICAgb3BlbkZpbGU/OiB7XG4gICAgICAgIGFjdGlvbjogKCkgPT4gdm9pZDtcbiAgICAgICAgbGFiZWw6IHN0cmluZyB8IFJlYWN0Tm9kZTtcbiAgICAgIH07XG4gICAgfVxuICB8IHtcbiAgICAgIHR5cGU6IFwiYWNjZXB0XCI7XG4gICAgICBsaW5rOiB7XG4gICAgICAgIHR5cGU6IFwiZmlsZVwiIHwgXCJyb3V0ZVwiO1xuICAgICAgICB0bzogc3RyaW5nO1xuICAgICAgfTtcbiAgICAgIGNvbnRyYWN0OiB7XG4gICAgICAgIGFjdGlvbjogKCkgPT4gdm9pZDtcbiAgICAgICAgbGFiZWw6IHN0cmluZyB8IFJlYWN0Tm9kZTtcbiAgICAgIH07XG4gICAgICBhY2NlcHQ6IHtcbiAgICAgICAgbGFiZWw6IHN0cmluZztcbiAgICAgICAgb3B0aW9uYWw/OiB0cnVlO1xuICAgICAgfVtdO1xuICAgIH1cbiAgfCBVbnJlc29sdmFibGVPcjxPbmVwZXJjZW50VXRpbGl0eS5VSUVsZW1lbnRzLkZvcm1FeHRlbnNpb25bXCJmaWVsZHNcIl0sIHt9PlxuPjtcblxudHlwZSBFeHRlcm5hbFF1ZXN0aW9uRmllbGRzID0gVW5yZXNvbHZhYmxlT3I8XG4gIE9uZXBlcmNlbnRVdGlsaXR5LlVJRWxlbWVudHMuRm9ybUV4dGVuc2lvbltcImZpZWxkQW5zd2VyXCJdLFxuICB7fVxuPjtcblxuZXhwb3J0IHR5cGUgQW5zd2VyQnlGaWVsZDxGIGV4dGVuZHMgUGljazxGb3JtRmllbGQsIFwidHlwZVwiPj4gPVxuICBGW1widHlwZVwiXSBleHRlbmRzIFwiZmlsZVwiXG4gICAgPyBVcGxvYWRUYXNrIHwgdHJ1ZVxuICAgIDogRltcInR5cGVcIl0gZXh0ZW5kcyBcImFjY2VwdFwiIHwgXCJjaGVja1wiIHwgXCJyYXdjaGVja1wiXG4gICAgPyBib29sZWFuW11cbiAgICA6IEZbXCJ0eXBlXCJdIGV4dGVuZHMgXCJyYWRpb1wiIHwgXCJ0ZXh0XCIgfCBcInNlbGVjdFwiIHwgXCJudW1iZXJcIlxuICAgID8gc3RyaW5nXG4gICAgOiBGW1widHlwZVwiXSBleHRlbmRzIGtleW9mIEV4dGVybmFsUXVlc3Rpb25GaWVsZHNcbiAgICA/IE9uZXBlcmNlbnRVdGlsaXR5LlVJRWxlbWVudHMuRm9ybUV4dGVuc2lvbltcImZpZWxkQW5zd2VyXCJdW0ZbXCJ0eXBlXCJdXVxuICAgIDogdW5rbm93bjtcblxudHlwZSBPID0gRm9ybUZpZWxkW1widHlwZVwiXTtcbnR5cGUgVGVzdEFuc3dlckJ5RmllbGQgPSBbXG4gIEFuc3dlckJ5RmllbGQ8eyB0eXBlOiBcIm51bWJlclwiIH0+LFxuICBBbnN3ZXJCeUZpZWxkPHsgdHlwZTogXCJjaGVja1wiIH0+LFxuICBBbnN3ZXJCeUZpZWxkPHsgdHlwZTogXCJyYXdjaGVja1wiIH0+LFxuICBBbnN3ZXJCeUZpZWxkPHsgdHlwZTogXCJmaWxlXCIgfT4sXG4gIEFuc3dlckJ5RmllbGQ8eyB0eXBlOiBcImFjY2VwdFwiIH0+LFxuICBBbnN3ZXJCeUZpZWxkPHsgdHlwZTogXCJyYWRpb1wiIH0+LFxuICBBbnN3ZXJCeUZpZWxkPHsgdHlwZTogXCJ0ZXh0XCIgfT4sXG4gIEFuc3dlckJ5RmllbGQ8eyB0eXBlOiBcInNlbGVjdFwiIH0+LFxuICBBbnN3ZXJCeUZpZWxkPHsgdHlwZTogXCJwaG9uZVwiIH0+LFxuICBBbnN3ZXJCeUZpZWxkPHsgdHlwZTogXCJkYXRlXCIgfT4sXG4gIEFuc3dlckJ5RmllbGQ8eyB0eXBlOiBPIH0+XG5dO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7SUFvQ1lBLFFBQVEsMEJBQVJBLFFBQVE7RUFBUkEsUUFBUSxDQUFSQSxRQUFRO0VBQVJBLFFBQVEsQ0FBUkEsUUFBUTtFQUFBLE9BQVJBLFFBQVE7QUFBQTtBQUFBQyxPQUFBLENBQUFELFFBQUEsR0FBQUEsUUFBQSJ9
13
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGb3JtTW9kZSIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Gb3JtL3YyL0Zvcm1GaWVsZC9Gb3JtRmllbGQudHlwZXMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVhY3RFbGVtZW50LCBSZWFjdE5vZGUgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7IFNlbGVjdEl0ZW0gfSBmcm9tIFwiLi4vLi4vLi4vU2VsZWN0L1NlbGVjdFwiO1xuaW1wb3J0IHsgVXBsb2FkVGFzayB9IGZyb20gXCJmaXJlYmFzZS9zdG9yYWdlXCI7XG5pbXBvcnQgeyBVbnJlc29sdmFibGVPciB9IGZyb20gXCIuLi8uLi8uLi8uLi90eXBlLXV0aWxzXCI7XG5cbmV4cG9ydCB0eXBlIEdlbmVyaWNGb3JtRmllbGRQcm9wczxUIGV4dGVuZHMgRm9ybUZpZWxkW1widHlwZVwiXT4gPSB7XG4gIHZhbHVlOiBBbnN3ZXJCeUZpZWxkPHsgdHlwZTogVCB9PjtcbiAgb25BbnN3ZXI6IChGb3JtRmllbGRQcm9wczx7IHR5cGU6IFQgfT4gJiB7XG4gICAgbW9kZTogRm9ybU1vZGUuV1JJVEU7XG4gIH0pW1wib25BbnN3ZXJcIl07XG4gIHF1ZXN0aW9uOiBGb3JtRmllbGRWaWV3ICYgeyB0eXBlOiBUIH07XG4gIGVycm9yPzogc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgRm9ybUZpZWxkUHJvcHM8USBleHRlbmRzIFBpY2s8Rm9ybUZpZWxkVmlldywgXCJ0eXBlXCI+PiA9IHtcbiAgY29uZmlnOiBRO1xuICB2YWx1ZTogQW5zd2VyQnlGaWVsZDxRPjtcbn0gJiAoXG4gIHwge1xuICAgICAgbW9kZTogRm9ybU1vZGUuUkVBRF9PTkxZO1xuICAgIH1cbiAgfCB7XG4gICAgICBtb2RlPzogRm9ybU1vZGUuV1JJVEU7XG4gICAgICBvbkFuc3dlcjogPFQgZXh0ZW5kcyBRW1widHlwZVwiXT4oXG4gICAgICAgIHF1ZXN0aW9uVHlwZTogVCxcbiAgICAgICAgcXVlc3Rpb25JZDogc3RyaW5nLFxuICAgICAgICBhbnN3ZXI6XG4gICAgICAgICAgfCBBbnN3ZXJBY3Rpb248e1xuICAgICAgICAgICAgICB0eXBlOiBUO1xuICAgICAgICAgICAgfT5cbiAgICAgICAgICB8IHVuZGVmaW5lZFxuICAgICAgKSA9PiB2b2lkO1xuICAgICAgZXJyb3I/OiBzdHJpbmcgfCBzdHJpbmdbXTtcbiAgICB9XG4pO1xuXG5leHBvcnQgZW51bSBGb3JtTW9kZSB7XG4gIFJFQURfT05MWSxcbiAgV1JJVEUsXG59XG5leHBvcnQgdHlwZSBGb3JtRmllbGRWaWV3ID0gRm9ybUZpZWxkICYge1xuICB0aXRsZTogc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgQW5zd2VyQWN0aW9uPEYgZXh0ZW5kcyBQaWNrPEZvcm1GaWVsZCwgXCJ0eXBlXCI+PiA9XG4gIEZbXCJ0eXBlXCJdIGV4dGVuZHMgXCJmaWxlXCIgPyBGaWxlIDogQW5zd2VyQnlGaWVsZDxGPjtcblxuZXhwb3J0IHR5cGUgQmFzaWNGb3JtRmllbGRzID1cbiAgfCB7XG4gICAgICB0eXBlOiBcInNlbGVjdFwiO1xuICAgICAgZmlsdGVyPzogKGl0ZW06IFNlbGVjdEl0ZW0sIHRlcm06IHN0cmluZykgPT4gYm9vbGVhbjtcbiAgICAgIG9wdGlvbnM6IFNlbGVjdEl0ZW1bXTtcbiAgICB9XG4gIHwge1xuICAgICAgdHlwZTogXCJ0ZXh0XCI7XG4gICAgICBtdWx0aWxpbmU/OiBudW1iZXI7XG4gICAgfVxuICB8IHtcbiAgICAgIHR5cGU6IFwibnVtYmVyXCI7XG4gICAgfTtcblxudHlwZSBEaXN0cmlidXRlVmFsaWRhdG9yT3ZlclVuaW9uPEZvcm1GaWVsZFR5cGVzIGV4dGVuZHMgeyB0eXBlOiBhbnkgfT4gPVxuICBGb3JtRmllbGRUeXBlcyBleHRlbmRzIGFueVxuICAgID8gRm9ybUZpZWxkVHlwZXMgJiB7XG4gICAgICAgIHZhbGlkYXRvcj86IChcbiAgICAgICAgICB2YWw6IEFuc3dlckFjdGlvbjxGb3JtRmllbGRUeXBlcz4gfCB1bmRlZmluZWRcbiAgICAgICAgKSA9PiBib29sZWFuIHwgc3RyaW5nO1xuICAgICAgfVxuICAgIDogbmV2ZXI7XG5leHBvcnQgdHlwZSBGb3JtRmllbGQgPSB7XG4gIG9wdGlvbmFsPzogYm9vbGVhbjtcbiAgaWQ6IHN0cmluZztcbn0gJiBEaXN0cmlidXRlVmFsaWRhdG9yT3ZlclVuaW9uPFxuICB8IEJhc2ljRm9ybUZpZWxkc1xuICB8IHtcbiAgICAgIHR5cGU6IFwicmFkaW9cIjtcbiAgICAgIG9wdGlvbnM6IFNlbGVjdEl0ZW1bXTtcbiAgICB9XG4gIHwge1xuICAgICAgdHlwZTogXCJjaGVja1wiIHwgXCJyYXdjaGVja1wiO1xuICAgICAgb3B0aW9uczogU2VsZWN0SXRlbVtdO1xuICAgIH1cbiAgfCB7XG4gICAgICB0eXBlOiBcImZpbGVcIjtcbiAgICAgIGZpbGVVc2FnZURlc2NyaXB0aW9uOiBzdHJpbmc7XG4gICAgICBleHRlbnNpb25zOiBzdHJpbmdbXTtcbiAgICAgIGZvb3Rlcjogc3RyaW5nO1xuICAgICAgb3BlbkZpbGU/OiB7XG4gICAgICAgIGFjdGlvbjogKCkgPT4gdm9pZDtcbiAgICAgICAgbGFiZWw6IHN0cmluZyB8IFJlYWN0Tm9kZTtcbiAgICAgIH07XG4gICAgfVxuICB8IHtcbiAgICAgIHR5cGU6IFwiYWNjZXB0XCI7XG4gICAgICBsaW5rOiB7XG4gICAgICAgIHR5cGU6IFwiZmlsZVwiIHwgXCJyb3V0ZVwiO1xuICAgICAgICB0bzogc3RyaW5nO1xuICAgICAgfTtcbiAgICAgIGNvbnRyYWN0OiB7XG4gICAgICAgIGFjdGlvbjogKCkgPT4gdm9pZDtcbiAgICAgICAgbGFiZWw6IHN0cmluZyB8IFJlYWN0Tm9kZTtcbiAgICAgIH07XG4gICAgICBhY2NlcHQ6IHtcbiAgICAgICAgbGFiZWw6IHN0cmluZztcbiAgICAgICAgb3B0aW9uYWw/OiB0cnVlO1xuICAgICAgfVtdO1xuICAgIH1cbiAgfCBVbnJlc29sdmFibGVPcjxPbmVwZXJjZW50VXRpbGl0eS5VSUVsZW1lbnRzLkZvcm1FeHRlbnNpb25bXCJmaWVsZHNcIl0sIHt9PlxuPjtcblxuZXhwb3J0IHR5cGUgRm9ybUZpZWxkVHlwZXMgPSBGb3JtRmllbGRbJ3R5cGUnXSB8ICdhY2NlcHQnXG5cbnR5cGUgRXh0ZXJuYWxRdWVzdGlvbkZpZWxkcyA9IFVucmVzb2x2YWJsZU9yPFxuICBPbmVwZXJjZW50VXRpbGl0eS5VSUVsZW1lbnRzLkZvcm1FeHRlbnNpb25bXCJmaWVsZEFuc3dlclwiXSxcbiAge31cbj47XG5cbmV4cG9ydCB0eXBlIEFuc3dlckJ5RmllbGQ8RiBleHRlbmRzIFBpY2s8Rm9ybUZpZWxkLCBcInR5cGVcIj4+ID1cbiAgRltcInR5cGVcIl0gZXh0ZW5kcyBcImZpbGVcIlxuICAgID8gVXBsb2FkVGFzayB8IHRydWVcbiAgICA6IEZbXCJ0eXBlXCJdIGV4dGVuZHMgXCJhY2NlcHRcIiB8IFwiY2hlY2tcIiB8IFwicmF3Y2hlY2tcIlxuICAgID8gYm9vbGVhbltdXG4gICAgOiBGW1widHlwZVwiXSBleHRlbmRzIFwicmFkaW9cIiB8IFwidGV4dFwiIHwgXCJzZWxlY3RcIiB8IFwibnVtYmVyXCJcbiAgICA/IHN0cmluZ1xuICAgIDogRltcInR5cGVcIl0gZXh0ZW5kcyBrZXlvZiBFeHRlcm5hbFF1ZXN0aW9uRmllbGRzXG4gICAgPyBPbmVwZXJjZW50VXRpbGl0eS5VSUVsZW1lbnRzLkZvcm1FeHRlbnNpb25bXCJmaWVsZEFuc3dlclwiXVtGW1widHlwZVwiXV1cbiAgICA6IHVua25vd247XG5cbnR5cGUgTyA9IEZvcm1GaWVsZFtcInR5cGVcIl07XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztJQW9DWUEsUUFBUSwwQkFBUkEsUUFBUTtFQUFSQSxRQUFRLENBQVJBLFFBQVE7RUFBUkEsUUFBUSxDQUFSQSxRQUFRO0VBQUEsT0FBUkEsUUFBUTtBQUFBO0FBQUFDLE9BQUEsQ0FBQUQsUUFBQSxHQUFBQSxRQUFBIn0=
@@ -0,0 +1,9 @@
1
+ # Animating component transition
2
+
3
+ When the key changes, a the transition between components will be controlled by UncontrolledTransition
4
+
5
+ ```tsx
6
+ <UncontrolledTransition>
7
+ <AComponent key={DYNAMIC_KEY}>
8
+ </UncontrolledTransition>
9
+ ```
@@ -3,7 +3,7 @@ import { TransitionProps, TransitionTypeDefinitions } from "../Transition/Transi
3
3
  /**
4
4
  * This component receives child with key and applies a transition when the key changes, allowing to swap elements with a fine transition.
5
5
  **/
6
- declare const UncontrolledTransition: React.ForwardRefExoticComponent<({
6
+ export declare const UncontrolledTransition: React.ForwardRefExoticComponent<({
7
7
  className?: string | undefined;
8
8
  contentClassName?: string | undefined;
9
9
  children?: React.ReactElement<unknown, string | React.JSXElementConstructor<any>> | undefined;
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.default = void 0;
6
+ exports.default = exports.UncontrolledTransition = void 0;
7
7
  var _react = _interopRequireWildcard(require("react"));
8
8
  var _Transition = _interopRequireDefault(require("../Transition"));
9
9
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
@@ -103,6 +103,7 @@ function _UncontrolledTransition(_ref, ref) {
103
103
  * This component receives child with key and applies a transition when the key changes, allowing to swap elements with a fine transition.
104
104
  **/
105
105
  const UncontrolledTransition = /*#__PURE__*/(0, _react.forwardRef)(_UncontrolledTransition);
106
+ exports.UncontrolledTransition = UncontrolledTransition;
106
107
  var _default = UncontrolledTransition;
107
108
  exports.default = _default;
108
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Transition","_interopRequireDefault","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_UncontrolledTransition","_ref","ref","className","contentClassName","children","createElement","Fragment","lockTransitionWidth","lockTransitionHeight","contentStyle","onDiscardStep","props","sectionRef","useRef","childStack","offset","setChildStack","useState","createdAt","Date","now","orientation","setOrientation","a","current","useImperativeHandle","useLayoutEffect","process","env","NODE_ENV","Error","p","useEffect","prev","forEach","arr","predictedStep","step","discardedKey","animatedAt","filter","UncontrolledTransition","forwardRef","_default","exports"],"sources":["../../../src/components/UncontrolledTransition/UncontrolledTransition.tsx"],"sourcesContent":["import React, {\n  DetailedHTMLProps,\n  ForwardedRef,\n  forwardRef,\n  Key,\n  RefObject,\n  useEffect,\n  useImperativeHandle,\n  useLayoutEffect,\n  useRef,\n  useState,\n} from \"react\";\nimport Transition from \"../Transition\";\nimport {\n  TransitionProps,\n  TransitionTypeDefinitions,\n} from \"../Transition/Transition\";\n\nfunction _UncontrolledTransition(\n  {\n    className = \"\",\n    contentClassName,\n    children = <React.Fragment key=\"default\"></React.Fragment>,\n    lockTransitionWidth = true,\n    lockTransitionHeight = false,\n    contentStyle,\n    onDiscardStep,\n    ...props\n  }: {\n    className?: string;\n    contentClassName?: string;\n    children?: React.ReactElement;\n    lockTransitionWidth?: boolean;\n    lockTransitionHeight?: boolean;\n    onDiscardStep?: (key: Key) => void;\n  } & Pick<TransitionProps, \"contentStyle\"> &\n    TransitionTypeDefinitions &\n    Omit<\n      DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, any>,\n      \"className\" | \"children\" | \"ref\"\n    >,\n  ref: ForwardedRef<{\n    setOrientation: (orientation: \"forward\" | \"backward\") => void;\n    sectionRef: RefObject<HTMLDivElement | null>;\n  }>\n) {\n  const sectionRef = useRef<HTMLDivElement>(null);\n  const [{ childStack, offset }, setChildStack] = useState<{\n    childStack: (React.ReactElement & { createdAt: number })[];\n    offset: number;\n  }>(() => ({\n    childStack: [{ ...children, createdAt: Date.now() }],\n    offset: 1,\n  }));\n  const orientation = useRef<\"forward\" | \"backward\">(\"forward\");\n  function setOrientation(a: typeof orientation.current) {\n    orientation.current = a;\n  }\n\n  useImperativeHandle(\n    ref,\n    () => ({\n      setOrientation,\n      sectionRef,\n    }),\n    []\n  );\n\n  useLayoutEffect(() => {\n    if (process.env.NODE_ENV !== \"production\" && !children.key)\n      throw new Error(\n        \"The provided child should have a key property, please provide it\"\n      );\n    if (childStack.length === 1 && childStack[0].key === children.key) return;\n    if (orientation.current === \"forward\")\n      setChildStack((p) => ({\n        ...p,\n        childStack: [...p.childStack, { ...children, createdAt: Date.now() }],\n      }));\n    else\n      setChildStack((p) => ({\n        ...p,\n        childStack: [{ ...children, createdAt: Date.now() }, ...p.childStack],\n      }));\n  }, [children.key]);\n\n  useEffect(() => {\n    if (orientation.current === \"backward\") {\n      setChildStack((prev) => {\n        return {\n          ...prev,\n          offset: prev.childStack.length,\n        };\n      });\n    }\n  }, [childStack.length]);\n\n  childStack.forEach((a, i, arr) => {\n    if (a.key === children.key)\n      arr[i] = { ...children, createdAt: a.createdAt };\n  });\n\n  const predictedStep = childStack.length - offset;\n\n  return (\n    <>\n      {childStack.length ? (\n        <Transition\n          ref={sectionRef}\n          contentStyle={contentStyle}\n          className={className}\n          step={predictedStep}\n          onDiscardStep={(discardedKey, animatedAt) => {\n            if (onDiscardStep) onDiscardStep(discardedKey);\n            orientation.current = \"forward\";\n            setChildStack((prev) => {\n              return {\n                childStack: prev.childStack.filter((a) => {\n                  return a.key !== discardedKey || a.createdAt > animatedAt;\n                }),\n                offset: prev.offset === 1 ? 1 : prev.offset - 1,\n              };\n            });\n          }}\n          lockTransitionWidth={lockTransitionWidth}\n          lockTransitionHeight={lockTransitionHeight}\n          contentClassName={contentClassName}\n          {...props}\n        >\n          {childStack}\n        </Transition>\n      ) : null}\n    </>\n  );\n}\n\n/**\n * This component receives child with key and applies a transition when the key changes, allowing to swap elements with a fine transition.\n **/\nconst UncontrolledTransition = forwardRef(_UncontrolledTransition);\nexport default UncontrolledTransition;\n"],"mappings":"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"}
109
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Transition","_interopRequireDefault","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_UncontrolledTransition","_ref","ref","className","contentClassName","children","createElement","Fragment","lockTransitionWidth","lockTransitionHeight","contentStyle","onDiscardStep","props","sectionRef","useRef","childStack","offset","setChildStack","useState","createdAt","Date","now","orientation","setOrientation","a","current","useImperativeHandle","useLayoutEffect","process","env","NODE_ENV","Error","p","useEffect","prev","forEach","arr","predictedStep","step","discardedKey","animatedAt","filter","UncontrolledTransition","forwardRef","exports","_default"],"sources":["../../../src/components/UncontrolledTransition/UncontrolledTransition.tsx"],"sourcesContent":["import React, {\n  DetailedHTMLProps,\n  ForwardedRef,\n  forwardRef,\n  Key,\n  RefObject,\n  useEffect,\n  useImperativeHandle,\n  useLayoutEffect,\n  useRef,\n  useState,\n} from \"react\";\nimport Transition from \"../Transition\";\nimport {\n  TransitionProps,\n  TransitionTypeDefinitions,\n} from \"../Transition/Transition\";\n\nfunction _UncontrolledTransition(\n  {\n    className = \"\",\n    contentClassName,\n    children = <React.Fragment key=\"default\"></React.Fragment>,\n    lockTransitionWidth = true,\n    lockTransitionHeight = false,\n    contentStyle,\n    onDiscardStep,\n    ...props\n  }: {\n    className?: string;\n    contentClassName?: string;\n    children?: React.ReactElement;\n    lockTransitionWidth?: boolean;\n    lockTransitionHeight?: boolean;\n    onDiscardStep?: (key: Key) => void;\n  } & Pick<TransitionProps, \"contentStyle\"> &\n    TransitionTypeDefinitions &\n    Omit<\n      DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, any>,\n      \"className\" | \"children\" | \"ref\"\n    >,\n  ref: ForwardedRef<{\n    setOrientation: (orientation: \"forward\" | \"backward\") => void;\n    sectionRef: RefObject<HTMLDivElement | null>;\n  }>\n) {\n  const sectionRef = useRef<HTMLDivElement>(null);\n  const [{ childStack, offset }, setChildStack] = useState<{\n    childStack: (React.ReactElement & { createdAt: number })[];\n    offset: number;\n  }>(() => ({\n    childStack: [{ ...children, createdAt: Date.now() }],\n    offset: 1,\n  }));\n  const orientation = useRef<\"forward\" | \"backward\">(\"forward\");\n  function setOrientation(a: typeof orientation.current) {\n    orientation.current = a;\n  }\n\n  useImperativeHandle(\n    ref,\n    () => ({\n      setOrientation,\n      sectionRef,\n    }),\n    []\n  );\n\n  useLayoutEffect(() => {\n    if (process.env.NODE_ENV !== \"production\" && !children.key)\n      throw new Error(\n        \"The provided child should have a key property, please provide it\"\n      );\n    if (childStack.length === 1 && childStack[0].key === children.key) return;\n    if (orientation.current === \"forward\")\n      setChildStack((p) => ({\n        ...p,\n        childStack: [...p.childStack, { ...children, createdAt: Date.now() }],\n      }));\n    else\n      setChildStack((p) => ({\n        ...p,\n        childStack: [{ ...children, createdAt: Date.now() }, ...p.childStack],\n      }));\n  }, [children.key]);\n\n  useEffect(() => {\n    if (orientation.current === \"backward\") {\n      setChildStack((prev) => {\n        return {\n          ...prev,\n          offset: prev.childStack.length,\n        };\n      });\n    }\n  }, [childStack.length]);\n\n  childStack.forEach((a, i, arr) => {\n    if (a.key === children.key)\n      arr[i] = { ...children, createdAt: a.createdAt };\n  });\n\n  const predictedStep = childStack.length - offset;\n\n  return (\n    <>\n      {childStack.length ? (\n        <Transition\n          ref={sectionRef}\n          contentStyle={contentStyle}\n          className={className}\n          step={predictedStep}\n          onDiscardStep={(discardedKey, animatedAt) => {\n            if (onDiscardStep) onDiscardStep(discardedKey);\n            orientation.current = \"forward\";\n            setChildStack((prev) => {\n              return {\n                childStack: prev.childStack.filter((a) => {\n                  return a.key !== discardedKey || a.createdAt > animatedAt;\n                }),\n                offset: prev.offset === 1 ? 1 : prev.offset - 1,\n              };\n            });\n          }}\n          lockTransitionWidth={lockTransitionWidth}\n          lockTransitionHeight={lockTransitionHeight}\n          contentClassName={contentClassName}\n          {...props}\n        >\n          {childStack}\n        </Transition>\n      ) : null}\n    </>\n  );\n}\n\n/**\n * This component receives child with key and applies a transition when the key changes, allowing to swap elements with a fine transition.\n **/\nexport const UncontrolledTransition = forwardRef(_UncontrolledTransition);\nexport default UncontrolledTransition;\n"],"mappings":"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"}
@@ -1 +1,2 @@
1
- export { default } from './UncontrolledTransition';
1
+ export { default } from "./UncontrolledTransition";
2
+ export * from "./UncontrolledTransition";
@@ -3,12 +3,25 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
+ var _exportNames = {};
6
7
  Object.defineProperty(exports, "default", {
7
8
  enumerable: true,
8
9
  get: function () {
9
10
  return _UncontrolledTransition.default;
10
11
  }
11
12
  });
12
- var _UncontrolledTransition = _interopRequireDefault(require("./UncontrolledTransition"));
13
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
14
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfVW5jb250cm9sbGVkVHJhbnNpdGlvbiIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwib2JqIiwiX19lc01vZHVsZSIsImRlZmF1bHQiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9VbmNvbnRyb2xsZWRUcmFuc2l0aW9uL2luZGV4LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBkZWZhdWx0IH0gZnJvbSAnLi9VbmNvbnRyb2xsZWRUcmFuc2l0aW9uJztcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFBQSxJQUFBQSx1QkFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQW1ELFNBQUFELHVCQUFBRSxHQUFBLFdBQUFBLEdBQUEsSUFBQUEsR0FBQSxDQUFBQyxVQUFBLEdBQUFELEdBQUEsS0FBQUUsT0FBQSxFQUFBRixHQUFBIn0=
13
+ var _UncontrolledTransition = _interopRequireWildcard(require("./UncontrolledTransition"));
14
+ Object.keys(_UncontrolledTransition).forEach(function (key) {
15
+ if (key === "default" || key === "__esModule") return;
16
+ if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
17
+ if (key in exports && exports[key] === _UncontrolledTransition[key]) return;
18
+ Object.defineProperty(exports, key, {
19
+ enumerable: true,
20
+ get: function () {
21
+ return _UncontrolledTransition[key];
22
+ }
23
+ });
24
+ });
25
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
26
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
27
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfVW5jb250cm9sbGVkVHJhbnNpdGlvbiIsIl9pbnRlcm9wUmVxdWlyZVdpbGRjYXJkIiwicmVxdWlyZSIsIk9iamVjdCIsImtleXMiLCJmb3JFYWNoIiwia2V5IiwicHJvdG90eXBlIiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwiX2V4cG9ydE5hbWVzIiwiZXhwb3J0cyIsImRlZmluZVByb3BlcnR5IiwiZW51bWVyYWJsZSIsImdldCIsIl9nZXRSZXF1aXJlV2lsZGNhcmRDYWNoZSIsIm5vZGVJbnRlcm9wIiwiV2Vha01hcCIsImNhY2hlQmFiZWxJbnRlcm9wIiwiY2FjaGVOb2RlSW50ZXJvcCIsIm9iaiIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiY2FjaGUiLCJoYXMiLCJuZXdPYmoiLCJoYXNQcm9wZXJ0eURlc2NyaXB0b3IiLCJnZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3IiLCJkZXNjIiwic2V0Il0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVW5jb250cm9sbGVkVHJhbnNpdGlvbi9pbmRleC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgZGVmYXVsdCB9IGZyb20gXCIuL1VuY29udHJvbGxlZFRyYW5zaXRpb25cIjtcbmV4cG9ydCAqIGZyb20gXCIuL1VuY29udHJvbGxlZFRyYW5zaXRpb25cIjtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsSUFBQUEsdUJBQUEsR0FBQUMsdUJBQUEsQ0FBQUMsT0FBQTtBQUNBQyxNQUFBLENBQUFDLElBQUEsQ0FBQUosdUJBQUEsRUFBQUssT0FBQSxXQUFBQyxHQUFBO0VBQUEsSUFBQUEsR0FBQSxrQkFBQUEsR0FBQTtFQUFBLElBQUFILE1BQUEsQ0FBQUksU0FBQSxDQUFBQyxjQUFBLENBQUFDLElBQUEsQ0FBQUMsWUFBQSxFQUFBSixHQUFBO0VBQUEsSUFBQUEsR0FBQSxJQUFBSyxPQUFBLElBQUFBLE9BQUEsQ0FBQUwsR0FBQSxNQUFBTix1QkFBQSxDQUFBTSxHQUFBO0VBQUFILE1BQUEsQ0FBQVMsY0FBQSxDQUFBRCxPQUFBLEVBQUFMLEdBQUE7SUFBQU8sVUFBQTtJQUFBQyxHQUFBLFdBQUFBLENBQUE7TUFBQSxPQUFBZCx1QkFBQSxDQUFBTSxHQUFBO0lBQUE7RUFBQTtBQUFBO0FBQXlDLFNBQUFTLHlCQUFBQyxXQUFBLGVBQUFDLE9BQUEsa0NBQUFDLGlCQUFBLE9BQUFELE9BQUEsUUFBQUUsZ0JBQUEsT0FBQUYsT0FBQSxZQUFBRix3QkFBQSxZQUFBQSxDQUFBQyxXQUFBLFdBQUFBLFdBQUEsR0FBQUcsZ0JBQUEsR0FBQUQsaUJBQUEsS0FBQUYsV0FBQTtBQUFBLFNBQUFmLHdCQUFBbUIsR0FBQSxFQUFBSixXQUFBLFNBQUFBLFdBQUEsSUFBQUksR0FBQSxJQUFBQSxHQUFBLENBQUFDLFVBQUEsV0FBQUQsR0FBQSxRQUFBQSxHQUFBLG9CQUFBQSxHQUFBLHdCQUFBQSxHQUFBLDRCQUFBRSxPQUFBLEVBQUFGLEdBQUEsVUFBQUcsS0FBQSxHQUFBUix3QkFBQSxDQUFBQyxXQUFBLE9BQUFPLEtBQUEsSUFBQUEsS0FBQSxDQUFBQyxHQUFBLENBQUFKLEdBQUEsWUFBQUcsS0FBQSxDQUFBVCxHQUFBLENBQUFNLEdBQUEsU0FBQUssTUFBQSxXQUFBQyxxQkFBQSxHQUFBdkIsTUFBQSxDQUFBUyxjQUFBLElBQUFULE1BQUEsQ0FBQXdCLHdCQUFBLFdBQUFyQixHQUFBLElBQUFjLEdBQUEsUUFBQWQsR0FBQSxrQkFBQUgsTUFBQSxDQUFBSSxTQUFBLENBQUFDLGNBQUEsQ0FBQUMsSUFBQSxDQUFBVyxHQUFBLEVBQUFkLEdBQUEsU0FBQXNCLElBQUEsR0FBQUYscUJBQUEsR0FBQXZCLE1BQUEsQ0FBQXdCLHdCQUFBLENBQUFQLEdBQUEsRUFBQWQsR0FBQSxjQUFBc0IsSUFBQSxLQUFBQSxJQUFBLENBQUFkLEdBQUEsSUFBQWMsSUFBQSxDQUFBQyxHQUFBLEtBQUExQixNQUFBLENBQUFTLGNBQUEsQ0FBQWEsTUFBQSxFQUFBbkIsR0FBQSxFQUFBc0IsSUFBQSxZQUFBSCxNQUFBLENBQUFuQixHQUFBLElBQUFjLEdBQUEsQ0FBQWQsR0FBQSxTQUFBbUIsTUFBQSxDQUFBSCxPQUFBLEdBQUFGLEdBQUEsTUFBQUcsS0FBQSxJQUFBQSxLQUFBLENBQUFNLEdBQUEsQ0FBQVQsR0FBQSxFQUFBSyxNQUFBLFlBQUFBLE1BQUEifQ==
@@ -15,7 +15,7 @@ export declare const ContextAsyncControlContext: React.Context<ContextAsyncContr
15
15
  export default function ContextAsyncControlProvider({ children, }: PropsWithChildren<{}>): import("react/jsx-runtime").JSX.Element;
16
16
  export declare function useShareState<E>(controlId: string, stateId: string): readonly [E, (value: React.SetStateAction<E>) => void];
17
17
  export declare function useContextControl<E, F extends FunctionMap>(controlId: string, functionsToWrap: F): {
18
- process: (asyncFn: () => Promise<any>) => Promise<any>;
18
+ process: (asyncFn: Promise<any> | (() => Promise<any>)) => Promise<any>;
19
19
  loading: boolean;
20
20
  error: Error | E | undefined;
21
21
  setError: React.Dispatch<React.SetStateAction<Error | E | undefined>>;
@@ -5,9 +5,21 @@ const control = useAsyncControl()
5
5
  control.process(() => anAsyncFunction());
6
6
  ```
7
7
 
8
- # Using an async function directly
8
+ # Using multiple async functions
9
9
  ```tsx
10
- const control = useAsyncControl({anAsyncFunction})
10
+ const control = useAsyncControl({
11
+ asyncFunctionOne,
12
+ asyncFunctionTwo,
13
+ })
11
14
 
12
- control.anAsyncFunction();
15
+ control.asyncFunctionOne();
16
+ control.asyncFunctionTwo();
17
+ ```
18
+
19
+ # Storing data
20
+ ```tsx
21
+ const [result, setResult] = useState()
22
+ const control = useAsyncControl({anAsyncFunctionThatReturnsData})
23
+
24
+ control.anAsyncFunctionThatReturnsData().then(setResult);
13
25
  ```
@@ -9,24 +9,24 @@ export type Control<E extends any = any> = {
9
9
  loading: boolean;
10
10
  };
11
11
  export declare function useRawAsynControl<E = any, F extends FunctionMap = {}>(functionsToWrap: F | undefined, [error, setError]: Arr<E | undefined>, [loading, setLoading]: Arr<boolean>): {
12
- process: (asyncFn: () => Promise<any>) => Promise<any>;
12
+ process: (asyncFn: (() => Promise<any>) | Promise<any>) => Promise<any>;
13
13
  loading: boolean;
14
14
  error: E | undefined;
15
15
  setError: import("react").Dispatch<SetStateAction<E | undefined>>;
16
16
  setLoading: import("react").Dispatch<SetStateAction<boolean>>;
17
17
  } & F;
18
- /**
19
- * This hook provides a way to handle async operations storing the loading state, or the error when if fails
20
- * @param functionsToWrap The functions to wrap in control. The wrapped functions can be called from the returned control object as control.functionName
21
- * @returns
22
- */
23
- export default function useAsyncControl<E = any, F extends {
18
+ export declare function useAsyncControl<E = any, F extends {
24
19
  [f: string]: ((...args: any[]) => Promise<any>) | Object | Primitive;
25
20
  } = {}>(functionsToWrap?: F): {
26
- process: (asyncFn: () => Promise<any>) => Promise<any>;
21
+ process: (asyncFn: Promise<any> | (() => Promise<any>)) => Promise<any>;
27
22
  loading: boolean;
28
- error: Error | E | undefined;
29
- setError: import("react").Dispatch<SetStateAction<Error | E | undefined>>;
23
+ error: E | Error | undefined;
24
+ setError: import("react").Dispatch<SetStateAction<E | Error | undefined>>;
30
25
  setLoading: import("react").Dispatch<SetStateAction<boolean>>;
31
26
  } & F;
32
- export {};
27
+ /**
28
+ * This hook provides a way to handle async operations storing the loading state, or the error when it fails, it does not store information returned from the functions.
29
+ * @param functionsToWrap The functions to wrap in control.
30
+ * @returns
31
+ */
32
+ export default useAsyncControl;
@@ -3,7 +3,8 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.default = useAsyncControl;
6
+ exports.default = void 0;
7
+ exports.useAsyncControl = useAsyncControl;
7
8
  exports.useRawAsynControl = useRawAsynControl;
8
9
  var _react = require("react");
9
10
  function useRawAsynControl(functionsToWrap, _ref, _ref2) {
@@ -13,7 +14,7 @@ function useRawAsynControl(functionsToWrap, _ref, _ref2) {
13
14
  try {
14
15
  setLoading(true);
15
16
  setError(undefined);
16
- return await asyncFn();
17
+ if (asyncFn instanceof Promise) await asyncFn;else return await asyncFn();
17
18
  } catch (e) {
18
19
  if (process.env.NODE_ENV === "development") console.error(e);
19
20
  setError(e);
@@ -66,15 +67,17 @@ function useRawAsynControl(functionsToWrap, _ref, _ref2) {
66
67
  }, {})
67
68
  };
68
69
  }
69
-
70
- /**
71
- * This hook provides a way to handle async operations storing the loading state, or the error when if fails
72
- * @param functionsToWrap The functions to wrap in control. The wrapped functions can be called from the returned control object as control.functionName
73
- * @returns
74
- */
75
70
  function useAsyncControl(functionsToWrap) {
76
71
  const error = (0, _react.useState)();
77
72
  const loading = (0, _react.useState)(false);
78
73
  return useRawAsynControl(functionsToWrap, error, loading);
79
74
  }
80
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJyZXF1aXJlIiwidXNlUmF3QXN5bkNvbnRyb2wiLCJmdW5jdGlvbnNUb1dyYXAiLCJfcmVmIiwiX3JlZjIiLCJlcnJvciIsInNldEVycm9yIiwibG9hZGluZyIsInNldExvYWRpbmciLCJfcHJvY2VzcyIsInVzZUNhbGxiYWNrIiwiYXN5bmNGbiIsInVuZGVmaW5lZCIsImUiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJjb25zb2xlIiwiZnVuY3Rpb25zVG9NZW1vaXplIiwib3RoZXIiLCJPYmplY3QiLCJlbnRyaWVzIiwicmVkdWNlIiwiciIsIl9yZWYzIiwiayIsImZ1bmMiLCJfcmVmNCIsInYiLCJ1c2VNZW1vIiwiX2xlbiIsImFyZ3VtZW50cyIsImxlbmd0aCIsImFyZ3MiLCJBcnJheSIsIl9rZXkiLCJ1c2VBc3luY0NvbnRyb2wiLCJ1c2VTdGF0ZSJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ob29rcy91c2VBc3luY0NvbnRyb2wudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2V0U3RhdGVBY3Rpb24sIHVzZUNhbGxiYWNrLCB1c2VNZW1vLCB1c2VTdGF0ZSB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHsgUHJpbWl0aXZlIH0gZnJvbSBcInR5cGUtZmVzdFwiO1xuXG50eXBlIEFycjxYPiA9IFtYLCBSZWFjdC5EaXNwYXRjaDxTZXRTdGF0ZUFjdGlvbjxYPj5dO1xuZXhwb3J0IHR5cGUgRnVuY3Rpb25NYXAgPSB7XG4gIFtmOiBzdHJpbmddOiAoKC4uLmFyZ3M6IGFueVtdKSA9PiBQcm9taXNlPGFueT4pIHwgT2JqZWN0IHwgUHJpbWl0aXZlO1xufTtcbmV4cG9ydCB0eXBlIENvbnRyb2w8RSBleHRlbmRzIGFueSA9IGFueT4gPSB7XG4gIGVycm9yPzogRTtcbiAgbG9hZGluZzogYm9vbGVhbjtcbn07XG5leHBvcnQgZnVuY3Rpb24gdXNlUmF3QXN5bkNvbnRyb2w8RSA9IGFueSwgRiBleHRlbmRzIEZ1bmN0aW9uTWFwID0ge30+KFxuICBmdW5jdGlvbnNUb1dyYXA6IEYgfCB1bmRlZmluZWQsXG4gIFtlcnJvciwgc2V0RXJyb3JdOiBBcnI8RSB8IHVuZGVmaW5lZD4sXG4gIFtsb2FkaW5nLCBzZXRMb2FkaW5nXTogQXJyPGJvb2xlYW4+XG4pIHtcbiAgY29uc3QgX3Byb2Nlc3MgPSB1c2VDYWxsYmFjayhhc3luYyAoYXN5bmNGbjogKCkgPT4gUHJvbWlzZTxhbnk+KSA9PiB7XG4gICAgdHJ5IHtcbiAgICAgIHNldExvYWRpbmcodHJ1ZSk7XG4gICAgICBzZXRFcnJvcih1bmRlZmluZWQpO1xuICAgICAgcmV0dXJuIGF3YWl0IGFzeW5jRm4oKTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09IFwiZGV2ZWxvcG1lbnRcIikgY29uc29sZS5lcnJvcihlKTtcbiAgICAgIHNldEVycm9yKGUgYXMgRSk7XG4gICAgICB0aHJvdyBlO1xuICAgIH0gZmluYWxseSB7XG4gICAgICBzZXRMb2FkaW5nKGZhbHNlKTtcbiAgICB9XG4gIH0sIFtdKTtcblxuICBjb25zdCB7IGZ1bmN0aW9uc1RvTWVtb2l6ZSwgb3RoZXIgfSA9IE9iamVjdC5lbnRyaWVzKFxuICAgIGZ1bmN0aW9uc1RvV3JhcCB8fCB7fVxuICApLnJlZHVjZShcbiAgICAociwgW2ssIGZ1bmNdKSA9PiB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICAuLi5yLFxuICAgICAgICAuLi4odHlwZW9mIGZ1bmMgPT09IFwiZnVuY3Rpb25cIlxuICAgICAgICAgID8ge1xuICAgICAgICAgICAgICBmdW5jdGlvbnNUb01lbW9pemU6IHtcbiAgICAgICAgICAgICAgICAuLi5yLmZ1bmN0aW9uc1RvTWVtb2l6ZSxcbiAgICAgICAgICAgICAgICBba106IGZ1bmMsXG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB9XG4gICAgICAgICAgOiB7XG4gICAgICAgICAgICAgIG90aGVyOiB7XG4gICAgICAgICAgICAgICAgLi4uci5vdGhlcixcbiAgICAgICAgICAgICAgICBba106IGZ1bmMsXG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB9KSxcbiAgICAgIH07XG4gICAgfSxcbiAgICB7XG4gICAgICBmdW5jdGlvbnNUb01lbW9pemU6IHt9LFxuICAgICAgb3RoZXI6IHt9LFxuICAgIH0gYXMge1xuICAgICAgZnVuY3Rpb25zVG9NZW1vaXplOiBGO1xuICAgICAgb3RoZXI6IEY7XG4gICAgfVxuICApO1xuXG4gIHJldHVybiB7XG4gICAgcHJvY2VzczogX3Byb2Nlc3MsXG4gICAgbG9hZGluZyxcbiAgICBlcnJvcixcbiAgICBzZXRFcnJvcixcbiAgICBzZXRMb2FkaW5nLFxuICAgIC4uLm90aGVyLFxuICAgIC4uLk9iamVjdC5lbnRyaWVzKGZ1bmN0aW9uc1RvTWVtb2l6ZSkucmVkdWNlKFxuICAgICAgKHIsIFtrLCB2XSkgPT4gKHtcbiAgICAgICAgLi4ucixcbiAgICAgICAgW2tdOiB1c2VNZW1vKFxuICAgICAgICAgICgpID0+XG4gICAgICAgICAgICAoLi4uYXJnczogYW55W10pID0+XG4gICAgICAgICAgICAgIF9wcm9jZXNzKCgpID0+ICh2IGFzIGFueSkoLi4uYXJncykpLFxuICAgICAgICAgIFt2XVxuICAgICAgICApLFxuICAgICAgfSksXG4gICAgICB7fSBhcyBGXG4gICAgKSxcbiAgfTtcbn1cblxuLyoqXG4gKiBUaGlzIGhvb2sgcHJvdmlkZXMgYSB3YXkgdG8gaGFuZGxlIGFzeW5jIG9wZXJhdGlvbnMgc3RvcmluZyB0aGUgbG9hZGluZyBzdGF0ZSwgb3IgdGhlIGVycm9yIHdoZW4gaWYgZmFpbHNcbiAqIEBwYXJhbSBmdW5jdGlvbnNUb1dyYXAgVGhlIGZ1bmN0aW9ucyB0byB3cmFwIGluIGNvbnRyb2wuIFRoZSB3cmFwcGVkIGZ1bmN0aW9ucyBjYW4gYmUgY2FsbGVkIGZyb20gdGhlIHJldHVybmVkIGNvbnRyb2wgb2JqZWN0IGFzIGNvbnRyb2wuZnVuY3Rpb25OYW1lXG4gKiBAcmV0dXJuc1xuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiB1c2VBc3luY0NvbnRyb2w8XG4gIEUgPSBhbnksXG4gIEYgZXh0ZW5kcyB7XG4gICAgW2Y6IHN0cmluZ106ICgoLi4uYXJnczogYW55W10pID0+IFByb21pc2U8YW55PikgfCBPYmplY3QgfCBQcmltaXRpdmU7XG4gIH0gPSB7fVxuPihmdW5jdGlvbnNUb1dyYXA/OiBGKSB7XG4gIGNvbnN0IGVycm9yID0gdXNlU3RhdGU8RSB8IEVycm9yPigpO1xuICBjb25zdCBsb2FkaW5nID0gdXNlU3RhdGU8Ym9vbGVhbj4oZmFsc2UpO1xuXG4gIHJldHVybiB1c2VSYXdBc3luQ29udHJvbChmdW5jdGlvbnNUb1dyYXAsIGVycm9yLCBsb2FkaW5nKTtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsT0FBQTtBQVdPLFNBQVNDLGlCQUFpQkEsQ0FDL0JDLGVBQThCLEVBQUFDLElBQUEsRUFBQUMsS0FBQSxFQUc5QjtFQUFBLElBRkEsQ0FBQ0MsS0FBSyxFQUFFQyxRQUFRLENBQXFCLEdBQUFILElBQUE7RUFBQSxJQUNyQyxDQUFDSSxPQUFPLEVBQUVDLFVBQVUsQ0FBZSxHQUFBSixLQUFBO0VBRW5DLE1BQU1LLFFBQVEsR0FBRyxJQUFBQyxrQkFBVyxFQUFDLE1BQU9DLE9BQTJCLElBQUs7SUFDbEUsSUFBSTtNQUNGSCxVQUFVLENBQUMsSUFBSSxDQUFDO01BQ2hCRixRQUFRLENBQUNNLFNBQVMsQ0FBQztNQUNuQixPQUFPLE1BQU1ELE9BQU8sQ0FBQyxDQUFDO0lBQ3hCLENBQUMsQ0FBQyxPQUFPRSxDQUFDLEVBQUU7TUFDVixJQUFJQyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLGFBQWEsRUFBRUMsT0FBTyxDQUFDWixLQUFLLENBQUNRLENBQUMsQ0FBQztNQUM1RFAsUUFBUSxDQUFDTyxDQUFNLENBQUM7TUFDaEIsTUFBTUEsQ0FBQztJQUNULENBQUMsU0FBUztNQUNSTCxVQUFVLENBQUMsS0FBSyxDQUFDO0lBQ25CO0VBQ0YsQ0FBQyxFQUFFLEVBQUUsQ0FBQztFQUVOLE1BQU07SUFBRVUsa0JBQWtCO0lBQUVDO0VBQU0sQ0FBQyxHQUFHQyxNQUFNLENBQUNDLE9BQU8sQ0FDbERuQixlQUFlLElBQUksQ0FBQyxDQUN0QixDQUFDLENBQUNvQixNQUFNLENBQ04sQ0FBQ0MsQ0FBQyxFQUFBQyxLQUFBLEtBQWdCO0lBQUEsSUFBZCxDQUFDQyxDQUFDLEVBQUVDLElBQUksQ0FBQyxHQUFBRixLQUFBO0lBQ1gsT0FBTztNQUNMLEdBQUdELENBQUM7TUFDSixJQUFJLE9BQU9HLElBQUksS0FBSyxVQUFVLEdBQzFCO1FBQ0VSLGtCQUFrQixFQUFFO1VBQ2xCLEdBQUdLLENBQUMsQ0FBQ0wsa0JBQWtCO1VBQ3ZCLENBQUNPLENBQUMsR0FBR0M7UUFDUDtNQUNGLENBQUMsR0FDRDtRQUNFUCxLQUFLLEVBQUU7VUFDTCxHQUFHSSxDQUFDLENBQUNKLEtBQUs7VUFDVixDQUFDTSxDQUFDLEdBQUdDO1FBQ1A7TUFDRixDQUFDO0lBQ1AsQ0FBQztFQUNILENBQUMsRUFDRDtJQUNFUixrQkFBa0IsRUFBRSxDQUFDLENBQUM7SUFDdEJDLEtBQUssRUFBRSxDQUFDO0VBQ1YsQ0FJRixDQUFDO0VBRUQsT0FBTztJQUNMTCxPQUFPLEVBQUVMLFFBQVE7SUFDakJGLE9BQU87SUFDUEYsS0FBSztJQUNMQyxRQUFRO0lBQ1JFLFVBQVU7SUFDVixHQUFHVyxLQUFLO0lBQ1IsR0FBR0MsTUFBTSxDQUFDQyxPQUFPLENBQUNILGtCQUFrQixDQUFDLENBQUNJLE1BQU0sQ0FDMUMsQ0FBQ0MsQ0FBQyxFQUFBSSxLQUFBO01BQUEsSUFBRSxDQUFDRixDQUFDLEVBQUVHLENBQUMsQ0FBQyxHQUFBRCxLQUFBO01BQUEsT0FBTTtRQUNkLEdBQUdKLENBQUM7UUFDSixDQUFDRSxDQUFDLEdBQUcsSUFBQUksY0FBTyxFQUNWLE1BQ0U7VUFBQSxTQUFBQyxJQUFBLEdBQUFDLFNBQUEsQ0FBQUMsTUFBQSxFQUFJQyxJQUFJLE9BQUFDLEtBQUEsQ0FBQUosSUFBQSxHQUFBSyxJQUFBLE1BQUFBLElBQUEsR0FBQUwsSUFBQSxFQUFBSyxJQUFBO1lBQUpGLElBQUksQ0FBQUUsSUFBQSxJQUFBSixTQUFBLENBQUFJLElBQUE7VUFBQTtVQUFBLE9BQ04xQixRQUFRLENBQUMsTUFBT21CLENBQUMsQ0FBUyxHQUFHSyxJQUFJLENBQUMsQ0FBQztRQUFBLEdBQ3ZDLENBQUNMLENBQUMsQ0FDSjtNQUNGLENBQUM7SUFBQSxDQUFDLEVBQ0YsQ0FBQyxDQUNIO0VBQ0YsQ0FBQztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDZSxTQUFTUSxlQUFlQSxDQUtyQ2xDLGVBQW1CLEVBQUU7RUFDckIsTUFBTUcsS0FBSyxHQUFHLElBQUFnQyxlQUFRLEVBQVksQ0FBQztFQUNuQyxNQUFNOUIsT0FBTyxHQUFHLElBQUE4QixlQUFRLEVBQVUsS0FBSyxDQUFDO0VBRXhDLE9BQU9wQyxpQkFBaUIsQ0FBQ0MsZUFBZSxFQUFFRyxLQUFLLEVBQUVFLE9BQU8sQ0FBQztBQUMzRCJ9
75
+
76
+ /**
77
+ * This hook provides a way to handle async operations storing the loading state, or the error when it fails, it does not store information returned from the functions.
78
+ * @param functionsToWrap The functions to wrap in control.
79
+ * @returns
80
+ */
81
+ var _default = useAsyncControl;
82
+ exports.default = _default;
83
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJyZXF1aXJlIiwidXNlUmF3QXN5bkNvbnRyb2wiLCJmdW5jdGlvbnNUb1dyYXAiLCJfcmVmIiwiX3JlZjIiLCJlcnJvciIsInNldEVycm9yIiwibG9hZGluZyIsInNldExvYWRpbmciLCJfcHJvY2VzcyIsInVzZUNhbGxiYWNrIiwiYXN5bmNGbiIsInVuZGVmaW5lZCIsIlByb21pc2UiLCJlIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiY29uc29sZSIsImZ1bmN0aW9uc1RvTWVtb2l6ZSIsIm90aGVyIiwiT2JqZWN0IiwiZW50cmllcyIsInJlZHVjZSIsInIiLCJfcmVmMyIsImsiLCJmdW5jIiwiX3JlZjQiLCJ2IiwidXNlTWVtbyIsIl9sZW4iLCJhcmd1bWVudHMiLCJsZW5ndGgiLCJhcmdzIiwiQXJyYXkiLCJfa2V5IiwidXNlQXN5bmNDb250cm9sIiwidXNlU3RhdGUiLCJfZGVmYXVsdCIsImV4cG9ydHMiLCJkZWZhdWx0Il0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hvb2tzL3VzZUFzeW5jQ29udHJvbC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTZXRTdGF0ZUFjdGlvbiwgdXNlQ2FsbGJhY2ssIHVzZU1lbW8sIHVzZVN0YXRlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgeyBQcmltaXRpdmUgfSBmcm9tIFwidHlwZS1mZXN0XCI7XG5cbnR5cGUgQXJyPFg+ID0gW1gsIFJlYWN0LkRpc3BhdGNoPFNldFN0YXRlQWN0aW9uPFg+Pl07XG5leHBvcnQgdHlwZSBGdW5jdGlvbk1hcCA9IHtcbiAgW2Y6IHN0cmluZ106ICgoLi4uYXJnczogYW55W10pID0+IFByb21pc2U8YW55PikgfCBPYmplY3QgfCBQcmltaXRpdmU7XG59O1xuZXhwb3J0IHR5cGUgQ29udHJvbDxFIGV4dGVuZHMgYW55ID0gYW55PiA9IHtcbiAgZXJyb3I/OiBFO1xuICBsb2FkaW5nOiBib29sZWFuO1xufTtcbmV4cG9ydCBmdW5jdGlvbiB1c2VSYXdBc3luQ29udHJvbDxFID0gYW55LCBGIGV4dGVuZHMgRnVuY3Rpb25NYXAgPSB7fT4oXG4gIGZ1bmN0aW9uc1RvV3JhcDogRiB8IHVuZGVmaW5lZCxcbiAgW2Vycm9yLCBzZXRFcnJvcl06IEFycjxFIHwgdW5kZWZpbmVkPixcbiAgW2xvYWRpbmcsIHNldExvYWRpbmddOiBBcnI8Ym9vbGVhbj5cbikge1xuICBjb25zdCBfcHJvY2VzcyA9IHVzZUNhbGxiYWNrKGFzeW5jIChhc3luY0ZuOiAoKCkgPT4gUHJvbWlzZTxhbnk+KSB8IFByb21pc2U8YW55PikgPT4ge1xuICAgIHRyeSB7XG4gICAgICBzZXRMb2FkaW5nKHRydWUpO1xuICAgICAgc2V0RXJyb3IodW5kZWZpbmVkKTtcbiAgICAgIGlmIChhc3luY0ZuIGluc3RhbmNlb2YgUHJvbWlzZSkgYXdhaXQgYXN5bmNGbjtcbiAgICAgIGVsc2UgcmV0dXJuIGF3YWl0IGFzeW5jRm4oKTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09IFwiZGV2ZWxvcG1lbnRcIikgY29uc29sZS5lcnJvcihlKTtcbiAgICAgIHNldEVycm9yKGUgYXMgRSk7XG4gICAgICB0aHJvdyBlO1xuICAgIH0gZmluYWxseSB7XG4gICAgICBzZXRMb2FkaW5nKGZhbHNlKTtcbiAgICB9XG4gIH0sIFtdKTtcblxuICBjb25zdCB7IGZ1bmN0aW9uc1RvTWVtb2l6ZSwgb3RoZXIgfSA9IE9iamVjdC5lbnRyaWVzKFxuICAgIGZ1bmN0aW9uc1RvV3JhcCB8fCB7fVxuICApLnJlZHVjZShcbiAgICAociwgW2ssIGZ1bmNdKSA9PiB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICAuLi5yLFxuICAgICAgICAuLi4odHlwZW9mIGZ1bmMgPT09IFwiZnVuY3Rpb25cIlxuICAgICAgICAgID8ge1xuICAgICAgICAgICAgICBmdW5jdGlvbnNUb01lbW9pemU6IHtcbiAgICAgICAgICAgICAgICAuLi5yLmZ1bmN0aW9uc1RvTWVtb2l6ZSxcbiAgICAgICAgICAgICAgICBba106IGZ1bmMsXG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB9XG4gICAgICAgICAgOiB7XG4gICAgICAgICAgICAgIG90aGVyOiB7XG4gICAgICAgICAgICAgICAgLi4uci5vdGhlcixcbiAgICAgICAgICAgICAgICBba106IGZ1bmMsXG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB9KSxcbiAgICAgIH07XG4gICAgfSxcbiAgICB7XG4gICAgICBmdW5jdGlvbnNUb01lbW9pemU6IHt9LFxuICAgICAgb3RoZXI6IHt9LFxuICAgIH0gYXMge1xuICAgICAgZnVuY3Rpb25zVG9NZW1vaXplOiBGO1xuICAgICAgb3RoZXI6IEY7XG4gICAgfVxuICApO1xuXG4gIHJldHVybiB7XG4gICAgcHJvY2VzczogX3Byb2Nlc3MsXG4gICAgbG9hZGluZyxcbiAgICBlcnJvcixcbiAgICBzZXRFcnJvcixcbiAgICBzZXRMb2FkaW5nLFxuICAgIC4uLm90aGVyLFxuICAgIC4uLk9iamVjdC5lbnRyaWVzKGZ1bmN0aW9uc1RvTWVtb2l6ZSkucmVkdWNlKFxuICAgICAgKHIsIFtrLCB2XSkgPT4gKHtcbiAgICAgICAgLi4ucixcbiAgICAgICAgW2tdOiB1c2VNZW1vKFxuICAgICAgICAgICgpID0+XG4gICAgICAgICAgICAoLi4uYXJnczogYW55W10pID0+XG4gICAgICAgICAgICAgIF9wcm9jZXNzKCgpID0+ICh2IGFzIGFueSkoLi4uYXJncykpLFxuICAgICAgICAgIFt2XVxuICAgICAgICApLFxuICAgICAgfSksXG4gICAgICB7fSBhcyBGXG4gICAgKSxcbiAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHVzZUFzeW5jQ29udHJvbDxcbiAgRSA9IGFueSxcbiAgRiBleHRlbmRzIHtcbiAgICBbZjogc3RyaW5nXTogKCguLi5hcmdzOiBhbnlbXSkgPT4gUHJvbWlzZTxhbnk+KSB8IE9iamVjdCB8IFByaW1pdGl2ZTtcbiAgfSA9IHt9XG4+KGZ1bmN0aW9uc1RvV3JhcD86IEYpIHtcbiAgY29uc3QgZXJyb3IgPSB1c2VTdGF0ZTxFIHwgRXJyb3I+KCk7XG4gIGNvbnN0IGxvYWRpbmcgPSB1c2VTdGF0ZTxib29sZWFuPihmYWxzZSk7XG5cbiAgcmV0dXJuIHVzZVJhd0FzeW5Db250cm9sKGZ1bmN0aW9uc1RvV3JhcCwgZXJyb3IsIGxvYWRpbmcpO1xufVxuXG4vKipcbiAqIFRoaXMgaG9vayBwcm92aWRlcyBhIHdheSB0byBoYW5kbGUgYXN5bmMgb3BlcmF0aW9ucyBzdG9yaW5nIHRoZSBsb2FkaW5nIHN0YXRlLCBvciB0aGUgZXJyb3Igd2hlbiBpdCBmYWlscywgaXQgZG9lcyBub3Qgc3RvcmUgaW5mb3JtYXRpb24gcmV0dXJuZWQgZnJvbSB0aGUgZnVuY3Rpb25zLlxuICogQHBhcmFtIGZ1bmN0aW9uc1RvV3JhcCBUaGUgZnVuY3Rpb25zIHRvIHdyYXAgaW4gY29udHJvbC5cbiAqIEByZXR1cm5zXG4gKi9cbmV4cG9ydCBkZWZhdWx0IHVzZUFzeW5jQ29udHJvbDtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLE9BQUE7QUFXTyxTQUFTQyxpQkFBaUJBLENBQy9CQyxlQUE4QixFQUFBQyxJQUFBLEVBQUFDLEtBQUEsRUFHOUI7RUFBQSxJQUZBLENBQUNDLEtBQUssRUFBRUMsUUFBUSxDQUFxQixHQUFBSCxJQUFBO0VBQUEsSUFDckMsQ0FBQ0ksT0FBTyxFQUFFQyxVQUFVLENBQWUsR0FBQUosS0FBQTtFQUVuQyxNQUFNSyxRQUFRLEdBQUcsSUFBQUMsa0JBQVcsRUFBQyxNQUFPQyxPQUE0QyxJQUFLO0lBQ25GLElBQUk7TUFDRkgsVUFBVSxDQUFDLElBQUksQ0FBQztNQUNoQkYsUUFBUSxDQUFDTSxTQUFTLENBQUM7TUFDbkIsSUFBSUQsT0FBTyxZQUFZRSxPQUFPLEVBQUUsTUFBTUYsT0FBTyxDQUFDLEtBQ3pDLE9BQU8sTUFBTUEsT0FBTyxDQUFDLENBQUM7SUFDN0IsQ0FBQyxDQUFDLE9BQU9HLENBQUMsRUFBRTtNQUNWLElB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
@@ -0,0 +1,3 @@
1
+ export * from "./types";
2
+ export * from "./hooks/useAsyncControl";
3
+ export * from "./components/UncontrolledTransition";
package/dist/index.js ADDED
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ var _types = require("./types");
7
+ Object.keys(_types).forEach(function (key) {
8
+ if (key === "default" || key === "__esModule") return;
9
+ if (key in exports && exports[key] === _types[key]) return;
10
+ Object.defineProperty(exports, key, {
11
+ enumerable: true,
12
+ get: function () {
13
+ return _types[key];
14
+ }
15
+ });
16
+ });
17
+ var _useAsyncControl = require("./hooks/useAsyncControl");
18
+ Object.keys(_useAsyncControl).forEach(function (key) {
19
+ if (key === "default" || key === "__esModule") return;
20
+ if (key in exports && exports[key] === _useAsyncControl[key]) return;
21
+ Object.defineProperty(exports, key, {
22
+ enumerable: true,
23
+ get: function () {
24
+ return _useAsyncControl[key];
25
+ }
26
+ });
27
+ });
28
+ var _UncontrolledTransition = require("./components/UncontrolledTransition");
29
+ Object.keys(_UncontrolledTransition).forEach(function (key) {
30
+ if (key === "default" || key === "__esModule") return;
31
+ if (key in exports && exports[key] === _UncontrolledTransition[key]) return;
32
+ Object.defineProperty(exports, key, {
33
+ enumerable: true,
34
+ get: function () {
35
+ return _UncontrolledTransition[key];
36
+ }
37
+ });
38
+ });
39
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfdHlwZXMiLCJyZXF1aXJlIiwiT2JqZWN0Iiwia2V5cyIsImZvckVhY2giLCJrZXkiLCJleHBvcnRzIiwiZGVmaW5lUHJvcGVydHkiLCJlbnVtZXJhYmxlIiwiZ2V0IiwiX3VzZUFzeW5jQ29udHJvbCIsIl9VbmNvbnRyb2xsZWRUcmFuc2l0aW9uIl0sInNvdXJjZXMiOlsiLi4vc3JjL2luZGV4LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL3R5cGVzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ob29rcy91c2VBc3luY0NvbnRyb2xcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NvbXBvbmVudHMvVW5jb250cm9sbGVkVHJhbnNpdGlvblwiIl0sIm1hcHBpbmdzIjoiOzs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsT0FBQTtBQUFBQyxNQUFBLENBQUFDLElBQUEsQ0FBQUgsTUFBQSxFQUFBSSxPQUFBLFdBQUFDLEdBQUE7RUFBQSxJQUFBQSxHQUFBLGtCQUFBQSxHQUFBO0VBQUEsSUFBQUEsR0FBQSxJQUFBQyxPQUFBLElBQUFBLE9BQUEsQ0FBQUQsR0FBQSxNQUFBTCxNQUFBLENBQUFLLEdBQUE7RUFBQUgsTUFBQSxDQUFBSyxjQUFBLENBQUFELE9BQUEsRUFBQUQsR0FBQTtJQUFBRyxVQUFBO0lBQUFDLEdBQUEsV0FBQUEsQ0FBQTtNQUFBLE9BQUFULE1BQUEsQ0FBQUssR0FBQTtJQUFBO0VBQUE7QUFBQTtBQUNBLElBQUFLLGdCQUFBLEdBQUFULE9BQUE7QUFBQUMsTUFBQSxDQUFBQyxJQUFBLENBQUFPLGdCQUFBLEVBQUFOLE9BQUEsV0FBQUMsR0FBQTtFQUFBLElBQUFBLEdBQUEsa0JBQUFBLEdBQUE7RUFBQSxJQUFBQSxHQUFBLElBQUFDLE9BQUEsSUFBQUEsT0FBQSxDQUFBRCxHQUFBLE1BQUFLLGdCQUFBLENBQUFMLEdBQUE7RUFBQUgsTUFBQSxDQUFBSyxjQUFBLENBQUFELE9BQUEsRUFBQUQsR0FBQTtJQUFBRyxVQUFBO0lBQUFDLEdBQUEsV0FBQUEsQ0FBQTtNQUFBLE9BQUFDLGdCQUFBLENBQUFMLEdBQUE7SUFBQTtFQUFBO0FBQUE7QUFDQSxJQUFBTSx1QkFBQSxHQUFBVixPQUFBO0FBQUFDLE1BQUEsQ0FBQUMsSUFBQSxDQUFBUSx1QkFBQSxFQUFBUCxPQUFBLFdBQUFDLEdBQUE7RUFBQSxJQUFBQSxHQUFBLGtCQUFBQSxHQUFBO0VBQUEsSUFBQUEsR0FBQSxJQUFBQyxPQUFBLElBQUFBLE9BQUEsQ0FBQUQsR0FBQSxNQUFBTSx1QkFBQSxDQUFBTixHQUFBO0VBQUFILE1BQUEsQ0FBQUssY0FBQSxDQUFBRCxPQUFBLEVBQUFELEdBQUE7SUFBQUcsVUFBQTtJQUFBQyxHQUFBLFdBQUFBLENBQUE7TUFBQSxPQUFBRSx1QkFBQSxDQUFBTixHQUFBO0lBQUE7RUFBQTtBQUFBIn0=
package/package.json CHANGED
@@ -1,11 +1,12 @@
1
1
  {
2
2
  "name": "@onepercentio/one-ui",
3
- "version": "0.27.5",
3
+ "version": "0.27.7",
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>",
7
7
  "license": "MIT",
8
- "types": "src/types.ts",
8
+ "types": "./dist/index.d.ts",
9
+ "main": "./dist/index.ts",
9
10
  "devDependencies": {
10
11
  "@babel/cli": "^7.22.9",
11
12
  "@babel/core": "^7.22.9",