matsuri-forms-sdk 2.0.0 → 2.0.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/MatsuriFormsQuestion.d.ts +1 -1
- package/MatsuriFormsQuestionProvider.d.ts +3 -3
- package/MatsuriFormsQuestionProvider.js.map +1 -1
- package/cjs/MatsuriFormsQuestionProvider.js.map +1 -1
- package/cjs/matsuri-ui/SelectQuestion.js +10 -16
- package/cjs/matsuri-ui/SelectQuestion.js.map +1 -1
- package/cjs/matsuri-ui/SurveyForm.js +8 -12
- package/cjs/matsuri-ui/SurveyForm.js.map +1 -1
- package/cjs/matsuri-ui/SurveyFormProvider.js +4 -1
- package/cjs/matsuri-ui/SurveyFormProvider.js.map +1 -1
- package/cjs/useMatsuriForms.js +6 -3
- package/cjs/useMatsuriForms.js.map +1 -1
- package/esm/MatsuriFormsQuestionProvider.js.map +1 -1
- package/esm/matsuri-ui/SelectQuestion.js +10 -16
- package/esm/matsuri-ui/SelectQuestion.js.map +1 -1
- package/esm/matsuri-ui/SurveyForm.js +10 -14
- package/esm/matsuri-ui/SurveyForm.js.map +1 -1
- package/esm/matsuri-ui/SurveyFormProvider.js +4 -1
- package/esm/matsuri-ui/SurveyFormProvider.js.map +1 -1
- package/esm/useMatsuriForms.js +9 -5
- package/esm/useMatsuriForms.js.map +1 -1
- package/matsuri-ui/SelectQuestion.js +10 -16
- package/matsuri-ui/SelectQuestion.js.map +1 -1
- package/matsuri-ui/SurveyForm.js +10 -14
- package/matsuri-ui/SurveyForm.js.map +1 -1
- package/matsuri-ui/SurveyFormProvider.js +4 -1
- package/matsuri-ui/SurveyFormProvider.js.map +1 -1
- package/package.json +13 -13
- package/types/MatsuriFormsQuestion.d.ts +1 -1
- package/types/MatsuriFormsQuestionProvider.d.ts +3 -3
- package/useMatsuriForms.js +9 -5
- package/useMatsuriForms.js.map +1 -1
package/matsuri-ui/SurveyForm.js
CHANGED
|
@@ -14,8 +14,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
14
14
|
styles: "margin-top:32px"
|
|
15
15
|
} : {
|
|
16
16
|
name: "13tjbcc-SurveyForm",
|
|
17
|
-
styles: "margin-top:32px;label:SurveyForm;",
|
|
18
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tYXRzdXJpLXVpL1N1cnZleUZvcm0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Md0IiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL21hdHN1cmktdWkvU3VydmV5Rm9ybS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBCdXR0b24sXG4gIE92ZXJsYXksXG4gIFBhcGVyLFxuICBQb3J0YWwsXG4gIFR5cG9ncmFwaHksXG4gIFVzZXJUZXh0UmVuZGVyZXIsXG4gIFZpc3VhbGx5SGlkZGVuLFxuICB1c2VBbGVydCxcbiAgdXNlVGhlbWUsXG59IGZyb20gXCJtYXRzdXJpLXVpXCI7XG5pbXBvcnQge1xuICBNYXRzdXJpRm9ybXNRdWVzdGlvbixcbiAgTWF0c3VyaUZvcm1zUXVlc3Rpb25Qcm92aWRlcixcbiAgdXNlTWF0c3VyaUZvcm1zLFxufSBmcm9tIFwiLi4vXCI7XG5pbXBvcnQgeyBNdWx0aXBsZVRleHRRdWVzdGlvbiB9IGZyb20gXCIuL011bHRpcGxlVGV4dFF1ZXN0aW9uXCI7XG5pbXBvcnQgeyBTZWxlY3RRdWVzdGlvbiB9IGZyb20gXCIuL1NlbGVjdFF1ZXN0aW9uXCI7XG5pbXBvcnQgeyBUZXh0UXVlc3Rpb24gfSBmcm9tIFwiLi9UZXh0UXVlc3Rpb25cIjtcbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN1cnZleUZvcm1Qcm9wcyB7XG4gIG9wZW4/OiBib29sZWFuO1xuICBvblN1Ym1pdD86ICgpID0+IHZvaWQ7XG4gIG9uQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICAvLyBQcm9wcyBmb3IgdXNlTWF0c3VyaUZvcm1zXG4gIGZvcm1JZD86IHN0cmluZztcbiAgLyoqXG4gICAqIOmWi+eZuueSsOWig+OBrkFQSeOCkuS9v+eUqOOBmeOCi+OBi+OBqeOBhuOBi+OCkuaMh+WumuOBl+OBvuOBmeOAglxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgZGV2PzogYm9vbGVhbjtcbiAgLy8gUHJvcHMgZm9yIEFsZXJ0XG4gIC8qKlxuICAgKiDlm57nrZTjga7pgIHkv6HjgavmiJDlip/jgZfjgZ/pmpvjgavooajnpLrjgZnjgovjg6Hjg4Pjgrvjg7zjgrjjgpLmjIflrprjgZfjgb7jgZnjgIJcbiAgICogQGRlZmF1bHQgXCLjgZTlm57nrZTjgYLjgorjgYzjgajjgYbjgZTjgZbjgYTjgb7jgZnjgIJcIlxuICAgKi9cbiAgc3VjY2Vzc01lc3NhZ2U/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiDlm57nrZTjga7pgIHkv6HjgavmiJDlip/jgZfjgZ/loLTlkIjjgavjgIHmiJDlip/jg6Hjg4Pjgrvjg7zjgrjjgpLnhKHoppbjgZnjgovjgYvjganjgYbjgYvjgpLmjIflrprjgZfjgb7jgZnjgIJcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIGlnbm9yZVN1Y2Nlc3NNZXNzYWdlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIOaMh+WumuOBl+OBn0lE44GuUXVlc2l0b27jga7jg6zjg7Pjg4Djg6rjg7PjgrDjgpJIaWRkZW4gaW5wdXTjgavjgZfjgb7jgZnjgIJcbiAgICovXG4gIGhpZGRlblF1ZXN0aW9uSWRzPzogc3RyaW5nW107XG4gIC8qKlxuICAgKiDmjIflrprjgZfjgZ9JROOBrlF1ZXN0aW9u44Gr5Yid5pyf5YCk44KS5LiO44GI44G+44GZ44CCXG4gICAqL1xuICBkZWZhdWx0VmFsdWVzPzogUmVjb3JkPHN0cmluZywgc3RyaW5nIHwgc3RyaW5nW10+O1xufVxuXG5leHBvcnQgY29uc3QgU3VydmV5Rm9ybSA9IChwcm9wczogU3VydmV5Rm9ybVByb3BzKSA9PiB7XG4gIGNvbnN0IGZvcm1JZCA9IHByb3BzLmZvcm1JZDtcbiAgaWYgKCFmb3JtSWQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXCJmb3JtSWQgaXMgcmVxdWlyZWRcIik7XG4gIH1cblxuICBjb25zdCB7XG4gICAgcXVlc3Rpb25zLFxuICAgIHRpdGxlLFxuICAgIGRlc2NyaXB0aW9uLFxuICAgIHN1Ym1pdCxcbiAgICBlcnJvcnMsXG4gICAgdmFsaWRhdGUsXG4gICAgaXNTdWJtaXR0aW5nLFxuICB9ID0gdXNlTWF0c3VyaUZvcm1zKGZvcm1JZCwge1xuICAgIGRldjogcHJvcHMuZGV2ID8/IGZhbHNlLFxuICB9KTtcblxuICBjb25zdCB7IHRocm93QWxlcnQgfSA9IHVzZUFsZXJ0KCk7XG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKTtcblxuICByZXR1cm4gKFxuICAgIDxQb3J0YWw+XG4gICAgICA8T3ZlcmxheVxuICAgICAgICBvcGVuPXtwcm9wcy5vcGVufVxuICAgICAgICBkaXNhYmxlQW5pbWF0aW9uXG4gICAgICAgIGZ1bGxTY3JlZW5cbiAgICAgICAgb25DbG9zZT17cHJvcHMub25DbG9zZX1cbiAgICAgID5cbiAgICAgICAgPFBhcGVyXG4gICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICBkaXNwbGF5OiBncmlkO1xuICAgICAgICAgICAgbWF4LXdpZHRoOiA3MjBweDtcbiAgICAgICAgICAgIG1heC1oZWlnaHQ6IDkwdmg7XG4gICAgICAgICAgICBtYXJnaW46IDBweCBhdXRvO1xuICAgICAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgICAgICAgIG9wYWNpdHk6IDE7XG4gICAgICAgICAgICB0cmFuc2l0aW9uOiBvcGFjaXR5IDAuMnMgZWFzZS1pbjtcbiAgICAgICAgICAgIEBzdGFydGluZy1zdHlsZSB7XG4gICAgICAgICAgICAgIG9wYWNpdHk6IDA7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgYH1cbiAgICAgICAgPlxuICAgICAgICAgIDxmb3JtXG4gICAgICAgICAgICBvblN1Ym1pdD17YXN5bmMgKGV2ZW50KSA9PiB7XG4gICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG5cbiAgICAgICAgICAgICAgY29uc3QgeyBlcnJvcnMgfSA9IHZhbGlkYXRlKGV2ZW50LmN1cnJlbnRUYXJnZXQpO1xuXG4gICAgICAgICAgICAgIGlmIChlcnJvcnMpIHtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICBjb25zdCB7IGVycm9yIH0gPSBhd2FpdCBzdWJtaXQoZXZlbnQuY3VycmVudFRhcmdldCk7XG5cbiAgICAgICAgICAgICAgdGhyb3dBbGVydChlcnJvciwge1xuICAgICAgICAgICAgICAgIGVycm9yTWVzc2FnZToge1xuICAgICAgICAgICAgICAgICAgcmVhc29uOiBcIuOCteODvOODkOODvOWBtOOBruOCqOODqeODvOOBruWPr+iDveaAp+OBjOOBguOCiuOBvuOBmeOAglwiLFxuICAgICAgICAgICAgICAgICAgYWN0aW9uOlxuICAgICAgICAgICAgICAgICAgICBcIuOBl+OBsOOCieOBj+aZgumWk+OCkuepuuOBkeOBpuippuOBmeOBi+OAgemWi+eZuuODgeODvOODoOOBuOOBiuWVj+OBhOWQiOOCj+OBm+OBj+OBoOOBleOBhOOAglwiLFxuICAgICAgICAgICAgICAgICAgaGFwcGVuZDogXCLlm57nrZTjga7pgIHkv6HjgavlpLHmlZfjgZfjgb7jgZfjgZ/jgIJcIixcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIHN1Y2Nlc3NNZXNzYWdlOlxuICAgICAgICAgICAgICAgICAgcHJvcHMuc3VjY2Vzc01lc3NhZ2UgPz8gXCLjgZTlm57nrZTjgYLjgorjgYzjgajjgYbjgZTjgZbjgYTjgb7jgZnjgIJcIixcbiAgICAgICAgICAgICAgICBpZ25vcmVTdWNjZXNzOiBwcm9wcy5pZ25vcmVTdWNjZXNzTWVzc2FnZSA/PyBmYWxzZSxcbiAgICAgICAgICAgICAgICBvblN1Y2Nlc3M6ICgpID0+IHtcbiAgICAgICAgICAgICAgICAgIHByb3BzLm9uU3VibWl0Py4oKTtcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH19XG4gICAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgICAgZGlzcGxheTogY29udGVudHM7XG4gICAgICAgICAgICBgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxoZWFkZXJcbiAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgcGFkZGluZzogMzJweDtcbiAgICAgICAgICAgICAgICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHt0aGVtZS5wYWxldHRlLmdyYXlbMjAwXX07XG4gICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxUeXBvZ3JhcGh5IHZhcmlhbnQ9XCJoMlwiPnt0aXRsZX08L1R5cG9ncmFwaHk+XG4gICAgICAgICAgICA8L2hlYWRlcj5cbiAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgICAgICAgICAgICAgIGRpc3BsYXk6IGdyaWQ7XG4gICAgICAgICAgICAgICAgZ2FwOiA0MHB4O1xuICAgICAgICAgICAgICAgIHBhZGRpbmc6IDIwcHggMzJweCA0MHB4O1xuICAgICAgICAgICAgICAgIG92ZXJmbG93LXk6IGF1dG87XG4gICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgICAgICA8VHlwb2dyYXBoeT5cbiAgICAgICAgICAgICAgICAgIDxVc2VyVGV4dFJlbmRlcmVyPntkZXNjcmlwdGlvbn08L1VzZXJUZXh0UmVuZGVyZXI+XG4gICAgICAgICAgICAgICAgPC9UeXBvZ3JhcGh5PlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgICAgPE1hdHN1cmlGb3Jtc1F1ZXN0aW9uUHJvdmlkZXJcbiAgICAgICAgICAgICAgICByZW5kZXJTZWxlY3Q9e1NlbGVjdFF1ZXN0aW9ufVxuICAgICAgICAgICAgICAgIHJlbmRlck11bHRpbGluZVRleHQ9e011bHRpcGxlVGV4dFF1ZXN0aW9ufVxuICAgICAgICAgICAgICAgIHJlbmRlclRleHQ9e1RleHRRdWVzdGlvbn1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtxdWVzdGlvbnMubWFwKChxdWVzdGlvbikgPT4ge1xuICAgICAgICAgICAgICAgICAgY29uc3QgcXVlc3Rpb25FbGVtZW50ID0gKFxuICAgICAgICAgICAgICAgICAgICA8TWF0c3VyaUZvcm1zUXVlc3Rpb25cbiAgICAgICAgICAgICAgICAgICAgICBkZWZhdWx0VmFsdWU9e3Byb3BzLmRlZmF1bHRWYWx1ZXM/LltxdWVzdGlvbi5pZF19XG4gICAgICAgICAgICAgICAgICAgICAgZXJyb3I9e2Vycm9yc1txdWVzdGlvbi5pZF19XG4gICAgICAgICAgICAgICAgICAgICAgey4uLnF1ZXN0aW9ufVxuICAgICAgICAgICAgICAgICAgICAgIGtleT17cXVlc3Rpb24uaWR9XG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICApO1xuXG4gICAgICAgICAgICAgICAgICAvLyBxdWV0aW9uLmlzSGlkZGVu44GMZmFsc2XjgafjgYLjgaPjgabjgoLjgIFoaWRkZW5RdWVzdGlvbklkc+OBq+WQq+OBvuOCjOOBpuOBhOOCi+WgtOWQiOOBr+mdnuihqOekuuOBq+OBmeOCi1xuICAgICAgICAgICAgICAgICAgY29uc3QgaGlkZGVuID1cbiAgICAgICAgICAgICAgICAgICAgcXVlc3Rpb24uaXNIaWRkZW4gPT09IHRydWVcbiAgICAgICAgICAgICAgICAgICAgICA/IHRydWVcbiAgICAgICAgICAgICAgICAgICAgICA6IHByb3BzLmhpZGRlblF1ZXN0aW9uSWRzPy5pbmNsdWRlcyhxdWVzdGlvbi5pZCk7XG4gICAgICAgICAgICAgICAgICByZXR1cm4gaGlkZGVuID8gKFxuICAgICAgICAgICAgICAgICAgICA8VmlzdWFsbHlIaWRkZW4ga2V5PXtxdWVzdGlvbi5pZH0+XG4gICAgICAgICAgICAgICAgICAgICAge3F1ZXN0aW9uRWxlbWVudH1cbiAgICAgICAgICAgICAgICAgICAgPC9WaXN1YWxseUhpZGRlbj5cbiAgICAgICAgICAgICAgICAgICkgOiAoXG4gICAgICAgICAgICAgICAgICAgIHF1ZXN0aW9uRWxlbWVudFxuICAgICAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgPC9NYXRzdXJpRm9ybXNRdWVzdGlvblByb3ZpZGVyPlxuICAgICAgICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgICBtYXJnaW4tdG9wOiAzMnB4O1xuICAgICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICAgICAgdmFyaWFudD1cImZpbGxlZFwiXG4gICAgICAgICAgICAgICAgZGlzYWJsZWQ9e2lzU3VibWl0dGluZ31cbiAgICAgICAgICAgICAgICBjb2xvcj1cInByaW1hcnlcIlxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAg6YCB5L+h44GZ44KLXG4gICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPC9mb3JtPlxuICAgICAgICA8L1BhcGVyPlxuICAgICAgPC9PdmVybGF5PlxuICAgIDwvUG9ydGFsPlxuICApO1xufTtcbiJdfQ== */",
|
|
17
|
+
styles: "margin-top:32px;label:SurveyForm;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/matsuri-ui/SurveyForm.tsx"],"names":[],"mappings":"AAoLwB","file":"../../../src/matsuri-ui/SurveyForm.tsx","sourcesContent":["import {\n  Button,\n  Overlay,\n  Paper,\n  Portal,\n  Typography,\n  UserTextRenderer,\n  VisuallyHidden,\n  useAlert,\n  useTheme,\n} from \"matsuri-ui\";\nimport {\n  MatsuriFormsQuestion,\n  MatsuriFormsQuestionProvider,\n  useMatsuriForms,\n} from \"../\";\nimport { MultipleTextQuestion } from \"./MultipleTextQuestion\";\nimport { SelectQuestion } from \"./SelectQuestion\";\nimport { TextQuestion } from \"./TextQuestion\";\nimport { css } from \"@emotion/react\";\n\nexport interface SurveyFormProps {\n  open?: boolean;\n  onSubmit?: () => void;\n  onClose?: () => void;\n  // Props for useMatsuriForms\n  formId?: string;\n  /**\n   * 開発環境のAPIを使用するかどうかを指定します。\n   * @default false\n   */\n  dev?: boolean;\n  // Props for Alert\n  /**\n   * 回答の送信に成功した際に表示するメッセージを指定します。\n   * @default \"ご回答ありがとうございます。\"\n   */\n  successMessage?: string;\n  /**\n   * 回答の送信に成功した場合に、成功メッセージを無視するかどうかを指定します。\n   * @default false\n   */\n  ignoreSuccessMessage?: boolean;\n  /**\n   * 指定したIDのQuesitonのレンダリングをHidden inputにします。\n   */\n  hiddenQuestionIds?: string[];\n  /**\n   * 指定したIDのQuestionに初期値を与えます。\n   */\n  defaultValues?: Record<string, string | string[]>;\n}\n\nexport const SurveyForm = (props: SurveyFormProps) => {\n  const formId = props.formId;\n  if (formId === undefined) {\n    throw new Error(\"formId is required\");\n  }\n\n  const {\n    questions,\n    title,\n    description,\n    submit,\n    errors,\n    validate,\n    isSubmitting,\n  } = useMatsuriForms(formId, {\n    dev: props.dev ?? false,\n  });\n\n  const { throwAlert } = useAlert();\n  const theme = useTheme();\n\n  return (\n    <Portal>\n      <Overlay\n        open={props.open}\n        disableAnimation\n        fullScreen\n        onClose={props.onClose}\n      >\n        <Paper\n          css={css`\n            display: grid;\n            max-width: 720px;\n            max-height: 90vh;\n            margin: 0px auto;\n            overflow: hidden;\n            opacity: 1;\n            transition: opacity 0.2s ease-in;\n            @starting-style {\n              opacity: 0;\n            }\n          `}\n        >\n          <form\n            onSubmit={async (event) => {\n              event.preventDefault();\n\n              const { errors } = validate(event.currentTarget);\n\n              if (errors) {\n                return;\n              }\n\n              const { error } = await submit(event.currentTarget);\n\n              throwAlert(error, {\n                errorMessage: {\n                  reason: \"サーバー側のエラーの可能性があります。\",\n                  action:\n                    \"しばらく時間を空けて試すか、開発チームへお問い合わせください。\",\n                  happend: \"回答の送信に失敗しました。\",\n                },\n                successMessage:\n                  props.successMessage ?? \"ご回答ありがとうございます。\",\n                ignoreSuccess: props.ignoreSuccessMessage ?? false,\n                onSuccess: () => {\n                  props.onSubmit?.();\n                },\n              });\n            }}\n            css={css`\n              display: contents;\n            `}\n          >\n            <header\n              css={css`\n                padding: 32px;\n                border-bottom: 1px solid ${theme.palette.gray[200]};\n              `}\n            >\n              <Typography variant=\"h2\">{title}</Typography>\n            </header>\n            <div\n              css={css`\n                position: relative;\n                display: grid;\n                gap: 40px;\n                padding: 20px 32px 40px;\n                overflow-y: auto;\n              `}\n            >\n              {description !== undefined ? (\n                <Typography>\n                  <UserTextRenderer>{description}</UserTextRenderer>\n                </Typography>\n              ) : null}\n              <MatsuriFormsQuestionProvider\n                renderSelect={SelectQuestion}\n                renderMultilineText={MultipleTextQuestion}\n                renderText={TextQuestion}\n              >\n                {questions.map((question) => {\n                  const questionElement = (\n                    <MatsuriFormsQuestion\n                      defaultValue={props.defaultValues?.[question.id]}\n                      error={errors[question.id]}\n                      {...question}\n                      key={question.id}\n                    />\n                  );\n\n                  // quetion.isHiddenがfalseであっても、hiddenQuestionIdsに含まれている場合は非表示にする\n                  const hidden =\n                    question.isHidden === true\n                      ? true\n                      : (props.hiddenQuestionIds?.includes(question.id) ??\n                        false);\n                  return hidden ? (\n                    <VisuallyHidden key={question.id}>\n                      {questionElement}\n                    </VisuallyHidden>\n                  ) : (\n                    questionElement\n                  );\n                })}\n              </MatsuriFormsQuestionProvider>\n              <Button\n                css={css`\n                  margin-top: 32px;\n                `}\n                variant=\"filled\"\n                disabled={isSubmitting}\n                color=\"primary\"\n              >\n                送信する\n              </Button>\n            </div>\n          </form>\n        </Paper>\n      </Overlay>\n    </Portal>\n  );\n};\n"]} */",
|
|
19
18
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
20
19
|
};
|
|
21
20
|
var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
@@ -23,8 +22,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
|
23
22
|
styles: "position:relative;display:grid;gap:40px;padding:20px 32px 40px;overflow-y:auto"
|
|
24
23
|
} : {
|
|
25
24
|
name: "ec8gfn-SurveyForm",
|
|
26
|
-
styles: "position:relative;display:grid;gap:40px;padding:20px 32px 40px;overflow-y:auto;label:SurveyForm;",
|
|
27
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tYXRzdXJpLXVpL1N1cnZleUZvcm0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXdJc0IiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL21hdHN1cmktdWkvU3VydmV5Rm9ybS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBCdXR0b24sXG4gIE92ZXJsYXksXG4gIFBhcGVyLFxuICBQb3J0YWwsXG4gIFR5cG9ncmFwaHksXG4gIFVzZXJUZXh0UmVuZGVyZXIsXG4gIFZpc3VhbGx5SGlkZGVuLFxuICB1c2VBbGVydCxcbiAgdXNlVGhlbWUsXG59IGZyb20gXCJtYXRzdXJpLXVpXCI7XG5pbXBvcnQge1xuICBNYXRzdXJpRm9ybXNRdWVzdGlvbixcbiAgTWF0c3VyaUZvcm1zUXVlc3Rpb25Qcm92aWRlcixcbiAgdXNlTWF0c3VyaUZvcm1zLFxufSBmcm9tIFwiLi4vXCI7XG5pbXBvcnQgeyBNdWx0aXBsZVRleHRRdWVzdGlvbiB9IGZyb20gXCIuL011bHRpcGxlVGV4dFF1ZXN0aW9uXCI7XG5pbXBvcnQgeyBTZWxlY3RRdWVzdGlvbiB9IGZyb20gXCIuL1NlbGVjdFF1ZXN0aW9uXCI7XG5pbXBvcnQgeyBUZXh0UXVlc3Rpb24gfSBmcm9tIFwiLi9UZXh0UXVlc3Rpb25cIjtcbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN1cnZleUZvcm1Qcm9wcyB7XG4gIG9wZW4/OiBib29sZWFuO1xuICBvblN1Ym1pdD86ICgpID0+IHZvaWQ7XG4gIG9uQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICAvLyBQcm9wcyBmb3IgdXNlTWF0c3VyaUZvcm1zXG4gIGZvcm1JZD86IHN0cmluZztcbiAgLyoqXG4gICAqIOmWi+eZuueSsOWig+OBrkFQSeOCkuS9v+eUqOOBmeOCi+OBi+OBqeOBhuOBi+OCkuaMh+WumuOBl+OBvuOBmeOAglxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgZGV2PzogYm9vbGVhbjtcbiAgLy8gUHJvcHMgZm9yIEFsZXJ0XG4gIC8qKlxuICAgKiDlm57nrZTjga7pgIHkv6HjgavmiJDlip/jgZfjgZ/pmpvjgavooajnpLrjgZnjgovjg6Hjg4Pjgrvjg7zjgrjjgpLmjIflrprjgZfjgb7jgZnjgIJcbiAgICogQGRlZmF1bHQgXCLjgZTlm57nrZTjgYLjgorjgYzjgajjgYbjgZTjgZbjgYTjgb7jgZnjgIJcIlxuICAgKi9cbiAgc3VjY2Vzc01lc3NhZ2U/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiDlm57nrZTjga7pgIHkv6HjgavmiJDlip/jgZfjgZ/loLTlkIjjgavjgIHmiJDlip/jg6Hjg4Pjgrvjg7zjgrjjgpLnhKHoppbjgZnjgovjgYvjganjgYbjgYvjgpLmjIflrprjgZfjgb7jgZnjgIJcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIGlnbm9yZVN1Y2Nlc3NNZXNzYWdlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIOaMh+WumuOBl+OBn0lE44GuUXVlc2l0b27jga7jg6zjg7Pjg4Djg6rjg7PjgrDjgpJIaWRkZW4gaW5wdXTjgavjgZfjgb7jgZnjgIJcbiAgICovXG4gIGhpZGRlblF1ZXN0aW9uSWRzPzogc3RyaW5nW107XG4gIC8qKlxuICAgKiDmjIflrprjgZfjgZ9JROOBrlF1ZXN0aW9u44Gr5Yid5pyf5YCk44KS5LiO44GI44G+44GZ44CCXG4gICAqL1xuICBkZWZhdWx0VmFsdWVzPzogUmVjb3JkPHN0cmluZywgc3RyaW5nIHwgc3RyaW5nW10+O1xufVxuXG5leHBvcnQgY29uc3QgU3VydmV5Rm9ybSA9IChwcm9wczogU3VydmV5Rm9ybVByb3BzKSA9PiB7XG4gIGNvbnN0IGZvcm1JZCA9IHByb3BzLmZvcm1JZDtcbiAgaWYgKCFmb3JtSWQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXCJmb3JtSWQgaXMgcmVxdWlyZWRcIik7XG4gIH1cblxuICBjb25zdCB7XG4gICAgcXVlc3Rpb25zLFxuICAgIHRpdGxlLFxuICAgIGRlc2NyaXB0aW9uLFxuICAgIHN1Ym1pdCxcbiAgICBlcnJvcnMsXG4gICAgdmFsaWRhdGUsXG4gICAgaXNTdWJtaXR0aW5nLFxuICB9ID0gdXNlTWF0c3VyaUZvcm1zKGZvcm1JZCwge1xuICAgIGRldjogcHJvcHMuZGV2ID8/IGZhbHNlLFxuICB9KTtcblxuICBjb25zdCB7IHRocm93QWxlcnQgfSA9IHVzZUFsZXJ0KCk7XG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKTtcblxuICByZXR1cm4gKFxuICAgIDxQb3J0YWw+XG4gICAgICA8T3ZlcmxheVxuICAgICAgICBvcGVuPXtwcm9wcy5vcGVufVxuICAgICAgICBkaXNhYmxlQW5pbWF0aW9uXG4gICAgICAgIGZ1bGxTY3JlZW5cbiAgICAgICAgb25DbG9zZT17cHJvcHMub25DbG9zZX1cbiAgICAgID5cbiAgICAgICAgPFBhcGVyXG4gICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICBkaXNwbGF5OiBncmlkO1xuICAgICAgICAgICAgbWF4LXdpZHRoOiA3MjBweDtcbiAgICAgICAgICAgIG1heC1oZWlnaHQ6IDkwdmg7XG4gICAgICAgICAgICBtYXJnaW46IDBweCBhdXRvO1xuICAgICAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgICAgICAgIG9wYWNpdHk6IDE7XG4gICAgICAgICAgICB0cmFuc2l0aW9uOiBvcGFjaXR5IDAuMnMgZWFzZS1pbjtcbiAgICAgICAgICAgIEBzdGFydGluZy1zdHlsZSB7XG4gICAgICAgICAgICAgIG9wYWNpdHk6IDA7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgYH1cbiAgICAgICAgPlxuICAgICAgICAgIDxmb3JtXG4gICAgICAgICAgICBvblN1Ym1pdD17YXN5bmMgKGV2ZW50KSA9PiB7XG4gICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG5cbiAgICAgICAgICAgICAgY29uc3QgeyBlcnJvcnMgfSA9IHZhbGlkYXRlKGV2ZW50LmN1cnJlbnRUYXJnZXQpO1xuXG4gICAgICAgICAgICAgIGlmIChlcnJvcnMpIHtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICBjb25zdCB7IGVycm9yIH0gPSBhd2FpdCBzdWJtaXQoZXZlbnQuY3VycmVudFRhcmdldCk7XG5cbiAgICAgICAgICAgICAgdGhyb3dBbGVydChlcnJvciwge1xuICAgICAgICAgICAgICAgIGVycm9yTWVzc2FnZToge1xuICAgICAgICAgICAgICAgICAgcmVhc29uOiBcIuOCteODvOODkOODvOWBtOOBruOCqOODqeODvOOBruWPr+iDveaAp+OBjOOBguOCiuOBvuOBmeOAglwiLFxuICAgICAgICAgICAgICAgICAgYWN0aW9uOlxuICAgICAgICAgICAgICAgICAgICBcIuOBl+OBsOOCieOBj+aZgumWk+OCkuepuuOBkeOBpuippuOBmeOBi+OAgemWi+eZuuODgeODvOODoOOBuOOBiuWVj+OBhOWQiOOCj+OBm+OBj+OBoOOBleOBhOOAglwiLFxuICAgICAgICAgICAgICAgICAgaGFwcGVuZDogXCLlm57nrZTjga7pgIHkv6HjgavlpLHmlZfjgZfjgb7jgZfjgZ/jgIJcIixcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIHN1Y2Nlc3NNZXNzYWdlOlxuICAgICAgICAgICAgICAgICAgcHJvcHMuc3VjY2Vzc01lc3NhZ2UgPz8gXCLjgZTlm57nrZTjgYLjgorjgYzjgajjgYbjgZTjgZbjgYTjgb7jgZnjgIJcIixcbiAgICAgICAgICAgICAgICBpZ25vcmVTdWNjZXNzOiBwcm9wcy5pZ25vcmVTdWNjZXNzTWVzc2FnZSA/PyBmYWxzZSxcbiAgICAgICAgICAgICAgICBvblN1Y2Nlc3M6ICgpID0+IHtcbiAgICAgICAgICAgICAgICAgIHByb3BzLm9uU3VibWl0Py4oKTtcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH19XG4gICAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgICAgZGlzcGxheTogY29udGVudHM7XG4gICAgICAgICAgICBgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxoZWFkZXJcbiAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgcGFkZGluZzogMzJweDtcbiAgICAgICAgICAgICAgICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHt0aGVtZS5wYWxldHRlLmdyYXlbMjAwXX07XG4gICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxUeXBvZ3JhcGh5IHZhcmlhbnQ9XCJoMlwiPnt0aXRsZX08L1R5cG9ncmFwaHk+XG4gICAgICAgICAgICA8L2hlYWRlcj5cbiAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgICAgICAgICAgICAgIGRpc3BsYXk6IGdyaWQ7XG4gICAgICAgICAgICAgICAgZ2FwOiA0MHB4O1xuICAgICAgICAgICAgICAgIHBhZGRpbmc6IDIwcHggMzJweCA0MHB4O1xuICAgICAgICAgICAgICAgIG92ZXJmbG93LXk6IGF1dG87XG4gICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgICAgICA8VHlwb2dyYXBoeT5cbiAgICAgICAgICAgICAgICAgIDxVc2VyVGV4dFJlbmRlcmVyPntkZXNjcmlwdGlvbn08L1VzZXJUZXh0UmVuZGVyZXI+XG4gICAgICAgICAgICAgICAgPC9UeXBvZ3JhcGh5PlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgICAgPE1hdHN1cmlGb3Jtc1F1ZXN0aW9uUHJvdmlkZXJcbiAgICAgICAgICAgICAgICByZW5kZXJTZWxlY3Q9e1NlbGVjdFF1ZXN0aW9ufVxuICAgICAgICAgICAgICAgIHJlbmRlck11bHRpbGluZVRleHQ9e011bHRpcGxlVGV4dFF1ZXN0aW9ufVxuICAgICAgICAgICAgICAgIHJlbmRlclRleHQ9e1RleHRRdWVzdGlvbn1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtxdWVzdGlvbnMubWFwKChxdWVzdGlvbikgPT4ge1xuICAgICAgICAgICAgICAgICAgY29uc3QgcXVlc3Rpb25FbGVtZW50ID0gKFxuICAgICAgICAgICAgICAgICAgICA8TWF0c3VyaUZvcm1zUXVlc3Rpb25cbiAgICAgICAgICAgICAgICAgICAgICBkZWZhdWx0VmFsdWU9e3Byb3BzLmRlZmF1bHRWYWx1ZXM/LltxdWVzdGlvbi5pZF19XG4gICAgICAgICAgICAgICAgICAgICAgZXJyb3I9e2Vycm9yc1txdWVzdGlvbi5pZF19XG4gICAgICAgICAgICAgICAgICAgICAgey4uLnF1ZXN0aW9ufVxuICAgICAgICAgICAgICAgICAgICAgIGtleT17cXVlc3Rpb24uaWR9XG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICApO1xuXG4gICAgICAgICAgICAgICAgICAvLyBxdWV0aW9uLmlzSGlkZGVu44GMZmFsc2XjgafjgYLjgaPjgabjgoLjgIFoaWRkZW5RdWVzdGlvbklkc+OBq+WQq+OBvuOCjOOBpuOBhOOCi+WgtOWQiOOBr+mdnuihqOekuuOBq+OBmeOCi1xuICAgICAgICAgICAgICAgICAgY29uc3QgaGlkZGVuID1cbiAgICAgICAgICAgICAgICAgICAgcXVlc3Rpb24uaXNIaWRkZW4gPT09IHRydWVcbiAgICAgICAgICAgICAgICAgICAgICA/IHRydWVcbiAgICAgICAgICAgICAgICAgICAgICA6IHByb3BzLmhpZGRlblF1ZXN0aW9uSWRzPy5pbmNsdWRlcyhxdWVzdGlvbi5pZCk7XG4gICAgICAgICAgICAgICAgICByZXR1cm4gaGlkZGVuID8gKFxuICAgICAgICAgICAgICAgICAgICA8VmlzdWFsbHlIaWRkZW4ga2V5PXtxdWVzdGlvbi5pZH0+XG4gICAgICAgICAgICAgICAgICAgICAge3F1ZXN0aW9uRWxlbWVudH1cbiAgICAgICAgICAgICAgICAgICAgPC9WaXN1YWxseUhpZGRlbj5cbiAgICAgICAgICAgICAgICAgICkgOiAoXG4gICAgICAgICAgICAgICAgICAgIHF1ZXN0aW9uRWxlbWVudFxuICAgICAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgPC9NYXRzdXJpRm9ybXNRdWVzdGlvblByb3ZpZGVyPlxuICAgICAgICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgICBtYXJnaW4tdG9wOiAzMnB4O1xuICAgICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICAgICAgdmFyaWFudD1cImZpbGxlZFwiXG4gICAgICAgICAgICAgICAgZGlzYWJsZWQ9e2lzU3VibWl0dGluZ31cbiAgICAgICAgICAgICAgICBjb2xvcj1cInByaW1hcnlcIlxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAg6YCB5L+h44GZ44KLXG4gICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPC9mb3JtPlxuICAgICAgICA8L1BhcGVyPlxuICAgICAgPC9PdmVybGF5PlxuICAgIDwvUG9ydGFsPlxuICApO1xufTtcbiJdfQ== */",
|
|
25
|
+
styles: "position:relative;display:grid;gap:40px;padding:20px 32px 40px;overflow-y:auto;label:SurveyForm;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/matsuri-ui/SurveyForm.tsx"],"names":[],"mappings":"AAwIsB","file":"../../../src/matsuri-ui/SurveyForm.tsx","sourcesContent":["import {\n  Button,\n  Overlay,\n  Paper,\n  Portal,\n  Typography,\n  UserTextRenderer,\n  VisuallyHidden,\n  useAlert,\n  useTheme,\n} from \"matsuri-ui\";\nimport {\n  MatsuriFormsQuestion,\n  MatsuriFormsQuestionProvider,\n  useMatsuriForms,\n} from \"../\";\nimport { MultipleTextQuestion } from \"./MultipleTextQuestion\";\nimport { SelectQuestion } from \"./SelectQuestion\";\nimport { TextQuestion } from \"./TextQuestion\";\nimport { css } from \"@emotion/react\";\n\nexport interface SurveyFormProps {\n  open?: boolean;\n  onSubmit?: () => void;\n  onClose?: () => void;\n  // Props for useMatsuriForms\n  formId?: string;\n  /**\n   * 開発環境のAPIを使用するかどうかを指定します。\n   * @default false\n   */\n  dev?: boolean;\n  // Props for Alert\n  /**\n   * 回答の送信に成功した際に表示するメッセージを指定します。\n   * @default \"ご回答ありがとうございます。\"\n   */\n  successMessage?: string;\n  /**\n   * 回答の送信に成功した場合に、成功メッセージを無視するかどうかを指定します。\n   * @default false\n   */\n  ignoreSuccessMessage?: boolean;\n  /**\n   * 指定したIDのQuesitonのレンダリングをHidden inputにします。\n   */\n  hiddenQuestionIds?: string[];\n  /**\n   * 指定したIDのQuestionに初期値を与えます。\n   */\n  defaultValues?: Record<string, string | string[]>;\n}\n\nexport const SurveyForm = (props: SurveyFormProps) => {\n  const formId = props.formId;\n  if (formId === undefined) {\n    throw new Error(\"formId is required\");\n  }\n\n  const {\n    questions,\n    title,\n    description,\n    submit,\n    errors,\n    validate,\n    isSubmitting,\n  } = useMatsuriForms(formId, {\n    dev: props.dev ?? false,\n  });\n\n  const { throwAlert } = useAlert();\n  const theme = useTheme();\n\n  return (\n    <Portal>\n      <Overlay\n        open={props.open}\n        disableAnimation\n        fullScreen\n        onClose={props.onClose}\n      >\n        <Paper\n          css={css`\n            display: grid;\n            max-width: 720px;\n            max-height: 90vh;\n            margin: 0px auto;\n            overflow: hidden;\n            opacity: 1;\n            transition: opacity 0.2s ease-in;\n            @starting-style {\n              opacity: 0;\n            }\n          `}\n        >\n          <form\n            onSubmit={async (event) => {\n              event.preventDefault();\n\n              const { errors } = validate(event.currentTarget);\n\n              if (errors) {\n                return;\n              }\n\n              const { error } = await submit(event.currentTarget);\n\n              throwAlert(error, {\n                errorMessage: {\n                  reason: \"サーバー側のエラーの可能性があります。\",\n                  action:\n                    \"しばらく時間を空けて試すか、開発チームへお問い合わせください。\",\n                  happend: \"回答の送信に失敗しました。\",\n                },\n                successMessage:\n                  props.successMessage ?? \"ご回答ありがとうございます。\",\n                ignoreSuccess: props.ignoreSuccessMessage ?? false,\n                onSuccess: () => {\n                  props.onSubmit?.();\n                },\n              });\n            }}\n            css={css`\n              display: contents;\n            `}\n          >\n            <header\n              css={css`\n                padding: 32px;\n                border-bottom: 1px solid ${theme.palette.gray[200]};\n              `}\n            >\n              <Typography variant=\"h2\">{title}</Typography>\n            </header>\n            <div\n              css={css`\n                position: relative;\n                display: grid;\n                gap: 40px;\n                padding: 20px 32px 40px;\n                overflow-y: auto;\n              `}\n            >\n              {description !== undefined ? (\n                <Typography>\n                  <UserTextRenderer>{description}</UserTextRenderer>\n                </Typography>\n              ) : null}\n              <MatsuriFormsQuestionProvider\n                renderSelect={SelectQuestion}\n                renderMultilineText={MultipleTextQuestion}\n                renderText={TextQuestion}\n              >\n                {questions.map((question) => {\n                  const questionElement = (\n                    <MatsuriFormsQuestion\n                      defaultValue={props.defaultValues?.[question.id]}\n                      error={errors[question.id]}\n                      {...question}\n                      key={question.id}\n                    />\n                  );\n\n                  // quetion.isHiddenがfalseであっても、hiddenQuestionIdsに含まれている場合は非表示にする\n                  const hidden =\n                    question.isHidden === true\n                      ? true\n                      : (props.hiddenQuestionIds?.includes(question.id) ??\n                        false);\n                  return hidden ? (\n                    <VisuallyHidden key={question.id}>\n                      {questionElement}\n                    </VisuallyHidden>\n                  ) : (\n                    questionElement\n                  );\n                })}\n              </MatsuriFormsQuestionProvider>\n              <Button\n                css={css`\n                  margin-top: 32px;\n                `}\n                variant=\"filled\"\n                disabled={isSubmitting}\n                color=\"primary\"\n              >\n                送信する\n              </Button>\n            </div>\n          </form>\n        </Paper>\n      </Overlay>\n    </Portal>\n  );\n};\n"]} */",
|
|
28
26
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
29
27
|
};
|
|
30
28
|
var _ref3 = process.env.NODE_ENV === "production" ? {
|
|
@@ -32,8 +30,7 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
|
|
|
32
30
|
styles: "display:contents"
|
|
33
31
|
} : {
|
|
34
32
|
name: "1tqbr44-SurveyForm",
|
|
35
|
-
styles: "display:contents;label:SurveyForm;",
|
|
36
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tYXRzdXJpLXVpL1N1cnZleUZvcm0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJIb0IiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL21hdHN1cmktdWkvU3VydmV5Rm9ybS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBCdXR0b24sXG4gIE92ZXJsYXksXG4gIFBhcGVyLFxuICBQb3J0YWwsXG4gIFR5cG9ncmFwaHksXG4gIFVzZXJUZXh0UmVuZGVyZXIsXG4gIFZpc3VhbGx5SGlkZGVuLFxuICB1c2VBbGVydCxcbiAgdXNlVGhlbWUsXG59IGZyb20gXCJtYXRzdXJpLXVpXCI7XG5pbXBvcnQge1xuICBNYXRzdXJpRm9ybXNRdWVzdGlvbixcbiAgTWF0c3VyaUZvcm1zUXVlc3Rpb25Qcm92aWRlcixcbiAgdXNlTWF0c3VyaUZvcm1zLFxufSBmcm9tIFwiLi4vXCI7XG5pbXBvcnQgeyBNdWx0aXBsZVRleHRRdWVzdGlvbiB9IGZyb20gXCIuL011bHRpcGxlVGV4dFF1ZXN0aW9uXCI7XG5pbXBvcnQgeyBTZWxlY3RRdWVzdGlvbiB9IGZyb20gXCIuL1NlbGVjdFF1ZXN0aW9uXCI7XG5pbXBvcnQgeyBUZXh0UXVlc3Rpb24gfSBmcm9tIFwiLi9UZXh0UXVlc3Rpb25cIjtcbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN1cnZleUZvcm1Qcm9wcyB7XG4gIG9wZW4/OiBib29sZWFuO1xuICBvblN1Ym1pdD86ICgpID0+IHZvaWQ7XG4gIG9uQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICAvLyBQcm9wcyBmb3IgdXNlTWF0c3VyaUZvcm1zXG4gIGZvcm1JZD86IHN0cmluZztcbiAgLyoqXG4gICAqIOmWi+eZuueSsOWig+OBrkFQSeOCkuS9v+eUqOOBmeOCi+OBi+OBqeOBhuOBi+OCkuaMh+WumuOBl+OBvuOBmeOAglxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgZGV2PzogYm9vbGVhbjtcbiAgLy8gUHJvcHMgZm9yIEFsZXJ0XG4gIC8qKlxuICAgKiDlm57nrZTjga7pgIHkv6HjgavmiJDlip/jgZfjgZ/pmpvjgavooajnpLrjgZnjgovjg6Hjg4Pjgrvjg7zjgrjjgpLmjIflrprjgZfjgb7jgZnjgIJcbiAgICogQGRlZmF1bHQgXCLjgZTlm57nrZTjgYLjgorjgYzjgajjgYbjgZTjgZbjgYTjgb7jgZnjgIJcIlxuICAgKi9cbiAgc3VjY2Vzc01lc3NhZ2U/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiDlm57nrZTjga7pgIHkv6HjgavmiJDlip/jgZfjgZ/loLTlkIjjgavjgIHmiJDlip/jg6Hjg4Pjgrvjg7zjgrjjgpLnhKHoppbjgZnjgovjgYvjganjgYbjgYvjgpLmjIflrprjgZfjgb7jgZnjgIJcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIGlnbm9yZVN1Y2Nlc3NNZXNzYWdlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIOaMh+WumuOBl+OBn0lE44GuUXVlc2l0b27jga7jg6zjg7Pjg4Djg6rjg7PjgrDjgpJIaWRkZW4gaW5wdXTjgavjgZfjgb7jgZnjgIJcbiAgICovXG4gIGhpZGRlblF1ZXN0aW9uSWRzPzogc3RyaW5nW107XG4gIC8qKlxuICAgKiDmjIflrprjgZfjgZ9JROOBrlF1ZXN0aW9u44Gr5Yid5pyf5YCk44KS5LiO44GI44G+44GZ44CCXG4gICAqL1xuICBkZWZhdWx0VmFsdWVzPzogUmVjb3JkPHN0cmluZywgc3RyaW5nIHwgc3RyaW5nW10+O1xufVxuXG5leHBvcnQgY29uc3QgU3VydmV5Rm9ybSA9IChwcm9wczogU3VydmV5Rm9ybVByb3BzKSA9PiB7XG4gIGNvbnN0IGZvcm1JZCA9IHByb3BzLmZvcm1JZDtcbiAgaWYgKCFmb3JtSWQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXCJmb3JtSWQgaXMgcmVxdWlyZWRcIik7XG4gIH1cblxuICBjb25zdCB7XG4gICAgcXVlc3Rpb25zLFxuICAgIHRpdGxlLFxuICAgIGRlc2NyaXB0aW9uLFxuICAgIHN1Ym1pdCxcbiAgICBlcnJvcnMsXG4gICAgdmFsaWRhdGUsXG4gICAgaXNTdWJtaXR0aW5nLFxuICB9ID0gdXNlTWF0c3VyaUZvcm1zKGZvcm1JZCwge1xuICAgIGRldjogcHJvcHMuZGV2ID8/IGZhbHNlLFxuICB9KTtcblxuICBjb25zdCB7IHRocm93QWxlcnQgfSA9IHVzZUFsZXJ0KCk7XG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKTtcblxuICByZXR1cm4gKFxuICAgIDxQb3J0YWw+XG4gICAgICA8T3ZlcmxheVxuICAgICAgICBvcGVuPXtwcm9wcy5vcGVufVxuICAgICAgICBkaXNhYmxlQW5pbWF0aW9uXG4gICAgICAgIGZ1bGxTY3JlZW5cbiAgICAgICAgb25DbG9zZT17cHJvcHMub25DbG9zZX1cbiAgICAgID5cbiAgICAgICAgPFBhcGVyXG4gICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICBkaXNwbGF5OiBncmlkO1xuICAgICAgICAgICAgbWF4LXdpZHRoOiA3MjBweDtcbiAgICAgICAgICAgIG1heC1oZWlnaHQ6IDkwdmg7XG4gICAgICAgICAgICBtYXJnaW46IDBweCBhdXRvO1xuICAgICAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgICAgICAgIG9wYWNpdHk6IDE7XG4gICAgICAgICAgICB0cmFuc2l0aW9uOiBvcGFjaXR5IDAuMnMgZWFzZS1pbjtcbiAgICAgICAgICAgIEBzdGFydGluZy1zdHlsZSB7XG4gICAgICAgICAgICAgIG9wYWNpdHk6IDA7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgYH1cbiAgICAgICAgPlxuICAgICAgICAgIDxmb3JtXG4gICAgICAgICAgICBvblN1Ym1pdD17YXN5bmMgKGV2ZW50KSA9PiB7XG4gICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG5cbiAgICAgICAgICAgICAgY29uc3QgeyBlcnJvcnMgfSA9IHZhbGlkYXRlKGV2ZW50LmN1cnJlbnRUYXJnZXQpO1xuXG4gICAgICAgICAgICAgIGlmIChlcnJvcnMpIHtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICBjb25zdCB7IGVycm9yIH0gPSBhd2FpdCBzdWJtaXQoZXZlbnQuY3VycmVudFRhcmdldCk7XG5cbiAgICAgICAgICAgICAgdGhyb3dBbGVydChlcnJvciwge1xuICAgICAgICAgICAgICAgIGVycm9yTWVzc2FnZToge1xuICAgICAgICAgICAgICAgICAgcmVhc29uOiBcIuOCteODvOODkOODvOWBtOOBruOCqOODqeODvOOBruWPr+iDveaAp+OBjOOBguOCiuOBvuOBmeOAglwiLFxuICAgICAgICAgICAgICAgICAgYWN0aW9uOlxuICAgICAgICAgICAgICAgICAgICBcIuOBl+OBsOOCieOBj+aZgumWk+OCkuepuuOBkeOBpuippuOBmeOBi+OAgemWi+eZuuODgeODvOODoOOBuOOBiuWVj+OBhOWQiOOCj+OBm+OBj+OBoOOBleOBhOOAglwiLFxuICAgICAgICAgICAgICAgICAgaGFwcGVuZDogXCLlm57nrZTjga7pgIHkv6HjgavlpLHmlZfjgZfjgb7jgZfjgZ/jgIJcIixcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIHN1Y2Nlc3NNZXNzYWdlOlxuICAgICAgICAgICAgICAgICAgcHJvcHMuc3VjY2Vzc01lc3NhZ2UgPz8gXCLjgZTlm57nrZTjgYLjgorjgYzjgajjgYbjgZTjgZbjgYTjgb7jgZnjgIJcIixcbiAgICAgICAgICAgICAgICBpZ25vcmVTdWNjZXNzOiBwcm9wcy5pZ25vcmVTdWNjZXNzTWVzc2FnZSA/PyBmYWxzZSxcbiAgICAgICAgICAgICAgICBvblN1Y2Nlc3M6ICgpID0+IHtcbiAgICAgICAgICAgICAgICAgIHByb3BzLm9uU3VibWl0Py4oKTtcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH19XG4gICAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgICAgZGlzcGxheTogY29udGVudHM7XG4gICAgICAgICAgICBgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxoZWFkZXJcbiAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgcGFkZGluZzogMzJweDtcbiAgICAgICAgICAgICAgICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHt0aGVtZS5wYWxldHRlLmdyYXlbMjAwXX07XG4gICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxUeXBvZ3JhcGh5IHZhcmlhbnQ9XCJoMlwiPnt0aXRsZX08L1R5cG9ncmFwaHk+XG4gICAgICAgICAgICA8L2hlYWRlcj5cbiAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgICAgICAgICAgICAgIGRpc3BsYXk6IGdyaWQ7XG4gICAgICAgICAgICAgICAgZ2FwOiA0MHB4O1xuICAgICAgICAgICAgICAgIHBhZGRpbmc6IDIwcHggMzJweCA0MHB4O1xuICAgICAgICAgICAgICAgIG92ZXJmbG93LXk6IGF1dG87XG4gICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgICAgICA8VHlwb2dyYXBoeT5cbiAgICAgICAgICAgICAgICAgIDxVc2VyVGV4dFJlbmRlcmVyPntkZXNjcmlwdGlvbn08L1VzZXJUZXh0UmVuZGVyZXI+XG4gICAgICAgICAgICAgICAgPC9UeXBvZ3JhcGh5PlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgICAgPE1hdHN1cmlGb3Jtc1F1ZXN0aW9uUHJvdmlkZXJcbiAgICAgICAgICAgICAgICByZW5kZXJTZWxlY3Q9e1NlbGVjdFF1ZXN0aW9ufVxuICAgICAgICAgICAgICAgIHJlbmRlck11bHRpbGluZVRleHQ9e011bHRpcGxlVGV4dFF1ZXN0aW9ufVxuICAgICAgICAgICAgICAgIHJlbmRlclRleHQ9e1RleHRRdWVzdGlvbn1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtxdWVzdGlvbnMubWFwKChxdWVzdGlvbikgPT4ge1xuICAgICAgICAgICAgICAgICAgY29uc3QgcXVlc3Rpb25FbGVtZW50ID0gKFxuICAgICAgICAgICAgICAgICAgICA8TWF0c3VyaUZvcm1zUXVlc3Rpb25cbiAgICAgICAgICAgICAgICAgICAgICBkZWZhdWx0VmFsdWU9e3Byb3BzLmRlZmF1bHRWYWx1ZXM/LltxdWVzdGlvbi5pZF19XG4gICAgICAgICAgICAgICAgICAgICAgZXJyb3I9e2Vycm9yc1txdWVzdGlvbi5pZF19XG4gICAgICAgICAgICAgICAgICAgICAgey4uLnF1ZXN0aW9ufVxuICAgICAgICAgICAgICAgICAgICAgIGtleT17cXVlc3Rpb24uaWR9XG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICApO1xuXG4gICAgICAgICAgICAgICAgICAvLyBxdWV0aW9uLmlzSGlkZGVu44GMZmFsc2XjgafjgYLjgaPjgabjgoLjgIFoaWRkZW5RdWVzdGlvbklkc+OBq+WQq+OBvuOCjOOBpuOBhOOCi+WgtOWQiOOBr+mdnuihqOekuuOBq+OBmeOCi1xuICAgICAgICAgICAgICAgICAgY29uc3QgaGlkZGVuID1cbiAgICAgICAgICAgICAgICAgICAgcXVlc3Rpb24uaXNIaWRkZW4gPT09IHRydWVcbiAgICAgICAgICAgICAgICAgICAgICA/IHRydWVcbiAgICAgICAgICAgICAgICAgICAgICA6IHByb3BzLmhpZGRlblF1ZXN0aW9uSWRzPy5pbmNsdWRlcyhxdWVzdGlvbi5pZCk7XG4gICAgICAgICAgICAgICAgICByZXR1cm4gaGlkZGVuID8gKFxuICAgICAgICAgICAgICAgICAgICA8VmlzdWFsbHlIaWRkZW4ga2V5PXtxdWVzdGlvbi5pZH0+XG4gICAgICAgICAgICAgICAgICAgICAge3F1ZXN0aW9uRWxlbWVudH1cbiAgICAgICAgICAgICAgICAgICAgPC9WaXN1YWxseUhpZGRlbj5cbiAgICAgICAgICAgICAgICAgICkgOiAoXG4gICAgICAgICAgICAgICAgICAgIHF1ZXN0aW9uRWxlbWVudFxuICAgICAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgPC9NYXRzdXJpRm9ybXNRdWVzdGlvblByb3ZpZGVyPlxuICAgICAgICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgICBtYXJnaW4tdG9wOiAzMnB4O1xuICAgICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICAgICAgdmFyaWFudD1cImZpbGxlZFwiXG4gICAgICAgICAgICAgICAgZGlzYWJsZWQ9e2lzU3VibWl0dGluZ31cbiAgICAgICAgICAgICAgICBjb2xvcj1cInByaW1hcnlcIlxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAg6YCB5L+h44GZ44KLXG4gICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPC9mb3JtPlxuICAgICAgICA8L1BhcGVyPlxuICAgICAgPC9PdmVybGF5PlxuICAgIDwvUG9ydGFsPlxuICApO1xufTtcbiJdfQ== */",
|
|
33
|
+
styles: "display:contents;label:SurveyForm;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/matsuri-ui/SurveyForm.tsx"],"names":[],"mappings":"AA2HoB","file":"../../../src/matsuri-ui/SurveyForm.tsx","sourcesContent":["import {\n  Button,\n  Overlay,\n  Paper,\n  Portal,\n  Typography,\n  UserTextRenderer,\n  VisuallyHidden,\n  useAlert,\n  useTheme,\n} from \"matsuri-ui\";\nimport {\n  MatsuriFormsQuestion,\n  MatsuriFormsQuestionProvider,\n  useMatsuriForms,\n} from \"../\";\nimport { MultipleTextQuestion } from \"./MultipleTextQuestion\";\nimport { SelectQuestion } from \"./SelectQuestion\";\nimport { TextQuestion } from \"./TextQuestion\";\nimport { css } from \"@emotion/react\";\n\nexport interface SurveyFormProps {\n  open?: boolean;\n  onSubmit?: () => void;\n  onClose?: () => void;\n  // Props for useMatsuriForms\n  formId?: string;\n  /**\n   * 開発環境のAPIを使用するかどうかを指定します。\n   * @default false\n   */\n  dev?: boolean;\n  // Props for Alert\n  /**\n   * 回答の送信に成功した際に表示するメッセージを指定します。\n   * @default \"ご回答ありがとうございます。\"\n   */\n  successMessage?: string;\n  /**\n   * 回答の送信に成功した場合に、成功メッセージを無視するかどうかを指定します。\n   * @default false\n   */\n  ignoreSuccessMessage?: boolean;\n  /**\n   * 指定したIDのQuesitonのレンダリングをHidden inputにします。\n   */\n  hiddenQuestionIds?: string[];\n  /**\n   * 指定したIDのQuestionに初期値を与えます。\n   */\n  defaultValues?: Record<string, string | string[]>;\n}\n\nexport const SurveyForm = (props: SurveyFormProps) => {\n  const formId = props.formId;\n  if (formId === undefined) {\n    throw new Error(\"formId is required\");\n  }\n\n  const {\n    questions,\n    title,\n    description,\n    submit,\n    errors,\n    validate,\n    isSubmitting,\n  } = useMatsuriForms(formId, {\n    dev: props.dev ?? false,\n  });\n\n  const { throwAlert } = useAlert();\n  const theme = useTheme();\n\n  return (\n    <Portal>\n      <Overlay\n        open={props.open}\n        disableAnimation\n        fullScreen\n        onClose={props.onClose}\n      >\n        <Paper\n          css={css`\n            display: grid;\n            max-width: 720px;\n            max-height: 90vh;\n            margin: 0px auto;\n            overflow: hidden;\n            opacity: 1;\n            transition: opacity 0.2s ease-in;\n            @starting-style {\n              opacity: 0;\n            }\n          `}\n        >\n          <form\n            onSubmit={async (event) => {\n              event.preventDefault();\n\n              const { errors } = validate(event.currentTarget);\n\n              if (errors) {\n                return;\n              }\n\n              const { error } = await submit(event.currentTarget);\n\n              throwAlert(error, {\n                errorMessage: {\n                  reason: \"サーバー側のエラーの可能性があります。\",\n                  action:\n                    \"しばらく時間を空けて試すか、開発チームへお問い合わせください。\",\n                  happend: \"回答の送信に失敗しました。\",\n                },\n                successMessage:\n                  props.successMessage ?? \"ご回答ありがとうございます。\",\n                ignoreSuccess: props.ignoreSuccessMessage ?? false,\n                onSuccess: () => {\n                  props.onSubmit?.();\n                },\n              });\n            }}\n            css={css`\n              display: contents;\n            `}\n          >\n            <header\n              css={css`\n                padding: 32px;\n                border-bottom: 1px solid ${theme.palette.gray[200]};\n              `}\n            >\n              <Typography variant=\"h2\">{title}</Typography>\n            </header>\n            <div\n              css={css`\n                position: relative;\n                display: grid;\n                gap: 40px;\n                padding: 20px 32px 40px;\n                overflow-y: auto;\n              `}\n            >\n              {description !== undefined ? (\n                <Typography>\n                  <UserTextRenderer>{description}</UserTextRenderer>\n                </Typography>\n              ) : null}\n              <MatsuriFormsQuestionProvider\n                renderSelect={SelectQuestion}\n                renderMultilineText={MultipleTextQuestion}\n                renderText={TextQuestion}\n              >\n                {questions.map((question) => {\n                  const questionElement = (\n                    <MatsuriFormsQuestion\n                      defaultValue={props.defaultValues?.[question.id]}\n                      error={errors[question.id]}\n                      {...question}\n                      key={question.id}\n                    />\n                  );\n\n                  // quetion.isHiddenがfalseであっても、hiddenQuestionIdsに含まれている場合は非表示にする\n                  const hidden =\n                    question.isHidden === true\n                      ? true\n                      : (props.hiddenQuestionIds?.includes(question.id) ??\n                        false);\n                  return hidden ? (\n                    <VisuallyHidden key={question.id}>\n                      {questionElement}\n                    </VisuallyHidden>\n                  ) : (\n                    questionElement\n                  );\n                })}\n              </MatsuriFormsQuestionProvider>\n              <Button\n                css={css`\n                  margin-top: 32px;\n                `}\n                variant=\"filled\"\n                disabled={isSubmitting}\n                color=\"primary\"\n              >\n                送信する\n              </Button>\n            </div>\n          </form>\n        </Paper>\n      </Overlay>\n    </Portal>\n  );\n};\n"]} */",
|
|
37
34
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
38
35
|
};
|
|
39
36
|
var _ref4 = process.env.NODE_ENV === "production" ? {
|
|
@@ -41,14 +38,13 @@ var _ref4 = process.env.NODE_ENV === "production" ? {
|
|
|
41
38
|
styles: "display:grid;max-width:720px;max-height:90vh;margin:0px auto;overflow:hidden;opacity:1;transition:opacity 0.2s ease-in;@starting-style{opacity:0;}"
|
|
42
39
|
} : {
|
|
43
40
|
name: "35d2k5-SurveyForm",
|
|
44
|
-
styles: "display:grid;max-width:720px;max-height:90vh;margin:0px auto;overflow:hidden;opacity:1;transition:opacity 0.2s ease-in;@starting-style{opacity:0;};label:SurveyForm;",
|
|
45
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tYXRzdXJpLXVpL1N1cnZleUZvcm0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Ga0IiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL21hdHN1cmktdWkvU3VydmV5Rm9ybS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBCdXR0b24sXG4gIE92ZXJsYXksXG4gIFBhcGVyLFxuICBQb3J0YWwsXG4gIFR5cG9ncmFwaHksXG4gIFVzZXJUZXh0UmVuZGVyZXIsXG4gIFZpc3VhbGx5SGlkZGVuLFxuICB1c2VBbGVydCxcbiAgdXNlVGhlbWUsXG59IGZyb20gXCJtYXRzdXJpLXVpXCI7XG5pbXBvcnQge1xuICBNYXRzdXJpRm9ybXNRdWVzdGlvbixcbiAgTWF0c3VyaUZvcm1zUXVlc3Rpb25Qcm92aWRlcixcbiAgdXNlTWF0c3VyaUZvcm1zLFxufSBmcm9tIFwiLi4vXCI7XG5pbXBvcnQgeyBNdWx0aXBsZVRleHRRdWVzdGlvbiB9IGZyb20gXCIuL011bHRpcGxlVGV4dFF1ZXN0aW9uXCI7XG5pbXBvcnQgeyBTZWxlY3RRdWVzdGlvbiB9IGZyb20gXCIuL1NlbGVjdFF1ZXN0aW9uXCI7XG5pbXBvcnQgeyBUZXh0UXVlc3Rpb24gfSBmcm9tIFwiLi9UZXh0UXVlc3Rpb25cIjtcbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN1cnZleUZvcm1Qcm9wcyB7XG4gIG9wZW4/OiBib29sZWFuO1xuICBvblN1Ym1pdD86ICgpID0+IHZvaWQ7XG4gIG9uQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICAvLyBQcm9wcyBmb3IgdXNlTWF0c3VyaUZvcm1zXG4gIGZvcm1JZD86IHN0cmluZztcbiAgLyoqXG4gICAqIOmWi+eZuueSsOWig+OBrkFQSeOCkuS9v+eUqOOBmeOCi+OBi+OBqeOBhuOBi+OCkuaMh+WumuOBl+OBvuOBmeOAglxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgZGV2PzogYm9vbGVhbjtcbiAgLy8gUHJvcHMgZm9yIEFsZXJ0XG4gIC8qKlxuICAgKiDlm57nrZTjga7pgIHkv6HjgavmiJDlip/jgZfjgZ/pmpvjgavooajnpLrjgZnjgovjg6Hjg4Pjgrvjg7zjgrjjgpLmjIflrprjgZfjgb7jgZnjgIJcbiAgICogQGRlZmF1bHQgXCLjgZTlm57nrZTjgYLjgorjgYzjgajjgYbjgZTjgZbjgYTjgb7jgZnjgIJcIlxuICAgKi9cbiAgc3VjY2Vzc01lc3NhZ2U/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiDlm57nrZTjga7pgIHkv6HjgavmiJDlip/jgZfjgZ/loLTlkIjjgavjgIHmiJDlip/jg6Hjg4Pjgrvjg7zjgrjjgpLnhKHoppbjgZnjgovjgYvjganjgYbjgYvjgpLmjIflrprjgZfjgb7jgZnjgIJcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIGlnbm9yZVN1Y2Nlc3NNZXNzYWdlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIOaMh+WumuOBl+OBn0lE44GuUXVlc2l0b27jga7jg6zjg7Pjg4Djg6rjg7PjgrDjgpJIaWRkZW4gaW5wdXTjgavjgZfjgb7jgZnjgIJcbiAgICovXG4gIGhpZGRlblF1ZXN0aW9uSWRzPzogc3RyaW5nW107XG4gIC8qKlxuICAgKiDmjIflrprjgZfjgZ9JROOBrlF1ZXN0aW9u44Gr5Yid5pyf5YCk44KS5LiO44GI44G+44GZ44CCXG4gICAqL1xuICBkZWZhdWx0VmFsdWVzPzogUmVjb3JkPHN0cmluZywgc3RyaW5nIHwgc3RyaW5nW10+O1xufVxuXG5leHBvcnQgY29uc3QgU3VydmV5Rm9ybSA9IChwcm9wczogU3VydmV5Rm9ybVByb3BzKSA9PiB7XG4gIGNvbnN0IGZvcm1JZCA9IHByb3BzLmZvcm1JZDtcbiAgaWYgKCFmb3JtSWQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXCJmb3JtSWQgaXMgcmVxdWlyZWRcIik7XG4gIH1cblxuICBjb25zdCB7XG4gICAgcXVlc3Rpb25zLFxuICAgIHRpdGxlLFxuICAgIGRlc2NyaXB0aW9uLFxuICAgIHN1Ym1pdCxcbiAgICBlcnJvcnMsXG4gICAgdmFsaWRhdGUsXG4gICAgaXNTdWJtaXR0aW5nLFxuICB9ID0gdXNlTWF0c3VyaUZvcm1zKGZvcm1JZCwge1xuICAgIGRldjogcHJvcHMuZGV2ID8/IGZhbHNlLFxuICB9KTtcblxuICBjb25zdCB7IHRocm93QWxlcnQgfSA9IHVzZUFsZXJ0KCk7XG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKTtcblxuICByZXR1cm4gKFxuICAgIDxQb3J0YWw+XG4gICAgICA8T3ZlcmxheVxuICAgICAgICBvcGVuPXtwcm9wcy5vcGVufVxuICAgICAgICBkaXNhYmxlQW5pbWF0aW9uXG4gICAgICAgIGZ1bGxTY3JlZW5cbiAgICAgICAgb25DbG9zZT17cHJvcHMub25DbG9zZX1cbiAgICAgID5cbiAgICAgICAgPFBhcGVyXG4gICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICBkaXNwbGF5OiBncmlkO1xuICAgICAgICAgICAgbWF4LXdpZHRoOiA3MjBweDtcbiAgICAgICAgICAgIG1heC1oZWlnaHQ6IDkwdmg7XG4gICAgICAgICAgICBtYXJnaW46IDBweCBhdXRvO1xuICAgICAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICAgICAgICAgIG9wYWNpdHk6IDE7XG4gICAgICAgICAgICB0cmFuc2l0aW9uOiBvcGFjaXR5IDAuMnMgZWFzZS1pbjtcbiAgICAgICAgICAgIEBzdGFydGluZy1zdHlsZSB7XG4gICAgICAgICAgICAgIG9wYWNpdHk6IDA7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgYH1cbiAgICAgICAgPlxuICAgICAgICAgIDxmb3JtXG4gICAgICAgICAgICBvblN1Ym1pdD17YXN5bmMgKGV2ZW50KSA9PiB7XG4gICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG5cbiAgICAgICAgICAgICAgY29uc3QgeyBlcnJvcnMgfSA9IHZhbGlkYXRlKGV2ZW50LmN1cnJlbnRUYXJnZXQpO1xuXG4gICAgICAgICAgICAgIGlmIChlcnJvcnMpIHtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICBjb25zdCB7IGVycm9yIH0gPSBhd2FpdCBzdWJtaXQoZXZlbnQuY3VycmVudFRhcmdldCk7XG5cbiAgICAgICAgICAgICAgdGhyb3dBbGVydChlcnJvciwge1xuICAgICAgICAgICAgICAgIGVycm9yTWVzc2FnZToge1xuICAgICAgICAgICAgICAgICAgcmVhc29uOiBcIuOCteODvOODkOODvOWBtOOBruOCqOODqeODvOOBruWPr+iDveaAp+OBjOOBguOCiuOBvuOBmeOAglwiLFxuICAgICAgICAgICAgICAgICAgYWN0aW9uOlxuICAgICAgICAgICAgICAgICAgICBcIuOBl+OBsOOCieOBj+aZgumWk+OCkuepuuOBkeOBpuippuOBmeOBi+OAgemWi+eZuuODgeODvOODoOOBuOOBiuWVj+OBhOWQiOOCj+OBm+OBj+OBoOOBleOBhOOAglwiLFxuICAgICAgICAgICAgICAgICAgaGFwcGVuZDogXCLlm57nrZTjga7pgIHkv6HjgavlpLHmlZfjgZfjgb7jgZfjgZ/jgIJcIixcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIHN1Y2Nlc3NNZXNzYWdlOlxuICAgICAgICAgICAgICAgICAgcHJvcHMuc3VjY2Vzc01lc3NhZ2UgPz8gXCLjgZTlm57nrZTjgYLjgorjgYzjgajjgYbjgZTjgZbjgYTjgb7jgZnjgIJcIixcbiAgICAgICAgICAgICAgICBpZ25vcmVTdWNjZXNzOiBwcm9wcy5pZ25vcmVTdWNjZXNzTWVzc2FnZSA/PyBmYWxzZSxcbiAgICAgICAgICAgICAgICBvblN1Y2Nlc3M6ICgpID0+IHtcbiAgICAgICAgICAgICAgICAgIHByb3BzLm9uU3VibWl0Py4oKTtcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH19XG4gICAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgICAgZGlzcGxheTogY29udGVudHM7XG4gICAgICAgICAgICBgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxoZWFkZXJcbiAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgcGFkZGluZzogMzJweDtcbiAgICAgICAgICAgICAgICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHt0aGVtZS5wYWxldHRlLmdyYXlbMjAwXX07XG4gICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxUeXBvZ3JhcGh5IHZhcmlhbnQ9XCJoMlwiPnt0aXRsZX08L1R5cG9ncmFwaHk+XG4gICAgICAgICAgICA8L2hlYWRlcj5cbiAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgICAgICAgICAgICAgIGRpc3BsYXk6IGdyaWQ7XG4gICAgICAgICAgICAgICAgZ2FwOiA0MHB4O1xuICAgICAgICAgICAgICAgIHBhZGRpbmc6IDIwcHggMzJweCA0MHB4O1xuICAgICAgICAgICAgICAgIG92ZXJmbG93LXk6IGF1dG87XG4gICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtkZXNjcmlwdGlvbiA/IChcbiAgICAgICAgICAgICAgICA8VHlwb2dyYXBoeT5cbiAgICAgICAgICAgICAgICAgIDxVc2VyVGV4dFJlbmRlcmVyPntkZXNjcmlwdGlvbn08L1VzZXJUZXh0UmVuZGVyZXI+XG4gICAgICAgICAgICAgICAgPC9UeXBvZ3JhcGh5PlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgICAgPE1hdHN1cmlGb3Jtc1F1ZXN0aW9uUHJvdmlkZXJcbiAgICAgICAgICAgICAgICByZW5kZXJTZWxlY3Q9e1NlbGVjdFF1ZXN0aW9ufVxuICAgICAgICAgICAgICAgIHJlbmRlck11bHRpbGluZVRleHQ9e011bHRpcGxlVGV4dFF1ZXN0aW9ufVxuICAgICAgICAgICAgICAgIHJlbmRlclRleHQ9e1RleHRRdWVzdGlvbn1cbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtxdWVzdGlvbnMubWFwKChxdWVzdGlvbikgPT4ge1xuICAgICAgICAgICAgICAgICAgY29uc3QgcXVlc3Rpb25FbGVtZW50ID0gKFxuICAgICAgICAgICAgICAgICAgICA8TWF0c3VyaUZvcm1zUXVlc3Rpb25cbiAgICAgICAgICAgICAgICAgICAgICBkZWZhdWx0VmFsdWU9e3Byb3BzLmRlZmF1bHRWYWx1ZXM/LltxdWVzdGlvbi5pZF19XG4gICAgICAgICAgICAgICAgICAgICAgZXJyb3I9e2Vycm9yc1txdWVzdGlvbi5pZF19XG4gICAgICAgICAgICAgICAgICAgICAgey4uLnF1ZXN0aW9ufVxuICAgICAgICAgICAgICAgICAgICAgIGtleT17cXVlc3Rpb24uaWR9XG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICApO1xuXG4gICAgICAgICAgICAgICAgICAvLyBxdWV0aW9uLmlzSGlkZGVu44GMZmFsc2XjgafjgYLjgaPjgabjgoLjgIFoaWRkZW5RdWVzdGlvbklkc+OBq+WQq+OBvuOCjOOBpuOBhOOCi+WgtOWQiOOBr+mdnuihqOekuuOBq+OBmeOCi1xuICAgICAgICAgICAgICAgICAgY29uc3QgaGlkZGVuID1cbiAgICAgICAgICAgICAgICAgICAgcXVlc3Rpb24uaXNIaWRkZW4gPT09IHRydWVcbiAgICAgICAgICAgICAgICAgICAgICA/IHRydWVcbiAgICAgICAgICAgICAgICAgICAgICA6IHByb3BzLmhpZGRlblF1ZXN0aW9uSWRzPy5pbmNsdWRlcyhxdWVzdGlvbi5pZCk7XG4gICAgICAgICAgICAgICAgICByZXR1cm4gaGlkZGVuID8gKFxuICAgICAgICAgICAgICAgICAgICA8VmlzdWFsbHlIaWRkZW4ga2V5PXtxdWVzdGlvbi5pZH0+XG4gICAgICAgICAgICAgICAgICAgICAge3F1ZXN0aW9uRWxlbWVudH1cbiAgICAgICAgICAgICAgICAgICAgPC9WaXN1YWxseUhpZGRlbj5cbiAgICAgICAgICAgICAgICAgICkgOiAoXG4gICAgICAgICAgICAgICAgICAgIHF1ZXN0aW9uRWxlbWVudFxuICAgICAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgICAgPC9NYXRzdXJpRm9ybXNRdWVzdGlvblByb3ZpZGVyPlxuICAgICAgICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgICBtYXJnaW4tdG9wOiAzMnB4O1xuICAgICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICAgICAgdmFyaWFudD1cImZpbGxlZFwiXG4gICAgICAgICAgICAgICAgZGlzYWJsZWQ9e2lzU3VibWl0dGluZ31cbiAgICAgICAgICAgICAgICBjb2xvcj1cInByaW1hcnlcIlxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAg6YCB5L+h44GZ44KLXG4gICAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPC9mb3JtPlxuICAgICAgICA8L1BhcGVyPlxuICAgICAgPC9PdmVybGF5PlxuICAgIDwvUG9ydGFsPlxuICApO1xufTtcbiJdfQ== */",
|
|
41
|
+
styles: "display:grid;max-width:720px;max-height:90vh;margin:0px auto;overflow:hidden;opacity:1;transition:opacity 0.2s ease-in;@starting-style{opacity:0;};label:SurveyForm;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/matsuri-ui/SurveyForm.tsx"],"names":[],"mappings":"AAmFkB","file":"../../../src/matsuri-ui/SurveyForm.tsx","sourcesContent":["import {\n  Button,\n  Overlay,\n  Paper,\n  Portal,\n  Typography,\n  UserTextRenderer,\n  VisuallyHidden,\n  useAlert,\n  useTheme,\n} from \"matsuri-ui\";\nimport {\n  MatsuriFormsQuestion,\n  MatsuriFormsQuestionProvider,\n  useMatsuriForms,\n} from \"../\";\nimport { MultipleTextQuestion } from \"./MultipleTextQuestion\";\nimport { SelectQuestion } from \"./SelectQuestion\";\nimport { TextQuestion } from \"./TextQuestion\";\nimport { css } from \"@emotion/react\";\n\nexport interface SurveyFormProps {\n  open?: boolean;\n  onSubmit?: () => void;\n  onClose?: () => void;\n  // Props for useMatsuriForms\n  formId?: string;\n  /**\n   * 開発環境のAPIを使用するかどうかを指定します。\n   * @default false\n   */\n  dev?: boolean;\n  // Props for Alert\n  /**\n   * 回答の送信に成功した際に表示するメッセージを指定します。\n   * @default \"ご回答ありがとうございます。\"\n   */\n  successMessage?: string;\n  /**\n   * 回答の送信に成功した場合に、成功メッセージを無視するかどうかを指定します。\n   * @default false\n   */\n  ignoreSuccessMessage?: boolean;\n  /**\n   * 指定したIDのQuesitonのレンダリングをHidden inputにします。\n   */\n  hiddenQuestionIds?: string[];\n  /**\n   * 指定したIDのQuestionに初期値を与えます。\n   */\n  defaultValues?: Record<string, string | string[]>;\n}\n\nexport const SurveyForm = (props: SurveyFormProps) => {\n  const formId = props.formId;\n  if (formId === undefined) {\n    throw new Error(\"formId is required\");\n  }\n\n  const {\n    questions,\n    title,\n    description,\n    submit,\n    errors,\n    validate,\n    isSubmitting,\n  } = useMatsuriForms(formId, {\n    dev: props.dev ?? false,\n  });\n\n  const { throwAlert } = useAlert();\n  const theme = useTheme();\n\n  return (\n    <Portal>\n      <Overlay\n        open={props.open}\n        disableAnimation\n        fullScreen\n        onClose={props.onClose}\n      >\n        <Paper\n          css={css`\n            display: grid;\n            max-width: 720px;\n            max-height: 90vh;\n            margin: 0px auto;\n            overflow: hidden;\n            opacity: 1;\n            transition: opacity 0.2s ease-in;\n            @starting-style {\n              opacity: 0;\n            }\n          `}\n        >\n          <form\n            onSubmit={async (event) => {\n              event.preventDefault();\n\n              const { errors } = validate(event.currentTarget);\n\n              if (errors) {\n                return;\n              }\n\n              const { error } = await submit(event.currentTarget);\n\n              throwAlert(error, {\n                errorMessage: {\n                  reason: \"サーバー側のエラーの可能性があります。\",\n                  action:\n                    \"しばらく時間を空けて試すか、開発チームへお問い合わせください。\",\n                  happend: \"回答の送信に失敗しました。\",\n                },\n                successMessage:\n                  props.successMessage ?? \"ご回答ありがとうございます。\",\n                ignoreSuccess: props.ignoreSuccessMessage ?? false,\n                onSuccess: () => {\n                  props.onSubmit?.();\n                },\n              });\n            }}\n            css={css`\n              display: contents;\n            `}\n          >\n            <header\n              css={css`\n                padding: 32px;\n                border-bottom: 1px solid ${theme.palette.gray[200]};\n              `}\n            >\n              <Typography variant=\"h2\">{title}</Typography>\n            </header>\n            <div\n              css={css`\n                position: relative;\n                display: grid;\n                gap: 40px;\n                padding: 20px 32px 40px;\n                overflow-y: auto;\n              `}\n            >\n              {description !== undefined ? (\n                <Typography>\n                  <UserTextRenderer>{description}</UserTextRenderer>\n                </Typography>\n              ) : null}\n              <MatsuriFormsQuestionProvider\n                renderSelect={SelectQuestion}\n                renderMultilineText={MultipleTextQuestion}\n                renderText={TextQuestion}\n              >\n                {questions.map((question) => {\n                  const questionElement = (\n                    <MatsuriFormsQuestion\n                      defaultValue={props.defaultValues?.[question.id]}\n                      error={errors[question.id]}\n                      {...question}\n                      key={question.id}\n                    />\n                  );\n\n                  // quetion.isHiddenがfalseであっても、hiddenQuestionIdsに含まれている場合は非表示にする\n                  const hidden =\n                    question.isHidden === true\n                      ? true\n                      : (props.hiddenQuestionIds?.includes(question.id) ??\n                        false);\n                  return hidden ? (\n                    <VisuallyHidden key={question.id}>\n                      {questionElement}\n                    </VisuallyHidden>\n                  ) : (\n                    questionElement\n                  );\n                })}\n              </MatsuriFormsQuestionProvider>\n              <Button\n                css={css`\n                  margin-top: 32px;\n                `}\n                variant=\"filled\"\n                disabled={isSubmitting}\n                color=\"primary\"\n              >\n                送信する\n              </Button>\n            </div>\n          </form>\n        </Paper>\n      </Overlay>\n    </Portal>\n  );\n};\n"]} */",
|
|
46
42
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
47
43
|
};
|
|
48
44
|
export var SurveyForm = props => {
|
|
49
45
|
var _props$dev;
|
|
50
46
|
var formId = props.formId;
|
|
51
|
-
if (
|
|
47
|
+
if (formId === undefined) {
|
|
52
48
|
throw new Error("formId is required");
|
|
53
49
|
}
|
|
54
50
|
var {
|
|
@@ -74,7 +70,7 @@ export var SurveyForm = props => {
|
|
|
74
70
|
}, ___EmotionJSX(Paper, {
|
|
75
71
|
css: _ref4
|
|
76
72
|
}, ___EmotionJSX("form", {
|
|
77
|
-
onSubmit: (
|
|
73
|
+
onSubmit: (/*#__PURE__*/function () {
|
|
78
74
|
var _ref5 = _asyncToGenerator(function* (event) {
|
|
79
75
|
var _props$successMessage, _props$ignoreSuccessM;
|
|
80
76
|
event.preventDefault();
|
|
@@ -107,17 +103,17 @@ export var SurveyForm = props => {
|
|
|
107
103
|
}()),
|
|
108
104
|
css: _ref3
|
|
109
105
|
}, ___EmotionJSX("header", {
|
|
110
|
-
css: /*#__PURE__*/css("padding:32px;border-bottom:1px solid ", theme.palette.gray[200], ";" + (process.env.NODE_ENV === "production" ? "" : ";label:SurveyForm;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tYXRzdXJpLXVpL1N1cnZleUZvcm0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdJc0IiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL21hdHN1cmktdWkvU3VydmV5Rm9ybS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBCdXR0b24sXG4gIE92ZXJsYXksXG4gIFBhcGVyLFxuICBQb3J0YWwsXG4gIFR5cG9ncmFwaHksXG4gIFVzZXJUZXh0UmVuZGVyZXIsXG4gIFZpc3VhbGx5SGlkZGVuLFxuICB1c2VBbGVydCxcbiAgdXNlVGhlbWUsXG59IGZyb20gXCJtYXRzdXJpLXVpXCI7XG5pbXBvcnQge1xuICBNYXRzdXJpRm9ybXNRdWVzdGlvbixcbiAgTWF0c3VyaUZvcm1zUXVlc3Rpb25Qcm92aWRlcixcbiAgdXNlTWF0c3VyaUZvcm1zLFxufSBmcm9tIFwiLi4vXCI7XG5pbXBvcnQgeyBNdWx0aXBsZVRleHRRdWVzdGlvbiB9IGZyb20gXCIuL011bHRpcGxlVGV4dFF1ZXN0aW9uXCI7XG5pbXBvcnQgeyBTZWxlY3RRdWVzdGlvbiB9IGZyb20gXCIuL1NlbGVjdFF1ZXN0aW9uXCI7XG5pbXBvcnQgeyBUZXh0UXVlc3Rpb24gfSBmcm9tIFwiLi9UZXh0UXVlc3Rpb25cIjtcbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN1cnZleUZvcm1Qcm9wcyB7XG4gIG9wZW4/OiBib29sZWFuO1xuICBvblN1Ym1pdD86ICgpID0+IHZvaWQ7XG4gIG9uQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICAvLyBQcm9wcyBmb3IgdXNlTWF0c3VyaUZvcm1zXG4gIGZvcm1JZD86IHN0cmluZztcbiAgLyoqXG4gICAqIOmWi+eZuueSsOWig+OBrkFQSeOCkuS9v+eUqOOBmeOCi+OBi+OBqeOBhuOBi+OCkuaMh+WumuOBl+OBvuOBmeOAglxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgZGV2PzogYm9vbGVhbjtcbiAgLy8gUHJvcHMgZm9yIEFsZXJ0XG4gIC8qKlxuICAgKiDlm57nrZTjga7pgIHkv6HjgavmiJDlip/jgZfjgZ/pmpvjgavooajnpLrjgZnjgovjg6Hjg4Pjgrvjg7zjgrjjgpLmjIflrprjgZfjgb7jgZnjgIJcbiAgICogQGRlZmF1bHQgXCLjgZTlm57nrZTjgYLjgorjgYzjgajjgYbjgZTjgZbjgYTjgb7jgZnjgIJcIlxuICAgKi9cbiAgc3VjY2Vzc01lc3NhZ2U/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiDlm57nrZTjga7pgIHkv6HjgavmiJDlip/jgZfjgZ/loLTlkIjjgavjgIHmiJDlip/jg6Hjg4Pjgrvjg7zjgrjjgpLnhKHoppbjgZnjgovjgYvjganjgYbjgYvjgpLmjIflrprjgZfjgb7jgZnjgIJcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIGlnbm9yZVN1Y2Nlc3NNZXNzYWdlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIOaMh+WumuOBl+OBn0lE44GuUXVlc2l0b27jga7jg6zjg7Pjg4Djg6rjg7PjgrDjgpJIaWRkZW4gaW5wdXTjgavjgZfjgb7jgZnjgIJcbiAgICovXG4gIGhpZGRlblF1ZXN0aW9uSWRzPzogc3RyaW5nW107XG4gIC8qKlxuICAgKiDmjIflrprjgZfjgZ9JROOBrlF1ZXN0aW9u44Gr5Yid5pyf5YCk44KS5LiO44GI44G+44GZ44CCXG4gICAqL1xuICBkZWZhdWx0VmFsdWVzPzogUmVjb3JkPHN0cmluZywgc3RyaW5nIHwgc3RyaW5nW10+
|
|
106
|
+
css: /*#__PURE__*/css("padding:32px;border-bottom:1px solid ", theme.palette.gray[200], ";" + (process.env.NODE_ENV === "production" ? "" : ";label:SurveyForm;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/matsuri-ui/SurveyForm.tsx"],"names":[],"mappings":"AAgIsB","file":"../../../src/matsuri-ui/SurveyForm.tsx","sourcesContent":["import {\n  Button,\n  Overlay,\n  Paper,\n  Portal,\n  Typography,\n  UserTextRenderer,\n  VisuallyHidden,\n  useAlert,\n  useTheme,\n} from \"matsuri-ui\";\nimport {\n  MatsuriFormsQuestion,\n  MatsuriFormsQuestionProvider,\n  useMatsuriForms,\n} from \"../\";\nimport { MultipleTextQuestion } from \"./MultipleTextQuestion\";\nimport { SelectQuestion } from \"./SelectQuestion\";\nimport { TextQuestion } from \"./TextQuestion\";\nimport { css } from \"@emotion/react\";\n\nexport interface SurveyFormProps {\n  open?: boolean;\n  onSubmit?: () => void;\n  onClose?: () => void;\n  // Props for useMatsuriForms\n  formId?: string;\n  /**\n   * 開発環境のAPIを使用するかどうかを指定します。\n   * @default false\n   */\n  dev?: boolean;\n  // Props for Alert\n  /**\n   * 回答の送信に成功した際に表示するメッセージを指定します。\n   * @default \"ご回答ありがとうございます。\"\n   */\n  successMessage?: string;\n  /**\n   * 回答の送信に成功した場合に、成功メッセージを無視するかどうかを指定します。\n   * @default false\n   */\n  ignoreSuccessMessage?: boolean;\n  /**\n   * 指定したIDのQuesitonのレンダリングをHidden inputにします。\n   */\n  hiddenQuestionIds?: string[];\n  /**\n   * 指定したIDのQuestionに初期値を与えます。\n   */\n  defaultValues?: Record<string, string | string[]>;\n}\n\nexport const SurveyForm = (props: SurveyFormProps) => {\n  const formId = props.formId;\n  if (formId === undefined) {\n    throw new Error(\"formId is required\");\n  }\n\n  const {\n    questions,\n    title,\n    description,\n    submit,\n    errors,\n    validate,\n    isSubmitting,\n  } = useMatsuriForms(formId, {\n    dev: props.dev ?? false,\n  });\n\n  const { throwAlert } = useAlert();\n  const theme = useTheme();\n\n  return (\n    <Portal>\n      <Overlay\n        open={props.open}\n        disableAnimation\n        fullScreen\n        onClose={props.onClose}\n      >\n        <Paper\n          css={css`\n            display: grid;\n            max-width: 720px;\n            max-height: 90vh;\n            margin: 0px auto;\n            overflow: hidden;\n            opacity: 1;\n            transition: opacity 0.2s ease-in;\n            @starting-style {\n              opacity: 0;\n            }\n          `}\n        >\n          <form\n            onSubmit={async (event) => {\n              event.preventDefault();\n\n              const { errors } = validate(event.currentTarget);\n\n              if (errors) {\n                return;\n              }\n\n              const { error } = await submit(event.currentTarget);\n\n              throwAlert(error, {\n                errorMessage: {\n                  reason: \"サーバー側のエラーの可能性があります。\",\n                  action:\n                    \"しばらく時間を空けて試すか、開発チームへお問い合わせください。\",\n                  happend: \"回答の送信に失敗しました。\",\n                },\n                successMessage:\n                  props.successMessage ?? \"ご回答ありがとうございます。\",\n                ignoreSuccess: props.ignoreSuccessMessage ?? false,\n                onSuccess: () => {\n                  props.onSubmit?.();\n                },\n              });\n            }}\n            css={css`\n              display: contents;\n            `}\n          >\n            <header\n              css={css`\n                padding: 32px;\n                border-bottom: 1px solid ${theme.palette.gray[200]};\n              `}\n            >\n              <Typography variant=\"h2\">{title}</Typography>\n            </header>\n            <div\n              css={css`\n                position: relative;\n                display: grid;\n                gap: 40px;\n                padding: 20px 32px 40px;\n                overflow-y: auto;\n              `}\n            >\n              {description !== undefined ? (\n                <Typography>\n                  <UserTextRenderer>{description}</UserTextRenderer>\n                </Typography>\n              ) : null}\n              <MatsuriFormsQuestionProvider\n                renderSelect={SelectQuestion}\n                renderMultilineText={MultipleTextQuestion}\n                renderText={TextQuestion}\n              >\n                {questions.map((question) => {\n                  const questionElement = (\n                    <MatsuriFormsQuestion\n                      defaultValue={props.defaultValues?.[question.id]}\n                      error={errors[question.id]}\n                      {...question}\n                      key={question.id}\n                    />\n                  );\n\n                  // quetion.isHiddenがfalseであっても、hiddenQuestionIdsに含まれている場合は非表示にする\n                  const hidden =\n                    question.isHidden === true\n                      ? true\n                      : (props.hiddenQuestionIds?.includes(question.id) ??\n                        false);\n                  return hidden ? (\n                    <VisuallyHidden key={question.id}>\n                      {questionElement}\n                    </VisuallyHidden>\n                  ) : (\n                    questionElement\n                  );\n                })}\n              </MatsuriFormsQuestionProvider>\n              <Button\n                css={css`\n                  margin-top: 32px;\n                `}\n                variant=\"filled\"\n                disabled={isSubmitting}\n                color=\"primary\"\n              >\n                送信する\n              </Button>\n            </div>\n          </form>\n        </Paper>\n      </Overlay>\n    </Portal>\n  );\n};\n"]} */")
|
|
111
107
|
}, ___EmotionJSX(Typography, {
|
|
112
108
|
variant: "h2"
|
|
113
109
|
}, title)), ___EmotionJSX("div", {
|
|
114
110
|
css: _ref2
|
|
115
|
-
}, description ? ___EmotionJSX(Typography, null, ___EmotionJSX(UserTextRenderer, null, description)) : null, ___EmotionJSX(MatsuriFormsQuestionProvider, {
|
|
111
|
+
}, description !== undefined ? ___EmotionJSX(Typography, null, ___EmotionJSX(UserTextRenderer, null, description)) : null, ___EmotionJSX(MatsuriFormsQuestionProvider, {
|
|
116
112
|
renderSelect: SelectQuestion,
|
|
117
113
|
renderMultilineText: MultipleTextQuestion,
|
|
118
114
|
renderText: TextQuestion
|
|
119
115
|
}, questions.map(question => {
|
|
120
|
-
var _props$defaultValues, _props$hiddenQuestion;
|
|
116
|
+
var _props$defaultValues, _props$hiddenQuestion, _props$hiddenQuestion2;
|
|
121
117
|
var questionElement = ___EmotionJSX(MatsuriFormsQuestion, _extends({
|
|
122
118
|
defaultValue: (_props$defaultValues = props.defaultValues) === null || _props$defaultValues === void 0 ? void 0 : _props$defaultValues[question.id],
|
|
123
119
|
error: errors[question.id]
|
|
@@ -126,7 +122,7 @@ export var SurveyForm = props => {
|
|
|
126
122
|
}));
|
|
127
123
|
|
|
128
124
|
// quetion.isHiddenがfalseであっても、hiddenQuestionIdsに含まれている場合は非表示にする
|
|
129
|
-
var hidden = question.isHidden === true ? true : (_props$hiddenQuestion = props.hiddenQuestionIds) === null || _props$
|
|
125
|
+
var hidden = question.isHidden === true ? true : (_props$hiddenQuestion = (_props$hiddenQuestion2 = props.hiddenQuestionIds) === null || _props$hiddenQuestion2 === void 0 ? void 0 : _props$hiddenQuestion2.includes(question.id)) !== null && _props$hiddenQuestion !== void 0 ? _props$hiddenQuestion : false;
|
|
130
126
|
return hidden ? ___EmotionJSX(VisuallyHidden, {
|
|
131
127
|
key: question.id
|
|
132
128
|
}, questionElement) : questionElement;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SurveyForm.js","names":["Button","Overlay","Paper","Portal","Typography","UserTextRenderer","VisuallyHidden","useAlert","useTheme","MatsuriFormsQuestion","MatsuriFormsQuestionProvider","useMatsuriForms","MultipleTextQuestion","SelectQuestion","TextQuestion","css","jsx","___EmotionJSX","_ref","process","env","NODE_ENV","name","styles","map","toString","_EMOTION_STRINGIFIED_CSS_ERROR__","_ref2","_ref3","_ref4","SurveyForm","props","_props$dev","formId","Error","questions","title","description","submit","errors","validate","isSubmitting","dev","throwAlert","theme","open","disableAnimation","fullScreen","onClose","onSubmit","_ref5","_asyncToGenerator","event","_props$successMessage","_props$ignoreSuccessM","preventDefault","currentTarget","error","errorMessage","reason","action","happend","successMessage","ignoreSuccess","ignoreSuccessMessage","onSuccess","_props$onSubmit","call","_x","apply","arguments","palette","gray","variant","renderSelect","renderMultilineText","renderText","question","_props$defaultValues","_props$hiddenQuestion","questionElement","_extends","defaultValue","defaultValues","id","key","hidden","isHidden","hiddenQuestionIds","includes","disabled","color"],"sources":["../../../src/matsuri-ui/SurveyForm.tsx"],"sourcesContent":["import {\n Button,\n Overlay,\n Paper,\n Portal,\n Typography,\n UserTextRenderer,\n VisuallyHidden,\n useAlert,\n useTheme,\n} from \"matsuri-ui\";\nimport {\n MatsuriFormsQuestion,\n MatsuriFormsQuestionProvider,\n useMatsuriForms,\n} from \"../\";\nimport { MultipleTextQuestion } from \"./MultipleTextQuestion\";\nimport { SelectQuestion } from \"./SelectQuestion\";\nimport { TextQuestion } from \"./TextQuestion\";\nimport { css } from \"@emotion/react\";\n\nexport interface SurveyFormProps {\n open?: boolean;\n onSubmit?: () => void;\n onClose?: () => void;\n // Props for useMatsuriForms\n formId?: string;\n /**\n * 開発環境のAPIを使用するかどうかを指定します。\n * @default false\n */\n dev?: boolean;\n // Props for Alert\n /**\n * 回答の送信に成功した際に表示するメッセージを指定します。\n * @default \"ご回答ありがとうございます。\"\n */\n successMessage?: string;\n /**\n * 回答の送信に成功した場合に、成功メッセージを無視するかどうかを指定します。\n * @default false\n */\n ignoreSuccessMessage?: boolean;\n /**\n * 指定したIDのQuesitonのレンダリングをHidden inputにします。\n */\n hiddenQuestionIds?: string[];\n /**\n * 指定したIDのQuestionに初期値を与えます。\n */\n defaultValues?: Record<string, string | string[]>;\n}\n\nexport const SurveyForm = (props: SurveyFormProps) => {\n const formId = props.formId;\n if (!formId) {\n throw new Error(\"formId is required\");\n }\n\n const {\n questions,\n title,\n description,\n submit,\n errors,\n validate,\n isSubmitting,\n } = useMatsuriForms(formId, {\n dev: props.dev ?? false,\n });\n\n const { throwAlert } = useAlert();\n const theme = useTheme();\n\n return (\n <Portal>\n <Overlay\n open={props.open}\n disableAnimation\n fullScreen\n onClose={props.onClose}\n >\n <Paper\n css={css`\n display: grid;\n max-width: 720px;\n max-height: 90vh;\n margin: 0px auto;\n overflow: hidden;\n opacity: 1;\n transition: opacity 0.2s ease-in;\n @starting-style {\n opacity: 0;\n }\n `}\n >\n <form\n onSubmit={async (event) => {\n event.preventDefault();\n\n const { errors } = validate(event.currentTarget);\n\n if (errors) {\n return;\n }\n\n const { error } = await submit(event.currentTarget);\n\n throwAlert(error, {\n errorMessage: {\n reason: \"サーバー側のエラーの可能性があります。\",\n action:\n \"しばらく時間を空けて試すか、開発チームへお問い合わせください。\",\n happend: \"回答の送信に失敗しました。\",\n },\n successMessage:\n props.successMessage ?? \"ご回答ありがとうございます。\",\n ignoreSuccess: props.ignoreSuccessMessage ?? false,\n onSuccess: () => {\n props.onSubmit?.();\n },\n });\n }}\n css={css`\n display: contents;\n `}\n >\n <header\n css={css`\n padding: 32px;\n border-bottom: 1px solid ${theme.palette.gray[200]};\n `}\n >\n <Typography variant=\"h2\">{title}</Typography>\n </header>\n <div\n css={css`\n position: relative;\n display: grid;\n gap: 40px;\n padding: 20px 32px 40px;\n overflow-y: auto;\n `}\n >\n {description ? (\n <Typography>\n <UserTextRenderer>{description}</UserTextRenderer>\n </Typography>\n ) : null}\n <MatsuriFormsQuestionProvider\n renderSelect={SelectQuestion}\n renderMultilineText={MultipleTextQuestion}\n renderText={TextQuestion}\n >\n {questions.map((question) => {\n const questionElement = (\n <MatsuriFormsQuestion\n defaultValue={props.defaultValues?.[question.id]}\n error={errors[question.id]}\n {...question}\n key={question.id}\n />\n );\n\n // quetion.isHiddenがfalseであっても、hiddenQuestionIdsに含まれている場合は非表示にする\n const hidden =\n question.isHidden === true\n ? true\n : props.hiddenQuestionIds?.includes(question.id);\n return hidden ? (\n <VisuallyHidden key={question.id}>\n {questionElement}\n </VisuallyHidden>\n ) : (\n questionElement\n );\n })}\n </MatsuriFormsQuestionProvider>\n <Button\n css={css`\n margin-top: 32px;\n `}\n variant=\"filled\"\n disabled={isSubmitting}\n color=\"primary\"\n >\n 送信する\n </Button>\n </div>\n </form>\n </Paper>\n </Overlay>\n </Portal>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"SurveyForm.js","names":["Button","Overlay","Paper","Portal","Typography","UserTextRenderer","VisuallyHidden","useAlert","useTheme","MatsuriFormsQuestion","MatsuriFormsQuestionProvider","useMatsuriForms","MultipleTextQuestion","SelectQuestion","TextQuestion","css","jsx","___EmotionJSX","_ref","process","env","NODE_ENV","name","styles","toString","_EMOTION_STRINGIFIED_CSS_ERROR__","_ref2","_ref3","_ref4","SurveyForm","props","_props$dev","formId","undefined","Error","questions","title","description","submit","errors","validate","isSubmitting","dev","throwAlert","theme","open","disableAnimation","fullScreen","onClose","onSubmit","_ref5","_asyncToGenerator","event","_props$successMessage","_props$ignoreSuccessM","preventDefault","currentTarget","error","errorMessage","reason","action","happend","successMessage","ignoreSuccess","ignoreSuccessMessage","onSuccess","_props$onSubmit","call","_x","apply","arguments","palette","gray","variant","renderSelect","renderMultilineText","renderText","map","question","_props$defaultValues","_props$hiddenQuestion","_props$hiddenQuestion2","questionElement","_extends","defaultValue","defaultValues","id","key","hidden","isHidden","hiddenQuestionIds","includes","disabled","color"],"sources":["../../../src/matsuri-ui/SurveyForm.tsx"],"sourcesContent":["import {\n Button,\n Overlay,\n Paper,\n Portal,\n Typography,\n UserTextRenderer,\n VisuallyHidden,\n useAlert,\n useTheme,\n} from \"matsuri-ui\";\nimport {\n MatsuriFormsQuestion,\n MatsuriFormsQuestionProvider,\n useMatsuriForms,\n} from \"../\";\nimport { MultipleTextQuestion } from \"./MultipleTextQuestion\";\nimport { SelectQuestion } from \"./SelectQuestion\";\nimport { TextQuestion } from \"./TextQuestion\";\nimport { css } from \"@emotion/react\";\n\nexport interface SurveyFormProps {\n open?: boolean;\n onSubmit?: () => void;\n onClose?: () => void;\n // Props for useMatsuriForms\n formId?: string;\n /**\n * 開発環境のAPIを使用するかどうかを指定します。\n * @default false\n */\n dev?: boolean;\n // Props for Alert\n /**\n * 回答の送信に成功した際に表示するメッセージを指定します。\n * @default \"ご回答ありがとうございます。\"\n */\n successMessage?: string;\n /**\n * 回答の送信に成功した場合に、成功メッセージを無視するかどうかを指定します。\n * @default false\n */\n ignoreSuccessMessage?: boolean;\n /**\n * 指定したIDのQuesitonのレンダリングをHidden inputにします。\n */\n hiddenQuestionIds?: string[];\n /**\n * 指定したIDのQuestionに初期値を与えます。\n */\n defaultValues?: Record<string, string | string[]>;\n}\n\nexport const SurveyForm = (props: SurveyFormProps) => {\n const formId = props.formId;\n if (formId === undefined) {\n throw new Error(\"formId is required\");\n }\n\n const {\n questions,\n title,\n description,\n submit,\n errors,\n validate,\n isSubmitting,\n } = useMatsuriForms(formId, {\n dev: props.dev ?? false,\n });\n\n const { throwAlert } = useAlert();\n const theme = useTheme();\n\n return (\n <Portal>\n <Overlay\n open={props.open}\n disableAnimation\n fullScreen\n onClose={props.onClose}\n >\n <Paper\n css={css`\n display: grid;\n max-width: 720px;\n max-height: 90vh;\n margin: 0px auto;\n overflow: hidden;\n opacity: 1;\n transition: opacity 0.2s ease-in;\n @starting-style {\n opacity: 0;\n }\n `}\n >\n <form\n onSubmit={async (event) => {\n event.preventDefault();\n\n const { errors } = validate(event.currentTarget);\n\n if (errors) {\n return;\n }\n\n const { error } = await submit(event.currentTarget);\n\n throwAlert(error, {\n errorMessage: {\n reason: \"サーバー側のエラーの可能性があります。\",\n action:\n \"しばらく時間を空けて試すか、開発チームへお問い合わせください。\",\n happend: \"回答の送信に失敗しました。\",\n },\n successMessage:\n props.successMessage ?? \"ご回答ありがとうございます。\",\n ignoreSuccess: props.ignoreSuccessMessage ?? false,\n onSuccess: () => {\n props.onSubmit?.();\n },\n });\n }}\n css={css`\n display: contents;\n `}\n >\n <header\n css={css`\n padding: 32px;\n border-bottom: 1px solid ${theme.palette.gray[200]};\n `}\n >\n <Typography variant=\"h2\">{title}</Typography>\n </header>\n <div\n css={css`\n position: relative;\n display: grid;\n gap: 40px;\n padding: 20px 32px 40px;\n overflow-y: auto;\n `}\n >\n {description !== undefined ? (\n <Typography>\n <UserTextRenderer>{description}</UserTextRenderer>\n </Typography>\n ) : null}\n <MatsuriFormsQuestionProvider\n renderSelect={SelectQuestion}\n renderMultilineText={MultipleTextQuestion}\n renderText={TextQuestion}\n >\n {questions.map((question) => {\n const questionElement = (\n <MatsuriFormsQuestion\n defaultValue={props.defaultValues?.[question.id]}\n error={errors[question.id]}\n {...question}\n key={question.id}\n />\n );\n\n // quetion.isHiddenがfalseであっても、hiddenQuestionIdsに含まれている場合は非表示にする\n const hidden =\n question.isHidden === true\n ? true\n : (props.hiddenQuestionIds?.includes(question.id) ??\n false);\n return hidden ? (\n <VisuallyHidden key={question.id}>\n {questionElement}\n </VisuallyHidden>\n ) : (\n questionElement\n );\n })}\n </MatsuriFormsQuestionProvider>\n <Button\n css={css`\n margin-top: 32px;\n `}\n variant=\"filled\"\n disabled={isSubmitting}\n color=\"primary\"\n >\n 送信する\n </Button>\n </div>\n </form>\n </Paper>\n </Overlay>\n </Portal>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -14,9 +14,12 @@ export var SurveyFormProvider = _ref => {
|
|
|
14
14
|
setFormProps
|
|
15
15
|
};
|
|
16
16
|
}, []);
|
|
17
|
+
var {
|
|
18
|
+
open = false
|
|
19
|
+
} = formProps;
|
|
17
20
|
return ___EmotionJSX(SurveyFormContext.Provider, {
|
|
18
21
|
value: contextValue
|
|
19
|
-
}, children,
|
|
22
|
+
}, children, open ? ___EmotionJSX(SurveyForm, formProps) : null);
|
|
20
23
|
};
|
|
21
24
|
export var useSurveyFormContext = () => {
|
|
22
25
|
var context = useContext(SurveyFormContext);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SurveyFormProvider.js","names":["SurveyForm","createContext","useContext","useMemo","useState","jsx","___EmotionJSX","SurveyFormContext","SurveyFormProvider","_ref","children","formProps","setFormProps","open","contextValue","Provider","value","useSurveyFormContext","context","Error"],"sources":["../../../src/matsuri-ui/SurveyFormProvider.tsx"],"sourcesContent":["import { SurveyForm, SurveyFormProps } from \"./SurveyForm\";\nimport { createContext, useContext, useMemo, useState } from \"react\";\n\nexport const SurveyFormContext = createContext<{\n setFormProps: (props: SurveyFormProps) => void;\n} | null>(null);\n\nexport const SurveyFormProvider = ({ children }: React.PropsWithChildren) => {\n const [formProps, setFormProps] = useState<SurveyFormProps>({\n open: false,\n });\n const contextValue = useMemo(() => {\n return {\n setFormProps,\n };\n }, []);\n return (\n <SurveyFormContext.Provider value={contextValue}>\n {children}\n {
|
|
1
|
+
{"version":3,"file":"SurveyFormProvider.js","names":["SurveyForm","createContext","useContext","useMemo","useState","jsx","___EmotionJSX","SurveyFormContext","SurveyFormProvider","_ref","children","formProps","setFormProps","open","contextValue","Provider","value","useSurveyFormContext","context","Error"],"sources":["../../../src/matsuri-ui/SurveyFormProvider.tsx"],"sourcesContent":["import { SurveyForm, SurveyFormProps } from \"./SurveyForm\";\nimport { createContext, useContext, useMemo, useState } from \"react\";\n\nexport const SurveyFormContext = createContext<{\n setFormProps: (props: SurveyFormProps) => void;\n} | null>(null);\n\nexport const SurveyFormProvider = ({ children }: React.PropsWithChildren) => {\n const [formProps, setFormProps] = useState<SurveyFormProps>({\n open: false,\n });\n const contextValue = useMemo(() => {\n return {\n setFormProps,\n };\n }, []);\n const { open = false } = formProps;\n return (\n <SurveyFormContext.Provider value={contextValue}>\n {children}\n {open ? <SurveyForm {...formProps} /> : null}\n </SurveyFormContext.Provider>\n );\n};\n\nexport const useSurveyFormContext = () => {\n const context = useContext(SurveyFormContext);\n if (context === null) {\n throw new Error(\"useSurveyForm must be used within a SurveyFormProvider\");\n }\n return context;\n};\n"],"mappings":"AAAA,SAASA,UAAU,QAAyB,cAAc;AAC1D,SAASC,aAAa,EAAEC,UAAU,EAAEC,OAAO,EAAEC,QAAQ,QAAQ,OAAO;AAAC,SAAAC,GAAA,IAAAC,aAAA;AAErE,OAAO,IAAMC,iBAAiB,gBAAGN,aAAa,CAEpC,IAAI,CAAC;AAEf,OAAO,IAAMO,kBAAkB,GAAGC,IAAA,IAA2C;EAAA,IAA1C;IAAEC;EAAkC,CAAC,GAAAD,IAAA;EACtE,IAAM,CAACE,SAAS,EAAEC,YAAY,CAAC,GAAGR,QAAQ,CAAkB;IAC1DS,IAAI,EAAE;EACR,CAAC,CAAC;EACF,IAAMC,YAAY,GAAGX,OAAO,CAAC,MAAM;IACjC,OAAO;MACLS;IACF,CAAC;EACH,CAAC,EAAE,EAAE,CAAC;EACN,IAAM;IAAEC,IAAI,GAAG;EAAM,CAAC,GAAGF,SAAS;EAClC,OACEL,aAAA,CAACC,iBAAiB,CAACQ,QAAQ;IAACC,KAAK,EAAEF;EAAa,GAC7CJ,QAAQ,EACRG,IAAI,GAAGP,aAAA,CAACN,UAAU,EAAKW,SAAY,CAAC,GAAG,IACd,CAAC;AAEjC,CAAC;AAED,OAAO,IAAMM,oBAAoB,GAAGA,CAAA,KAAM;EACxC,IAAMC,OAAO,GAAGhB,UAAU,CAACK,iBAAiB,CAAC;EAC7C,IAAIW,OAAO,KAAK,IAAI,EAAE;IACpB,MAAM,IAAIC,KAAK,CAAC,wDAAwD,CAAC;EAC3E;EACA,OAAOD,OAAO;AAChB,CAAC","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "matsuri-forms-sdk",
|
|
3
|
-
"version": "2.0.
|
|
3
|
+
"version": "2.0.2",
|
|
4
4
|
"sideEffects": false,
|
|
5
5
|
"main": "./index.js",
|
|
6
6
|
"types": "./index.d.ts",
|
|
@@ -20,22 +20,22 @@
|
|
|
20
20
|
},
|
|
21
21
|
"peerDependencies": {
|
|
22
22
|
"matsuri-hooks": "^3.0.0 || ^4.0.0",
|
|
23
|
-
"react": "^18.0.0",
|
|
23
|
+
"react": "^18.0.0 || ^19.0.0",
|
|
24
24
|
"swr": "^2.0.0"
|
|
25
25
|
},
|
|
26
26
|
"devDependencies": {
|
|
27
|
-
"@babel/cli": "7.
|
|
28
|
-
"@babel/core": "7.
|
|
27
|
+
"@babel/cli": "7.27.2",
|
|
28
|
+
"@babel/core": "7.27.7",
|
|
29
29
|
"@babel/plugin-proposal-class-properties": "7.18.6",
|
|
30
|
-
"@babel/plugin-proposal-decorators": "7.
|
|
31
|
-
"@babel/preset-env": "7.
|
|
32
|
-
"@babel/preset-react": "7.
|
|
33
|
-
"@babel/preset-typescript": "7.
|
|
30
|
+
"@babel/plugin-proposal-decorators": "7.27.1",
|
|
31
|
+
"@babel/preset-env": "7.27.2",
|
|
32
|
+
"@babel/preset-react": "7.27.1",
|
|
33
|
+
"@babel/preset-typescript": "7.27.1",
|
|
34
34
|
"@emotion/babel-preset-css-prop": "11.12.0",
|
|
35
|
-
"@types/react": "
|
|
36
|
-
"@types/react-dom": "
|
|
37
|
-
"concurrently": "
|
|
38
|
-
"swr": "2.
|
|
39
|
-
"typescript": "5.
|
|
35
|
+
"@types/react": "19.1.8",
|
|
36
|
+
"@types/react-dom": "19.1.6",
|
|
37
|
+
"concurrently": "9.2.0",
|
|
38
|
+
"swr": "2.3.3",
|
|
39
|
+
"typescript": "5.8.3"
|
|
40
40
|
}
|
|
41
41
|
}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { MatsuriFormsMultilineTextQuestionProps, MatsuriFormsSelectQuestionProps, MatsuriFormsTextQuestionProps } from "./MatsuriFormsQuestionProvider";
|
|
2
2
|
export type MatsuriFormsQuestionProps = MatsuriFormsTextQuestionProps | MatsuriFormsMultilineTextQuestionProps | MatsuriFormsSelectQuestionProps;
|
|
3
|
-
export declare const MatsuriFormsQuestion: <T extends MatsuriFormsQuestionProps>(props: T) => JSX.Element;
|
|
3
|
+
export declare const MatsuriFormsQuestion: <T extends MatsuriFormsQuestionProps>(props: T) => import("react").JSX.Element;
|
|
@@ -14,9 +14,9 @@ export interface MatsuriFormsTextQuestionProps extends ParsedTextQuestion, Matsu
|
|
|
14
14
|
export interface MatsuriFormsMultilineTextQuestionProps extends ParsedMultilineTextQuestion, MatsuriFormsQuestionCommonProps {
|
|
15
15
|
}
|
|
16
16
|
interface MatsuriFormsQuestionContextValue {
|
|
17
|
-
renderMultilineText?: (props: MatsuriFormsMultilineTextQuestionProps) => JSX.Element;
|
|
18
|
-
renderText?: (props: MatsuriFormsTextQuestionProps) => JSX.Element;
|
|
19
|
-
renderSelect?: (props: MatsuriFormsSelectQuestionProps) => JSX.Element;
|
|
17
|
+
renderMultilineText?: (props: MatsuriFormsMultilineTextQuestionProps) => React.JSX.Element;
|
|
18
|
+
renderText?: (props: MatsuriFormsTextQuestionProps) => React.JSX.Element;
|
|
19
|
+
renderSelect?: (props: MatsuriFormsSelectQuestionProps) => React.JSX.Element;
|
|
20
20
|
}
|
|
21
21
|
export declare const MatsuriFormsQuestionContext: React.Context<MatsuriFormsQuestionContextValue | null>;
|
|
22
22
|
interface MatsuriFormsQuestionProviderProps extends MatsuriFormsQuestionContextValue {
|
package/useMatsuriForms.js
CHANGED
|
@@ -5,8 +5,12 @@ import { getForm, submissionCreate } from "./endpoints";
|
|
|
5
5
|
import { isQuestionType } from "./model/question";
|
|
6
6
|
import { parseQuestion } from "./model/parsedQuestion";
|
|
7
7
|
import { useCallback, useMemo, useState } from "react";
|
|
8
|
-
export var useMatsuriForms = (formId
|
|
9
|
-
var
|
|
8
|
+
export var useMatsuriForms = function useMatsuriForms(formId) {
|
|
9
|
+
var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
10
|
+
var {
|
|
11
|
+
dev = false
|
|
12
|
+
} = options;
|
|
13
|
+
var environment = dev ? "development" : "production";
|
|
10
14
|
var [isSubmitting, setIsSubmitting] = useState(false);
|
|
11
15
|
var {
|
|
12
16
|
data
|
|
@@ -41,7 +45,7 @@ export var useMatsuriForms = (formId, options) => {
|
|
|
41
45
|
if (_options.find(option => option.value === value)) {
|
|
42
46
|
return value;
|
|
43
47
|
} else {
|
|
44
|
-
return
|
|
48
|
+
return "".concat(otherValuePrefix).concat(typeof value === "object" ? JSON.stringify(value) : String(value));
|
|
45
49
|
}
|
|
46
50
|
}) : _values
|
|
47
51
|
};
|
|
@@ -62,7 +66,7 @@ export var useMatsuriForms = (formId, options) => {
|
|
|
62
66
|
* 回答を編集して送信したい場合にgetSubmissionValuesと合わせて利用する。
|
|
63
67
|
* それ以外の場合は、submitを利用した方が良い。
|
|
64
68
|
*/
|
|
65
|
-
var sendSubmission = useCallback(
|
|
69
|
+
var sendSubmission = useCallback(/*#__PURE__*/function () {
|
|
66
70
|
var _ref = _asyncToGenerator(function* (values) {
|
|
67
71
|
setIsSubmitting(true);
|
|
68
72
|
var {
|
|
@@ -89,7 +93,7 @@ export var useMatsuriForms = (formId, options) => {
|
|
|
89
93
|
* Form要素からMatsuriFormsValue[]を取得し、回答を送信する
|
|
90
94
|
* = getSubmissionValues + sendSubmission
|
|
91
95
|
*/
|
|
92
|
-
var submit = useCallback(
|
|
96
|
+
var submit = useCallback(/*#__PURE__*/function () {
|
|
93
97
|
var _ref2 = _asyncToGenerator(function* (form) {
|
|
94
98
|
var values = getSubmissionValues(form);
|
|
95
99
|
return sendSubmission(values);
|
package/useMatsuriForms.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useMatsuriForms.js","names":["fetcher","useFetch","getForm","submissionCreate","isQuestionType","parseQuestion","useCallback","useMemo","useState","useMatsuriForms","formId","options","environment","dev","isSubmitting","setIsSubmitting","data","method","parsedQuestions","_data$content$questio","content","questions","map","question","getSubmissionValues","form","formData","FormData","values","value","otherOption","otherValuePrefix","select","getAll","id","questionId","find","option","join","_formData$get","get","sendSubmission","_ref","_asyncToGenerator","error","body","JSON","stringify","revision","_x","apply","arguments","submit","_ref2","_x2","errors","setErrors","validate","forEach","required","length","code","message","maxAnswer","Object","keys","undefined","title","description"],"sources":["../../src/useMatsuriForms.tsx"],"sourcesContent":["import { FormDetail } from \"./model/form\";\nimport { MatsuriFormsQuestionError } from \"./MatsuriFormsQuestionProvider\";\nimport { fetcher, useFetch } from \"matsuri-hooks\";\nimport { getForm, submissionCreate } from \"./endpoints\";\nimport { isQuestionType } from \"./model/question\";\nimport { parseQuestion } from \"./model/parsedQuestion\";\nimport { useCallback, useMemo, useState } from \"react\";\n\nexport type MatsuriFormsQuestionErrorMap = Record<\n string,\n MatsuriFormsQuestionError\n>;\n\nexport interface UseMatsuriFormsOptions {\n /**\n * これをtrueにすると、開発環境のフォームを取得します。\n * 開発環境は、私たちのみが利用するため、デフォルトではfalseになっています。\n *\n * @default false\n */\n dev?: boolean;\n}\n\nexport interface MatsuriFormsSubmissionValue {\n questionId: string;\n value: FormDataEntryValue | FormDataEntryValue[];\n}\n\nexport const useMatsuriForms = (\n formId: string,\n options?: UseMatsuriFormsOptions,\n) => {\n const environment = options?.dev ? \"development\" : \"production\";\n\n const [isSubmitting, setIsSubmitting] = useState(false);\n\n const { data } = useFetch<FormDetail>(getForm(formId, environment), {\n method: getForm.method,\n });\n\n const parsedQuestions = useMemo(() => {\n return (\n data?.content.questions.map((question) => {\n return parseQuestion(question);\n }) ?? []\n );\n }, [data?.content.questions]);\n\n /**\n * Form要素からMatsuriFormsValue[]を取得する\n * 回答を編集して送信したい場合にsendSubmissionと合わせて利用する。\n * それ以外の場合は、submitを利用した方が良い。\n */\n const getSubmissionValues = useCallback(\n (form: HTMLFormElement): MatsuriFormsSubmissionValue[] => {\n const formData = new FormData(form);\n\n const values = data?.content.questions.map((question) => {\n if (isQuestionType(question.value, \"select\")) {\n const { otherOption, options, otherValuePrefix } =\n question.value.select;\n const values = formData.getAll(question.id);\n return {\n questionId: question.id,\n value: otherOption\n ? values.map((value) => {\n if (options.find((option) => option.value === value)) {\n return value;\n } else {\n return [otherValuePrefix, value].join(\"\");\n }\n })\n : values,\n };\n } else {\n const value = formData.get(question.id) ?? \"\";\n return {\n questionId: question.id,\n value,\n };\n }\n });\n return values ?? [];\n },\n [data?.content.questions],\n );\n\n /**\n * MasuriFormsValues[]を受け取り回答を送信する。\n * 回答を編集して送信したい場合にgetSubmissionValuesと合わせて利用する。\n * それ以外の場合は、submitを利用した方が良い。\n */\n const sendSubmission = useCallback(\n async (\n values: MatsuriFormsSubmissionValue[],\n ): Promise<{ error?: Error }> => {\n setIsSubmitting(true);\n const { error } = await fetcher(submissionCreate(environment), {\n method: submissionCreate.method,\n body: JSON.stringify({\n formId: data?.content.formId,\n revision: data?.content.revision,\n values,\n }),\n });\n setIsSubmitting(false);\n return { error };\n },\n [data?.content.formId, data?.content.revision, environment],\n );\n\n /**\n * Form要素からMatsuriFormsValue[]を取得し、回答を送信する\n * = getSubmissionValues + sendSubmission\n */\n const submit = useCallback(\n async (form: HTMLFormElement): Promise<{ error?: Error }> => {\n const values = getSubmissionValues(form);\n return sendSubmission(values);\n },\n [getSubmissionValues, sendSubmission],\n );\n\n const [errors, setErrors] = useState<MatsuriFormsQuestionErrorMap>({});\n /**\n * Form要素が責務を負えないmatsuri-forms由来のバリデーションを行う\n */\n const validate = useCallback(\n (form: HTMLFormElement) => {\n const formData = new FormData(form);\n\n const errors: MatsuriFormsQuestionErrorMap = {};\n data?.content.questions.forEach((question) => {\n if (isQuestionType(question.value, \"select\")) {\n const values = formData.getAll(question.id);\n if (question.required && values.length === 0) {\n errors[question.id] = {\n code: \"required\",\n message: \"この質問は回答が必須です。\",\n };\n return;\n }\n if (question.value.select.maxAnswer < values.length) {\n errors[question.id] = {\n code: \"too_many\",\n message: \"この質問で選択できる回答数を超えています。\",\n };\n return;\n }\n }\n });\n\n setErrors(errors);\n\n return {\n errors: Object.keys(errors).length ? errors : undefined,\n };\n },\n [data?.content.questions],\n );\n\n return {\n title: data?.form.title,\n description: data?.form.description,\n questions: parsedQuestions,\n submit,\n validate,\n errors,\n getSubmissionValues,\n sendSubmission,\n isSubmitting,\n };\n};\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"useMatsuriForms.js","names":["fetcher","useFetch","getForm","submissionCreate","isQuestionType","parseQuestion","useCallback","useMemo","useState","useMatsuriForms","formId","options","arguments","length","undefined","dev","environment","isSubmitting","setIsSubmitting","data","method","parsedQuestions","_data$content$questio","content","questions","map","question","getSubmissionValues","form","formData","FormData","values","value","otherOption","otherValuePrefix","select","getAll","id","questionId","find","option","concat","JSON","stringify","String","_formData$get","get","sendSubmission","_ref","_asyncToGenerator","error","body","revision","_x","apply","submit","_ref2","_x2","errors","setErrors","validate","forEach","required","code","message","maxAnswer","Object","keys","title","description"],"sources":["../../src/useMatsuriForms.tsx"],"sourcesContent":["import { FormDetail } from \"./model/form\";\nimport { MatsuriFormsQuestionError } from \"./MatsuriFormsQuestionProvider\";\nimport { fetcher, useFetch } from \"matsuri-hooks\";\nimport { getForm, submissionCreate } from \"./endpoints\";\nimport { isQuestionType } from \"./model/question\";\nimport { parseQuestion } from \"./model/parsedQuestion\";\nimport { useCallback, useMemo, useState } from \"react\";\n\nexport type MatsuriFormsQuestionErrorMap = Record<\n string,\n MatsuriFormsQuestionError\n>;\n\nexport interface UseMatsuriFormsOptions {\n /**\n * これをtrueにすると、開発環境のフォームを取得します。\n * 開発環境は、私たちのみが利用するため、デフォルトではfalseになっています。\n *\n * @default false\n */\n dev?: boolean;\n}\n\nexport interface MatsuriFormsSubmissionValue {\n questionId: string;\n value: FormDataEntryValue | FormDataEntryValue[];\n}\n\nexport const useMatsuriForms = (\n formId: string,\n options: UseMatsuriFormsOptions = {},\n) => {\n const { dev = false } = options;\n const environment = dev ? \"development\" : \"production\";\n\n const [isSubmitting, setIsSubmitting] = useState(false);\n\n const { data } = useFetch<FormDetail>(getForm(formId, environment), {\n method: getForm.method,\n });\n\n const parsedQuestions = useMemo(() => {\n return (\n data?.content.questions.map((question) => {\n return parseQuestion(question);\n }) ?? []\n );\n }, [data?.content.questions]);\n\n /**\n * Form要素からMatsuriFormsValue[]を取得する\n * 回答を編集して送信したい場合にsendSubmissionと合わせて利用する。\n * それ以外の場合は、submitを利用した方が良い。\n */\n const getSubmissionValues = useCallback(\n (form: HTMLFormElement): MatsuriFormsSubmissionValue[] => {\n const formData = new FormData(form);\n\n const values = data?.content.questions.map((question) => {\n if (isQuestionType(question.value, \"select\")) {\n const { otherOption, options, otherValuePrefix } =\n question.value.select;\n const values = formData.getAll(question.id);\n return {\n questionId: question.id,\n value: otherOption\n ? values.map((value) => {\n if (options.find((option) => option.value === value)) {\n return value;\n } else {\n return `${otherValuePrefix}${typeof value === \"object\" ? JSON.stringify(value) : String(value)}`;\n }\n })\n : values,\n };\n } else {\n const value = formData.get(question.id) ?? \"\";\n return {\n questionId: question.id,\n value,\n };\n }\n });\n return values ?? [];\n },\n [data?.content.questions],\n );\n\n /**\n * MasuriFormsValues[]を受け取り回答を送信する。\n * 回答を編集して送信したい場合にgetSubmissionValuesと合わせて利用する。\n * それ以外の場合は、submitを利用した方が良い。\n */\n const sendSubmission = useCallback(\n async (\n values: MatsuriFormsSubmissionValue[],\n ): Promise<{ error?: Error }> => {\n setIsSubmitting(true);\n const { error } = await fetcher(submissionCreate(environment), {\n method: submissionCreate.method,\n body: JSON.stringify({\n formId: data?.content.formId,\n revision: data?.content.revision,\n values,\n }),\n });\n setIsSubmitting(false);\n return { error };\n },\n [data?.content.formId, data?.content.revision, environment],\n );\n\n /**\n * Form要素からMatsuriFormsValue[]を取得し、回答を送信する\n * = getSubmissionValues + sendSubmission\n */\n const submit = useCallback(\n async (form: HTMLFormElement): Promise<{ error?: Error }> => {\n const values = getSubmissionValues(form);\n return sendSubmission(values);\n },\n [getSubmissionValues, sendSubmission],\n );\n\n const [errors, setErrors] = useState<MatsuriFormsQuestionErrorMap>({});\n /**\n * Form要素が責務を負えないmatsuri-forms由来のバリデーションを行う\n */\n const validate = useCallback(\n (form: HTMLFormElement) => {\n const formData = new FormData(form);\n\n const errors: MatsuriFormsQuestionErrorMap = {};\n data?.content.questions.forEach((question) => {\n if (isQuestionType(question.value, \"select\")) {\n const values = formData.getAll(question.id);\n if (question.required && values.length === 0) {\n errors[question.id] = {\n code: \"required\",\n message: \"この質問は回答が必須です。\",\n };\n return;\n }\n if (question.value.select.maxAnswer < values.length) {\n errors[question.id] = {\n code: \"too_many\",\n message: \"この質問で選択できる回答数を超えています。\",\n };\n return;\n }\n }\n });\n\n setErrors(errors);\n\n return {\n errors: Object.keys(errors).length ? errors : undefined,\n };\n },\n [data?.content.questions],\n );\n\n return {\n title: data?.form.title,\n description: data?.form.description,\n questions: parsedQuestions,\n submit,\n validate,\n errors,\n getSubmissionValues,\n sendSubmission,\n isSubmitting,\n };\n};\n"],"mappings":"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","ignoreList":[]}
|