matsuri-ui 17.0.2-alpha-1744608698998-b7ec1d2.0 → 17.0.2-alpha-1744613157347-8fe3e3d.0
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/CSVImportUI/CSVImportUI.d.ts +12 -0
- package/CSVImportUI/CSVImportUI.js.map +1 -1
- package/Tooltip/Tooltip.d.ts +7 -0
- package/Tooltip/Tooltip.js +4 -4
- package/Tooltip/Tooltip.js.map +1 -1
- package/cjs/CSVImportUI/CSVImportUI.js.map +1 -1
- package/cjs/Tooltip/Tooltip.js +4 -4
- package/cjs/Tooltip/Tooltip.js.map +1 -1
- package/esm/CSVImportUI/CSVImportUI.js.map +1 -1
- package/esm/Tooltip/Tooltip.js +4 -4
- package/esm/Tooltip/Tooltip.js.map +1 -1
- package/package.json +1 -1
- package/types/CSVImportUI/CSVImportUI.d.ts +12 -0
- package/types/Tooltip/Tooltip.d.ts +7 -0
|
@@ -43,6 +43,12 @@ export interface CSVImportUIProps<Columns extends CSVImportUIColumns, Row extend
|
|
|
43
43
|
* 行ごとにデータを処理する。
|
|
44
44
|
*
|
|
45
45
|
* onPreUploadDataが指定されている場合、こちらは無視される。
|
|
46
|
+
*
|
|
47
|
+
* この関数内でsetStateを使用すると、行ごとの処理で過剰なレンダリングを引き起こす可能性があります。
|
|
48
|
+
* 状態更新が必要な場合は、以下の方法を検討してください:
|
|
49
|
+
* - onPreUploadDataを使用して一括でデータを処理する
|
|
50
|
+
* - 複数の更新をバッチ処理して、すべての行の処理後に一度だけ状態を更新する
|
|
51
|
+
* - レンダリングを必要としない中間値にはuseRefを使用する
|
|
46
52
|
*/
|
|
47
53
|
onPreUploadDataByRow?: (args: {
|
|
48
54
|
index: number;
|
|
@@ -76,6 +82,12 @@ export interface CSVImportUIProps<Columns extends CSVImportUIColumns, Row extend
|
|
|
76
82
|
* 行ごとにデータをアップロードする。
|
|
77
83
|
*
|
|
78
84
|
* onUploadDataが指定されている場合、こちらは無視される。
|
|
85
|
+
*
|
|
86
|
+
* この関数内でsetStateを使用すると、行ごとの処理で過剰なレンダリングを引き起こす可能性があります。
|
|
87
|
+
* 状態更新が必要な場合は、以下の方法を検討してください:
|
|
88
|
+
* - onUploadDataを使用して一括でデータを処理する
|
|
89
|
+
* - 複数の更新をバッチ処理して、すべての行の処理後に一度だけ状態を更新する
|
|
90
|
+
* - レンダリングを必要としない中間値にはuseRefを使用する
|
|
79
91
|
*/
|
|
80
92
|
onUploadDataByRow?: (args: {
|
|
81
93
|
index: number;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CSVImportUI.js","names":["CompleteScreen","DownloadCreateTemplateScreen","DownloadUpdateTemplateScreen","LoadCSVScreen","ScreenProvider","useScreen","SelectModeScreen","UploadCSVScreen","useCallback","useMemo","useState","jsx","___EmotionJSX","CSVImportUIContent","_ref","columns","onDownloadCSV","searchLabel","onSearchData","renderSearchField","csvPrefix","csvParser","csvValidator","onPreUploadData","onPreUploadDataByRow","onUploadData","onUploadDataByRow","acceptMode","skipDownloadTemplate","selectDownloadTemplateColumns","defaultTemplateData","id","mode","setMode","uploadedData","setUploadedData","errors","setErrors","handleUpdateData","data","headers","_uploadedData$","rowKeys","Object","keys","values","filter","column","length","hiddenIfNoHeader","includes","label","map","filledData","_uploadedData$2","row","_extends","fromEntries","header","onChangeMode","onSearch","onUpdateData","onSubmitComplete","getFirstScreenId","accptMode","CSVImportUI","props","firstScreenId"],"sources":["../../../src/CSVImportUI/CSVImportUI.tsx"],"sourcesContent":["import { AlertMessageType } from \"../Alert\";\nimport { AssertType } from \"../@types/AssertType\";\nimport { CompleteScreen } from \"./screens/CompleteScreen\";\nimport { DownloadCreateTemplateScreen } from \"./screens/DownloadCreateTemplateScreen\";\nimport { DownloadUpdateTemplateScreen } from \"./screens/DownloadUpdateTemplateScreen\";\nimport { LoadCSVScreen } from \"./screens/LoadCSVScreen\";\nimport { ScreenId } from \"./screens/types\";\nimport { ScreenProvider, useScreen } from \"./ScreenProvider\";\nimport { SelectModeScreen } from \"./screens/SelectModeScreen\";\nimport { UnionToIntersection } from \"../@types/UnionToIntersection\";\nimport { UploadCSVScreen } from \"./screens/UploadCSVScreen\";\nimport { useCallback, useMemo, useState } from \"react\";\n\nexport type Mode = \"create\" | \"update\";\n\nexport type CellError = [string, string];\n\nexport type CSVImportUIColumn = Readonly<{\n label: string;\n description?: string;\n type?: \"date\" | \"number\";\n options?: readonly string[];\n required?: boolean;\n hiddenOnCreateTemplate?: boolean;\n /**\n * アップロードされたCSVにヘッダーがなければ表示しない。\n */\n hiddenIfNoHeader?: boolean;\n renderCell?: (props: {\n value: string;\n header: string;\n row: Record<string, string>;\n }) => React.JSX.Element;\n}>;\n\n/**\n * ライブラリ利用者用の型\n */\nexport type CSVImportUIColumns = Record<string, CSVImportUIColumn>;\n\nexport interface CSVImportUIRenderSearchFieldProps<Row> {\n onChange: (args: Row[]) => void;\n}\n\ntype OptionByLabel<Columns extends CSVImportUIColumns> = {\n [Key in keyof Columns]: Record<\n Columns[Key][\"label\"],\n Columns[Key] extends {\n options: readonly (infer Option)[];\n }\n ? Option extends string\n ? Option\n : never\n : string\n >;\n}[keyof Columns];\n\nexport type CSVImportUIRow<Columns extends CSVImportUIColumns> = AssertType<\n UnionToIntersection<OptionByLabel<Columns>>,\n Record<string, string>\n>;\n\nexport interface CSVImportUIProps<\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n> {\n /**\n * 利用できるモードを指定する。\n */\n acceptMode: Mode[];\n /**\n * アップロード画面に進む前にトリガーされる。\n * 行ごとにデータを処理する。\n *\n * onPreUploadDataが指定されている場合、こちらは無視される。\n */\n onPreUploadDataByRow?: (args: {\n index: number;\n /**\n * 欠損したフィールドがある可能性があるため、型を緩くする。\n */\n row: Partial<Row>;\n mode: Mode;\n }) => Promise<{ error?: CellError; data?: Record<string, string> }>;\n /**\n * アップロード画面に進む前にトリガーされる。\n * 一括でデータをアップロードする。\n *\n * 現状onPreUploadDataByRowByRowとは異なり、行ごとにエラーを表示することはできない。\n * 代わりに、エラー時に表示されるアラートのメッセージをerrorMessageで指定する。\n *\n * 行毎にエラーを表示したくなった場合は、要望を出すこと。\n */\n onPreUploadData?: (args: { data: Partial<Row>[]; mode: Mode }) => Promise<{\n errorMessage?: AlertMessageType;\n data?: Record<string, string>[];\n }>;\n /**\n * CSVをパースしたデータのアップロードがトリガーされた際に呼ばれる。\n * 行ごとにデータをアップロードする。\n *\n * onUploadDataが指定されている場合、こちらは無視される。\n */\n onUploadDataByRow?: (args: {\n index: number;\n /**\n * 欠損したフィールドがある可能性があるため、型を緩くする。\n */\n row: Partial<Row>;\n mode: Mode;\n }) => Promise<{\n error?: CellError;\n data?: Record<string, string>;\n }>;\n /**\n * CSVをパースしたデータのアップロードがトリガーされた際に呼ばれる。\n * 一括でデータをアップロードする。\n *\n * 現状onUploadDataByRowとは異なり、行ごとにエラーを表示することはできない。\n * 代わりに、エラー時に表示されるアラートのメッセージをerrorMessageで指定する。\n *\n * 行毎にエラーを表示したくなった場合は、要望を出すこと。\n */\n onUploadData?: (args: { data: Partial<Row>[]; mode: Mode }) => Promise<{\n errorMessage?: AlertMessageType;\n data?: Record<string, string>[];\n }>;\n /**\n * 検索フォームのラベルとして利用される。\n * (only upload mode)\n */\n searchLabel?: string;\n /**\n * 検索が行われた際にトリガーされる。\n * ユーザーの入力した文字列に応じてデータを返却する。このデータはCSVとしてダウンロードされる。\n * (only upload mode)\n */\n onSearchData?: (args: { value: string }) => Promise<{\n data: Row[];\n }>;\n /**\n * CSVの各列をどのように表示するか指定する。\n * 各列には、次のプロパティが指定できる。\n *\n * `label` : CSVのヘッダーとして利用される。\n *\n * `type` : `date`または`number`が指定でき、それぞれ日付と数値としてアップロードされたCSVの値が正しいかどうかを検証する。\n *\n * `options` : その列が持てる値のリストを指定する。アップロードされたCSVの値がこのリストに含まれているかどうかを検証する。\n *\n * `required` : その列が必須かどうかを指定する。アップロードされたCSVの値が空でないかどうかを検証する。\n *\n * `renderCell` : その列のセルをどのように表示するかを指定する。その列の値、ヘッダー、行のデータが渡される。\n *\n * `hiddenOnCreateTemplate` : 作成用のCSVのテンプレートに、その列を表示しないかどうかを決定する。\n *\n * `hiddenIfNoHeader` : アップロードされたCSVにそのヘッダーがなければ、その列を表示しないかどうかを決定する。\n */\n columns: Columns;\n /**\n * ダウンロードされるCSVに付与されるプレフィックスを指定する\n */\n csvPrefix?: string;\n /**\n * CSVのダウンロードがトリガーされたときに呼ばれる\n */\n onDownloadCSV: (args: { data: Row[]; filename: string }) => void;\n /**\n * CSVがアップロードされたときに呼ばれる\n */\n csvParser: (args: {\n file: File;\n }) => Promise<{ data: Record<string, string>[] }>;\n /**\n * アップロードされたCSVのデータをバリデーションする。\n */\n csvValidator?: (args: {\n /**\n * ここで渡されるデータがRowと一致するとは限らない。\n */\n row: Record<string, string>;\n }) => Promise<{ errors?: CellError[] }>;\n /**\n * 更新モードで検索のカスタマイズをする。\n * 省略するとonSearchData, searchLabelを用いた単一の検索フィールドが表示される。これを指定するとonSearchData, searchLabelは無視される。\n * (only upload mode)\n */\n renderSearchField?: (\n props: CSVImportUIRenderSearchFieldProps<Row>,\n ) => React.JSX.Element;\n /**\n * 編集用CSVをダウンロードするページをスキップする\n */\n skipDownloadTemplate?: boolean;\n /**\n * 更新用のCSVをダウンロードする際にデフォルトで表示されるデータを指定する。\n */\n defaultTemplateData?: Row[];\n\n /**\n * ダウンロードテンプレートで利用する項目を選択するかどうかを指定する。\n * デフォルトでは、hiddenOnCreateTemplateが指定されていない列の全ての項目が追加される。\n * @default false\n */\n selectDownloadTemplateColumns?: boolean;\n}\n\nconst CSVImportUIContent = <\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n>({\n columns,\n onDownloadCSV,\n searchLabel,\n onSearchData,\n renderSearchField,\n csvPrefix,\n csvParser,\n csvValidator,\n onPreUploadData,\n onPreUploadDataByRow,\n onUploadData,\n onUploadDataByRow,\n acceptMode,\n skipDownloadTemplate,\n selectDownloadTemplateColumns,\n defaultTemplateData,\n}: CSVImportUIProps<Columns, Row>) => {\n const id = useScreen();\n const [mode, setMode] = useState<Mode>(acceptMode[0]);\n const [uploadedData, setUploadedData] = useState<Row[]>([]);\n const [errors, setErrors] = useState<(CellError[] | undefined)[]>([]);\n\n const handleUpdateData = useCallback(\n (data: Row[], errors: (CellError[] | undefined)[]) => {\n setErrors(errors);\n setUploadedData(data);\n },\n [],\n );\n\n const headers = useMemo(() => {\n const rowKeys = Object.keys(uploadedData[0] ?? {});\n\n return Object.values(columns)\n .filter((column) => {\n if (rowKeys.length === 0) {\n return true;\n }\n if (column.hiddenIfNoHeader && !rowKeys.includes(column.label)) {\n return false;\n }\n return true;\n })\n .map((column) => column.label);\n }, [columns, uploadedData]);\n\n const filledData = useMemo(() => {\n return headers.length > Object.keys(uploadedData[0] ?? {}).length\n ? uploadedData.map((row) => {\n return {\n ...Object.fromEntries(headers.map((header) => [header, \"\"])),\n ...row,\n };\n })\n : uploadedData;\n }, [headers, uploadedData]);\n\n switch (id) {\n case \"selectMode\": {\n return (\n <SelectModeScreen\n skipDownloadTemplate={skipDownloadTemplate}\n onChangeMode={setMode}\n />\n );\n }\n case \"downloadCreateTemplate\": {\n return (\n <DownloadCreateTemplateScreen\n onDownloadCSV={onDownloadCSV}\n headers={headers}\n columns={columns}\n csvPrefix={csvPrefix}\n selectDownloadTemplateColumns={selectDownloadTemplateColumns}\n />\n );\n }\n case \"downloadUpdateTemplate\": {\n return (\n <DownloadUpdateTemplateScreen\n searchLabel={searchLabel}\n onSearch={onSearchData}\n renderSearchField={renderSearchField}\n onDownloadCSV={onDownloadCSV}\n csvPrefix={csvPrefix}\n headers={headers}\n defaultTemplateData={defaultTemplateData}\n columns={columns}\n />\n );\n }\n case \"loadCSV\": {\n return (\n <LoadCSVScreen\n mode={mode}\n columns={columns}\n data={filledData}\n headers={headers}\n errors={errors}\n csvParser={csvParser}\n csvValidator={csvValidator}\n onPreUploadData={onPreUploadData}\n onPreUploadDataByRow={onPreUploadDataByRow}\n onUpdateData={handleUpdateData}\n />\n );\n }\n case \"uploadCSV\": {\n return (\n <UploadCSVScreen\n mode={mode}\n data={filledData}\n headers={headers}\n errors={errors}\n columns={columns}\n onUploadData={onUploadData}\n onUploadDataByRow={onUploadDataByRow}\n onSubmitComplete={handleUpdateData}\n />\n );\n }\n case \"complete\": {\n return (\n <CompleteScreen\n csvPrefix={csvPrefix}\n onDownloadCSV={onDownloadCSV}\n data={filledData}\n columns={columns}\n headers={headers}\n errors={errors}\n />\n );\n }\n default: {\n return null;\n }\n }\n};\n\nconst getFirstScreenId = (\n accptMode: Mode[],\n skipDownloadTemplate?: boolean,\n): ScreenId => {\n if (accptMode.length > 1) {\n return \"selectMode\";\n }\n if (skipDownloadTemplate) {\n return \"loadCSV\";\n }\n if (accptMode[0] === \"create\") {\n return \"downloadCreateTemplate\";\n }\n if (accptMode[0] === \"update\") {\n return \"downloadUpdateTemplate\";\n }\n return \"selectMode\";\n};\n\nexport const CSVImportUI = <\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n>(\n props: CSVImportUIProps<Columns, Row>,\n) => {\n return (\n <ScreenProvider\n firstScreenId={getFirstScreenId(\n props.acceptMode,\n props.skipDownloadTemplate,\n )}\n >\n <CSVImportUIContent {...props} />\n </ScreenProvider>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"CSVImportUI.js","names":["CompleteScreen","DownloadCreateTemplateScreen","DownloadUpdateTemplateScreen","LoadCSVScreen","ScreenProvider","useScreen","SelectModeScreen","UploadCSVScreen","useCallback","useMemo","useState","jsx","___EmotionJSX","CSVImportUIContent","_ref","columns","onDownloadCSV","searchLabel","onSearchData","renderSearchField","csvPrefix","csvParser","csvValidator","onPreUploadData","onPreUploadDataByRow","onUploadData","onUploadDataByRow","acceptMode","skipDownloadTemplate","selectDownloadTemplateColumns","defaultTemplateData","id","mode","setMode","uploadedData","setUploadedData","errors","setErrors","handleUpdateData","data","headers","_uploadedData$","rowKeys","Object","keys","values","filter","column","length","hiddenIfNoHeader","includes","label","map","filledData","_uploadedData$2","row","_extends","fromEntries","header","onChangeMode","onSearch","onUpdateData","onSubmitComplete","getFirstScreenId","accptMode","CSVImportUI","props","firstScreenId"],"sources":["../../../src/CSVImportUI/CSVImportUI.tsx"],"sourcesContent":["import { AlertMessageType } from \"../Alert\";\nimport { AssertType } from \"../@types/AssertType\";\nimport { CompleteScreen } from \"./screens/CompleteScreen\";\nimport { DownloadCreateTemplateScreen } from \"./screens/DownloadCreateTemplateScreen\";\nimport { DownloadUpdateTemplateScreen } from \"./screens/DownloadUpdateTemplateScreen\";\nimport { LoadCSVScreen } from \"./screens/LoadCSVScreen\";\nimport { ScreenId } from \"./screens/types\";\nimport { ScreenProvider, useScreen } from \"./ScreenProvider\";\nimport { SelectModeScreen } from \"./screens/SelectModeScreen\";\nimport { UnionToIntersection } from \"../@types/UnionToIntersection\";\nimport { UploadCSVScreen } from \"./screens/UploadCSVScreen\";\nimport { useCallback, useMemo, useState } from \"react\";\n\nexport type Mode = \"create\" | \"update\";\n\nexport type CellError = [string, string];\n\nexport type CSVImportUIColumn = Readonly<{\n label: string;\n description?: string;\n type?: \"date\" | \"number\";\n options?: readonly string[];\n required?: boolean;\n hiddenOnCreateTemplate?: boolean;\n /**\n * アップロードされたCSVにヘッダーがなければ表示しない。\n */\n hiddenIfNoHeader?: boolean;\n renderCell?: (props: {\n value: string;\n header: string;\n row: Record<string, string>;\n }) => React.JSX.Element;\n}>;\n\n/**\n * ライブラリ利用者用の型\n */\nexport type CSVImportUIColumns = Record<string, CSVImportUIColumn>;\n\nexport interface CSVImportUIRenderSearchFieldProps<Row> {\n onChange: (args: Row[]) => void;\n}\n\ntype OptionByLabel<Columns extends CSVImportUIColumns> = {\n [Key in keyof Columns]: Record<\n Columns[Key][\"label\"],\n Columns[Key] extends {\n options: readonly (infer Option)[];\n }\n ? Option extends string\n ? Option\n : never\n : string\n >;\n}[keyof Columns];\n\nexport type CSVImportUIRow<Columns extends CSVImportUIColumns> = AssertType<\n UnionToIntersection<OptionByLabel<Columns>>,\n Record<string, string>\n>;\n\nexport interface CSVImportUIProps<\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n> {\n /**\n * 利用できるモードを指定する。\n */\n acceptMode: Mode[];\n /**\n * アップロード画面に進む前にトリガーされる。\n * 行ごとにデータを処理する。\n *\n * onPreUploadDataが指定されている場合、こちらは無視される。\n *\n * この関数内でsetStateを使用すると、行ごとの処理で過剰なレンダリングを引き起こす可能性があります。\n * 状態更新が必要な場合は、以下の方法を検討してください:\n * - onPreUploadDataを使用して一括でデータを処理する\n * - 複数の更新をバッチ処理して、すべての行の処理後に一度だけ状態を更新する\n * - レンダリングを必要としない中間値にはuseRefを使用する\n */\n onPreUploadDataByRow?: (args: {\n index: number;\n /**\n * 欠損したフィールドがある可能性があるため、型を緩くする。\n */\n row: Partial<Row>;\n mode: Mode;\n }) => Promise<{ error?: CellError; data?: Record<string, string> }>;\n /**\n * アップロード画面に進む前にトリガーされる。\n * 一括でデータをアップロードする。\n *\n * 現状onPreUploadDataByRowByRowとは異なり、行ごとにエラーを表示することはできない。\n * 代わりに、エラー時に表示されるアラートのメッセージをerrorMessageで指定する。\n *\n * 行毎にエラーを表示したくなった場合は、要望を出すこと。\n */\n onPreUploadData?: (args: { data: Partial<Row>[]; mode: Mode }) => Promise<{\n errorMessage?: AlertMessageType;\n data?: Record<string, string>[];\n }>;\n /**\n * CSVをパースしたデータのアップロードがトリガーされた際に呼ばれる。\n * 行ごとにデータをアップロードする。\n *\n * onUploadDataが指定されている場合、こちらは無視される。\n *\n * この関数内でsetStateを使用すると、行ごとの処理で過剰なレンダリングを引き起こす可能性があります。\n * 状態更新が必要な場合は、以下の方法を検討してください:\n * - onUploadDataを使用して一括でデータを処理する\n * - 複数の更新をバッチ処理して、すべての行の処理後に一度だけ状態を更新する\n * - レンダリングを必要としない中間値にはuseRefを使用する\n */\n onUploadDataByRow?: (args: {\n index: number;\n /**\n * 欠損したフィールドがある可能性があるため、型を緩くする。\n */\n row: Partial<Row>;\n mode: Mode;\n }) => Promise<{\n error?: CellError;\n data?: Record<string, string>;\n }>;\n /**\n * CSVをパースしたデータのアップロードがトリガーされた際に呼ばれる。\n * 一括でデータをアップロードする。\n *\n * 現状onUploadDataByRowとは異なり、行ごとにエラーを表示することはできない。\n * 代わりに、エラー時に表示されるアラートのメッセージをerrorMessageで指定する。\n *\n * 行毎にエラーを表示したくなった場合は、要望を出すこと。\n */\n onUploadData?: (args: { data: Partial<Row>[]; mode: Mode }) => Promise<{\n errorMessage?: AlertMessageType;\n data?: Record<string, string>[];\n }>;\n /**\n * 検索フォームのラベルとして利用される。\n * (only upload mode)\n */\n searchLabel?: string;\n /**\n * 検索が行われた際にトリガーされる。\n * ユーザーの入力した文字列に応じてデータを返却する。このデータはCSVとしてダウンロードされる。\n * (only upload mode)\n */\n onSearchData?: (args: { value: string }) => Promise<{\n data: Row[];\n }>;\n /**\n * CSVの各列をどのように表示するか指定する。\n * 各列には、次のプロパティが指定できる。\n *\n * `label` : CSVのヘッダーとして利用される。\n *\n * `type` : `date`または`number`が指定でき、それぞれ日付と数値としてアップロードされたCSVの値が正しいかどうかを検証する。\n *\n * `options` : その列が持てる値のリストを指定する。アップロードされたCSVの値がこのリストに含まれているかどうかを検証する。\n *\n * `required` : その列が必須かどうかを指定する。アップロードされたCSVの値が空でないかどうかを検証する。\n *\n * `renderCell` : その列のセルをどのように表示するかを指定する。その列の値、ヘッダー、行のデータが渡される。\n *\n * `hiddenOnCreateTemplate` : 作成用のCSVのテンプレートに、その列を表示しないかどうかを決定する。\n *\n * `hiddenIfNoHeader` : アップロードされたCSVにそのヘッダーがなければ、その列を表示しないかどうかを決定する。\n */\n columns: Columns;\n /**\n * ダウンロードされるCSVに付与されるプレフィックスを指定する\n */\n csvPrefix?: string;\n /**\n * CSVのダウンロードがトリガーされたときに呼ばれる\n */\n onDownloadCSV: (args: { data: Row[]; filename: string }) => void;\n /**\n * CSVがアップロードされたときに呼ばれる\n */\n csvParser: (args: {\n file: File;\n }) => Promise<{ data: Record<string, string>[] }>;\n /**\n * アップロードされたCSVのデータをバリデーションする。\n */\n csvValidator?: (args: {\n /**\n * ここで渡されるデータがRowと一致するとは限らない。\n */\n row: Record<string, string>;\n }) => Promise<{ errors?: CellError[] }>;\n /**\n * 更新モードで検索のカスタマイズをする。\n * 省略するとonSearchData, searchLabelを用いた単一の検索フィールドが表示される。これを指定するとonSearchData, searchLabelは無視される。\n * (only upload mode)\n */\n renderSearchField?: (\n props: CSVImportUIRenderSearchFieldProps<Row>,\n ) => React.JSX.Element;\n /**\n * 編集用CSVをダウンロードするページをスキップする\n */\n skipDownloadTemplate?: boolean;\n /**\n * 更新用のCSVをダウンロードする際にデフォルトで表示されるデータを指定する。\n */\n defaultTemplateData?: Row[];\n\n /**\n * ダウンロードテンプレートで利用する項目を選択するかどうかを指定する。\n * デフォルトでは、hiddenOnCreateTemplateが指定されていない列の全ての項目が追加される。\n * @default false\n */\n selectDownloadTemplateColumns?: boolean;\n}\n\nconst CSVImportUIContent = <\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n>({\n columns,\n onDownloadCSV,\n searchLabel,\n onSearchData,\n renderSearchField,\n csvPrefix,\n csvParser,\n csvValidator,\n onPreUploadData,\n onPreUploadDataByRow,\n onUploadData,\n onUploadDataByRow,\n acceptMode,\n skipDownloadTemplate,\n selectDownloadTemplateColumns,\n defaultTemplateData,\n}: CSVImportUIProps<Columns, Row>) => {\n const id = useScreen();\n const [mode, setMode] = useState<Mode>(acceptMode[0]);\n const [uploadedData, setUploadedData] = useState<Row[]>([]);\n const [errors, setErrors] = useState<(CellError[] | undefined)[]>([]);\n\n const handleUpdateData = useCallback(\n (data: Row[], errors: (CellError[] | undefined)[]) => {\n setErrors(errors);\n setUploadedData(data);\n },\n [],\n );\n\n const headers = useMemo(() => {\n const rowKeys = Object.keys(uploadedData[0] ?? {});\n\n return Object.values(columns)\n .filter((column) => {\n if (rowKeys.length === 0) {\n return true;\n }\n if (column.hiddenIfNoHeader && !rowKeys.includes(column.label)) {\n return false;\n }\n return true;\n })\n .map((column) => column.label);\n }, [columns, uploadedData]);\n\n const filledData = useMemo(() => {\n return headers.length > Object.keys(uploadedData[0] ?? {}).length\n ? uploadedData.map((row) => {\n return {\n ...Object.fromEntries(headers.map((header) => [header, \"\"])),\n ...row,\n };\n })\n : uploadedData;\n }, [headers, uploadedData]);\n\n switch (id) {\n case \"selectMode\": {\n return (\n <SelectModeScreen\n skipDownloadTemplate={skipDownloadTemplate}\n onChangeMode={setMode}\n />\n );\n }\n case \"downloadCreateTemplate\": {\n return (\n <DownloadCreateTemplateScreen\n onDownloadCSV={onDownloadCSV}\n headers={headers}\n columns={columns}\n csvPrefix={csvPrefix}\n selectDownloadTemplateColumns={selectDownloadTemplateColumns}\n />\n );\n }\n case \"downloadUpdateTemplate\": {\n return (\n <DownloadUpdateTemplateScreen\n searchLabel={searchLabel}\n onSearch={onSearchData}\n renderSearchField={renderSearchField}\n onDownloadCSV={onDownloadCSV}\n csvPrefix={csvPrefix}\n headers={headers}\n defaultTemplateData={defaultTemplateData}\n columns={columns}\n />\n );\n }\n case \"loadCSV\": {\n return (\n <LoadCSVScreen\n mode={mode}\n columns={columns}\n data={filledData}\n headers={headers}\n errors={errors}\n csvParser={csvParser}\n csvValidator={csvValidator}\n onPreUploadData={onPreUploadData}\n onPreUploadDataByRow={onPreUploadDataByRow}\n onUpdateData={handleUpdateData}\n />\n );\n }\n case \"uploadCSV\": {\n return (\n <UploadCSVScreen\n mode={mode}\n data={filledData}\n headers={headers}\n errors={errors}\n columns={columns}\n onUploadData={onUploadData}\n onUploadDataByRow={onUploadDataByRow}\n onSubmitComplete={handleUpdateData}\n />\n );\n }\n case \"complete\": {\n return (\n <CompleteScreen\n csvPrefix={csvPrefix}\n onDownloadCSV={onDownloadCSV}\n data={filledData}\n columns={columns}\n headers={headers}\n errors={errors}\n />\n );\n }\n default: {\n return null;\n }\n }\n};\n\nconst getFirstScreenId = (\n accptMode: Mode[],\n skipDownloadTemplate?: boolean,\n): ScreenId => {\n if (accptMode.length > 1) {\n return \"selectMode\";\n }\n if (skipDownloadTemplate) {\n return \"loadCSV\";\n }\n if (accptMode[0] === \"create\") {\n return \"downloadCreateTemplate\";\n }\n if (accptMode[0] === \"update\") {\n return \"downloadUpdateTemplate\";\n }\n return \"selectMode\";\n};\n\nexport const CSVImportUI = <\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n>(\n props: CSVImportUIProps<Columns, Row>,\n) => {\n return (\n <ScreenProvider\n firstScreenId={getFirstScreenId(\n props.acceptMode,\n props.skipDownloadTemplate,\n )}\n >\n <CSVImportUIContent {...props} />\n </ScreenProvider>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
package/Tooltip/Tooltip.d.ts
CHANGED
|
@@ -1,7 +1,14 @@
|
|
|
1
1
|
import { PopperBaseProps } from "../Popper";
|
|
2
2
|
import React from "react";
|
|
3
3
|
export interface TooltipProps extends Pick<PopperBaseProps, "placement"> {
|
|
4
|
+
/**
|
|
5
|
+
* Tooltipに表示するテキスト
|
|
6
|
+
*/
|
|
4
7
|
title: string;
|
|
8
|
+
/**
|
|
9
|
+
* Tooltipを表示する要素
|
|
10
|
+
* 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません
|
|
11
|
+
*/
|
|
5
12
|
children: React.ReactElement<any> | string;
|
|
6
13
|
/**
|
|
7
14
|
* 矢印を表示します。
|
package/Tooltip/Tooltip.js
CHANGED
|
@@ -15,7 +15,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
15
15
|
styles: "position:absolute;color:rgba(97, 97, 97, 0.9);&::before{display:block;width:0px;height:0px;margin:auto;content:\"\";border-style:solid;}"
|
|
16
16
|
} : {
|
|
17
17
|
name: "ynymi0-Tooltip",
|
|
18
|
-
styles: "position:absolute;color:rgba(97, 97, 97, 0.9);&::before{display:block;width:0px;height:0px;margin:auto;content:\"\";border-style:solid;};label:Tooltip;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
18
|
+
styles: "position:absolute;color:rgba(97, 97, 97, 0.9);&::before{display:block;width:0px;height:0px;margin:auto;content:\"\";border-style:solid;};label:Tooltip;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AA2NsB","file":"../../../src/Tooltip/Tooltip.tsx","sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n  tooltip: {\n    arrow: \"m2mui_Tooltip_arrow\",\n  },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n  /**\n   * Tooltipに表示するテキスト\n   */\n  title: string;\n  /**\n   * Tooltipを表示する要素\n   * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません\n   */\n  children: React.ReactElement<any> | string;\n  /**\n   * 矢印を表示します。\n   *\n   * @default false\n   */\n  arrow?: boolean;\n  /**\n   * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n   *\n   * @default undefined\n   */\n  open?: boolean;\n}\n\nexport const Tooltip = ({\n  children,\n  title,\n  placement,\n  arrow,\n  open: openProp,\n}: TooltipProps) => {\n  const [node, setNode] = useState<HTMLElement | null>(null);\n\n  const theme = useTheme();\n\n  const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n  const [open, setOpen] = useState(false);\n  const prevOpen = useRef<boolean>(undefined);\n  const [hidden, setHidden] = useState(true);\n\n  if (isControlled && openProp !== prevOpen.current) {\n    prevOpen.current = openProp;\n    if (openProp) {\n      setOpen(true);\n      setHidden(false);\n    } else {\n      setHidden(true);\n    }\n  }\n\n  const handleMouseEnter = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setOpen(true);\n          setHidden(false);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  const handleMouseLeave = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setHidden(true);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  return (\n    <React.Fragment>\n      {typeof children === \"string\" ? (\n        <span\n          ref={setNode}\n          onMouseEnter={handleMouseEnter()}\n          onMouseLeave={handleMouseLeave()}\n        >\n          {children}\n        </span>\n      ) : (\n        React.cloneElement(children, {\n          ref: setNode,\n          onMouseEnter: handleMouseEnter(\n            hasOwnProp(children.props, \"onMouseEnter\")\n              ? (children.props.onMouseEnter as React.MouseEventHandler)\n              : undefined,\n          ),\n          onMouseLeave: handleMouseLeave(\n            hasOwnProp(children.props, \"onMouseLeave\")\n              ? (children.props.onMouseLeave as React.MouseEventHandler)\n              : undefined,\n          ),\n        })\n      )}\n      <Popper\n        anchorEl={node}\n        placement={placement}\n        open={open}\n        aria-hidden={hidden}\n        disablePortal\n        onTransitionEnd={() => {\n          if (hidden) {\n            setOpen(false);\n          }\n        }}\n        css={css`\n          opacity: 1;\n          transition: opacity 200ms;\n          &[aria-hidden=\"true\"] {\n            opacity: 0;\n          }\n          &[data-popper-placement*=\"bottom\"] {\n            .${classNames.tooltip.arrow} {\n              top: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-top: -6px;\n              &::before {\n                border-color: transparent transparent currentcolor transparent;\n                border-width: 0 6px 6px 6px;\n              }\n            }\n            & > * {\n              margin-top: 8px;\n            }\n          }\n          &[data-popper-placement*=\"top\"] {\n            .${classNames.tooltip.arrow} {\n              bottom: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-bottom: -6px;\n              &::before {\n                border-color: currentcolor transparent transparent transparent;\n                border-width: 6px 6px 0 6px;\n              }\n            }\n            & > * {\n              margin-bottom: 8px;\n            }\n          }\n          &[data-popper-placement*=\"right\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              left: 0;\n              width: 6px;\n              height: 12px;\n              margin-left: -6px;\n              &::before {\n                border-color: transparent currentcolor transparent transparent;\n                border-width: 6px 6px 6px 0;\n              }\n            }\n            & > * {\n              margin-left: 8px;\n            }\n          }\n          &[data-popper-placement*=\"left\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              right: 0;\n              width: 6px;\n              height: 12px;\n              margin-right: -6px;\n              &::before {\n                border-color: transparent transparent transparent currentcolor;\n                border-width: 6px 0 6px 6px;\n              }\n            }\n            & > * {\n              margin-right: 8px;\n            }\n          }\n        `}\n      >\n        <div\n          css={[\n            theme.typography.caption,\n            css`\n              position: relative;\n              max-width: 300px;\n              padding: 6px 10px;\n              color: #fff;\n              text-align: left;\n              word-wrap: break-word;\n              background-color: rgba(97, 97, 97, 0.9);\n              border-radius: 4px;\n            `,\n          ]}\n        >\n          {title}\n          {arrow ? (\n            <div\n              className={classNames.tooltip.arrow}\n              css={css`\n                position: absolute;\n                color: rgba(97, 97, 97, 0.9);\n                &::before {\n                  display: block;\n                  width: 0px;\n                  height: 0px;\n                  margin: auto;\n                  content: \"\";\n                  border-style: solid;\n                }\n              `}\n            />\n          ) : null}\n        </div>\n      </Popper>\n    </React.Fragment>\n  );\n};\n"]} */",
|
|
19
19
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
20
20
|
};
|
|
21
21
|
var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
@@ -23,7 +23,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
|
23
23
|
styles: "position:relative;max-width:300px;padding:6px 10px;color:#fff;text-align:left;word-wrap:break-word;background-color:rgba(97, 97, 97, 0.9);border-radius:4px"
|
|
24
24
|
} : {
|
|
25
25
|
name: "1350k6g-Tooltip",
|
|
26
|
-
styles: "position:relative;max-width:300px;padding:6px 10px;color:#fff;text-align:left;word-wrap:break-word;background-color:rgba(97, 97, 97, 0.9);border-radius:4px;label:Tooltip;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
26
|
+
styles: "position:relative;max-width:300px;padding:6px 10px;color:#fff;text-align:left;word-wrap:break-word;background-color:rgba(97, 97, 97, 0.9);border-radius:4px;label:Tooltip;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AA2Me","file":"../../../src/Tooltip/Tooltip.tsx","sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n  tooltip: {\n    arrow: \"m2mui_Tooltip_arrow\",\n  },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n  /**\n   * Tooltipに表示するテキスト\n   */\n  title: string;\n  /**\n   * Tooltipを表示する要素\n   * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません\n   */\n  children: React.ReactElement<any> | string;\n  /**\n   * 矢印を表示します。\n   *\n   * @default false\n   */\n  arrow?: boolean;\n  /**\n   * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n   *\n   * @default undefined\n   */\n  open?: boolean;\n}\n\nexport const Tooltip = ({\n  children,\n  title,\n  placement,\n  arrow,\n  open: openProp,\n}: TooltipProps) => {\n  const [node, setNode] = useState<HTMLElement | null>(null);\n\n  const theme = useTheme();\n\n  const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n  const [open, setOpen] = useState(false);\n  const prevOpen = useRef<boolean>(undefined);\n  const [hidden, setHidden] = useState(true);\n\n  if (isControlled && openProp !== prevOpen.current) {\n    prevOpen.current = openProp;\n    if (openProp) {\n      setOpen(true);\n      setHidden(false);\n    } else {\n      setHidden(true);\n    }\n  }\n\n  const handleMouseEnter = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setOpen(true);\n          setHidden(false);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  const handleMouseLeave = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setHidden(true);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  return (\n    <React.Fragment>\n      {typeof children === \"string\" ? (\n        <span\n          ref={setNode}\n          onMouseEnter={handleMouseEnter()}\n          onMouseLeave={handleMouseLeave()}\n        >\n          {children}\n        </span>\n      ) : (\n        React.cloneElement(children, {\n          ref: setNode,\n          onMouseEnter: handleMouseEnter(\n            hasOwnProp(children.props, \"onMouseEnter\")\n              ? (children.props.onMouseEnter as React.MouseEventHandler)\n              : undefined,\n          ),\n          onMouseLeave: handleMouseLeave(\n            hasOwnProp(children.props, \"onMouseLeave\")\n              ? (children.props.onMouseLeave as React.MouseEventHandler)\n              : undefined,\n          ),\n        })\n      )}\n      <Popper\n        anchorEl={node}\n        placement={placement}\n        open={open}\n        aria-hidden={hidden}\n        disablePortal\n        onTransitionEnd={() => {\n          if (hidden) {\n            setOpen(false);\n          }\n        }}\n        css={css`\n          opacity: 1;\n          transition: opacity 200ms;\n          &[aria-hidden=\"true\"] {\n            opacity: 0;\n          }\n          &[data-popper-placement*=\"bottom\"] {\n            .${classNames.tooltip.arrow} {\n              top: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-top: -6px;\n              &::before {\n                border-color: transparent transparent currentcolor transparent;\n                border-width: 0 6px 6px 6px;\n              }\n            }\n            & > * {\n              margin-top: 8px;\n            }\n          }\n          &[data-popper-placement*=\"top\"] {\n            .${classNames.tooltip.arrow} {\n              bottom: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-bottom: -6px;\n              &::before {\n                border-color: currentcolor transparent transparent transparent;\n                border-width: 6px 6px 0 6px;\n              }\n            }\n            & > * {\n              margin-bottom: 8px;\n            }\n          }\n          &[data-popper-placement*=\"right\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              left: 0;\n              width: 6px;\n              height: 12px;\n              margin-left: -6px;\n              &::before {\n                border-color: transparent currentcolor transparent transparent;\n                border-width: 6px 6px 6px 0;\n              }\n            }\n            & > * {\n              margin-left: 8px;\n            }\n          }\n          &[data-popper-placement*=\"left\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              right: 0;\n              width: 6px;\n              height: 12px;\n              margin-right: -6px;\n              &::before {\n                border-color: transparent transparent transparent currentcolor;\n                border-width: 6px 0 6px 6px;\n              }\n            }\n            & > * {\n              margin-right: 8px;\n            }\n          }\n        `}\n      >\n        <div\n          css={[\n            theme.typography.caption,\n            css`\n              position: relative;\n              max-width: 300px;\n              padding: 6px 10px;\n              color: #fff;\n              text-align: left;\n              word-wrap: break-word;\n              background-color: rgba(97, 97, 97, 0.9);\n              border-radius: 4px;\n            `,\n          ]}\n        >\n          {title}\n          {arrow ? (\n            <div\n              className={classNames.tooltip.arrow}\n              css={css`\n                position: absolute;\n                color: rgba(97, 97, 97, 0.9);\n                &::before {\n                  display: block;\n                  width: 0px;\n                  height: 0px;\n                  margin: auto;\n                  content: \"\";\n                  border-style: solid;\n                }\n              `}\n            />\n          ) : null}\n        </div>\n      </Popper>\n    </React.Fragment>\n  );\n};\n"]} */",
|
|
27
27
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
28
28
|
};
|
|
29
29
|
export var Tooltip = _ref3 => {
|
|
@@ -85,9 +85,9 @@ export var Tooltip = _ref3 => {
|
|
|
85
85
|
setOpen(false);
|
|
86
86
|
}
|
|
87
87
|
},
|
|
88
|
-
css: /*#__PURE__*/css("opacity:1;transition:opacity 200ms;&[aria-hidden=\"true\"]{opacity:0;}&[data-popper-placement*=\"bottom\"]{.", classNames.tooltip.arrow, "{top:0;left:12px;width:12px;height:6px;margin-top:-6px;&::before{border-color:transparent transparent currentcolor transparent;border-width:0 6px 6px 6px;}}&>*{margin-top:8px;}}&[data-popper-placement*=\"top\"]{.", classNames.tooltip.arrow, "{bottom:0;left:12px;width:12px;height:6px;margin-bottom:-6px;&::before{border-color:currentcolor transparent transparent transparent;border-width:6px 6px 0 6px;}}&>*{margin-bottom:8px;}}&[data-popper-placement*=\"right\"]{.", classNames.tooltip.arrow, "{top:12px;left:0;width:6px;height:12px;margin-left:-6px;&::before{border-color:transparent currentcolor transparent transparent;border-width:6px 6px 6px 0;}}&>*{margin-left:8px;}}&[data-popper-placement*=\"left\"]{.", classNames.tooltip.arrow, "{top:12px;right:0;width:6px;height:12px;margin-right:-6px;&::before{border-color:transparent transparent transparent currentcolor;border-width:6px 0 6px 6px;}}&>*{margin-right:8px;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AAyHgB","file":"../../../src/Tooltip/Tooltip.tsx","sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n  tooltip: {\n    arrow: \"m2mui_Tooltip_arrow\",\n  },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n  title: string;\n  children: React.ReactElement<any> | string;\n  /**\n   * 矢印を表示します。\n   *\n   * @default false\n   */\n  arrow?: boolean;\n  /**\n   * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n   *\n   * @default undefined\n   */\n  open?: boolean;\n}\n\nexport const Tooltip = ({\n  children,\n  title,\n  placement,\n  arrow,\n  open: openProp,\n}: TooltipProps) => {\n  const [node, setNode] = useState<HTMLElement | null>(null);\n\n  const theme = useTheme();\n\n  const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n  const [open, setOpen] = useState(false);\n  const prevOpen = useRef<boolean>(undefined);\n  const [hidden, setHidden] = useState(true);\n\n  if (isControlled && openProp !== prevOpen.current) {\n    prevOpen.current = openProp;\n    if (openProp) {\n      setOpen(true);\n      setHidden(false);\n    } else {\n      setHidden(true);\n    }\n  }\n\n  const handleMouseEnter = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setOpen(true);\n          setHidden(false);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  const handleMouseLeave = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setHidden(true);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  return (\n    <React.Fragment>\n      {typeof children === \"string\" ? (\n        <span\n          ref={setNode}\n          onMouseEnter={handleMouseEnter()}\n          onMouseLeave={handleMouseLeave()}\n        >\n          {children}\n        </span>\n      ) : (\n        React.cloneElement(children, {\n          ref: setNode,\n          onMouseEnter: handleMouseEnter(\n            hasOwnProp(children.props, \"onMouseEnter\")\n              ? (children.props.onMouseEnter as React.MouseEventHandler)\n              : undefined,\n          ),\n          onMouseLeave: handleMouseLeave(\n            hasOwnProp(children.props, \"onMouseLeave\")\n              ? (children.props.onMouseLeave as React.MouseEventHandler)\n              : undefined,\n          ),\n        })\n      )}\n      <Popper\n        anchorEl={node}\n        placement={placement}\n        open={open}\n        aria-hidden={hidden}\n        disablePortal\n        onTransitionEnd={() => {\n          if (hidden) {\n            setOpen(false);\n          }\n        }}\n        css={css`\n          opacity: 1;\n          transition: opacity 200ms;\n          &[aria-hidden=\"true\"] {\n            opacity: 0;\n          }\n          &[data-popper-placement*=\"bottom\"] {\n            .${classNames.tooltip.arrow} {\n              top: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-top: -6px;\n              &::before {\n                border-color: transparent transparent currentcolor transparent;\n                border-width: 0 6px 6px 6px;\n              }\n            }\n            & > * {\n              margin-top: 8px;\n            }\n          }\n          &[data-popper-placement*=\"top\"] {\n            .${classNames.tooltip.arrow} {\n              bottom: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-bottom: -6px;\n              &::before {\n                border-color: currentcolor transparent transparent transparent;\n                border-width: 6px 6px 0 6px;\n              }\n            }\n            & > * {\n              margin-bottom: 8px;\n            }\n          }\n          &[data-popper-placement*=\"right\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              left: 0;\n              width: 6px;\n              height: 12px;\n              margin-left: -6px;\n              &::before {\n                border-color: transparent currentcolor transparent transparent;\n                border-width: 6px 6px 6px 0;\n              }\n            }\n            & > * {\n              margin-left: 8px;\n            }\n          }\n          &[data-popper-placement*=\"left\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              right: 0;\n              width: 6px;\n              height: 12px;\n              margin-right: -6px;\n              &::before {\n                border-color: transparent transparent transparent currentcolor;\n                border-width: 6px 0 6px 6px;\n              }\n            }\n            & > * {\n              margin-right: 8px;\n            }\n          }\n        `}\n      >\n        <div\n          css={[\n            theme.typography.caption,\n            css`\n              position: relative;\n              max-width: 300px;\n              padding: 6px 10px;\n              color: #fff;\n              text-align: left;\n              word-wrap: break-word;\n              background-color: rgba(97, 97, 97, 0.9);\n              border-radius: 4px;\n            `,\n          ]}\n        >\n          {title}\n          {arrow ? (\n            <div\n              className={classNames.tooltip.arrow}\n              css={css`\n                position: absolute;\n                color: rgba(97, 97, 97, 0.9);\n                &::before {\n                  display: block;\n                  width: 0px;\n                  height: 0px;\n                  margin: auto;\n                  content: \"\";\n                  border-style: solid;\n                }\n              `}\n            />\n          ) : null}\n        </div>\n      </Popper>\n    </React.Fragment>\n  );\n};\n"]} */")
|
|
88
|
+
css: /*#__PURE__*/css("opacity:1;transition:opacity 200ms;&[aria-hidden=\"true\"]{opacity:0;}&[data-popper-placement*=\"bottom\"]{.", classNames.tooltip.arrow, "{top:0;left:12px;width:12px;height:6px;margin-top:-6px;&::before{border-color:transparent transparent currentcolor transparent;border-width:0 6px 6px 6px;}}&>*{margin-top:8px;}}&[data-popper-placement*=\"top\"]{.", classNames.tooltip.arrow, "{bottom:0;left:12px;width:12px;height:6px;margin-bottom:-6px;&::before{border-color:currentcolor transparent transparent transparent;border-width:6px 6px 0 6px;}}&>*{margin-bottom:8px;}}&[data-popper-placement*=\"right\"]{.", classNames.tooltip.arrow, "{top:12px;left:0;width:6px;height:12px;margin-left:-6px;&::before{border-color:transparent currentcolor transparent transparent;border-width:6px 6px 6px 0;}}&>*{margin-left:8px;}}&[data-popper-placement*=\"left\"]{.", classNames.tooltip.arrow, "{top:12px;right:0;width:6px;height:12px;margin-right:-6px;&::before{border-color:transparent transparent transparent currentcolor;border-width:6px 0 6px 6px;}}&>*{margin-right:8px;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AAgIgB","file":"../../../src/Tooltip/Tooltip.tsx","sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n  tooltip: {\n    arrow: \"m2mui_Tooltip_arrow\",\n  },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n  /**\n   * Tooltipに表示するテキスト\n   */\n  title: string;\n  /**\n   * Tooltipを表示する要素\n   * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません\n   */\n  children: React.ReactElement<any> | string;\n  /**\n   * 矢印を表示します。\n   *\n   * @default false\n   */\n  arrow?: boolean;\n  /**\n   * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n   *\n   * @default undefined\n   */\n  open?: boolean;\n}\n\nexport const Tooltip = ({\n  children,\n  title,\n  placement,\n  arrow,\n  open: openProp,\n}: TooltipProps) => {\n  const [node, setNode] = useState<HTMLElement | null>(null);\n\n  const theme = useTheme();\n\n  const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n  const [open, setOpen] = useState(false);\n  const prevOpen = useRef<boolean>(undefined);\n  const [hidden, setHidden] = useState(true);\n\n  if (isControlled && openProp !== prevOpen.current) {\n    prevOpen.current = openProp;\n    if (openProp) {\n      setOpen(true);\n      setHidden(false);\n    } else {\n      setHidden(true);\n    }\n  }\n\n  const handleMouseEnter = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setOpen(true);\n          setHidden(false);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  const handleMouseLeave = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setHidden(true);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  return (\n    <React.Fragment>\n      {typeof children === \"string\" ? (\n        <span\n          ref={setNode}\n          onMouseEnter={handleMouseEnter()}\n          onMouseLeave={handleMouseLeave()}\n        >\n          {children}\n        </span>\n      ) : (\n        React.cloneElement(children, {\n          ref: setNode,\n          onMouseEnter: handleMouseEnter(\n            hasOwnProp(children.props, \"onMouseEnter\")\n              ? (children.props.onMouseEnter as React.MouseEventHandler)\n              : undefined,\n          ),\n          onMouseLeave: handleMouseLeave(\n            hasOwnProp(children.props, \"onMouseLeave\")\n              ? (children.props.onMouseLeave as React.MouseEventHandler)\n              : undefined,\n          ),\n        })\n      )}\n      <Popper\n        anchorEl={node}\n        placement={placement}\n        open={open}\n        aria-hidden={hidden}\n        disablePortal\n        onTransitionEnd={() => {\n          if (hidden) {\n            setOpen(false);\n          }\n        }}\n        css={css`\n          opacity: 1;\n          transition: opacity 200ms;\n          &[aria-hidden=\"true\"] {\n            opacity: 0;\n          }\n          &[data-popper-placement*=\"bottom\"] {\n            .${classNames.tooltip.arrow} {\n              top: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-top: -6px;\n              &::before {\n                border-color: transparent transparent currentcolor transparent;\n                border-width: 0 6px 6px 6px;\n              }\n            }\n            & > * {\n              margin-top: 8px;\n            }\n          }\n          &[data-popper-placement*=\"top\"] {\n            .${classNames.tooltip.arrow} {\n              bottom: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-bottom: -6px;\n              &::before {\n                border-color: currentcolor transparent transparent transparent;\n                border-width: 6px 6px 0 6px;\n              }\n            }\n            & > * {\n              margin-bottom: 8px;\n            }\n          }\n          &[data-popper-placement*=\"right\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              left: 0;\n              width: 6px;\n              height: 12px;\n              margin-left: -6px;\n              &::before {\n                border-color: transparent currentcolor transparent transparent;\n                border-width: 6px 6px 6px 0;\n              }\n            }\n            & > * {\n              margin-left: 8px;\n            }\n          }\n          &[data-popper-placement*=\"left\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              right: 0;\n              width: 6px;\n              height: 12px;\n              margin-right: -6px;\n              &::before {\n                border-color: transparent transparent transparent currentcolor;\n                border-width: 6px 0 6px 6px;\n              }\n            }\n            & > * {\n              margin-right: 8px;\n            }\n          }\n        `}\n      >\n        <div\n          css={[\n            theme.typography.caption,\n            css`\n              position: relative;\n              max-width: 300px;\n              padding: 6px 10px;\n              color: #fff;\n              text-align: left;\n              word-wrap: break-word;\n              background-color: rgba(97, 97, 97, 0.9);\n              border-radius: 4px;\n            `,\n          ]}\n        >\n          {title}\n          {arrow ? (\n            <div\n              className={classNames.tooltip.arrow}\n              css={css`\n                position: absolute;\n                color: rgba(97, 97, 97, 0.9);\n                &::before {\n                  display: block;\n                  width: 0px;\n                  height: 0px;\n                  margin: auto;\n                  content: \"\";\n                  border-style: solid;\n                }\n              `}\n            />\n          ) : null}\n        </div>\n      </Popper>\n    </React.Fragment>\n  );\n};\n"]} */")
|
|
89
89
|
}, ___EmotionJSX("div", {
|
|
90
|
-
css: [theme.typography.caption, _ref2, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
90
|
+
css: [theme.typography.caption, _ref2, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AAyMU","file":"../../../src/Tooltip/Tooltip.tsx","sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n  tooltip: {\n    arrow: \"m2mui_Tooltip_arrow\",\n  },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n  /**\n   * Tooltipに表示するテキスト\n   */\n  title: string;\n  /**\n   * Tooltipを表示する要素\n   * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません\n   */\n  children: React.ReactElement<any> | string;\n  /**\n   * 矢印を表示します。\n   *\n   * @default false\n   */\n  arrow?: boolean;\n  /**\n   * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n   *\n   * @default undefined\n   */\n  open?: boolean;\n}\n\nexport const Tooltip = ({\n  children,\n  title,\n  placement,\n  arrow,\n  open: openProp,\n}: TooltipProps) => {\n  const [node, setNode] = useState<HTMLElement | null>(null);\n\n  const theme = useTheme();\n\n  const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n  const [open, setOpen] = useState(false);\n  const prevOpen = useRef<boolean>(undefined);\n  const [hidden, setHidden] = useState(true);\n\n  if (isControlled && openProp !== prevOpen.current) {\n    prevOpen.current = openProp;\n    if (openProp) {\n      setOpen(true);\n      setHidden(false);\n    } else {\n      setHidden(true);\n    }\n  }\n\n  const handleMouseEnter = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setOpen(true);\n          setHidden(false);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  const handleMouseLeave = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setHidden(true);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  return (\n    <React.Fragment>\n      {typeof children === \"string\" ? (\n        <span\n          ref={setNode}\n          onMouseEnter={handleMouseEnter()}\n          onMouseLeave={handleMouseLeave()}\n        >\n          {children}\n        </span>\n      ) : (\n        React.cloneElement(children, {\n          ref: setNode,\n          onMouseEnter: handleMouseEnter(\n            hasOwnProp(children.props, \"onMouseEnter\")\n              ? (children.props.onMouseEnter as React.MouseEventHandler)\n              : undefined,\n          ),\n          onMouseLeave: handleMouseLeave(\n            hasOwnProp(children.props, \"onMouseLeave\")\n              ? (children.props.onMouseLeave as React.MouseEventHandler)\n              : undefined,\n          ),\n        })\n      )}\n      <Popper\n        anchorEl={node}\n        placement={placement}\n        open={open}\n        aria-hidden={hidden}\n        disablePortal\n        onTransitionEnd={() => {\n          if (hidden) {\n            setOpen(false);\n          }\n        }}\n        css={css`\n          opacity: 1;\n          transition: opacity 200ms;\n          &[aria-hidden=\"true\"] {\n            opacity: 0;\n          }\n          &[data-popper-placement*=\"bottom\"] {\n            .${classNames.tooltip.arrow} {\n              top: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-top: -6px;\n              &::before {\n                border-color: transparent transparent currentcolor transparent;\n                border-width: 0 6px 6px 6px;\n              }\n            }\n            & > * {\n              margin-top: 8px;\n            }\n          }\n          &[data-popper-placement*=\"top\"] {\n            .${classNames.tooltip.arrow} {\n              bottom: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-bottom: -6px;\n              &::before {\n                border-color: currentcolor transparent transparent transparent;\n                border-width: 6px 6px 0 6px;\n              }\n            }\n            & > * {\n              margin-bottom: 8px;\n            }\n          }\n          &[data-popper-placement*=\"right\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              left: 0;\n              width: 6px;\n              height: 12px;\n              margin-left: -6px;\n              &::before {\n                border-color: transparent currentcolor transparent transparent;\n                border-width: 6px 6px 6px 0;\n              }\n            }\n            & > * {\n              margin-left: 8px;\n            }\n          }\n          &[data-popper-placement*=\"left\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              right: 0;\n              width: 6px;\n              height: 12px;\n              margin-right: -6px;\n              &::before {\n                border-color: transparent transparent transparent currentcolor;\n                border-width: 6px 0 6px 6px;\n              }\n            }\n            & > * {\n              margin-right: 8px;\n            }\n          }\n        `}\n      >\n        <div\n          css={[\n            theme.typography.caption,\n            css`\n              position: relative;\n              max-width: 300px;\n              padding: 6px 10px;\n              color: #fff;\n              text-align: left;\n              word-wrap: break-word;\n              background-color: rgba(97, 97, 97, 0.9);\n              border-radius: 4px;\n            `,\n          ]}\n        >\n          {title}\n          {arrow ? (\n            <div\n              className={classNames.tooltip.arrow}\n              css={css`\n                position: absolute;\n                color: rgba(97, 97, 97, 0.9);\n                &::before {\n                  display: block;\n                  width: 0px;\n                  height: 0px;\n                  margin: auto;\n                  content: \"\";\n                  border-style: solid;\n                }\n              `}\n            />\n          ) : null}\n        </div>\n      </Popper>\n    </React.Fragment>\n  );\n};\n"]} */"]
|
|
91
91
|
}, title, arrow ? ___EmotionJSX("div", {
|
|
92
92
|
className: classNames.tooltip.arrow,
|
|
93
93
|
css: _ref
|
package/Tooltip/Tooltip.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Tooltip.js","names":["Popper","css","hasOwnProp","useTheme","React","useCallback","useMemo","useRef","useState","jsx","___EmotionJSX","classNames","tooltip","arrow","_ref","process","env","NODE_ENV","name","styles","toString","_EMOTION_STRINGIFIED_CSS_ERROR__","_ref2","Tooltip","_ref3","children","title","placement","open","openProp","node","setNode","theme","isControlled","undefined","setOpen","prevOpen","hidden","setHidden","current","handleMouseEnter","original","event","handleMouseLeave","Fragment","ref","onMouseEnter","onMouseLeave","cloneElement","props","anchorEl","disablePortal","onTransitionEnd","typography","caption","className"],"sources":["../../../src/Tooltip/Tooltip.tsx"],"sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n tooltip: {\n arrow: \"m2mui_Tooltip_arrow\",\n },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n title: string;\n children: React.ReactElement<any> | string;\n /**\n * 矢印を表示します。\n *\n * @default false\n */\n arrow?: boolean;\n /**\n * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n *\n * @default undefined\n */\n open?: boolean;\n}\n\nexport const Tooltip = ({\n children,\n title,\n placement,\n arrow,\n open: openProp,\n}: TooltipProps) => {\n const [node, setNode] = useState<HTMLElement | null>(null);\n\n const theme = useTheme();\n\n const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n const [open, setOpen] = useState(false);\n const prevOpen = useRef<boolean>(undefined);\n const [hidden, setHidden] = useState(true);\n\n if (isControlled && openProp !== prevOpen.current) {\n prevOpen.current = openProp;\n if (openProp) {\n setOpen(true);\n setHidden(false);\n } else {\n setHidden(true);\n }\n }\n\n const handleMouseEnter = useCallback(\n (original?: (event: React.MouseEvent) => void) =>\n (event: React.MouseEvent) => {\n if (!isControlled) {\n setOpen(true);\n setHidden(false);\n }\n\n if (original) {\n original(event);\n }\n },\n [isControlled],\n );\n\n const handleMouseLeave = useCallback(\n (original?: (event: React.MouseEvent) => void) =>\n (event: React.MouseEvent) => {\n if (!isControlled) {\n setHidden(true);\n }\n\n if (original) {\n original(event);\n }\n },\n [isControlled],\n );\n\n return (\n <React.Fragment>\n {typeof children === \"string\" ? (\n <span\n ref={setNode}\n onMouseEnter={handleMouseEnter()}\n onMouseLeave={handleMouseLeave()}\n >\n {children}\n </span>\n ) : (\n React.cloneElement(children, {\n ref: setNode,\n onMouseEnter: handleMouseEnter(\n hasOwnProp(children.props, \"onMouseEnter\")\n ? (children.props.onMouseEnter as React.MouseEventHandler)\n : undefined,\n ),\n onMouseLeave: handleMouseLeave(\n hasOwnProp(children.props, \"onMouseLeave\")\n ? (children.props.onMouseLeave as React.MouseEventHandler)\n : undefined,\n ),\n })\n )}\n <Popper\n anchorEl={node}\n placement={placement}\n open={open}\n aria-hidden={hidden}\n disablePortal\n onTransitionEnd={() => {\n if (hidden) {\n setOpen(false);\n }\n }}\n css={css`\n opacity: 1;\n transition: opacity 200ms;\n &[aria-hidden=\"true\"] {\n opacity: 0;\n }\n &[data-popper-placement*=\"bottom\"] {\n .${classNames.tooltip.arrow} {\n top: 0;\n left: 12px;\n width: 12px;\n height: 6px;\n margin-top: -6px;\n &::before {\n border-color: transparent transparent currentcolor transparent;\n border-width: 0 6px 6px 6px;\n }\n }\n & > * {\n margin-top: 8px;\n }\n }\n &[data-popper-placement*=\"top\"] {\n .${classNames.tooltip.arrow} {\n bottom: 0;\n left: 12px;\n width: 12px;\n height: 6px;\n margin-bottom: -6px;\n &::before {\n border-color: currentcolor transparent transparent transparent;\n border-width: 6px 6px 0 6px;\n }\n }\n & > * {\n margin-bottom: 8px;\n }\n }\n &[data-popper-placement*=\"right\"] {\n .${classNames.tooltip.arrow} {\n top: 12px;\n left: 0;\n width: 6px;\n height: 12px;\n margin-left: -6px;\n &::before {\n border-color: transparent currentcolor transparent transparent;\n border-width: 6px 6px 6px 0;\n }\n }\n & > * {\n margin-left: 8px;\n }\n }\n &[data-popper-placement*=\"left\"] {\n .${classNames.tooltip.arrow} {\n top: 12px;\n right: 0;\n width: 6px;\n height: 12px;\n margin-right: -6px;\n &::before {\n border-color: transparent transparent transparent currentcolor;\n border-width: 6px 0 6px 6px;\n }\n }\n & > * {\n margin-right: 8px;\n }\n }\n `}\n >\n <div\n css={[\n theme.typography.caption,\n css`\n position: relative;\n max-width: 300px;\n padding: 6px 10px;\n color: #fff;\n text-align: left;\n word-wrap: break-word;\n background-color: rgba(97, 97, 97, 0.9);\n border-radius: 4px;\n `,\n ]}\n >\n {title}\n {arrow ? (\n <div\n className={classNames.tooltip.arrow}\n css={css`\n position: absolute;\n color: rgba(97, 97, 97, 0.9);\n &::before {\n display: block;\n width: 0px;\n height: 0px;\n margin: auto;\n content: \"\";\n border-style: solid;\n }\n `}\n />\n ) : null}\n </div>\n </Popper>\n </React.Fragment>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"Tooltip.js","names":["Popper","css","hasOwnProp","useTheme","React","useCallback","useMemo","useRef","useState","jsx","___EmotionJSX","classNames","tooltip","arrow","_ref","process","env","NODE_ENV","name","styles","toString","_EMOTION_STRINGIFIED_CSS_ERROR__","_ref2","Tooltip","_ref3","children","title","placement","open","openProp","node","setNode","theme","isControlled","undefined","setOpen","prevOpen","hidden","setHidden","current","handleMouseEnter","original","event","handleMouseLeave","Fragment","ref","onMouseEnter","onMouseLeave","cloneElement","props","anchorEl","disablePortal","onTransitionEnd","typography","caption","className"],"sources":["../../../src/Tooltip/Tooltip.tsx"],"sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n tooltip: {\n arrow: \"m2mui_Tooltip_arrow\",\n },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n /**\n * Tooltipに表示するテキスト\n */\n title: string;\n /**\n * Tooltipを表示する要素\n * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません\n */\n children: React.ReactElement<any> | string;\n /**\n * 矢印を表示します。\n *\n * @default false\n */\n arrow?: boolean;\n /**\n * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n *\n * @default undefined\n */\n open?: boolean;\n}\n\nexport const Tooltip = ({\n children,\n title,\n placement,\n arrow,\n open: openProp,\n}: TooltipProps) => {\n const [node, setNode] = useState<HTMLElement | null>(null);\n\n const theme = useTheme();\n\n const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n const [open, setOpen] = useState(false);\n const prevOpen = useRef<boolean>(undefined);\n const [hidden, setHidden] = useState(true);\n\n if (isControlled && openProp !== prevOpen.current) {\n prevOpen.current = openProp;\n if (openProp) {\n setOpen(true);\n setHidden(false);\n } else {\n setHidden(true);\n }\n }\n\n const handleMouseEnter = useCallback(\n (original?: (event: React.MouseEvent) => void) =>\n (event: React.MouseEvent) => {\n if (!isControlled) {\n setOpen(true);\n setHidden(false);\n }\n\n if (original) {\n original(event);\n }\n },\n [isControlled],\n );\n\n const handleMouseLeave = useCallback(\n (original?: (event: React.MouseEvent) => void) =>\n (event: React.MouseEvent) => {\n if (!isControlled) {\n setHidden(true);\n }\n\n if (original) {\n original(event);\n }\n },\n [isControlled],\n );\n\n return (\n <React.Fragment>\n {typeof children === \"string\" ? (\n <span\n ref={setNode}\n onMouseEnter={handleMouseEnter()}\n onMouseLeave={handleMouseLeave()}\n >\n {children}\n </span>\n ) : (\n React.cloneElement(children, {\n ref: setNode,\n onMouseEnter: handleMouseEnter(\n hasOwnProp(children.props, \"onMouseEnter\")\n ? (children.props.onMouseEnter as React.MouseEventHandler)\n : undefined,\n ),\n onMouseLeave: handleMouseLeave(\n hasOwnProp(children.props, \"onMouseLeave\")\n ? (children.props.onMouseLeave as React.MouseEventHandler)\n : undefined,\n ),\n })\n )}\n <Popper\n anchorEl={node}\n placement={placement}\n open={open}\n aria-hidden={hidden}\n disablePortal\n onTransitionEnd={() => {\n if (hidden) {\n setOpen(false);\n }\n }}\n css={css`\n opacity: 1;\n transition: opacity 200ms;\n &[aria-hidden=\"true\"] {\n opacity: 0;\n }\n &[data-popper-placement*=\"bottom\"] {\n .${classNames.tooltip.arrow} {\n top: 0;\n left: 12px;\n width: 12px;\n height: 6px;\n margin-top: -6px;\n &::before {\n border-color: transparent transparent currentcolor transparent;\n border-width: 0 6px 6px 6px;\n }\n }\n & > * {\n margin-top: 8px;\n }\n }\n &[data-popper-placement*=\"top\"] {\n .${classNames.tooltip.arrow} {\n bottom: 0;\n left: 12px;\n width: 12px;\n height: 6px;\n margin-bottom: -6px;\n &::before {\n border-color: currentcolor transparent transparent transparent;\n border-width: 6px 6px 0 6px;\n }\n }\n & > * {\n margin-bottom: 8px;\n }\n }\n &[data-popper-placement*=\"right\"] {\n .${classNames.tooltip.arrow} {\n top: 12px;\n left: 0;\n width: 6px;\n height: 12px;\n margin-left: -6px;\n &::before {\n border-color: transparent currentcolor transparent transparent;\n border-width: 6px 6px 6px 0;\n }\n }\n & > * {\n margin-left: 8px;\n }\n }\n &[data-popper-placement*=\"left\"] {\n .${classNames.tooltip.arrow} {\n top: 12px;\n right: 0;\n width: 6px;\n height: 12px;\n margin-right: -6px;\n &::before {\n border-color: transparent transparent transparent currentcolor;\n border-width: 6px 0 6px 6px;\n }\n }\n & > * {\n margin-right: 8px;\n }\n }\n `}\n >\n <div\n css={[\n theme.typography.caption,\n css`\n position: relative;\n max-width: 300px;\n padding: 6px 10px;\n color: #fff;\n text-align: left;\n word-wrap: break-word;\n background-color: rgba(97, 97, 97, 0.9);\n border-radius: 4px;\n `,\n ]}\n >\n {title}\n {arrow ? (\n <div\n className={classNames.tooltip.arrow}\n css={css`\n position: absolute;\n color: rgba(97, 97, 97, 0.9);\n &::before {\n display: block;\n width: 0px;\n height: 0px;\n margin: auto;\n content: \"\";\n border-style: solid;\n }\n `}\n />\n ) : null}\n </div>\n </Popper>\n </React.Fragment>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CSVImportUI.js","names":["_CompleteScreen","require","_DownloadCreateTemplateScreen","_DownloadUpdateTemplateScreen","_LoadCSVScreen","_ScreenProvider","_SelectModeScreen","_UploadCSVScreen","_react","_react2","CSVImportUIContent","columns","onDownloadCSV","searchLabel","onSearchData","renderSearchField","csvPrefix","csvParser","csvValidator","onPreUploadData","onPreUploadDataByRow","onUploadData","onUploadDataByRow","acceptMode","skipDownloadTemplate","selectDownloadTemplateColumns","defaultTemplateData","id","useScreen","mode","setMode","useState","uploadedData","setUploadedData","errors","setErrors","handleUpdateData","useCallback","data","headers","useMemo","rowKeys","Object","keys","values","filter","column","length","hiddenIfNoHeader","includes","label","map","filledData","row","fromEntries","header","jsx","SelectModeScreen","onChangeMode","DownloadCreateTemplateScreen","DownloadUpdateTemplateScreen","onSearch","LoadCSVScreen","onUpdateData","UploadCSVScreen","onSubmitComplete","CompleteScreen","getFirstScreenId","accptMode","CSVImportUI","props","ScreenProvider","firstScreenId","exports"],"sources":["../../../src/CSVImportUI/CSVImportUI.tsx"],"sourcesContent":["import { AlertMessageType } from \"../Alert\";\nimport { AssertType } from \"../@types/AssertType\";\nimport { CompleteScreen } from \"./screens/CompleteScreen\";\nimport { DownloadCreateTemplateScreen } from \"./screens/DownloadCreateTemplateScreen\";\nimport { DownloadUpdateTemplateScreen } from \"./screens/DownloadUpdateTemplateScreen\";\nimport { LoadCSVScreen } from \"./screens/LoadCSVScreen\";\nimport { ScreenId } from \"./screens/types\";\nimport { ScreenProvider, useScreen } from \"./ScreenProvider\";\nimport { SelectModeScreen } from \"./screens/SelectModeScreen\";\nimport { UnionToIntersection } from \"../@types/UnionToIntersection\";\nimport { UploadCSVScreen } from \"./screens/UploadCSVScreen\";\nimport { useCallback, useMemo, useState } from \"react\";\n\nexport type Mode = \"create\" | \"update\";\n\nexport type CellError = [string, string];\n\nexport type CSVImportUIColumn = Readonly<{\n label: string;\n description?: string;\n type?: \"date\" | \"number\";\n options?: readonly string[];\n required?: boolean;\n hiddenOnCreateTemplate?: boolean;\n /**\n * アップロードされたCSVにヘッダーがなければ表示しない。\n */\n hiddenIfNoHeader?: boolean;\n renderCell?: (props: {\n value: string;\n header: string;\n row: Record<string, string>;\n }) => React.JSX.Element;\n}>;\n\n/**\n * ライブラリ利用者用の型\n */\nexport type CSVImportUIColumns = Record<string, CSVImportUIColumn>;\n\nexport interface CSVImportUIRenderSearchFieldProps<Row> {\n onChange: (args: Row[]) => void;\n}\n\ntype OptionByLabel<Columns extends CSVImportUIColumns> = {\n [Key in keyof Columns]: Record<\n Columns[Key][\"label\"],\n Columns[Key] extends {\n options: readonly (infer Option)[];\n }\n ? Option extends string\n ? Option\n : never\n : string\n >;\n}[keyof Columns];\n\nexport type CSVImportUIRow<Columns extends CSVImportUIColumns> = AssertType<\n UnionToIntersection<OptionByLabel<Columns>>,\n Record<string, string>\n>;\n\nexport interface CSVImportUIProps<\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n> {\n /**\n * 利用できるモードを指定する。\n */\n acceptMode: Mode[];\n /**\n * アップロード画面に進む前にトリガーされる。\n * 行ごとにデータを処理する。\n *\n * onPreUploadDataが指定されている場合、こちらは無視される。\n */\n onPreUploadDataByRow?: (args: {\n index: number;\n /**\n * 欠損したフィールドがある可能性があるため、型を緩くする。\n */\n row: Partial<Row>;\n mode: Mode;\n }) => Promise<{ error?: CellError; data?: Record<string, string> }>;\n /**\n * アップロード画面に進む前にトリガーされる。\n * 一括でデータをアップロードする。\n *\n * 現状onPreUploadDataByRowByRowとは異なり、行ごとにエラーを表示することはできない。\n * 代わりに、エラー時に表示されるアラートのメッセージをerrorMessageで指定する。\n *\n * 行毎にエラーを表示したくなった場合は、要望を出すこと。\n */\n onPreUploadData?: (args: { data: Partial<Row>[]; mode: Mode }) => Promise<{\n errorMessage?: AlertMessageType;\n data?: Record<string, string>[];\n }>;\n /**\n * CSVをパースしたデータのアップロードがトリガーされた際に呼ばれる。\n * 行ごとにデータをアップロードする。\n *\n * onUploadDataが指定されている場合、こちらは無視される。\n */\n onUploadDataByRow?: (args: {\n index: number;\n /**\n * 欠損したフィールドがある可能性があるため、型を緩くする。\n */\n row: Partial<Row>;\n mode: Mode;\n }) => Promise<{\n error?: CellError;\n data?: Record<string, string>;\n }>;\n /**\n * CSVをパースしたデータのアップロードがトリガーされた際に呼ばれる。\n * 一括でデータをアップロードする。\n *\n * 現状onUploadDataByRowとは異なり、行ごとにエラーを表示することはできない。\n * 代わりに、エラー時に表示されるアラートのメッセージをerrorMessageで指定する。\n *\n * 行毎にエラーを表示したくなった場合は、要望を出すこと。\n */\n onUploadData?: (args: { data: Partial<Row>[]; mode: Mode }) => Promise<{\n errorMessage?: AlertMessageType;\n data?: Record<string, string>[];\n }>;\n /**\n * 検索フォームのラベルとして利用される。\n * (only upload mode)\n */\n searchLabel?: string;\n /**\n * 検索が行われた際にトリガーされる。\n * ユーザーの入力した文字列に応じてデータを返却する。このデータはCSVとしてダウンロードされる。\n * (only upload mode)\n */\n onSearchData?: (args: { value: string }) => Promise<{\n data: Row[];\n }>;\n /**\n * CSVの各列をどのように表示するか指定する。\n * 各列には、次のプロパティが指定できる。\n *\n * `label` : CSVのヘッダーとして利用される。\n *\n * `type` : `date`または`number`が指定でき、それぞれ日付と数値としてアップロードされたCSVの値が正しいかどうかを検証する。\n *\n * `options` : その列が持てる値のリストを指定する。アップロードされたCSVの値がこのリストに含まれているかどうかを検証する。\n *\n * `required` : その列が必須かどうかを指定する。アップロードされたCSVの値が空でないかどうかを検証する。\n *\n * `renderCell` : その列のセルをどのように表示するかを指定する。その列の値、ヘッダー、行のデータが渡される。\n *\n * `hiddenOnCreateTemplate` : 作成用のCSVのテンプレートに、その列を表示しないかどうかを決定する。\n *\n * `hiddenIfNoHeader` : アップロードされたCSVにそのヘッダーがなければ、その列を表示しないかどうかを決定する。\n */\n columns: Columns;\n /**\n * ダウンロードされるCSVに付与されるプレフィックスを指定する\n */\n csvPrefix?: string;\n /**\n * CSVのダウンロードがトリガーされたときに呼ばれる\n */\n onDownloadCSV: (args: { data: Row[]; filename: string }) => void;\n /**\n * CSVがアップロードされたときに呼ばれる\n */\n csvParser: (args: {\n file: File;\n }) => Promise<{ data: Record<string, string>[] }>;\n /**\n * アップロードされたCSVのデータをバリデーションする。\n */\n csvValidator?: (args: {\n /**\n * ここで渡されるデータがRowと一致するとは限らない。\n */\n row: Record<string, string>;\n }) => Promise<{ errors?: CellError[] }>;\n /**\n * 更新モードで検索のカスタマイズをする。\n * 省略するとonSearchData, searchLabelを用いた単一の検索フィールドが表示される。これを指定するとonSearchData, searchLabelは無視される。\n * (only upload mode)\n */\n renderSearchField?: (\n props: CSVImportUIRenderSearchFieldProps<Row>,\n ) => React.JSX.Element;\n /**\n * 編集用CSVをダウンロードするページをスキップする\n */\n skipDownloadTemplate?: boolean;\n /**\n * 更新用のCSVをダウンロードする際にデフォルトで表示されるデータを指定する。\n */\n defaultTemplateData?: Row[];\n\n /**\n * ダウンロードテンプレートで利用する項目を選択するかどうかを指定する。\n * デフォルトでは、hiddenOnCreateTemplateが指定されていない列の全ての項目が追加される。\n * @default false\n */\n selectDownloadTemplateColumns?: boolean;\n}\n\nconst CSVImportUIContent = <\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n>({\n columns,\n onDownloadCSV,\n searchLabel,\n onSearchData,\n renderSearchField,\n csvPrefix,\n csvParser,\n csvValidator,\n onPreUploadData,\n onPreUploadDataByRow,\n onUploadData,\n onUploadDataByRow,\n acceptMode,\n skipDownloadTemplate,\n selectDownloadTemplateColumns,\n defaultTemplateData,\n}: CSVImportUIProps<Columns, Row>) => {\n const id = useScreen();\n const [mode, setMode] = useState<Mode>(acceptMode[0]);\n const [uploadedData, setUploadedData] = useState<Row[]>([]);\n const [errors, setErrors] = useState<(CellError[] | undefined)[]>([]);\n\n const handleUpdateData = useCallback(\n (data: Row[], errors: (CellError[] | undefined)[]) => {\n setErrors(errors);\n setUploadedData(data);\n },\n [],\n );\n\n const headers = useMemo(() => {\n const rowKeys = Object.keys(uploadedData[0] ?? {});\n\n return Object.values(columns)\n .filter((column) => {\n if (rowKeys.length === 0) {\n return true;\n }\n if (column.hiddenIfNoHeader && !rowKeys.includes(column.label)) {\n return false;\n }\n return true;\n })\n .map((column) => column.label);\n }, [columns, uploadedData]);\n\n const filledData = useMemo(() => {\n return headers.length > Object.keys(uploadedData[0] ?? {}).length\n ? uploadedData.map((row) => {\n return {\n ...Object.fromEntries(headers.map((header) => [header, \"\"])),\n ...row,\n };\n })\n : uploadedData;\n }, [headers, uploadedData]);\n\n switch (id) {\n case \"selectMode\": {\n return (\n <SelectModeScreen\n skipDownloadTemplate={skipDownloadTemplate}\n onChangeMode={setMode}\n />\n );\n }\n case \"downloadCreateTemplate\": {\n return (\n <DownloadCreateTemplateScreen\n onDownloadCSV={onDownloadCSV}\n headers={headers}\n columns={columns}\n csvPrefix={csvPrefix}\n selectDownloadTemplateColumns={selectDownloadTemplateColumns}\n />\n );\n }\n case \"downloadUpdateTemplate\": {\n return (\n <DownloadUpdateTemplateScreen\n searchLabel={searchLabel}\n onSearch={onSearchData}\n renderSearchField={renderSearchField}\n onDownloadCSV={onDownloadCSV}\n csvPrefix={csvPrefix}\n headers={headers}\n defaultTemplateData={defaultTemplateData}\n columns={columns}\n />\n );\n }\n case \"loadCSV\": {\n return (\n <LoadCSVScreen\n mode={mode}\n columns={columns}\n data={filledData}\n headers={headers}\n errors={errors}\n csvParser={csvParser}\n csvValidator={csvValidator}\n onPreUploadData={onPreUploadData}\n onPreUploadDataByRow={onPreUploadDataByRow}\n onUpdateData={handleUpdateData}\n />\n );\n }\n case \"uploadCSV\": {\n return (\n <UploadCSVScreen\n mode={mode}\n data={filledData}\n headers={headers}\n errors={errors}\n columns={columns}\n onUploadData={onUploadData}\n onUploadDataByRow={onUploadDataByRow}\n onSubmitComplete={handleUpdateData}\n />\n );\n }\n case \"complete\": {\n return (\n <CompleteScreen\n csvPrefix={csvPrefix}\n onDownloadCSV={onDownloadCSV}\n data={filledData}\n columns={columns}\n headers={headers}\n errors={errors}\n />\n );\n }\n default: {\n return null;\n }\n }\n};\n\nconst getFirstScreenId = (\n accptMode: Mode[],\n skipDownloadTemplate?: boolean,\n): ScreenId => {\n if (accptMode.length > 1) {\n return \"selectMode\";\n }\n if (skipDownloadTemplate) {\n return \"loadCSV\";\n }\n if (accptMode[0] === \"create\") {\n return \"downloadCreateTemplate\";\n }\n if (accptMode[0] === \"update\") {\n return \"downloadUpdateTemplate\";\n }\n return \"selectMode\";\n};\n\nexport const CSVImportUI = <\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n>(\n props: CSVImportUIProps<Columns, Row>,\n) => {\n return (\n <ScreenProvider\n firstScreenId={getFirstScreenId(\n props.acceptMode,\n props.skipDownloadTemplate,\n )}\n >\n <CSVImportUIContent {...props} />\n </ScreenProvider>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"CSVImportUI.js","names":["_CompleteScreen","require","_DownloadCreateTemplateScreen","_DownloadUpdateTemplateScreen","_LoadCSVScreen","_ScreenProvider","_SelectModeScreen","_UploadCSVScreen","_react","_react2","CSVImportUIContent","columns","onDownloadCSV","searchLabel","onSearchData","renderSearchField","csvPrefix","csvParser","csvValidator","onPreUploadData","onPreUploadDataByRow","onUploadData","onUploadDataByRow","acceptMode","skipDownloadTemplate","selectDownloadTemplateColumns","defaultTemplateData","id","useScreen","mode","setMode","useState","uploadedData","setUploadedData","errors","setErrors","handleUpdateData","useCallback","data","headers","useMemo","rowKeys","Object","keys","values","filter","column","length","hiddenIfNoHeader","includes","label","map","filledData","row","fromEntries","header","jsx","SelectModeScreen","onChangeMode","DownloadCreateTemplateScreen","DownloadUpdateTemplateScreen","onSearch","LoadCSVScreen","onUpdateData","UploadCSVScreen","onSubmitComplete","CompleteScreen","getFirstScreenId","accptMode","CSVImportUI","props","ScreenProvider","firstScreenId","exports"],"sources":["../../../src/CSVImportUI/CSVImportUI.tsx"],"sourcesContent":["import { AlertMessageType } from \"../Alert\";\nimport { AssertType } from \"../@types/AssertType\";\nimport { CompleteScreen } from \"./screens/CompleteScreen\";\nimport { DownloadCreateTemplateScreen } from \"./screens/DownloadCreateTemplateScreen\";\nimport { DownloadUpdateTemplateScreen } from \"./screens/DownloadUpdateTemplateScreen\";\nimport { LoadCSVScreen } from \"./screens/LoadCSVScreen\";\nimport { ScreenId } from \"./screens/types\";\nimport { ScreenProvider, useScreen } from \"./ScreenProvider\";\nimport { SelectModeScreen } from \"./screens/SelectModeScreen\";\nimport { UnionToIntersection } from \"../@types/UnionToIntersection\";\nimport { UploadCSVScreen } from \"./screens/UploadCSVScreen\";\nimport { useCallback, useMemo, useState } from \"react\";\n\nexport type Mode = \"create\" | \"update\";\n\nexport type CellError = [string, string];\n\nexport type CSVImportUIColumn = Readonly<{\n label: string;\n description?: string;\n type?: \"date\" | \"number\";\n options?: readonly string[];\n required?: boolean;\n hiddenOnCreateTemplate?: boolean;\n /**\n * アップロードされたCSVにヘッダーがなければ表示しない。\n */\n hiddenIfNoHeader?: boolean;\n renderCell?: (props: {\n value: string;\n header: string;\n row: Record<string, string>;\n }) => React.JSX.Element;\n}>;\n\n/**\n * ライブラリ利用者用の型\n */\nexport type CSVImportUIColumns = Record<string, CSVImportUIColumn>;\n\nexport interface CSVImportUIRenderSearchFieldProps<Row> {\n onChange: (args: Row[]) => void;\n}\n\ntype OptionByLabel<Columns extends CSVImportUIColumns> = {\n [Key in keyof Columns]: Record<\n Columns[Key][\"label\"],\n Columns[Key] extends {\n options: readonly (infer Option)[];\n }\n ? Option extends string\n ? Option\n : never\n : string\n >;\n}[keyof Columns];\n\nexport type CSVImportUIRow<Columns extends CSVImportUIColumns> = AssertType<\n UnionToIntersection<OptionByLabel<Columns>>,\n Record<string, string>\n>;\n\nexport interface CSVImportUIProps<\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n> {\n /**\n * 利用できるモードを指定する。\n */\n acceptMode: Mode[];\n /**\n * アップロード画面に進む前にトリガーされる。\n * 行ごとにデータを処理する。\n *\n * onPreUploadDataが指定されている場合、こちらは無視される。\n *\n * この関数内でsetStateを使用すると、行ごとの処理で過剰なレンダリングを引き起こす可能性があります。\n * 状態更新が必要な場合は、以下の方法を検討してください:\n * - onPreUploadDataを使用して一括でデータを処理する\n * - 複数の更新をバッチ処理して、すべての行の処理後に一度だけ状態を更新する\n * - レンダリングを必要としない中間値にはuseRefを使用する\n */\n onPreUploadDataByRow?: (args: {\n index: number;\n /**\n * 欠損したフィールドがある可能性があるため、型を緩くする。\n */\n row: Partial<Row>;\n mode: Mode;\n }) => Promise<{ error?: CellError; data?: Record<string, string> }>;\n /**\n * アップロード画面に進む前にトリガーされる。\n * 一括でデータをアップロードする。\n *\n * 現状onPreUploadDataByRowByRowとは異なり、行ごとにエラーを表示することはできない。\n * 代わりに、エラー時に表示されるアラートのメッセージをerrorMessageで指定する。\n *\n * 行毎にエラーを表示したくなった場合は、要望を出すこと。\n */\n onPreUploadData?: (args: { data: Partial<Row>[]; mode: Mode }) => Promise<{\n errorMessage?: AlertMessageType;\n data?: Record<string, string>[];\n }>;\n /**\n * CSVをパースしたデータのアップロードがトリガーされた際に呼ばれる。\n * 行ごとにデータをアップロードする。\n *\n * onUploadDataが指定されている場合、こちらは無視される。\n *\n * この関数内でsetStateを使用すると、行ごとの処理で過剰なレンダリングを引き起こす可能性があります。\n * 状態更新が必要な場合は、以下の方法を検討してください:\n * - onUploadDataを使用して一括でデータを処理する\n * - 複数の更新をバッチ処理して、すべての行の処理後に一度だけ状態を更新する\n * - レンダリングを必要としない中間値にはuseRefを使用する\n */\n onUploadDataByRow?: (args: {\n index: number;\n /**\n * 欠損したフィールドがある可能性があるため、型を緩くする。\n */\n row: Partial<Row>;\n mode: Mode;\n }) => Promise<{\n error?: CellError;\n data?: Record<string, string>;\n }>;\n /**\n * CSVをパースしたデータのアップロードがトリガーされた際に呼ばれる。\n * 一括でデータをアップロードする。\n *\n * 現状onUploadDataByRowとは異なり、行ごとにエラーを表示することはできない。\n * 代わりに、エラー時に表示されるアラートのメッセージをerrorMessageで指定する。\n *\n * 行毎にエラーを表示したくなった場合は、要望を出すこと。\n */\n onUploadData?: (args: { data: Partial<Row>[]; mode: Mode }) => Promise<{\n errorMessage?: AlertMessageType;\n data?: Record<string, string>[];\n }>;\n /**\n * 検索フォームのラベルとして利用される。\n * (only upload mode)\n */\n searchLabel?: string;\n /**\n * 検索が行われた際にトリガーされる。\n * ユーザーの入力した文字列に応じてデータを返却する。このデータはCSVとしてダウンロードされる。\n * (only upload mode)\n */\n onSearchData?: (args: { value: string }) => Promise<{\n data: Row[];\n }>;\n /**\n * CSVの各列をどのように表示するか指定する。\n * 各列には、次のプロパティが指定できる。\n *\n * `label` : CSVのヘッダーとして利用される。\n *\n * `type` : `date`または`number`が指定でき、それぞれ日付と数値としてアップロードされたCSVの値が正しいかどうかを検証する。\n *\n * `options` : その列が持てる値のリストを指定する。アップロードされたCSVの値がこのリストに含まれているかどうかを検証する。\n *\n * `required` : その列が必須かどうかを指定する。アップロードされたCSVの値が空でないかどうかを検証する。\n *\n * `renderCell` : その列のセルをどのように表示するかを指定する。その列の値、ヘッダー、行のデータが渡される。\n *\n * `hiddenOnCreateTemplate` : 作成用のCSVのテンプレートに、その列を表示しないかどうかを決定する。\n *\n * `hiddenIfNoHeader` : アップロードされたCSVにそのヘッダーがなければ、その列を表示しないかどうかを決定する。\n */\n columns: Columns;\n /**\n * ダウンロードされるCSVに付与されるプレフィックスを指定する\n */\n csvPrefix?: string;\n /**\n * CSVのダウンロードがトリガーされたときに呼ばれる\n */\n onDownloadCSV: (args: { data: Row[]; filename: string }) => void;\n /**\n * CSVがアップロードされたときに呼ばれる\n */\n csvParser: (args: {\n file: File;\n }) => Promise<{ data: Record<string, string>[] }>;\n /**\n * アップロードされたCSVのデータをバリデーションする。\n */\n csvValidator?: (args: {\n /**\n * ここで渡されるデータがRowと一致するとは限らない。\n */\n row: Record<string, string>;\n }) => Promise<{ errors?: CellError[] }>;\n /**\n * 更新モードで検索のカスタマイズをする。\n * 省略するとonSearchData, searchLabelを用いた単一の検索フィールドが表示される。これを指定するとonSearchData, searchLabelは無視される。\n * (only upload mode)\n */\n renderSearchField?: (\n props: CSVImportUIRenderSearchFieldProps<Row>,\n ) => React.JSX.Element;\n /**\n * 編集用CSVをダウンロードするページをスキップする\n */\n skipDownloadTemplate?: boolean;\n /**\n * 更新用のCSVをダウンロードする際にデフォルトで表示されるデータを指定する。\n */\n defaultTemplateData?: Row[];\n\n /**\n * ダウンロードテンプレートで利用する項目を選択するかどうかを指定する。\n * デフォルトでは、hiddenOnCreateTemplateが指定されていない列の全ての項目が追加される。\n * @default false\n */\n selectDownloadTemplateColumns?: boolean;\n}\n\nconst CSVImportUIContent = <\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n>({\n columns,\n onDownloadCSV,\n searchLabel,\n onSearchData,\n renderSearchField,\n csvPrefix,\n csvParser,\n csvValidator,\n onPreUploadData,\n onPreUploadDataByRow,\n onUploadData,\n onUploadDataByRow,\n acceptMode,\n skipDownloadTemplate,\n selectDownloadTemplateColumns,\n defaultTemplateData,\n}: CSVImportUIProps<Columns, Row>) => {\n const id = useScreen();\n const [mode, setMode] = useState<Mode>(acceptMode[0]);\n const [uploadedData, setUploadedData] = useState<Row[]>([]);\n const [errors, setErrors] = useState<(CellError[] | undefined)[]>([]);\n\n const handleUpdateData = useCallback(\n (data: Row[], errors: (CellError[] | undefined)[]) => {\n setErrors(errors);\n setUploadedData(data);\n },\n [],\n );\n\n const headers = useMemo(() => {\n const rowKeys = Object.keys(uploadedData[0] ?? {});\n\n return Object.values(columns)\n .filter((column) => {\n if (rowKeys.length === 0) {\n return true;\n }\n if (column.hiddenIfNoHeader && !rowKeys.includes(column.label)) {\n return false;\n }\n return true;\n })\n .map((column) => column.label);\n }, [columns, uploadedData]);\n\n const filledData = useMemo(() => {\n return headers.length > Object.keys(uploadedData[0] ?? {}).length\n ? uploadedData.map((row) => {\n return {\n ...Object.fromEntries(headers.map((header) => [header, \"\"])),\n ...row,\n };\n })\n : uploadedData;\n }, [headers, uploadedData]);\n\n switch (id) {\n case \"selectMode\": {\n return (\n <SelectModeScreen\n skipDownloadTemplate={skipDownloadTemplate}\n onChangeMode={setMode}\n />\n );\n }\n case \"downloadCreateTemplate\": {\n return (\n <DownloadCreateTemplateScreen\n onDownloadCSV={onDownloadCSV}\n headers={headers}\n columns={columns}\n csvPrefix={csvPrefix}\n selectDownloadTemplateColumns={selectDownloadTemplateColumns}\n />\n );\n }\n case \"downloadUpdateTemplate\": {\n return (\n <DownloadUpdateTemplateScreen\n searchLabel={searchLabel}\n onSearch={onSearchData}\n renderSearchField={renderSearchField}\n onDownloadCSV={onDownloadCSV}\n csvPrefix={csvPrefix}\n headers={headers}\n defaultTemplateData={defaultTemplateData}\n columns={columns}\n />\n );\n }\n case \"loadCSV\": {\n return (\n <LoadCSVScreen\n mode={mode}\n columns={columns}\n data={filledData}\n headers={headers}\n errors={errors}\n csvParser={csvParser}\n csvValidator={csvValidator}\n onPreUploadData={onPreUploadData}\n onPreUploadDataByRow={onPreUploadDataByRow}\n onUpdateData={handleUpdateData}\n />\n );\n }\n case \"uploadCSV\": {\n return (\n <UploadCSVScreen\n mode={mode}\n data={filledData}\n headers={headers}\n errors={errors}\n columns={columns}\n onUploadData={onUploadData}\n onUploadDataByRow={onUploadDataByRow}\n onSubmitComplete={handleUpdateData}\n />\n );\n }\n case \"complete\": {\n return (\n <CompleteScreen\n csvPrefix={csvPrefix}\n onDownloadCSV={onDownloadCSV}\n data={filledData}\n columns={columns}\n headers={headers}\n errors={errors}\n />\n );\n }\n default: {\n return null;\n }\n }\n};\n\nconst getFirstScreenId = (\n accptMode: Mode[],\n skipDownloadTemplate?: boolean,\n): ScreenId => {\n if (accptMode.length > 1) {\n return \"selectMode\";\n }\n if (skipDownloadTemplate) {\n return \"loadCSV\";\n }\n if (accptMode[0] === \"create\") {\n return \"downloadCreateTemplate\";\n }\n if (accptMode[0] === \"update\") {\n return \"downloadUpdateTemplate\";\n }\n return \"selectMode\";\n};\n\nexport const CSVImportUI = <\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n>(\n props: CSVImportUIProps<Columns, Row>,\n) => {\n return (\n <ScreenProvider\n firstScreenId={getFirstScreenId(\n props.acceptMode,\n props.skipDownloadTemplate,\n )}\n >\n <CSVImportUIContent {...props} />\n </ScreenProvider>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
package/cjs/Tooltip/Tooltip.js
CHANGED
|
@@ -20,7 +20,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
20
20
|
styles: "position:absolute;color:rgba(97, 97, 97, 0.9);&::before{display:block;width:0px;height:0px;margin:auto;content:\"\";border-style:solid;}"
|
|
21
21
|
} : {
|
|
22
22
|
name: "ynymi0-Tooltip",
|
|
23
|
-
styles: "position:absolute;color:rgba(97, 97, 97, 0.9);&::before{display:block;width:0px;height:0px;margin:auto;content:\"\";border-style:solid;};label:Tooltip;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
23
|
+
styles: "position:absolute;color:rgba(97, 97, 97, 0.9);&::before{display:block;width:0px;height:0px;margin:auto;content:\"\";border-style:solid;};label:Tooltip;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AA2NsB","file":"../../../src/Tooltip/Tooltip.tsx","sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n  tooltip: {\n    arrow: \"m2mui_Tooltip_arrow\",\n  },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n  /**\n   * Tooltipに表示するテキスト\n   */\n  title: string;\n  /**\n   * Tooltipを表示する要素\n   * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません\n   */\n  children: React.ReactElement<any> | string;\n  /**\n   * 矢印を表示します。\n   *\n   * @default false\n   */\n  arrow?: boolean;\n  /**\n   * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n   *\n   * @default undefined\n   */\n  open?: boolean;\n}\n\nexport const Tooltip = ({\n  children,\n  title,\n  placement,\n  arrow,\n  open: openProp,\n}: TooltipProps) => {\n  const [node, setNode] = useState<HTMLElement | null>(null);\n\n  const theme = useTheme();\n\n  const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n  const [open, setOpen] = useState(false);\n  const prevOpen = useRef<boolean>(undefined);\n  const [hidden, setHidden] = useState(true);\n\n  if (isControlled && openProp !== prevOpen.current) {\n    prevOpen.current = openProp;\n    if (openProp) {\n      setOpen(true);\n      setHidden(false);\n    } else {\n      setHidden(true);\n    }\n  }\n\n  const handleMouseEnter = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setOpen(true);\n          setHidden(false);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  const handleMouseLeave = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setHidden(true);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  return (\n    <React.Fragment>\n      {typeof children === \"string\" ? (\n        <span\n          ref={setNode}\n          onMouseEnter={handleMouseEnter()}\n          onMouseLeave={handleMouseLeave()}\n        >\n          {children}\n        </span>\n      ) : (\n        React.cloneElement(children, {\n          ref: setNode,\n          onMouseEnter: handleMouseEnter(\n            hasOwnProp(children.props, \"onMouseEnter\")\n              ? (children.props.onMouseEnter as React.MouseEventHandler)\n              : undefined,\n          ),\n          onMouseLeave: handleMouseLeave(\n            hasOwnProp(children.props, \"onMouseLeave\")\n              ? (children.props.onMouseLeave as React.MouseEventHandler)\n              : undefined,\n          ),\n        })\n      )}\n      <Popper\n        anchorEl={node}\n        placement={placement}\n        open={open}\n        aria-hidden={hidden}\n        disablePortal\n        onTransitionEnd={() => {\n          if (hidden) {\n            setOpen(false);\n          }\n        }}\n        css={css`\n          opacity: 1;\n          transition: opacity 200ms;\n          &[aria-hidden=\"true\"] {\n            opacity: 0;\n          }\n          &[data-popper-placement*=\"bottom\"] {\n            .${classNames.tooltip.arrow} {\n              top: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-top: -6px;\n              &::before {\n                border-color: transparent transparent currentcolor transparent;\n                border-width: 0 6px 6px 6px;\n              }\n            }\n            & > * {\n              margin-top: 8px;\n            }\n          }\n          &[data-popper-placement*=\"top\"] {\n            .${classNames.tooltip.arrow} {\n              bottom: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-bottom: -6px;\n              &::before {\n                border-color: currentcolor transparent transparent transparent;\n                border-width: 6px 6px 0 6px;\n              }\n            }\n            & > * {\n              margin-bottom: 8px;\n            }\n          }\n          &[data-popper-placement*=\"right\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              left: 0;\n              width: 6px;\n              height: 12px;\n              margin-left: -6px;\n              &::before {\n                border-color: transparent currentcolor transparent transparent;\n                border-width: 6px 6px 6px 0;\n              }\n            }\n            & > * {\n              margin-left: 8px;\n            }\n          }\n          &[data-popper-placement*=\"left\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              right: 0;\n              width: 6px;\n              height: 12px;\n              margin-right: -6px;\n              &::before {\n                border-color: transparent transparent transparent currentcolor;\n                border-width: 6px 0 6px 6px;\n              }\n            }\n            & > * {\n              margin-right: 8px;\n            }\n          }\n        `}\n      >\n        <div\n          css={[\n            theme.typography.caption,\n            css`\n              position: relative;\n              max-width: 300px;\n              padding: 6px 10px;\n              color: #fff;\n              text-align: left;\n              word-wrap: break-word;\n              background-color: rgba(97, 97, 97, 0.9);\n              border-radius: 4px;\n            `,\n          ]}\n        >\n          {title}\n          {arrow ? (\n            <div\n              className={classNames.tooltip.arrow}\n              css={css`\n                position: absolute;\n                color: rgba(97, 97, 97, 0.9);\n                &::before {\n                  display: block;\n                  width: 0px;\n                  height: 0px;\n                  margin: auto;\n                  content: \"\";\n                  border-style: solid;\n                }\n              `}\n            />\n          ) : null}\n        </div>\n      </Popper>\n    </React.Fragment>\n  );\n};\n"]} */",
|
|
24
24
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
25
25
|
};
|
|
26
26
|
var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
@@ -28,7 +28,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
|
28
28
|
styles: "position:relative;max-width:300px;padding:6px 10px;color:#fff;text-align:left;word-wrap:break-word;background-color:rgba(97, 97, 97, 0.9);border-radius:4px"
|
|
29
29
|
} : {
|
|
30
30
|
name: "1350k6g-Tooltip",
|
|
31
|
-
styles: "position:relative;max-width:300px;padding:6px 10px;color:#fff;text-align:left;word-wrap:break-word;background-color:rgba(97, 97, 97, 0.9);border-radius:4px;label:Tooltip;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
31
|
+
styles: "position:relative;max-width:300px;padding:6px 10px;color:#fff;text-align:left;word-wrap:break-word;background-color:rgba(97, 97, 97, 0.9);border-radius:4px;label:Tooltip;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AA2Me","file":"../../../src/Tooltip/Tooltip.tsx","sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n  tooltip: {\n    arrow: \"m2mui_Tooltip_arrow\",\n  },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n  /**\n   * Tooltipに表示するテキスト\n   */\n  title: string;\n  /**\n   * Tooltipを表示する要素\n   * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません\n   */\n  children: React.ReactElement<any> | string;\n  /**\n   * 矢印を表示します。\n   *\n   * @default false\n   */\n  arrow?: boolean;\n  /**\n   * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n   *\n   * @default undefined\n   */\n  open?: boolean;\n}\n\nexport const Tooltip = ({\n  children,\n  title,\n  placement,\n  arrow,\n  open: openProp,\n}: TooltipProps) => {\n  const [node, setNode] = useState<HTMLElement | null>(null);\n\n  const theme = useTheme();\n\n  const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n  const [open, setOpen] = useState(false);\n  const prevOpen = useRef<boolean>(undefined);\n  const [hidden, setHidden] = useState(true);\n\n  if (isControlled && openProp !== prevOpen.current) {\n    prevOpen.current = openProp;\n    if (openProp) {\n      setOpen(true);\n      setHidden(false);\n    } else {\n      setHidden(true);\n    }\n  }\n\n  const handleMouseEnter = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setOpen(true);\n          setHidden(false);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  const handleMouseLeave = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setHidden(true);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  return (\n    <React.Fragment>\n      {typeof children === \"string\" ? (\n        <span\n          ref={setNode}\n          onMouseEnter={handleMouseEnter()}\n          onMouseLeave={handleMouseLeave()}\n        >\n          {children}\n        </span>\n      ) : (\n        React.cloneElement(children, {\n          ref: setNode,\n          onMouseEnter: handleMouseEnter(\n            hasOwnProp(children.props, \"onMouseEnter\")\n              ? (children.props.onMouseEnter as React.MouseEventHandler)\n              : undefined,\n          ),\n          onMouseLeave: handleMouseLeave(\n            hasOwnProp(children.props, \"onMouseLeave\")\n              ? (children.props.onMouseLeave as React.MouseEventHandler)\n              : undefined,\n          ),\n        })\n      )}\n      <Popper\n        anchorEl={node}\n        placement={placement}\n        open={open}\n        aria-hidden={hidden}\n        disablePortal\n        onTransitionEnd={() => {\n          if (hidden) {\n            setOpen(false);\n          }\n        }}\n        css={css`\n          opacity: 1;\n          transition: opacity 200ms;\n          &[aria-hidden=\"true\"] {\n            opacity: 0;\n          }\n          &[data-popper-placement*=\"bottom\"] {\n            .${classNames.tooltip.arrow} {\n              top: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-top: -6px;\n              &::before {\n                border-color: transparent transparent currentcolor transparent;\n                border-width: 0 6px 6px 6px;\n              }\n            }\n            & > * {\n              margin-top: 8px;\n            }\n          }\n          &[data-popper-placement*=\"top\"] {\n            .${classNames.tooltip.arrow} {\n              bottom: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-bottom: -6px;\n              &::before {\n                border-color: currentcolor transparent transparent transparent;\n                border-width: 6px 6px 0 6px;\n              }\n            }\n            & > * {\n              margin-bottom: 8px;\n            }\n          }\n          &[data-popper-placement*=\"right\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              left: 0;\n              width: 6px;\n              height: 12px;\n              margin-left: -6px;\n              &::before {\n                border-color: transparent currentcolor transparent transparent;\n                border-width: 6px 6px 6px 0;\n              }\n            }\n            & > * {\n              margin-left: 8px;\n            }\n          }\n          &[data-popper-placement*=\"left\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              right: 0;\n              width: 6px;\n              height: 12px;\n              margin-right: -6px;\n              &::before {\n                border-color: transparent transparent transparent currentcolor;\n                border-width: 6px 0 6px 6px;\n              }\n            }\n            & > * {\n              margin-right: 8px;\n            }\n          }\n        `}\n      >\n        <div\n          css={[\n            theme.typography.caption,\n            css`\n              position: relative;\n              max-width: 300px;\n              padding: 6px 10px;\n              color: #fff;\n              text-align: left;\n              word-wrap: break-word;\n              background-color: rgba(97, 97, 97, 0.9);\n              border-radius: 4px;\n            `,\n          ]}\n        >\n          {title}\n          {arrow ? (\n            <div\n              className={classNames.tooltip.arrow}\n              css={css`\n                position: absolute;\n                color: rgba(97, 97, 97, 0.9);\n                &::before {\n                  display: block;\n                  width: 0px;\n                  height: 0px;\n                  margin: auto;\n                  content: \"\";\n                  border-style: solid;\n                }\n              `}\n            />\n          ) : null}\n        </div>\n      </Popper>\n    </React.Fragment>\n  );\n};\n"]} */",
|
|
32
32
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
33
33
|
};
|
|
34
34
|
const Tooltip = ({
|
|
@@ -89,9 +89,9 @@ const Tooltip = ({
|
|
|
89
89
|
setOpen(false);
|
|
90
90
|
}
|
|
91
91
|
},
|
|
92
|
-
css: /*#__PURE__*/(0, _react.css)("opacity:1;transition:opacity 200ms;&[aria-hidden=\"true\"]{opacity:0;}&[data-popper-placement*=\"bottom\"]{.", classNames.tooltip.arrow, "{top:0;left:12px;width:12px;height:6px;margin-top:-6px;&::before{border-color:transparent transparent currentcolor transparent;border-width:0 6px 6px 6px;}}&>*{margin-top:8px;}}&[data-popper-placement*=\"top\"]{.", classNames.tooltip.arrow, "{bottom:0;left:12px;width:12px;height:6px;margin-bottom:-6px;&::before{border-color:currentcolor transparent transparent transparent;border-width:6px 6px 0 6px;}}&>*{margin-bottom:8px;}}&[data-popper-placement*=\"right\"]{.", classNames.tooltip.arrow, "{top:12px;left:0;width:6px;height:12px;margin-left:-6px;&::before{border-color:transparent currentcolor transparent transparent;border-width:6px 6px 6px 0;}}&>*{margin-left:8px;}}&[data-popper-placement*=\"left\"]{.", classNames.tooltip.arrow, "{top:12px;right:0;width:6px;height:12px;margin-right:-6px;&::before{border-color:transparent transparent transparent currentcolor;border-width:6px 0 6px 6px;}}&>*{margin-right:8px;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AAyHgB","file":"../../../src/Tooltip/Tooltip.tsx","sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n  tooltip: {\n    arrow: \"m2mui_Tooltip_arrow\",\n  },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n  title: string;\n  children: React.ReactElement<any> | string;\n  /**\n   * 矢印を表示します。\n   *\n   * @default false\n   */\n  arrow?: boolean;\n  /**\n   * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n   *\n   * @default undefined\n   */\n  open?: boolean;\n}\n\nexport const Tooltip = ({\n  children,\n  title,\n  placement,\n  arrow,\n  open: openProp,\n}: TooltipProps) => {\n  const [node, setNode] = useState<HTMLElement | null>(null);\n\n  const theme = useTheme();\n\n  const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n  const [open, setOpen] = useState(false);\n  const prevOpen = useRef<boolean>(undefined);\n  const [hidden, setHidden] = useState(true);\n\n  if (isControlled && openProp !== prevOpen.current) {\n    prevOpen.current = openProp;\n    if (openProp) {\n      setOpen(true);\n      setHidden(false);\n    } else {\n      setHidden(true);\n    }\n  }\n\n  const handleMouseEnter = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setOpen(true);\n          setHidden(false);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  const handleMouseLeave = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setHidden(true);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  return (\n    <React.Fragment>\n      {typeof children === \"string\" ? (\n        <span\n          ref={setNode}\n          onMouseEnter={handleMouseEnter()}\n          onMouseLeave={handleMouseLeave()}\n        >\n          {children}\n        </span>\n      ) : (\n        React.cloneElement(children, {\n          ref: setNode,\n          onMouseEnter: handleMouseEnter(\n            hasOwnProp(children.props, \"onMouseEnter\")\n              ? (children.props.onMouseEnter as React.MouseEventHandler)\n              : undefined,\n          ),\n          onMouseLeave: handleMouseLeave(\n            hasOwnProp(children.props, \"onMouseLeave\")\n              ? (children.props.onMouseLeave as React.MouseEventHandler)\n              : undefined,\n          ),\n        })\n      )}\n      <Popper\n        anchorEl={node}\n        placement={placement}\n        open={open}\n        aria-hidden={hidden}\n        disablePortal\n        onTransitionEnd={() => {\n          if (hidden) {\n            setOpen(false);\n          }\n        }}\n        css={css`\n          opacity: 1;\n          transition: opacity 200ms;\n          &[aria-hidden=\"true\"] {\n            opacity: 0;\n          }\n          &[data-popper-placement*=\"bottom\"] {\n            .${classNames.tooltip.arrow} {\n              top: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-top: -6px;\n              &::before {\n                border-color: transparent transparent currentcolor transparent;\n                border-width: 0 6px 6px 6px;\n              }\n            }\n            & > * {\n              margin-top: 8px;\n            }\n          }\n          &[data-popper-placement*=\"top\"] {\n            .${classNames.tooltip.arrow} {\n              bottom: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-bottom: -6px;\n              &::before {\n                border-color: currentcolor transparent transparent transparent;\n                border-width: 6px 6px 0 6px;\n              }\n            }\n            & > * {\n              margin-bottom: 8px;\n            }\n          }\n          &[data-popper-placement*=\"right\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              left: 0;\n              width: 6px;\n              height: 12px;\n              margin-left: -6px;\n              &::before {\n                border-color: transparent currentcolor transparent transparent;\n                border-width: 6px 6px 6px 0;\n              }\n            }\n            & > * {\n              margin-left: 8px;\n            }\n          }\n          &[data-popper-placement*=\"left\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              right: 0;\n              width: 6px;\n              height: 12px;\n              margin-right: -6px;\n              &::before {\n                border-color: transparent transparent transparent currentcolor;\n                border-width: 6px 0 6px 6px;\n              }\n            }\n            & > * {\n              margin-right: 8px;\n            }\n          }\n        `}\n      >\n        <div\n          css={[\n            theme.typography.caption,\n            css`\n              position: relative;\n              max-width: 300px;\n              padding: 6px 10px;\n              color: #fff;\n              text-align: left;\n              word-wrap: break-word;\n              background-color: rgba(97, 97, 97, 0.9);\n              border-radius: 4px;\n            `,\n          ]}\n        >\n          {title}\n          {arrow ? (\n            <div\n              className={classNames.tooltip.arrow}\n              css={css`\n                position: absolute;\n                color: rgba(97, 97, 97, 0.9);\n                &::before {\n                  display: block;\n                  width: 0px;\n                  height: 0px;\n                  margin: auto;\n                  content: \"\";\n                  border-style: solid;\n                }\n              `}\n            />\n          ) : null}\n        </div>\n      </Popper>\n    </React.Fragment>\n  );\n};\n"]} */")
|
|
92
|
+
css: /*#__PURE__*/(0, _react.css)("opacity:1;transition:opacity 200ms;&[aria-hidden=\"true\"]{opacity:0;}&[data-popper-placement*=\"bottom\"]{.", classNames.tooltip.arrow, "{top:0;left:12px;width:12px;height:6px;margin-top:-6px;&::before{border-color:transparent transparent currentcolor transparent;border-width:0 6px 6px 6px;}}&>*{margin-top:8px;}}&[data-popper-placement*=\"top\"]{.", classNames.tooltip.arrow, "{bottom:0;left:12px;width:12px;height:6px;margin-bottom:-6px;&::before{border-color:currentcolor transparent transparent transparent;border-width:6px 6px 0 6px;}}&>*{margin-bottom:8px;}}&[data-popper-placement*=\"right\"]{.", classNames.tooltip.arrow, "{top:12px;left:0;width:6px;height:12px;margin-left:-6px;&::before{border-color:transparent currentcolor transparent transparent;border-width:6px 6px 6px 0;}}&>*{margin-left:8px;}}&[data-popper-placement*=\"left\"]{.", classNames.tooltip.arrow, "{top:12px;right:0;width:6px;height:12px;margin-right:-6px;&::before{border-color:transparent transparent transparent currentcolor;border-width:6px 0 6px 6px;}}&>*{margin-right:8px;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AAgIgB","file":"../../../src/Tooltip/Tooltip.tsx","sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n  tooltip: {\n    arrow: \"m2mui_Tooltip_arrow\",\n  },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n  /**\n   * Tooltipに表示するテキスト\n   */\n  title: string;\n  /**\n   * Tooltipを表示する要素\n   * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません\n   */\n  children: React.ReactElement<any> | string;\n  /**\n   * 矢印を表示します。\n   *\n   * @default false\n   */\n  arrow?: boolean;\n  /**\n   * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n   *\n   * @default undefined\n   */\n  open?: boolean;\n}\n\nexport const Tooltip = ({\n  children,\n  title,\n  placement,\n  arrow,\n  open: openProp,\n}: TooltipProps) => {\n  const [node, setNode] = useState<HTMLElement | null>(null);\n\n  const theme = useTheme();\n\n  const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n  const [open, setOpen] = useState(false);\n  const prevOpen = useRef<boolean>(undefined);\n  const [hidden, setHidden] = useState(true);\n\n  if (isControlled && openProp !== prevOpen.current) {\n    prevOpen.current = openProp;\n    if (openProp) {\n      setOpen(true);\n      setHidden(false);\n    } else {\n      setHidden(true);\n    }\n  }\n\n  const handleMouseEnter = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setOpen(true);\n          setHidden(false);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  const handleMouseLeave = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setHidden(true);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  return (\n    <React.Fragment>\n      {typeof children === \"string\" ? (\n        <span\n          ref={setNode}\n          onMouseEnter={handleMouseEnter()}\n          onMouseLeave={handleMouseLeave()}\n        >\n          {children}\n        </span>\n      ) : (\n        React.cloneElement(children, {\n          ref: setNode,\n          onMouseEnter: handleMouseEnter(\n            hasOwnProp(children.props, \"onMouseEnter\")\n              ? (children.props.onMouseEnter as React.MouseEventHandler)\n              : undefined,\n          ),\n          onMouseLeave: handleMouseLeave(\n            hasOwnProp(children.props, \"onMouseLeave\")\n              ? (children.props.onMouseLeave as React.MouseEventHandler)\n              : undefined,\n          ),\n        })\n      )}\n      <Popper\n        anchorEl={node}\n        placement={placement}\n        open={open}\n        aria-hidden={hidden}\n        disablePortal\n        onTransitionEnd={() => {\n          if (hidden) {\n            setOpen(false);\n          }\n        }}\n        css={css`\n          opacity: 1;\n          transition: opacity 200ms;\n          &[aria-hidden=\"true\"] {\n            opacity: 0;\n          }\n          &[data-popper-placement*=\"bottom\"] {\n            .${classNames.tooltip.arrow} {\n              top: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-top: -6px;\n              &::before {\n                border-color: transparent transparent currentcolor transparent;\n                border-width: 0 6px 6px 6px;\n              }\n            }\n            & > * {\n              margin-top: 8px;\n            }\n          }\n          &[data-popper-placement*=\"top\"] {\n            .${classNames.tooltip.arrow} {\n              bottom: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-bottom: -6px;\n              &::before {\n                border-color: currentcolor transparent transparent transparent;\n                border-width: 6px 6px 0 6px;\n              }\n            }\n            & > * {\n              margin-bottom: 8px;\n            }\n          }\n          &[data-popper-placement*=\"right\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              left: 0;\n              width: 6px;\n              height: 12px;\n              margin-left: -6px;\n              &::before {\n                border-color: transparent currentcolor transparent transparent;\n                border-width: 6px 6px 6px 0;\n              }\n            }\n            & > * {\n              margin-left: 8px;\n            }\n          }\n          &[data-popper-placement*=\"left\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              right: 0;\n              width: 6px;\n              height: 12px;\n              margin-right: -6px;\n              &::before {\n                border-color: transparent transparent transparent currentcolor;\n                border-width: 6px 0 6px 6px;\n              }\n            }\n            & > * {\n              margin-right: 8px;\n            }\n          }\n        `}\n      >\n        <div\n          css={[\n            theme.typography.caption,\n            css`\n              position: relative;\n              max-width: 300px;\n              padding: 6px 10px;\n              color: #fff;\n              text-align: left;\n              word-wrap: break-word;\n              background-color: rgba(97, 97, 97, 0.9);\n              border-radius: 4px;\n            `,\n          ]}\n        >\n          {title}\n          {arrow ? (\n            <div\n              className={classNames.tooltip.arrow}\n              css={css`\n                position: absolute;\n                color: rgba(97, 97, 97, 0.9);\n                &::before {\n                  display: block;\n                  width: 0px;\n                  height: 0px;\n                  margin: auto;\n                  content: \"\";\n                  border-style: solid;\n                }\n              `}\n            />\n          ) : null}\n        </div>\n      </Popper>\n    </React.Fragment>\n  );\n};\n"]} */")
|
|
93
93
|
}, (0, _react.jsx)("div", {
|
|
94
|
-
css: [theme.typography.caption, _ref2, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
94
|
+
css: [theme.typography.caption, _ref2, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AAyMU","file":"../../../src/Tooltip/Tooltip.tsx","sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n  tooltip: {\n    arrow: \"m2mui_Tooltip_arrow\",\n  },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n  /**\n   * Tooltipに表示するテキスト\n   */\n  title: string;\n  /**\n   * Tooltipを表示する要素\n   * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません\n   */\n  children: React.ReactElement<any> | string;\n  /**\n   * 矢印を表示します。\n   *\n   * @default false\n   */\n  arrow?: boolean;\n  /**\n   * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n   *\n   * @default undefined\n   */\n  open?: boolean;\n}\n\nexport const Tooltip = ({\n  children,\n  title,\n  placement,\n  arrow,\n  open: openProp,\n}: TooltipProps) => {\n  const [node, setNode] = useState<HTMLElement | null>(null);\n\n  const theme = useTheme();\n\n  const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n  const [open, setOpen] = useState(false);\n  const prevOpen = useRef<boolean>(undefined);\n  const [hidden, setHidden] = useState(true);\n\n  if (isControlled && openProp !== prevOpen.current) {\n    prevOpen.current = openProp;\n    if (openProp) {\n      setOpen(true);\n      setHidden(false);\n    } else {\n      setHidden(true);\n    }\n  }\n\n  const handleMouseEnter = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setOpen(true);\n          setHidden(false);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  const handleMouseLeave = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setHidden(true);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  return (\n    <React.Fragment>\n      {typeof children === \"string\" ? (\n        <span\n          ref={setNode}\n          onMouseEnter={handleMouseEnter()}\n          onMouseLeave={handleMouseLeave()}\n        >\n          {children}\n        </span>\n      ) : (\n        React.cloneElement(children, {\n          ref: setNode,\n          onMouseEnter: handleMouseEnter(\n            hasOwnProp(children.props, \"onMouseEnter\")\n              ? (children.props.onMouseEnter as React.MouseEventHandler)\n              : undefined,\n          ),\n          onMouseLeave: handleMouseLeave(\n            hasOwnProp(children.props, \"onMouseLeave\")\n              ? (children.props.onMouseLeave as React.MouseEventHandler)\n              : undefined,\n          ),\n        })\n      )}\n      <Popper\n        anchorEl={node}\n        placement={placement}\n        open={open}\n        aria-hidden={hidden}\n        disablePortal\n        onTransitionEnd={() => {\n          if (hidden) {\n            setOpen(false);\n          }\n        }}\n        css={css`\n          opacity: 1;\n          transition: opacity 200ms;\n          &[aria-hidden=\"true\"] {\n            opacity: 0;\n          }\n          &[data-popper-placement*=\"bottom\"] {\n            .${classNames.tooltip.arrow} {\n              top: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-top: -6px;\n              &::before {\n                border-color: transparent transparent currentcolor transparent;\n                border-width: 0 6px 6px 6px;\n              }\n            }\n            & > * {\n              margin-top: 8px;\n            }\n          }\n          &[data-popper-placement*=\"top\"] {\n            .${classNames.tooltip.arrow} {\n              bottom: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-bottom: -6px;\n              &::before {\n                border-color: currentcolor transparent transparent transparent;\n                border-width: 6px 6px 0 6px;\n              }\n            }\n            & > * {\n              margin-bottom: 8px;\n            }\n          }\n          &[data-popper-placement*=\"right\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              left: 0;\n              width: 6px;\n              height: 12px;\n              margin-left: -6px;\n              &::before {\n                border-color: transparent currentcolor transparent transparent;\n                border-width: 6px 6px 6px 0;\n              }\n            }\n            & > * {\n              margin-left: 8px;\n            }\n          }\n          &[data-popper-placement*=\"left\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              right: 0;\n              width: 6px;\n              height: 12px;\n              margin-right: -6px;\n              &::before {\n                border-color: transparent transparent transparent currentcolor;\n                border-width: 6px 0 6px 6px;\n              }\n            }\n            & > * {\n              margin-right: 8px;\n            }\n          }\n        `}\n      >\n        <div\n          css={[\n            theme.typography.caption,\n            css`\n              position: relative;\n              max-width: 300px;\n              padding: 6px 10px;\n              color: #fff;\n              text-align: left;\n              word-wrap: break-word;\n              background-color: rgba(97, 97, 97, 0.9);\n              border-radius: 4px;\n            `,\n          ]}\n        >\n          {title}\n          {arrow ? (\n            <div\n              className={classNames.tooltip.arrow}\n              css={css`\n                position: absolute;\n                color: rgba(97, 97, 97, 0.9);\n                &::before {\n                  display: block;\n                  width: 0px;\n                  height: 0px;\n                  margin: auto;\n                  content: \"\";\n                  border-style: solid;\n                }\n              `}\n            />\n          ) : null}\n        </div>\n      </Popper>\n    </React.Fragment>\n  );\n};\n"]} */"]
|
|
95
95
|
}, title, arrow ? (0, _react.jsx)("div", {
|
|
96
96
|
className: classNames.tooltip.arrow,
|
|
97
97
|
css: _ref
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Tooltip.js","names":["_Popper","require","_react","_hasOwnProp","_theme","_react2","_interopRequireWildcard","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","_EMOTION_STRINGIFIED_CSS_ERROR__","classNames","tooltip","arrow","_ref","process","env","NODE_ENV","name","styles","toString","_ref2","Tooltip","children","title","placement","open","openProp","node","setNode","useState","theme","useTheme","isControlled","useMemo","undefined","setOpen","prevOpen","useRef","hidden","setHidden","current","handleMouseEnter","useCallback","original","event","handleMouseLeave","jsx","Fragment","ref","onMouseEnter","onMouseLeave","React","cloneElement","hasOwnProp","props","Popper","anchorEl","disablePortal","onTransitionEnd","css","typography","caption","className","exports"],"sources":["../../../src/Tooltip/Tooltip.tsx"],"sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n tooltip: {\n arrow: \"m2mui_Tooltip_arrow\",\n },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n title: string;\n children: React.ReactElement<any> | string;\n /**\n * 矢印を表示します。\n *\n * @default false\n */\n arrow?: boolean;\n /**\n * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n *\n * @default undefined\n */\n open?: boolean;\n}\n\nexport const Tooltip = ({\n children,\n title,\n placement,\n arrow,\n open: openProp,\n}: TooltipProps) => {\n const [node, setNode] = useState<HTMLElement | null>(null);\n\n const theme = useTheme();\n\n const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n const [open, setOpen] = useState(false);\n const prevOpen = useRef<boolean>(undefined);\n const [hidden, setHidden] = useState(true);\n\n if (isControlled && openProp !== prevOpen.current) {\n prevOpen.current = openProp;\n if (openProp) {\n setOpen(true);\n setHidden(false);\n } else {\n setHidden(true);\n }\n }\n\n const handleMouseEnter = useCallback(\n (original?: (event: React.MouseEvent) => void) =>\n (event: React.MouseEvent) => {\n if (!isControlled) {\n setOpen(true);\n setHidden(false);\n }\n\n if (original) {\n original(event);\n }\n },\n [isControlled],\n );\n\n const handleMouseLeave = useCallback(\n (original?: (event: React.MouseEvent) => void) =>\n (event: React.MouseEvent) => {\n if (!isControlled) {\n setHidden(true);\n }\n\n if (original) {\n original(event);\n }\n },\n [isControlled],\n );\n\n return (\n <React.Fragment>\n {typeof children === \"string\" ? (\n <span\n ref={setNode}\n onMouseEnter={handleMouseEnter()}\n onMouseLeave={handleMouseLeave()}\n >\n {children}\n </span>\n ) : (\n React.cloneElement(children, {\n ref: setNode,\n onMouseEnter: handleMouseEnter(\n hasOwnProp(children.props, \"onMouseEnter\")\n ? (children.props.onMouseEnter as React.MouseEventHandler)\n : undefined,\n ),\n onMouseLeave: handleMouseLeave(\n hasOwnProp(children.props, \"onMouseLeave\")\n ? (children.props.onMouseLeave as React.MouseEventHandler)\n : undefined,\n ),\n })\n )}\n <Popper\n anchorEl={node}\n placement={placement}\n open={open}\n aria-hidden={hidden}\n disablePortal\n onTransitionEnd={() => {\n if (hidden) {\n setOpen(false);\n }\n }}\n css={css`\n opacity: 1;\n transition: opacity 200ms;\n &[aria-hidden=\"true\"] {\n opacity: 0;\n }\n &[data-popper-placement*=\"bottom\"] {\n .${classNames.tooltip.arrow} {\n top: 0;\n left: 12px;\n width: 12px;\n height: 6px;\n margin-top: -6px;\n &::before {\n border-color: transparent transparent currentcolor transparent;\n border-width: 0 6px 6px 6px;\n }\n }\n & > * {\n margin-top: 8px;\n }\n }\n &[data-popper-placement*=\"top\"] {\n .${classNames.tooltip.arrow} {\n bottom: 0;\n left: 12px;\n width: 12px;\n height: 6px;\n margin-bottom: -6px;\n &::before {\n border-color: currentcolor transparent transparent transparent;\n border-width: 6px 6px 0 6px;\n }\n }\n & > * {\n margin-bottom: 8px;\n }\n }\n &[data-popper-placement*=\"right\"] {\n .${classNames.tooltip.arrow} {\n top: 12px;\n left: 0;\n width: 6px;\n height: 12px;\n margin-left: -6px;\n &::before {\n border-color: transparent currentcolor transparent transparent;\n border-width: 6px 6px 6px 0;\n }\n }\n & > * {\n margin-left: 8px;\n }\n }\n &[data-popper-placement*=\"left\"] {\n .${classNames.tooltip.arrow} {\n top: 12px;\n right: 0;\n width: 6px;\n height: 12px;\n margin-right: -6px;\n &::before {\n border-color: transparent transparent transparent currentcolor;\n border-width: 6px 0 6px 6px;\n }\n }\n & > * {\n margin-right: 8px;\n }\n }\n `}\n >\n <div\n css={[\n theme.typography.caption,\n css`\n position: relative;\n max-width: 300px;\n padding: 6px 10px;\n color: #fff;\n text-align: left;\n word-wrap: break-word;\n background-color: rgba(97, 97, 97, 0.9);\n border-radius: 4px;\n `,\n ]}\n >\n {title}\n {arrow ? (\n <div\n className={classNames.tooltip.arrow}\n css={css`\n position: absolute;\n color: rgba(97, 97, 97, 0.9);\n &::before {\n display: block;\n width: 0px;\n height: 0px;\n margin: auto;\n content: \"\";\n border-style: solid;\n }\n `}\n />\n ) : null}\n </div>\n </Popper>\n </React.Fragment>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"Tooltip.js","names":["_Popper","require","_react","_hasOwnProp","_theme","_react2","_interopRequireWildcard","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","_EMOTION_STRINGIFIED_CSS_ERROR__","classNames","tooltip","arrow","_ref","process","env","NODE_ENV","name","styles","toString","_ref2","Tooltip","children","title","placement","open","openProp","node","setNode","useState","theme","useTheme","isControlled","useMemo","undefined","setOpen","prevOpen","useRef","hidden","setHidden","current","handleMouseEnter","useCallback","original","event","handleMouseLeave","jsx","Fragment","ref","onMouseEnter","onMouseLeave","React","cloneElement","hasOwnProp","props","Popper","anchorEl","disablePortal","onTransitionEnd","css","typography","caption","className","exports"],"sources":["../../../src/Tooltip/Tooltip.tsx"],"sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n tooltip: {\n arrow: \"m2mui_Tooltip_arrow\",\n },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n /**\n * Tooltipに表示するテキスト\n */\n title: string;\n /**\n * Tooltipを表示する要素\n * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません\n */\n children: React.ReactElement<any> | string;\n /**\n * 矢印を表示します。\n *\n * @default false\n */\n arrow?: boolean;\n /**\n * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n *\n * @default undefined\n */\n open?: boolean;\n}\n\nexport const Tooltip = ({\n children,\n title,\n placement,\n arrow,\n open: openProp,\n}: TooltipProps) => {\n const [node, setNode] = useState<HTMLElement | null>(null);\n\n const theme = useTheme();\n\n const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n const [open, setOpen] = useState(false);\n const prevOpen = useRef<boolean>(undefined);\n const [hidden, setHidden] = useState(true);\n\n if (isControlled && openProp !== prevOpen.current) {\n prevOpen.current = openProp;\n if (openProp) {\n setOpen(true);\n setHidden(false);\n } else {\n setHidden(true);\n }\n }\n\n const handleMouseEnter = useCallback(\n (original?: (event: React.MouseEvent) => void) =>\n (event: React.MouseEvent) => {\n if (!isControlled) {\n setOpen(true);\n setHidden(false);\n }\n\n if (original) {\n original(event);\n }\n },\n [isControlled],\n );\n\n const handleMouseLeave = useCallback(\n (original?: (event: React.MouseEvent) => void) =>\n (event: React.MouseEvent) => {\n if (!isControlled) {\n setHidden(true);\n }\n\n if (original) {\n original(event);\n }\n },\n [isControlled],\n );\n\n return (\n <React.Fragment>\n {typeof children === \"string\" ? (\n <span\n ref={setNode}\n onMouseEnter={handleMouseEnter()}\n onMouseLeave={handleMouseLeave()}\n >\n {children}\n </span>\n ) : (\n React.cloneElement(children, {\n ref: setNode,\n onMouseEnter: handleMouseEnter(\n hasOwnProp(children.props, \"onMouseEnter\")\n ? (children.props.onMouseEnter as React.MouseEventHandler)\n : undefined,\n ),\n onMouseLeave: handleMouseLeave(\n hasOwnProp(children.props, \"onMouseLeave\")\n ? (children.props.onMouseLeave as React.MouseEventHandler)\n : undefined,\n ),\n })\n )}\n <Popper\n anchorEl={node}\n placement={placement}\n open={open}\n aria-hidden={hidden}\n disablePortal\n onTransitionEnd={() => {\n if (hidden) {\n setOpen(false);\n }\n }}\n css={css`\n opacity: 1;\n transition: opacity 200ms;\n &[aria-hidden=\"true\"] {\n opacity: 0;\n }\n &[data-popper-placement*=\"bottom\"] {\n .${classNames.tooltip.arrow} {\n top: 0;\n left: 12px;\n width: 12px;\n height: 6px;\n margin-top: -6px;\n &::before {\n border-color: transparent transparent currentcolor transparent;\n border-width: 0 6px 6px 6px;\n }\n }\n & > * {\n margin-top: 8px;\n }\n }\n &[data-popper-placement*=\"top\"] {\n .${classNames.tooltip.arrow} {\n bottom: 0;\n left: 12px;\n width: 12px;\n height: 6px;\n margin-bottom: -6px;\n &::before {\n border-color: currentcolor transparent transparent transparent;\n border-width: 6px 6px 0 6px;\n }\n }\n & > * {\n margin-bottom: 8px;\n }\n }\n &[data-popper-placement*=\"right\"] {\n .${classNames.tooltip.arrow} {\n top: 12px;\n left: 0;\n width: 6px;\n height: 12px;\n margin-left: -6px;\n &::before {\n border-color: transparent currentcolor transparent transparent;\n border-width: 6px 6px 6px 0;\n }\n }\n & > * {\n margin-left: 8px;\n }\n }\n &[data-popper-placement*=\"left\"] {\n .${classNames.tooltip.arrow} {\n top: 12px;\n right: 0;\n width: 6px;\n height: 12px;\n margin-right: -6px;\n &::before {\n border-color: transparent transparent transparent currentcolor;\n border-width: 6px 0 6px 6px;\n }\n }\n & > * {\n margin-right: 8px;\n }\n }\n `}\n >\n <div\n css={[\n theme.typography.caption,\n css`\n position: relative;\n max-width: 300px;\n padding: 6px 10px;\n color: #fff;\n text-align: left;\n word-wrap: break-word;\n background-color: rgba(97, 97, 97, 0.9);\n border-radius: 4px;\n `,\n ]}\n >\n {title}\n {arrow ? (\n <div\n className={classNames.tooltip.arrow}\n css={css`\n position: absolute;\n color: rgba(97, 97, 97, 0.9);\n &::before {\n display: block;\n width: 0px;\n height: 0px;\n margin: auto;\n content: \"\";\n border-style: solid;\n }\n `}\n />\n ) : null}\n </div>\n </Popper>\n </React.Fragment>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CSVImportUI.js","names":["CompleteScreen","DownloadCreateTemplateScreen","DownloadUpdateTemplateScreen","LoadCSVScreen","ScreenProvider","useScreen","SelectModeScreen","UploadCSVScreen","useCallback","useMemo","useState","jsx","___EmotionJSX","CSVImportUIContent","_ref","columns","onDownloadCSV","searchLabel","onSearchData","renderSearchField","csvPrefix","csvParser","csvValidator","onPreUploadData","onPreUploadDataByRow","onUploadData","onUploadDataByRow","acceptMode","skipDownloadTemplate","selectDownloadTemplateColumns","defaultTemplateData","id","mode","setMode","uploadedData","setUploadedData","errors","setErrors","handleUpdateData","data","headers","_uploadedData$","rowKeys","Object","keys","values","filter","column","length","hiddenIfNoHeader","includes","label","map","filledData","_uploadedData$2","row","_extends","fromEntries","header","onChangeMode","onSearch","onUpdateData","onSubmitComplete","getFirstScreenId","accptMode","CSVImportUI","props","firstScreenId"],"sources":["../../../src/CSVImportUI/CSVImportUI.tsx"],"sourcesContent":["import { AlertMessageType } from \"../Alert\";\nimport { AssertType } from \"../@types/AssertType\";\nimport { CompleteScreen } from \"./screens/CompleteScreen\";\nimport { DownloadCreateTemplateScreen } from \"./screens/DownloadCreateTemplateScreen\";\nimport { DownloadUpdateTemplateScreen } from \"./screens/DownloadUpdateTemplateScreen\";\nimport { LoadCSVScreen } from \"./screens/LoadCSVScreen\";\nimport { ScreenId } from \"./screens/types\";\nimport { ScreenProvider, useScreen } from \"./ScreenProvider\";\nimport { SelectModeScreen } from \"./screens/SelectModeScreen\";\nimport { UnionToIntersection } from \"../@types/UnionToIntersection\";\nimport { UploadCSVScreen } from \"./screens/UploadCSVScreen\";\nimport { useCallback, useMemo, useState } from \"react\";\n\nexport type Mode = \"create\" | \"update\";\n\nexport type CellError = [string, string];\n\nexport type CSVImportUIColumn = Readonly<{\n label: string;\n description?: string;\n type?: \"date\" | \"number\";\n options?: readonly string[];\n required?: boolean;\n hiddenOnCreateTemplate?: boolean;\n /**\n * アップロードされたCSVにヘッダーがなければ表示しない。\n */\n hiddenIfNoHeader?: boolean;\n renderCell?: (props: {\n value: string;\n header: string;\n row: Record<string, string>;\n }) => React.JSX.Element;\n}>;\n\n/**\n * ライブラリ利用者用の型\n */\nexport type CSVImportUIColumns = Record<string, CSVImportUIColumn>;\n\nexport interface CSVImportUIRenderSearchFieldProps<Row> {\n onChange: (args: Row[]) => void;\n}\n\ntype OptionByLabel<Columns extends CSVImportUIColumns> = {\n [Key in keyof Columns]: Record<\n Columns[Key][\"label\"],\n Columns[Key] extends {\n options: readonly (infer Option)[];\n }\n ? Option extends string\n ? Option\n : never\n : string\n >;\n}[keyof Columns];\n\nexport type CSVImportUIRow<Columns extends CSVImportUIColumns> = AssertType<\n UnionToIntersection<OptionByLabel<Columns>>,\n Record<string, string>\n>;\n\nexport interface CSVImportUIProps<\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n> {\n /**\n * 利用できるモードを指定する。\n */\n acceptMode: Mode[];\n /**\n * アップロード画面に進む前にトリガーされる。\n * 行ごとにデータを処理する。\n *\n * onPreUploadDataが指定されている場合、こちらは無視される。\n */\n onPreUploadDataByRow?: (args: {\n index: number;\n /**\n * 欠損したフィールドがある可能性があるため、型を緩くする。\n */\n row: Partial<Row>;\n mode: Mode;\n }) => Promise<{ error?: CellError; data?: Record<string, string> }>;\n /**\n * アップロード画面に進む前にトリガーされる。\n * 一括でデータをアップロードする。\n *\n * 現状onPreUploadDataByRowByRowとは異なり、行ごとにエラーを表示することはできない。\n * 代わりに、エラー時に表示されるアラートのメッセージをerrorMessageで指定する。\n *\n * 行毎にエラーを表示したくなった場合は、要望を出すこと。\n */\n onPreUploadData?: (args: { data: Partial<Row>[]; mode: Mode }) => Promise<{\n errorMessage?: AlertMessageType;\n data?: Record<string, string>[];\n }>;\n /**\n * CSVをパースしたデータのアップロードがトリガーされた際に呼ばれる。\n * 行ごとにデータをアップロードする。\n *\n * onUploadDataが指定されている場合、こちらは無視される。\n */\n onUploadDataByRow?: (args: {\n index: number;\n /**\n * 欠損したフィールドがある可能性があるため、型を緩くする。\n */\n row: Partial<Row>;\n mode: Mode;\n }) => Promise<{\n error?: CellError;\n data?: Record<string, string>;\n }>;\n /**\n * CSVをパースしたデータのアップロードがトリガーされた際に呼ばれる。\n * 一括でデータをアップロードする。\n *\n * 現状onUploadDataByRowとは異なり、行ごとにエラーを表示することはできない。\n * 代わりに、エラー時に表示されるアラートのメッセージをerrorMessageで指定する。\n *\n * 行毎にエラーを表示したくなった場合は、要望を出すこと。\n */\n onUploadData?: (args: { data: Partial<Row>[]; mode: Mode }) => Promise<{\n errorMessage?: AlertMessageType;\n data?: Record<string, string>[];\n }>;\n /**\n * 検索フォームのラベルとして利用される。\n * (only upload mode)\n */\n searchLabel?: string;\n /**\n * 検索が行われた際にトリガーされる。\n * ユーザーの入力した文字列に応じてデータを返却する。このデータはCSVとしてダウンロードされる。\n * (only upload mode)\n */\n onSearchData?: (args: { value: string }) => Promise<{\n data: Row[];\n }>;\n /**\n * CSVの各列をどのように表示するか指定する。\n * 各列には、次のプロパティが指定できる。\n *\n * `label` : CSVのヘッダーとして利用される。\n *\n * `type` : `date`または`number`が指定でき、それぞれ日付と数値としてアップロードされたCSVの値が正しいかどうかを検証する。\n *\n * `options` : その列が持てる値のリストを指定する。アップロードされたCSVの値がこのリストに含まれているかどうかを検証する。\n *\n * `required` : その列が必須かどうかを指定する。アップロードされたCSVの値が空でないかどうかを検証する。\n *\n * `renderCell` : その列のセルをどのように表示するかを指定する。その列の値、ヘッダー、行のデータが渡される。\n *\n * `hiddenOnCreateTemplate` : 作成用のCSVのテンプレートに、その列を表示しないかどうかを決定する。\n *\n * `hiddenIfNoHeader` : アップロードされたCSVにそのヘッダーがなければ、その列を表示しないかどうかを決定する。\n */\n columns: Columns;\n /**\n * ダウンロードされるCSVに付与されるプレフィックスを指定する\n */\n csvPrefix?: string;\n /**\n * CSVのダウンロードがトリガーされたときに呼ばれる\n */\n onDownloadCSV: (args: { data: Row[]; filename: string }) => void;\n /**\n * CSVがアップロードされたときに呼ばれる\n */\n csvParser: (args: {\n file: File;\n }) => Promise<{ data: Record<string, string>[] }>;\n /**\n * アップロードされたCSVのデータをバリデーションする。\n */\n csvValidator?: (args: {\n /**\n * ここで渡されるデータがRowと一致するとは限らない。\n */\n row: Record<string, string>;\n }) => Promise<{ errors?: CellError[] }>;\n /**\n * 更新モードで検索のカスタマイズをする。\n * 省略するとonSearchData, searchLabelを用いた単一の検索フィールドが表示される。これを指定するとonSearchData, searchLabelは無視される。\n * (only upload mode)\n */\n renderSearchField?: (\n props: CSVImportUIRenderSearchFieldProps<Row>,\n ) => React.JSX.Element;\n /**\n * 編集用CSVをダウンロードするページをスキップする\n */\n skipDownloadTemplate?: boolean;\n /**\n * 更新用のCSVをダウンロードする際にデフォルトで表示されるデータを指定する。\n */\n defaultTemplateData?: Row[];\n\n /**\n * ダウンロードテンプレートで利用する項目を選択するかどうかを指定する。\n * デフォルトでは、hiddenOnCreateTemplateが指定されていない列の全ての項目が追加される。\n * @default false\n */\n selectDownloadTemplateColumns?: boolean;\n}\n\nconst CSVImportUIContent = <\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n>({\n columns,\n onDownloadCSV,\n searchLabel,\n onSearchData,\n renderSearchField,\n csvPrefix,\n csvParser,\n csvValidator,\n onPreUploadData,\n onPreUploadDataByRow,\n onUploadData,\n onUploadDataByRow,\n acceptMode,\n skipDownloadTemplate,\n selectDownloadTemplateColumns,\n defaultTemplateData,\n}: CSVImportUIProps<Columns, Row>) => {\n const id = useScreen();\n const [mode, setMode] = useState<Mode>(acceptMode[0]);\n const [uploadedData, setUploadedData] = useState<Row[]>([]);\n const [errors, setErrors] = useState<(CellError[] | undefined)[]>([]);\n\n const handleUpdateData = useCallback(\n (data: Row[], errors: (CellError[] | undefined)[]) => {\n setErrors(errors);\n setUploadedData(data);\n },\n [],\n );\n\n const headers = useMemo(() => {\n const rowKeys = Object.keys(uploadedData[0] ?? {});\n\n return Object.values(columns)\n .filter((column) => {\n if (rowKeys.length === 0) {\n return true;\n }\n if (column.hiddenIfNoHeader && !rowKeys.includes(column.label)) {\n return false;\n }\n return true;\n })\n .map((column) => column.label);\n }, [columns, uploadedData]);\n\n const filledData = useMemo(() => {\n return headers.length > Object.keys(uploadedData[0] ?? {}).length\n ? uploadedData.map((row) => {\n return {\n ...Object.fromEntries(headers.map((header) => [header, \"\"])),\n ...row,\n };\n })\n : uploadedData;\n }, [headers, uploadedData]);\n\n switch (id) {\n case \"selectMode\": {\n return (\n <SelectModeScreen\n skipDownloadTemplate={skipDownloadTemplate}\n onChangeMode={setMode}\n />\n );\n }\n case \"downloadCreateTemplate\": {\n return (\n <DownloadCreateTemplateScreen\n onDownloadCSV={onDownloadCSV}\n headers={headers}\n columns={columns}\n csvPrefix={csvPrefix}\n selectDownloadTemplateColumns={selectDownloadTemplateColumns}\n />\n );\n }\n case \"downloadUpdateTemplate\": {\n return (\n <DownloadUpdateTemplateScreen\n searchLabel={searchLabel}\n onSearch={onSearchData}\n renderSearchField={renderSearchField}\n onDownloadCSV={onDownloadCSV}\n csvPrefix={csvPrefix}\n headers={headers}\n defaultTemplateData={defaultTemplateData}\n columns={columns}\n />\n );\n }\n case \"loadCSV\": {\n return (\n <LoadCSVScreen\n mode={mode}\n columns={columns}\n data={filledData}\n headers={headers}\n errors={errors}\n csvParser={csvParser}\n csvValidator={csvValidator}\n onPreUploadData={onPreUploadData}\n onPreUploadDataByRow={onPreUploadDataByRow}\n onUpdateData={handleUpdateData}\n />\n );\n }\n case \"uploadCSV\": {\n return (\n <UploadCSVScreen\n mode={mode}\n data={filledData}\n headers={headers}\n errors={errors}\n columns={columns}\n onUploadData={onUploadData}\n onUploadDataByRow={onUploadDataByRow}\n onSubmitComplete={handleUpdateData}\n />\n );\n }\n case \"complete\": {\n return (\n <CompleteScreen\n csvPrefix={csvPrefix}\n onDownloadCSV={onDownloadCSV}\n data={filledData}\n columns={columns}\n headers={headers}\n errors={errors}\n />\n );\n }\n default: {\n return null;\n }\n }\n};\n\nconst getFirstScreenId = (\n accptMode: Mode[],\n skipDownloadTemplate?: boolean,\n): ScreenId => {\n if (accptMode.length > 1) {\n return \"selectMode\";\n }\n if (skipDownloadTemplate) {\n return \"loadCSV\";\n }\n if (accptMode[0] === \"create\") {\n return \"downloadCreateTemplate\";\n }\n if (accptMode[0] === \"update\") {\n return \"downloadUpdateTemplate\";\n }\n return \"selectMode\";\n};\n\nexport const CSVImportUI = <\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n>(\n props: CSVImportUIProps<Columns, Row>,\n) => {\n return (\n <ScreenProvider\n firstScreenId={getFirstScreenId(\n props.acceptMode,\n props.skipDownloadTemplate,\n )}\n >\n <CSVImportUIContent {...props} />\n </ScreenProvider>\n );\n};\n"],"mappings":";AAEA,SAASA,cAAc,QAAQ,0BAA0B;AACzD,SAASC,4BAA4B,QAAQ,wCAAwC;AACrF,SAASC,4BAA4B,QAAQ,wCAAwC;AACrF,SAASC,aAAa,QAAQ,yBAAyB;AAEvD,SAASC,cAAc,EAAEC,SAAS,QAAQ,kBAAkB;AAC5D,SAASC,gBAAgB,QAAQ,4BAA4B;AAE7D,SAASC,eAAe,QAAQ,2BAA2B;AAC3D,SAASC,WAAW,EAAEC,OAAO,EAAEC,QAAQ,QAAQ,OAAO;;AAwBtD;AACA;AACA;AAFA,SAAAC,GAAA,IAAAC,aAAA;AA4KA,IAAMC,kBAAkB,GAAGC,IAAA,IAoBW;EAAA,IAjBpC;IACAC,OAAO;IACPC,aAAa;IACbC,WAAW;IACXC,YAAY;IACZC,iBAAiB;IACjBC,SAAS;IACTC,SAAS;IACTC,YAAY;IACZC,eAAe;IACfC,oBAAoB;IACpBC,YAAY;IACZC,iBAAiB;IACjBC,UAAU;IACVC,oBAAoB;IACpBC,6BAA6B;IAC7BC;EAC8B,CAAC,GAAAhB,IAAA;EAC/B,IAAMiB,EAAE,GAAG1B,SAAS,CAAC,CAAC;EACtB,IAAM,CAAC2B,IAAI,EAAEC,OAAO,CAAC,GAAGvB,QAAQ,CAAOiB,UAAU,CAAC,CAAC,CAAC,CAAC;EACrD,IAAM,CAACO,YAAY,EAAEC,eAAe,CAAC,GAAGzB,QAAQ,CAAQ,EAAE,CAAC;EAC3D,IAAM,CAAC0B,MAAM,EAAEC,SAAS,CAAC,GAAG3B,QAAQ,CAA8B,EAAE,CAAC;EAErE,IAAM4B,gBAAgB,GAAG9B,WAAW,CAClC,CAAC+B,IAAW,EAAEH,MAAmC,KAAK;IACpDC,SAAS,CAACD,MAAM,CAAC;IACjBD,eAAe,CAACI,IAAI,CAAC;EACvB,CAAC,EACD,EACF,CAAC;EAED,IAAMC,OAAO,GAAG/B,OAAO,CAAC,MAAM;IAAA,IAAAgC,cAAA;IAC5B,IAAMC,OAAO,GAAGC,MAAM,CAACC,IAAI,EAAAH,cAAA,GAACP,YAAY,CAAC,CAAC,CAAC,YAAAO,cAAA,GAAI,CAAC,CAAC,CAAC;IAElD,OAAOE,MAAM,CAACE,MAAM,CAAC9B,OAAO,CAAC,CAC1B+B,MAAM,CAAEC,MAAM,IAAK;MAClB,IAAIL,OAAO,CAACM,MAAM,KAAK,CAAC,EAAE;QACxB,OAAO,IAAI;MACb;MACA,IAAID,MAAM,CAACE,gBAAgB,IAAI,CAACP,OAAO,CAACQ,QAAQ,CAACH,MAAM,CAACI,KAAK,CAAC,EAAE;QAC9D,OAAO,KAAK;MACd;MACA,OAAO,IAAI;IACb,CAAC,CAAC,CACDC,GAAG,CAAEL,MAAM,IAAKA,MAAM,CAACI,KAAK,CAAC;EAClC,CAAC,EAAE,CAACpC,OAAO,EAAEmB,YAAY,CAAC,CAAC;EAE3B,IAAMmB,UAAU,GAAG5C,OAAO,CAAC,MAAM;IAAA,IAAA6C,eAAA;IAC/B,OAAOd,OAAO,CAACQ,MAAM,GAAGL,MAAM,CAACC,IAAI,EAAAU,eAAA,GAACpB,YAAY,CAAC,CAAC,CAAC,YAAAoB,eAAA,GAAI,CAAC,CAAC,CAAC,CAACN,MAAM,GAC7Dd,YAAY,CAACkB,GAAG,CAAEG,GAAG,IAAK;MACxB,OAAAC,QAAA,KACKb,MAAM,CAACc,WAAW,CAACjB,OAAO,CAACY,GAAG,CAAEM,MAAM,IAAK,CAACA,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC,EACzDH,GAAG;IAEV,CAAC,CAAC,GACFrB,YAAY;EAClB,CAAC,EAAE,CAACM,OAAO,EAAEN,YAAY,CAAC,CAAC;EAE3B,QAAQH,EAAE;IACR,KAAK,YAAY;MAAE;QACjB,OACEnB,aAAA,CAACN,gBAAgB;UACfsB,oBAAoB,EAAEA,oBAAqB;UAC3C+B,YAAY,EAAE1B;QAAQ,CACvB,CAAC;MAEN;IACA,KAAK,wBAAwB;MAAE;QAC7B,OACErB,aAAA,CAACX,4BAA4B;UAC3Be,aAAa,EAAEA,aAAc;UAC7BwB,OAAO,EAAEA,OAAQ;UACjBzB,OAAO,EAAEA,OAAQ;UACjBK,SAAS,EAAEA,SAAU;UACrBS,6BAA6B,EAAEA;QAA8B,CAC9D,CAAC;MAEN;IACA,KAAK,wBAAwB;MAAE;QAC7B,OACEjB,aAAA,CAACV,4BAA4B;UAC3Be,WAAW,EAAEA,WAAY;UACzB2C,QAAQ,EAAE1C,YAAa;UACvBC,iBAAiB,EAAEA,iBAAkB;UACrCH,aAAa,EAAEA,aAAc;UAC7BI,SAAS,EAAEA,SAAU;UACrBoB,OAAO,EAAEA,OAAQ;UACjBV,mBAAmB,EAAEA,mBAAoB;UACzCf,OAAO,EAAEA;QAAQ,CAClB,CAAC;MAEN;IACA,KAAK,SAAS;MAAE;QACd,OACEH,aAAA,CAACT,aAAa;UACZ6B,IAAI,EAAEA,IAAK;UACXjB,OAAO,EAAEA,OAAQ;UACjBwB,IAAI,EAAEc,UAAW;UACjBb,OAAO,EAAEA,OAAQ;UACjBJ,MAAM,EAAEA,MAAO;UACff,SAAS,EAAEA,SAAU;UACrBC,YAAY,EAAEA,YAAa;UAC3BC,eAAe,EAAEA,eAAgB;UACjCC,oBAAoB,EAAEA,oBAAqB;UAC3CqC,YAAY,EAAEvB;QAAiB,CAChC,CAAC;MAEN;IACA,KAAK,WAAW;MAAE;QAChB,OACE1B,aAAA,CAACL,eAAe;UACdyB,IAAI,EAAEA,IAAK;UACXO,IAAI,EAAEc,UAAW;UACjBb,OAAO,EAAEA,OAAQ;UACjBJ,MAAM,EAAEA,MAAO;UACfrB,OAAO,EAAEA,OAAQ;UACjBU,YAAY,EAAEA,YAAa;UAC3BC,iBAAiB,EAAEA,iBAAkB;UACrCoC,gBAAgB,EAAExB;QAAiB,CACpC,CAAC;MAEN;IACA,KAAK,UAAU;MAAE;QACf,OACE1B,aAAA,CAACZ,cAAc;UACboB,SAAS,EAAEA,SAAU;UACrBJ,aAAa,EAAEA,aAAc;UAC7BuB,IAAI,EAAEc,UAAW;UACjBtC,OAAO,EAAEA,OAAQ;UACjByB,OAAO,EAAEA,OAAQ;UACjBJ,MAAM,EAAEA;QAAO,CAChB,CAAC;MAEN;IACA;MAAS;QACP,OAAO,IAAI;MACb;EACF;AACF,CAAC;AAED,IAAM2B,gBAAgB,GAAGA,CACvBC,SAAiB,EACjBpC,oBAA8B,KACjB;EACb,IAAIoC,SAAS,CAAChB,MAAM,GAAG,CAAC,EAAE;IACxB,OAAO,YAAY;EACrB;EACA,IAAIpB,oBAAoB,EAAE;IACxB,OAAO,SAAS;EAClB;EACA,IAAIoC,SAAS,CAAC,CAAC,CAAC,KAAK,QAAQ,EAAE;IAC7B,OAAO,wBAAwB;EACjC;EACA,IAAIA,SAAS,CAAC,CAAC,CAAC,KAAK,QAAQ,EAAE;IAC7B,OAAO,wBAAwB;EACjC;EACA,OAAO,YAAY;AACrB,CAAC;AAED,OAAO,IAAMC,WAAW,GAItBC,KAAqC,IAClC;EACH,OACEtD,aAAA,CAACR,cAAc;IACb+D,aAAa,EAAEJ,gBAAgB,CAC7BG,KAAK,CAACvC,UAAU,EAChBuC,KAAK,CAACtC,oBACR;EAAE,GAEFhB,aAAA,CAACC,kBAAkB,EAAKqD,KAAQ,CAClB,CAAC;AAErB,CAAC","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"CSVImportUI.js","names":["CompleteScreen","DownloadCreateTemplateScreen","DownloadUpdateTemplateScreen","LoadCSVScreen","ScreenProvider","useScreen","SelectModeScreen","UploadCSVScreen","useCallback","useMemo","useState","jsx","___EmotionJSX","CSVImportUIContent","_ref","columns","onDownloadCSV","searchLabel","onSearchData","renderSearchField","csvPrefix","csvParser","csvValidator","onPreUploadData","onPreUploadDataByRow","onUploadData","onUploadDataByRow","acceptMode","skipDownloadTemplate","selectDownloadTemplateColumns","defaultTemplateData","id","mode","setMode","uploadedData","setUploadedData","errors","setErrors","handleUpdateData","data","headers","_uploadedData$","rowKeys","Object","keys","values","filter","column","length","hiddenIfNoHeader","includes","label","map","filledData","_uploadedData$2","row","_extends","fromEntries","header","onChangeMode","onSearch","onUpdateData","onSubmitComplete","getFirstScreenId","accptMode","CSVImportUI","props","firstScreenId"],"sources":["../../../src/CSVImportUI/CSVImportUI.tsx"],"sourcesContent":["import { AlertMessageType } from \"../Alert\";\nimport { AssertType } from \"../@types/AssertType\";\nimport { CompleteScreen } from \"./screens/CompleteScreen\";\nimport { DownloadCreateTemplateScreen } from \"./screens/DownloadCreateTemplateScreen\";\nimport { DownloadUpdateTemplateScreen } from \"./screens/DownloadUpdateTemplateScreen\";\nimport { LoadCSVScreen } from \"./screens/LoadCSVScreen\";\nimport { ScreenId } from \"./screens/types\";\nimport { ScreenProvider, useScreen } from \"./ScreenProvider\";\nimport { SelectModeScreen } from \"./screens/SelectModeScreen\";\nimport { UnionToIntersection } from \"../@types/UnionToIntersection\";\nimport { UploadCSVScreen } from \"./screens/UploadCSVScreen\";\nimport { useCallback, useMemo, useState } from \"react\";\n\nexport type Mode = \"create\" | \"update\";\n\nexport type CellError = [string, string];\n\nexport type CSVImportUIColumn = Readonly<{\n label: string;\n description?: string;\n type?: \"date\" | \"number\";\n options?: readonly string[];\n required?: boolean;\n hiddenOnCreateTemplate?: boolean;\n /**\n * アップロードされたCSVにヘッダーがなければ表示しない。\n */\n hiddenIfNoHeader?: boolean;\n renderCell?: (props: {\n value: string;\n header: string;\n row: Record<string, string>;\n }) => React.JSX.Element;\n}>;\n\n/**\n * ライブラリ利用者用の型\n */\nexport type CSVImportUIColumns = Record<string, CSVImportUIColumn>;\n\nexport interface CSVImportUIRenderSearchFieldProps<Row> {\n onChange: (args: Row[]) => void;\n}\n\ntype OptionByLabel<Columns extends CSVImportUIColumns> = {\n [Key in keyof Columns]: Record<\n Columns[Key][\"label\"],\n Columns[Key] extends {\n options: readonly (infer Option)[];\n }\n ? Option extends string\n ? Option\n : never\n : string\n >;\n}[keyof Columns];\n\nexport type CSVImportUIRow<Columns extends CSVImportUIColumns> = AssertType<\n UnionToIntersection<OptionByLabel<Columns>>,\n Record<string, string>\n>;\n\nexport interface CSVImportUIProps<\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n> {\n /**\n * 利用できるモードを指定する。\n */\n acceptMode: Mode[];\n /**\n * アップロード画面に進む前にトリガーされる。\n * 行ごとにデータを処理する。\n *\n * onPreUploadDataが指定されている場合、こちらは無視される。\n *\n * この関数内でsetStateを使用すると、行ごとの処理で過剰なレンダリングを引き起こす可能性があります。\n * 状態更新が必要な場合は、以下の方法を検討してください:\n * - onPreUploadDataを使用して一括でデータを処理する\n * - 複数の更新をバッチ処理して、すべての行の処理後に一度だけ状態を更新する\n * - レンダリングを必要としない中間値にはuseRefを使用する\n */\n onPreUploadDataByRow?: (args: {\n index: number;\n /**\n * 欠損したフィールドがある可能性があるため、型を緩くする。\n */\n row: Partial<Row>;\n mode: Mode;\n }) => Promise<{ error?: CellError; data?: Record<string, string> }>;\n /**\n * アップロード画面に進む前にトリガーされる。\n * 一括でデータをアップロードする。\n *\n * 現状onPreUploadDataByRowByRowとは異なり、行ごとにエラーを表示することはできない。\n * 代わりに、エラー時に表示されるアラートのメッセージをerrorMessageで指定する。\n *\n * 行毎にエラーを表示したくなった場合は、要望を出すこと。\n */\n onPreUploadData?: (args: { data: Partial<Row>[]; mode: Mode }) => Promise<{\n errorMessage?: AlertMessageType;\n data?: Record<string, string>[];\n }>;\n /**\n * CSVをパースしたデータのアップロードがトリガーされた際に呼ばれる。\n * 行ごとにデータをアップロードする。\n *\n * onUploadDataが指定されている場合、こちらは無視される。\n *\n * この関数内でsetStateを使用すると、行ごとの処理で過剰なレンダリングを引き起こす可能性があります。\n * 状態更新が必要な場合は、以下の方法を検討してください:\n * - onUploadDataを使用して一括でデータを処理する\n * - 複数の更新をバッチ処理して、すべての行の処理後に一度だけ状態を更新する\n * - レンダリングを必要としない中間値にはuseRefを使用する\n */\n onUploadDataByRow?: (args: {\n index: number;\n /**\n * 欠損したフィールドがある可能性があるため、型を緩くする。\n */\n row: Partial<Row>;\n mode: Mode;\n }) => Promise<{\n error?: CellError;\n data?: Record<string, string>;\n }>;\n /**\n * CSVをパースしたデータのアップロードがトリガーされた際に呼ばれる。\n * 一括でデータをアップロードする。\n *\n * 現状onUploadDataByRowとは異なり、行ごとにエラーを表示することはできない。\n * 代わりに、エラー時に表示されるアラートのメッセージをerrorMessageで指定する。\n *\n * 行毎にエラーを表示したくなった場合は、要望を出すこと。\n */\n onUploadData?: (args: { data: Partial<Row>[]; mode: Mode }) => Promise<{\n errorMessage?: AlertMessageType;\n data?: Record<string, string>[];\n }>;\n /**\n * 検索フォームのラベルとして利用される。\n * (only upload mode)\n */\n searchLabel?: string;\n /**\n * 検索が行われた際にトリガーされる。\n * ユーザーの入力した文字列に応じてデータを返却する。このデータはCSVとしてダウンロードされる。\n * (only upload mode)\n */\n onSearchData?: (args: { value: string }) => Promise<{\n data: Row[];\n }>;\n /**\n * CSVの各列をどのように表示するか指定する。\n * 各列には、次のプロパティが指定できる。\n *\n * `label` : CSVのヘッダーとして利用される。\n *\n * `type` : `date`または`number`が指定でき、それぞれ日付と数値としてアップロードされたCSVの値が正しいかどうかを検証する。\n *\n * `options` : その列が持てる値のリストを指定する。アップロードされたCSVの値がこのリストに含まれているかどうかを検証する。\n *\n * `required` : その列が必須かどうかを指定する。アップロードされたCSVの値が空でないかどうかを検証する。\n *\n * `renderCell` : その列のセルをどのように表示するかを指定する。その列の値、ヘッダー、行のデータが渡される。\n *\n * `hiddenOnCreateTemplate` : 作成用のCSVのテンプレートに、その列を表示しないかどうかを決定する。\n *\n * `hiddenIfNoHeader` : アップロードされたCSVにそのヘッダーがなければ、その列を表示しないかどうかを決定する。\n */\n columns: Columns;\n /**\n * ダウンロードされるCSVに付与されるプレフィックスを指定する\n */\n csvPrefix?: string;\n /**\n * CSVのダウンロードがトリガーされたときに呼ばれる\n */\n onDownloadCSV: (args: { data: Row[]; filename: string }) => void;\n /**\n * CSVがアップロードされたときに呼ばれる\n */\n csvParser: (args: {\n file: File;\n }) => Promise<{ data: Record<string, string>[] }>;\n /**\n * アップロードされたCSVのデータをバリデーションする。\n */\n csvValidator?: (args: {\n /**\n * ここで渡されるデータがRowと一致するとは限らない。\n */\n row: Record<string, string>;\n }) => Promise<{ errors?: CellError[] }>;\n /**\n * 更新モードで検索のカスタマイズをする。\n * 省略するとonSearchData, searchLabelを用いた単一の検索フィールドが表示される。これを指定するとonSearchData, searchLabelは無視される。\n * (only upload mode)\n */\n renderSearchField?: (\n props: CSVImportUIRenderSearchFieldProps<Row>,\n ) => React.JSX.Element;\n /**\n * 編集用CSVをダウンロードするページをスキップする\n */\n skipDownloadTemplate?: boolean;\n /**\n * 更新用のCSVをダウンロードする際にデフォルトで表示されるデータを指定する。\n */\n defaultTemplateData?: Row[];\n\n /**\n * ダウンロードテンプレートで利用する項目を選択するかどうかを指定する。\n * デフォルトでは、hiddenOnCreateTemplateが指定されていない列の全ての項目が追加される。\n * @default false\n */\n selectDownloadTemplateColumns?: boolean;\n}\n\nconst CSVImportUIContent = <\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n>({\n columns,\n onDownloadCSV,\n searchLabel,\n onSearchData,\n renderSearchField,\n csvPrefix,\n csvParser,\n csvValidator,\n onPreUploadData,\n onPreUploadDataByRow,\n onUploadData,\n onUploadDataByRow,\n acceptMode,\n skipDownloadTemplate,\n selectDownloadTemplateColumns,\n defaultTemplateData,\n}: CSVImportUIProps<Columns, Row>) => {\n const id = useScreen();\n const [mode, setMode] = useState<Mode>(acceptMode[0]);\n const [uploadedData, setUploadedData] = useState<Row[]>([]);\n const [errors, setErrors] = useState<(CellError[] | undefined)[]>([]);\n\n const handleUpdateData = useCallback(\n (data: Row[], errors: (CellError[] | undefined)[]) => {\n setErrors(errors);\n setUploadedData(data);\n },\n [],\n );\n\n const headers = useMemo(() => {\n const rowKeys = Object.keys(uploadedData[0] ?? {});\n\n return Object.values(columns)\n .filter((column) => {\n if (rowKeys.length === 0) {\n return true;\n }\n if (column.hiddenIfNoHeader && !rowKeys.includes(column.label)) {\n return false;\n }\n return true;\n })\n .map((column) => column.label);\n }, [columns, uploadedData]);\n\n const filledData = useMemo(() => {\n return headers.length > Object.keys(uploadedData[0] ?? {}).length\n ? uploadedData.map((row) => {\n return {\n ...Object.fromEntries(headers.map((header) => [header, \"\"])),\n ...row,\n };\n })\n : uploadedData;\n }, [headers, uploadedData]);\n\n switch (id) {\n case \"selectMode\": {\n return (\n <SelectModeScreen\n skipDownloadTemplate={skipDownloadTemplate}\n onChangeMode={setMode}\n />\n );\n }\n case \"downloadCreateTemplate\": {\n return (\n <DownloadCreateTemplateScreen\n onDownloadCSV={onDownloadCSV}\n headers={headers}\n columns={columns}\n csvPrefix={csvPrefix}\n selectDownloadTemplateColumns={selectDownloadTemplateColumns}\n />\n );\n }\n case \"downloadUpdateTemplate\": {\n return (\n <DownloadUpdateTemplateScreen\n searchLabel={searchLabel}\n onSearch={onSearchData}\n renderSearchField={renderSearchField}\n onDownloadCSV={onDownloadCSV}\n csvPrefix={csvPrefix}\n headers={headers}\n defaultTemplateData={defaultTemplateData}\n columns={columns}\n />\n );\n }\n case \"loadCSV\": {\n return (\n <LoadCSVScreen\n mode={mode}\n columns={columns}\n data={filledData}\n headers={headers}\n errors={errors}\n csvParser={csvParser}\n csvValidator={csvValidator}\n onPreUploadData={onPreUploadData}\n onPreUploadDataByRow={onPreUploadDataByRow}\n onUpdateData={handleUpdateData}\n />\n );\n }\n case \"uploadCSV\": {\n return (\n <UploadCSVScreen\n mode={mode}\n data={filledData}\n headers={headers}\n errors={errors}\n columns={columns}\n onUploadData={onUploadData}\n onUploadDataByRow={onUploadDataByRow}\n onSubmitComplete={handleUpdateData}\n />\n );\n }\n case \"complete\": {\n return (\n <CompleteScreen\n csvPrefix={csvPrefix}\n onDownloadCSV={onDownloadCSV}\n data={filledData}\n columns={columns}\n headers={headers}\n errors={errors}\n />\n );\n }\n default: {\n return null;\n }\n }\n};\n\nconst getFirstScreenId = (\n accptMode: Mode[],\n skipDownloadTemplate?: boolean,\n): ScreenId => {\n if (accptMode.length > 1) {\n return \"selectMode\";\n }\n if (skipDownloadTemplate) {\n return \"loadCSV\";\n }\n if (accptMode[0] === \"create\") {\n return \"downloadCreateTemplate\";\n }\n if (accptMode[0] === \"update\") {\n return \"downloadUpdateTemplate\";\n }\n return \"selectMode\";\n};\n\nexport const CSVImportUI = <\n Columns extends CSVImportUIColumns,\n Row extends Record<string, string> = CSVImportUIRow<Columns>,\n>(\n props: CSVImportUIProps<Columns, Row>,\n) => {\n return (\n <ScreenProvider\n firstScreenId={getFirstScreenId(\n props.acceptMode,\n props.skipDownloadTemplate,\n )}\n >\n <CSVImportUIContent {...props} />\n </ScreenProvider>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
package/esm/Tooltip/Tooltip.js
CHANGED
|
@@ -15,7 +15,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
15
15
|
styles: "position:absolute;color:rgba(97, 97, 97, 0.9);&::before{display:block;width:0px;height:0px;margin:auto;content:\"\";border-style:solid;}"
|
|
16
16
|
} : {
|
|
17
17
|
name: "ynymi0-Tooltip",
|
|
18
|
-
styles: "position:absolute;color:rgba(97, 97, 97, 0.9);&::before{display:block;width:0px;height:0px;margin:auto;content:\"\";border-style:solid;};label:Tooltip;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
18
|
+
styles: "position:absolute;color:rgba(97, 97, 97, 0.9);&::before{display:block;width:0px;height:0px;margin:auto;content:\"\";border-style:solid;};label:Tooltip;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AA2NsB","file":"../../../src/Tooltip/Tooltip.tsx","sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n  tooltip: {\n    arrow: \"m2mui_Tooltip_arrow\",\n  },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n  /**\n   * Tooltipに表示するテキスト\n   */\n  title: string;\n  /**\n   * Tooltipを表示する要素\n   * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません\n   */\n  children: React.ReactElement<any> | string;\n  /**\n   * 矢印を表示します。\n   *\n   * @default false\n   */\n  arrow?: boolean;\n  /**\n   * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n   *\n   * @default undefined\n   */\n  open?: boolean;\n}\n\nexport const Tooltip = ({\n  children,\n  title,\n  placement,\n  arrow,\n  open: openProp,\n}: TooltipProps) => {\n  const [node, setNode] = useState<HTMLElement | null>(null);\n\n  const theme = useTheme();\n\n  const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n  const [open, setOpen] = useState(false);\n  const prevOpen = useRef<boolean>(undefined);\n  const [hidden, setHidden] = useState(true);\n\n  if (isControlled && openProp !== prevOpen.current) {\n    prevOpen.current = openProp;\n    if (openProp) {\n      setOpen(true);\n      setHidden(false);\n    } else {\n      setHidden(true);\n    }\n  }\n\n  const handleMouseEnter = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setOpen(true);\n          setHidden(false);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  const handleMouseLeave = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setHidden(true);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  return (\n    <React.Fragment>\n      {typeof children === \"string\" ? (\n        <span\n          ref={setNode}\n          onMouseEnter={handleMouseEnter()}\n          onMouseLeave={handleMouseLeave()}\n        >\n          {children}\n        </span>\n      ) : (\n        React.cloneElement(children, {\n          ref: setNode,\n          onMouseEnter: handleMouseEnter(\n            hasOwnProp(children.props, \"onMouseEnter\")\n              ? (children.props.onMouseEnter as React.MouseEventHandler)\n              : undefined,\n          ),\n          onMouseLeave: handleMouseLeave(\n            hasOwnProp(children.props, \"onMouseLeave\")\n              ? (children.props.onMouseLeave as React.MouseEventHandler)\n              : undefined,\n          ),\n        })\n      )}\n      <Popper\n        anchorEl={node}\n        placement={placement}\n        open={open}\n        aria-hidden={hidden}\n        disablePortal\n        onTransitionEnd={() => {\n          if (hidden) {\n            setOpen(false);\n          }\n        }}\n        css={css`\n          opacity: 1;\n          transition: opacity 200ms;\n          &[aria-hidden=\"true\"] {\n            opacity: 0;\n          }\n          &[data-popper-placement*=\"bottom\"] {\n            .${classNames.tooltip.arrow} {\n              top: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-top: -6px;\n              &::before {\n                border-color: transparent transparent currentcolor transparent;\n                border-width: 0 6px 6px 6px;\n              }\n            }\n            & > * {\n              margin-top: 8px;\n            }\n          }\n          &[data-popper-placement*=\"top\"] {\n            .${classNames.tooltip.arrow} {\n              bottom: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-bottom: -6px;\n              &::before {\n                border-color: currentcolor transparent transparent transparent;\n                border-width: 6px 6px 0 6px;\n              }\n            }\n            & > * {\n              margin-bottom: 8px;\n            }\n          }\n          &[data-popper-placement*=\"right\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              left: 0;\n              width: 6px;\n              height: 12px;\n              margin-left: -6px;\n              &::before {\n                border-color: transparent currentcolor transparent transparent;\n                border-width: 6px 6px 6px 0;\n              }\n            }\n            & > * {\n              margin-left: 8px;\n            }\n          }\n          &[data-popper-placement*=\"left\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              right: 0;\n              width: 6px;\n              height: 12px;\n              margin-right: -6px;\n              &::before {\n                border-color: transparent transparent transparent currentcolor;\n                border-width: 6px 0 6px 6px;\n              }\n            }\n            & > * {\n              margin-right: 8px;\n            }\n          }\n        `}\n      >\n        <div\n          css={[\n            theme.typography.caption,\n            css`\n              position: relative;\n              max-width: 300px;\n              padding: 6px 10px;\n              color: #fff;\n              text-align: left;\n              word-wrap: break-word;\n              background-color: rgba(97, 97, 97, 0.9);\n              border-radius: 4px;\n            `,\n          ]}\n        >\n          {title}\n          {arrow ? (\n            <div\n              className={classNames.tooltip.arrow}\n              css={css`\n                position: absolute;\n                color: rgba(97, 97, 97, 0.9);\n                &::before {\n                  display: block;\n                  width: 0px;\n                  height: 0px;\n                  margin: auto;\n                  content: \"\";\n                  border-style: solid;\n                }\n              `}\n            />\n          ) : null}\n        </div>\n      </Popper>\n    </React.Fragment>\n  );\n};\n"]} */",
|
|
19
19
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
20
20
|
};
|
|
21
21
|
var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
@@ -23,7 +23,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
|
23
23
|
styles: "position:relative;max-width:300px;padding:6px 10px;color:#fff;text-align:left;word-wrap:break-word;background-color:rgba(97, 97, 97, 0.9);border-radius:4px"
|
|
24
24
|
} : {
|
|
25
25
|
name: "1350k6g-Tooltip",
|
|
26
|
-
styles: "position:relative;max-width:300px;padding:6px 10px;color:#fff;text-align:left;word-wrap:break-word;background-color:rgba(97, 97, 97, 0.9);border-radius:4px;label:Tooltip;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
26
|
+
styles: "position:relative;max-width:300px;padding:6px 10px;color:#fff;text-align:left;word-wrap:break-word;background-color:rgba(97, 97, 97, 0.9);border-radius:4px;label:Tooltip;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AA2Me","file":"../../../src/Tooltip/Tooltip.tsx","sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n  tooltip: {\n    arrow: \"m2mui_Tooltip_arrow\",\n  },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n  /**\n   * Tooltipに表示するテキスト\n   */\n  title: string;\n  /**\n   * Tooltipを表示する要素\n   * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません\n   */\n  children: React.ReactElement<any> | string;\n  /**\n   * 矢印を表示します。\n   *\n   * @default false\n   */\n  arrow?: boolean;\n  /**\n   * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n   *\n   * @default undefined\n   */\n  open?: boolean;\n}\n\nexport const Tooltip = ({\n  children,\n  title,\n  placement,\n  arrow,\n  open: openProp,\n}: TooltipProps) => {\n  const [node, setNode] = useState<HTMLElement | null>(null);\n\n  const theme = useTheme();\n\n  const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n  const [open, setOpen] = useState(false);\n  const prevOpen = useRef<boolean>(undefined);\n  const [hidden, setHidden] = useState(true);\n\n  if (isControlled && openProp !== prevOpen.current) {\n    prevOpen.current = openProp;\n    if (openProp) {\n      setOpen(true);\n      setHidden(false);\n    } else {\n      setHidden(true);\n    }\n  }\n\n  const handleMouseEnter = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setOpen(true);\n          setHidden(false);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  const handleMouseLeave = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setHidden(true);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  return (\n    <React.Fragment>\n      {typeof children === \"string\" ? (\n        <span\n          ref={setNode}\n          onMouseEnter={handleMouseEnter()}\n          onMouseLeave={handleMouseLeave()}\n        >\n          {children}\n        </span>\n      ) : (\n        React.cloneElement(children, {\n          ref: setNode,\n          onMouseEnter: handleMouseEnter(\n            hasOwnProp(children.props, \"onMouseEnter\")\n              ? (children.props.onMouseEnter as React.MouseEventHandler)\n              : undefined,\n          ),\n          onMouseLeave: handleMouseLeave(\n            hasOwnProp(children.props, \"onMouseLeave\")\n              ? (children.props.onMouseLeave as React.MouseEventHandler)\n              : undefined,\n          ),\n        })\n      )}\n      <Popper\n        anchorEl={node}\n        placement={placement}\n        open={open}\n        aria-hidden={hidden}\n        disablePortal\n        onTransitionEnd={() => {\n          if (hidden) {\n            setOpen(false);\n          }\n        }}\n        css={css`\n          opacity: 1;\n          transition: opacity 200ms;\n          &[aria-hidden=\"true\"] {\n            opacity: 0;\n          }\n          &[data-popper-placement*=\"bottom\"] {\n            .${classNames.tooltip.arrow} {\n              top: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-top: -6px;\n              &::before {\n                border-color: transparent transparent currentcolor transparent;\n                border-width: 0 6px 6px 6px;\n              }\n            }\n            & > * {\n              margin-top: 8px;\n            }\n          }\n          &[data-popper-placement*=\"top\"] {\n            .${classNames.tooltip.arrow} {\n              bottom: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-bottom: -6px;\n              &::before {\n                border-color: currentcolor transparent transparent transparent;\n                border-width: 6px 6px 0 6px;\n              }\n            }\n            & > * {\n              margin-bottom: 8px;\n            }\n          }\n          &[data-popper-placement*=\"right\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              left: 0;\n              width: 6px;\n              height: 12px;\n              margin-left: -6px;\n              &::before {\n                border-color: transparent currentcolor transparent transparent;\n                border-width: 6px 6px 6px 0;\n              }\n            }\n            & > * {\n              margin-left: 8px;\n            }\n          }\n          &[data-popper-placement*=\"left\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              right: 0;\n              width: 6px;\n              height: 12px;\n              margin-right: -6px;\n              &::before {\n                border-color: transparent transparent transparent currentcolor;\n                border-width: 6px 0 6px 6px;\n              }\n            }\n            & > * {\n              margin-right: 8px;\n            }\n          }\n        `}\n      >\n        <div\n          css={[\n            theme.typography.caption,\n            css`\n              position: relative;\n              max-width: 300px;\n              padding: 6px 10px;\n              color: #fff;\n              text-align: left;\n              word-wrap: break-word;\n              background-color: rgba(97, 97, 97, 0.9);\n              border-radius: 4px;\n            `,\n          ]}\n        >\n          {title}\n          {arrow ? (\n            <div\n              className={classNames.tooltip.arrow}\n              css={css`\n                position: absolute;\n                color: rgba(97, 97, 97, 0.9);\n                &::before {\n                  display: block;\n                  width: 0px;\n                  height: 0px;\n                  margin: auto;\n                  content: \"\";\n                  border-style: solid;\n                }\n              `}\n            />\n          ) : null}\n        </div>\n      </Popper>\n    </React.Fragment>\n  );\n};\n"]} */",
|
|
27
27
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
28
28
|
};
|
|
29
29
|
export var Tooltip = _ref3 => {
|
|
@@ -85,9 +85,9 @@ export var Tooltip = _ref3 => {
|
|
|
85
85
|
setOpen(false);
|
|
86
86
|
}
|
|
87
87
|
},
|
|
88
|
-
css: /*#__PURE__*/css("opacity:1;transition:opacity 200ms;&[aria-hidden=\"true\"]{opacity:0;}&[data-popper-placement*=\"bottom\"]{.", classNames.tooltip.arrow, "{top:0;left:12px;width:12px;height:6px;margin-top:-6px;&::before{border-color:transparent transparent currentcolor transparent;border-width:0 6px 6px 6px;}}&>*{margin-top:8px;}}&[data-popper-placement*=\"top\"]{.", classNames.tooltip.arrow, "{bottom:0;left:12px;width:12px;height:6px;margin-bottom:-6px;&::before{border-color:currentcolor transparent transparent transparent;border-width:6px 6px 0 6px;}}&>*{margin-bottom:8px;}}&[data-popper-placement*=\"right\"]{.", classNames.tooltip.arrow, "{top:12px;left:0;width:6px;height:12px;margin-left:-6px;&::before{border-color:transparent currentcolor transparent transparent;border-width:6px 6px 6px 0;}}&>*{margin-left:8px;}}&[data-popper-placement*=\"left\"]{.", classNames.tooltip.arrow, "{top:12px;right:0;width:6px;height:12px;margin-right:-6px;&::before{border-color:transparent transparent transparent currentcolor;border-width:6px 0 6px 6px;}}&>*{margin-right:8px;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AAyHgB","file":"../../../src/Tooltip/Tooltip.tsx","sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n  tooltip: {\n    arrow: \"m2mui_Tooltip_arrow\",\n  },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n  title: string;\n  children: React.ReactElement<any> | string;\n  /**\n   * 矢印を表示します。\n   *\n   * @default false\n   */\n  arrow?: boolean;\n  /**\n   * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n   *\n   * @default undefined\n   */\n  open?: boolean;\n}\n\nexport const Tooltip = ({\n  children,\n  title,\n  placement,\n  arrow,\n  open: openProp,\n}: TooltipProps) => {\n  const [node, setNode] = useState<HTMLElement | null>(null);\n\n  const theme = useTheme();\n\n  const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n  const [open, setOpen] = useState(false);\n  const prevOpen = useRef<boolean>(undefined);\n  const [hidden, setHidden] = useState(true);\n\n  if (isControlled && openProp !== prevOpen.current) {\n    prevOpen.current = openProp;\n    if (openProp) {\n      setOpen(true);\n      setHidden(false);\n    } else {\n      setHidden(true);\n    }\n  }\n\n  const handleMouseEnter = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setOpen(true);\n          setHidden(false);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  const handleMouseLeave = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setHidden(true);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  return (\n    <React.Fragment>\n      {typeof children === \"string\" ? (\n        <span\n          ref={setNode}\n          onMouseEnter={handleMouseEnter()}\n          onMouseLeave={handleMouseLeave()}\n        >\n          {children}\n        </span>\n      ) : (\n        React.cloneElement(children, {\n          ref: setNode,\n          onMouseEnter: handleMouseEnter(\n            hasOwnProp(children.props, \"onMouseEnter\")\n              ? (children.props.onMouseEnter as React.MouseEventHandler)\n              : undefined,\n          ),\n          onMouseLeave: handleMouseLeave(\n            hasOwnProp(children.props, \"onMouseLeave\")\n              ? (children.props.onMouseLeave as React.MouseEventHandler)\n              : undefined,\n          ),\n        })\n      )}\n      <Popper\n        anchorEl={node}\n        placement={placement}\n        open={open}\n        aria-hidden={hidden}\n        disablePortal\n        onTransitionEnd={() => {\n          if (hidden) {\n            setOpen(false);\n          }\n        }}\n        css={css`\n          opacity: 1;\n          transition: opacity 200ms;\n          &[aria-hidden=\"true\"] {\n            opacity: 0;\n          }\n          &[data-popper-placement*=\"bottom\"] {\n            .${classNames.tooltip.arrow} {\n              top: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-top: -6px;\n              &::before {\n                border-color: transparent transparent currentcolor transparent;\n                border-width: 0 6px 6px 6px;\n              }\n            }\n            & > * {\n              margin-top: 8px;\n            }\n          }\n          &[data-popper-placement*=\"top\"] {\n            .${classNames.tooltip.arrow} {\n              bottom: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-bottom: -6px;\n              &::before {\n                border-color: currentcolor transparent transparent transparent;\n                border-width: 6px 6px 0 6px;\n              }\n            }\n            & > * {\n              margin-bottom: 8px;\n            }\n          }\n          &[data-popper-placement*=\"right\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              left: 0;\n              width: 6px;\n              height: 12px;\n              margin-left: -6px;\n              &::before {\n                border-color: transparent currentcolor transparent transparent;\n                border-width: 6px 6px 6px 0;\n              }\n            }\n            & > * {\n              margin-left: 8px;\n            }\n          }\n          &[data-popper-placement*=\"left\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              right: 0;\n              width: 6px;\n              height: 12px;\n              margin-right: -6px;\n              &::before {\n                border-color: transparent transparent transparent currentcolor;\n                border-width: 6px 0 6px 6px;\n              }\n            }\n            & > * {\n              margin-right: 8px;\n            }\n          }\n        `}\n      >\n        <div\n          css={[\n            theme.typography.caption,\n            css`\n              position: relative;\n              max-width: 300px;\n              padding: 6px 10px;\n              color: #fff;\n              text-align: left;\n              word-wrap: break-word;\n              background-color: rgba(97, 97, 97, 0.9);\n              border-radius: 4px;\n            `,\n          ]}\n        >\n          {title}\n          {arrow ? (\n            <div\n              className={classNames.tooltip.arrow}\n              css={css`\n                position: absolute;\n                color: rgba(97, 97, 97, 0.9);\n                &::before {\n                  display: block;\n                  width: 0px;\n                  height: 0px;\n                  margin: auto;\n                  content: \"\";\n                  border-style: solid;\n                }\n              `}\n            />\n          ) : null}\n        </div>\n      </Popper>\n    </React.Fragment>\n  );\n};\n"]} */")
|
|
88
|
+
css: /*#__PURE__*/css("opacity:1;transition:opacity 200ms;&[aria-hidden=\"true\"]{opacity:0;}&[data-popper-placement*=\"bottom\"]{.", classNames.tooltip.arrow, "{top:0;left:12px;width:12px;height:6px;margin-top:-6px;&::before{border-color:transparent transparent currentcolor transparent;border-width:0 6px 6px 6px;}}&>*{margin-top:8px;}}&[data-popper-placement*=\"top\"]{.", classNames.tooltip.arrow, "{bottom:0;left:12px;width:12px;height:6px;margin-bottom:-6px;&::before{border-color:currentcolor transparent transparent transparent;border-width:6px 6px 0 6px;}}&>*{margin-bottom:8px;}}&[data-popper-placement*=\"right\"]{.", classNames.tooltip.arrow, "{top:12px;left:0;width:6px;height:12px;margin-left:-6px;&::before{border-color:transparent currentcolor transparent transparent;border-width:6px 6px 6px 0;}}&>*{margin-left:8px;}}&[data-popper-placement*=\"left\"]{.", classNames.tooltip.arrow, "{top:12px;right:0;width:6px;height:12px;margin-right:-6px;&::before{border-color:transparent transparent transparent currentcolor;border-width:6px 0 6px 6px;}}&>*{margin-right:8px;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AAgIgB","file":"../../../src/Tooltip/Tooltip.tsx","sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n  tooltip: {\n    arrow: \"m2mui_Tooltip_arrow\",\n  },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n  /**\n   * Tooltipに表示するテキスト\n   */\n  title: string;\n  /**\n   * Tooltipを表示する要素\n   * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません\n   */\n  children: React.ReactElement<any> | string;\n  /**\n   * 矢印を表示します。\n   *\n   * @default false\n   */\n  arrow?: boolean;\n  /**\n   * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n   *\n   * @default undefined\n   */\n  open?: boolean;\n}\n\nexport const Tooltip = ({\n  children,\n  title,\n  placement,\n  arrow,\n  open: openProp,\n}: TooltipProps) => {\n  const [node, setNode] = useState<HTMLElement | null>(null);\n\n  const theme = useTheme();\n\n  const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n  const [open, setOpen] = useState(false);\n  const prevOpen = useRef<boolean>(undefined);\n  const [hidden, setHidden] = useState(true);\n\n  if (isControlled && openProp !== prevOpen.current) {\n    prevOpen.current = openProp;\n    if (openProp) {\n      setOpen(true);\n      setHidden(false);\n    } else {\n      setHidden(true);\n    }\n  }\n\n  const handleMouseEnter = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setOpen(true);\n          setHidden(false);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  const handleMouseLeave = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setHidden(true);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  return (\n    <React.Fragment>\n      {typeof children === \"string\" ? (\n        <span\n          ref={setNode}\n          onMouseEnter={handleMouseEnter()}\n          onMouseLeave={handleMouseLeave()}\n        >\n          {children}\n        </span>\n      ) : (\n        React.cloneElement(children, {\n          ref: setNode,\n          onMouseEnter: handleMouseEnter(\n            hasOwnProp(children.props, \"onMouseEnter\")\n              ? (children.props.onMouseEnter as React.MouseEventHandler)\n              : undefined,\n          ),\n          onMouseLeave: handleMouseLeave(\n            hasOwnProp(children.props, \"onMouseLeave\")\n              ? (children.props.onMouseLeave as React.MouseEventHandler)\n              : undefined,\n          ),\n        })\n      )}\n      <Popper\n        anchorEl={node}\n        placement={placement}\n        open={open}\n        aria-hidden={hidden}\n        disablePortal\n        onTransitionEnd={() => {\n          if (hidden) {\n            setOpen(false);\n          }\n        }}\n        css={css`\n          opacity: 1;\n          transition: opacity 200ms;\n          &[aria-hidden=\"true\"] {\n            opacity: 0;\n          }\n          &[data-popper-placement*=\"bottom\"] {\n            .${classNames.tooltip.arrow} {\n              top: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-top: -6px;\n              &::before {\n                border-color: transparent transparent currentcolor transparent;\n                border-width: 0 6px 6px 6px;\n              }\n            }\n            & > * {\n              margin-top: 8px;\n            }\n          }\n          &[data-popper-placement*=\"top\"] {\n            .${classNames.tooltip.arrow} {\n              bottom: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-bottom: -6px;\n              &::before {\n                border-color: currentcolor transparent transparent transparent;\n                border-width: 6px 6px 0 6px;\n              }\n            }\n            & > * {\n              margin-bottom: 8px;\n            }\n          }\n          &[data-popper-placement*=\"right\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              left: 0;\n              width: 6px;\n              height: 12px;\n              margin-left: -6px;\n              &::before {\n                border-color: transparent currentcolor transparent transparent;\n                border-width: 6px 6px 6px 0;\n              }\n            }\n            & > * {\n              margin-left: 8px;\n            }\n          }\n          &[data-popper-placement*=\"left\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              right: 0;\n              width: 6px;\n              height: 12px;\n              margin-right: -6px;\n              &::before {\n                border-color: transparent transparent transparent currentcolor;\n                border-width: 6px 0 6px 6px;\n              }\n            }\n            & > * {\n              margin-right: 8px;\n            }\n          }\n        `}\n      >\n        <div\n          css={[\n            theme.typography.caption,\n            css`\n              position: relative;\n              max-width: 300px;\n              padding: 6px 10px;\n              color: #fff;\n              text-align: left;\n              word-wrap: break-word;\n              background-color: rgba(97, 97, 97, 0.9);\n              border-radius: 4px;\n            `,\n          ]}\n        >\n          {title}\n          {arrow ? (\n            <div\n              className={classNames.tooltip.arrow}\n              css={css`\n                position: absolute;\n                color: rgba(97, 97, 97, 0.9);\n                &::before {\n                  display: block;\n                  width: 0px;\n                  height: 0px;\n                  margin: auto;\n                  content: \"\";\n                  border-style: solid;\n                }\n              `}\n            />\n          ) : null}\n        </div>\n      </Popper>\n    </React.Fragment>\n  );\n};\n"]} */")
|
|
89
89
|
}, ___EmotionJSX("div", {
|
|
90
|
-
css: [theme.typography.caption, _ref2, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
90
|
+
css: [theme.typography.caption, _ref2, process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Tooltip/Tooltip.tsx"],"names":[],"mappings":"AAyMU","file":"../../../src/Tooltip/Tooltip.tsx","sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n  tooltip: {\n    arrow: \"m2mui_Tooltip_arrow\",\n  },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n  /**\n   * Tooltipに表示するテキスト\n   */\n  title: string;\n  /**\n   * Tooltipを表示する要素\n   * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません\n   */\n  children: React.ReactElement<any> | string;\n  /**\n   * 矢印を表示します。\n   *\n   * @default false\n   */\n  arrow?: boolean;\n  /**\n   * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n   *\n   * @default undefined\n   */\n  open?: boolean;\n}\n\nexport const Tooltip = ({\n  children,\n  title,\n  placement,\n  arrow,\n  open: openProp,\n}: TooltipProps) => {\n  const [node, setNode] = useState<HTMLElement | null>(null);\n\n  const theme = useTheme();\n\n  const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n  const [open, setOpen] = useState(false);\n  const prevOpen = useRef<boolean>(undefined);\n  const [hidden, setHidden] = useState(true);\n\n  if (isControlled && openProp !== prevOpen.current) {\n    prevOpen.current = openProp;\n    if (openProp) {\n      setOpen(true);\n      setHidden(false);\n    } else {\n      setHidden(true);\n    }\n  }\n\n  const handleMouseEnter = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setOpen(true);\n          setHidden(false);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  const handleMouseLeave = useCallback(\n    (original?: (event: React.MouseEvent) => void) =>\n      (event: React.MouseEvent) => {\n        if (!isControlled) {\n          setHidden(true);\n        }\n\n        if (original) {\n          original(event);\n        }\n      },\n    [isControlled],\n  );\n\n  return (\n    <React.Fragment>\n      {typeof children === \"string\" ? (\n        <span\n          ref={setNode}\n          onMouseEnter={handleMouseEnter()}\n          onMouseLeave={handleMouseLeave()}\n        >\n          {children}\n        </span>\n      ) : (\n        React.cloneElement(children, {\n          ref: setNode,\n          onMouseEnter: handleMouseEnter(\n            hasOwnProp(children.props, \"onMouseEnter\")\n              ? (children.props.onMouseEnter as React.MouseEventHandler)\n              : undefined,\n          ),\n          onMouseLeave: handleMouseLeave(\n            hasOwnProp(children.props, \"onMouseLeave\")\n              ? (children.props.onMouseLeave as React.MouseEventHandler)\n              : undefined,\n          ),\n        })\n      )}\n      <Popper\n        anchorEl={node}\n        placement={placement}\n        open={open}\n        aria-hidden={hidden}\n        disablePortal\n        onTransitionEnd={() => {\n          if (hidden) {\n            setOpen(false);\n          }\n        }}\n        css={css`\n          opacity: 1;\n          transition: opacity 200ms;\n          &[aria-hidden=\"true\"] {\n            opacity: 0;\n          }\n          &[data-popper-placement*=\"bottom\"] {\n            .${classNames.tooltip.arrow} {\n              top: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-top: -6px;\n              &::before {\n                border-color: transparent transparent currentcolor transparent;\n                border-width: 0 6px 6px 6px;\n              }\n            }\n            & > * {\n              margin-top: 8px;\n            }\n          }\n          &[data-popper-placement*=\"top\"] {\n            .${classNames.tooltip.arrow} {\n              bottom: 0;\n              left: 12px;\n              width: 12px;\n              height: 6px;\n              margin-bottom: -6px;\n              &::before {\n                border-color: currentcolor transparent transparent transparent;\n                border-width: 6px 6px 0 6px;\n              }\n            }\n            & > * {\n              margin-bottom: 8px;\n            }\n          }\n          &[data-popper-placement*=\"right\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              left: 0;\n              width: 6px;\n              height: 12px;\n              margin-left: -6px;\n              &::before {\n                border-color: transparent currentcolor transparent transparent;\n                border-width: 6px 6px 6px 0;\n              }\n            }\n            & > * {\n              margin-left: 8px;\n            }\n          }\n          &[data-popper-placement*=\"left\"] {\n            .${classNames.tooltip.arrow} {\n              top: 12px;\n              right: 0;\n              width: 6px;\n              height: 12px;\n              margin-right: -6px;\n              &::before {\n                border-color: transparent transparent transparent currentcolor;\n                border-width: 6px 0 6px 6px;\n              }\n            }\n            & > * {\n              margin-right: 8px;\n            }\n          }\n        `}\n      >\n        <div\n          css={[\n            theme.typography.caption,\n            css`\n              position: relative;\n              max-width: 300px;\n              padding: 6px 10px;\n              color: #fff;\n              text-align: left;\n              word-wrap: break-word;\n              background-color: rgba(97, 97, 97, 0.9);\n              border-radius: 4px;\n            `,\n          ]}\n        >\n          {title}\n          {arrow ? (\n            <div\n              className={classNames.tooltip.arrow}\n              css={css`\n                position: absolute;\n                color: rgba(97, 97, 97, 0.9);\n                &::before {\n                  display: block;\n                  width: 0px;\n                  height: 0px;\n                  margin: auto;\n                  content: \"\";\n                  border-style: solid;\n                }\n              `}\n            />\n          ) : null}\n        </div>\n      </Popper>\n    </React.Fragment>\n  );\n};\n"]} */"]
|
|
91
91
|
}, title, arrow ? ___EmotionJSX("div", {
|
|
92
92
|
className: classNames.tooltip.arrow,
|
|
93
93
|
css: _ref
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Tooltip.js","names":["Popper","css","hasOwnProp","useTheme","React","useCallback","useMemo","useRef","useState","jsx","___EmotionJSX","classNames","tooltip","arrow","_ref","process","env","NODE_ENV","name","styles","toString","_EMOTION_STRINGIFIED_CSS_ERROR__","_ref2","Tooltip","_ref3","children","title","placement","open","openProp","node","setNode","theme","isControlled","undefined","setOpen","prevOpen","hidden","setHidden","current","handleMouseEnter","original","event","handleMouseLeave","Fragment","ref","onMouseEnter","onMouseLeave","cloneElement","props","anchorEl","disablePortal","onTransitionEnd","typography","caption","className"],"sources":["../../../src/Tooltip/Tooltip.tsx"],"sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n tooltip: {\n arrow: \"m2mui_Tooltip_arrow\",\n },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n title: string;\n children: React.ReactElement<any> | string;\n /**\n * 矢印を表示します。\n *\n * @default false\n */\n arrow?: boolean;\n /**\n * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n *\n * @default undefined\n */\n open?: boolean;\n}\n\nexport const Tooltip = ({\n children,\n title,\n placement,\n arrow,\n open: openProp,\n}: TooltipProps) => {\n const [node, setNode] = useState<HTMLElement | null>(null);\n\n const theme = useTheme();\n\n const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n const [open, setOpen] = useState(false);\n const prevOpen = useRef<boolean>(undefined);\n const [hidden, setHidden] = useState(true);\n\n if (isControlled && openProp !== prevOpen.current) {\n prevOpen.current = openProp;\n if (openProp) {\n setOpen(true);\n setHidden(false);\n } else {\n setHidden(true);\n }\n }\n\n const handleMouseEnter = useCallback(\n (original?: (event: React.MouseEvent) => void) =>\n (event: React.MouseEvent) => {\n if (!isControlled) {\n setOpen(true);\n setHidden(false);\n }\n\n if (original) {\n original(event);\n }\n },\n [isControlled],\n );\n\n const handleMouseLeave = useCallback(\n (original?: (event: React.MouseEvent) => void) =>\n (event: React.MouseEvent) => {\n if (!isControlled) {\n setHidden(true);\n }\n\n if (original) {\n original(event);\n }\n },\n [isControlled],\n );\n\n return (\n <React.Fragment>\n {typeof children === \"string\" ? (\n <span\n ref={setNode}\n onMouseEnter={handleMouseEnter()}\n onMouseLeave={handleMouseLeave()}\n >\n {children}\n </span>\n ) : (\n React.cloneElement(children, {\n ref: setNode,\n onMouseEnter: handleMouseEnter(\n hasOwnProp(children.props, \"onMouseEnter\")\n ? (children.props.onMouseEnter as React.MouseEventHandler)\n : undefined,\n ),\n onMouseLeave: handleMouseLeave(\n hasOwnProp(children.props, \"onMouseLeave\")\n ? (children.props.onMouseLeave as React.MouseEventHandler)\n : undefined,\n ),\n })\n )}\n <Popper\n anchorEl={node}\n placement={placement}\n open={open}\n aria-hidden={hidden}\n disablePortal\n onTransitionEnd={() => {\n if (hidden) {\n setOpen(false);\n }\n }}\n css={css`\n opacity: 1;\n transition: opacity 200ms;\n &[aria-hidden=\"true\"] {\n opacity: 0;\n }\n &[data-popper-placement*=\"bottom\"] {\n .${classNames.tooltip.arrow} {\n top: 0;\n left: 12px;\n width: 12px;\n height: 6px;\n margin-top: -6px;\n &::before {\n border-color: transparent transparent currentcolor transparent;\n border-width: 0 6px 6px 6px;\n }\n }\n & > * {\n margin-top: 8px;\n }\n }\n &[data-popper-placement*=\"top\"] {\n .${classNames.tooltip.arrow} {\n bottom: 0;\n left: 12px;\n width: 12px;\n height: 6px;\n margin-bottom: -6px;\n &::before {\n border-color: currentcolor transparent transparent transparent;\n border-width: 6px 6px 0 6px;\n }\n }\n & > * {\n margin-bottom: 8px;\n }\n }\n &[data-popper-placement*=\"right\"] {\n .${classNames.tooltip.arrow} {\n top: 12px;\n left: 0;\n width: 6px;\n height: 12px;\n margin-left: -6px;\n &::before {\n border-color: transparent currentcolor transparent transparent;\n border-width: 6px 6px 6px 0;\n }\n }\n & > * {\n margin-left: 8px;\n }\n }\n &[data-popper-placement*=\"left\"] {\n .${classNames.tooltip.arrow} {\n top: 12px;\n right: 0;\n width: 6px;\n height: 12px;\n margin-right: -6px;\n &::before {\n border-color: transparent transparent transparent currentcolor;\n border-width: 6px 0 6px 6px;\n }\n }\n & > * {\n margin-right: 8px;\n }\n }\n `}\n >\n <div\n css={[\n theme.typography.caption,\n css`\n position: relative;\n max-width: 300px;\n padding: 6px 10px;\n color: #fff;\n text-align: left;\n word-wrap: break-word;\n background-color: rgba(97, 97, 97, 0.9);\n border-radius: 4px;\n `,\n ]}\n >\n {title}\n {arrow ? (\n <div\n className={classNames.tooltip.arrow}\n css={css`\n position: absolute;\n color: rgba(97, 97, 97, 0.9);\n &::before {\n display: block;\n width: 0px;\n height: 0px;\n margin: auto;\n content: \"\";\n border-style: solid;\n }\n `}\n />\n ) : null}\n </div>\n </Popper>\n </React.Fragment>\n );\n};\n"],"mappings":";AAAA,SAASA,MAAM,QAAyB,WAAW;AACnD,SAASC,GAAG,QAAQ,gBAAgB;AACpC,SAASC,UAAU,QAAQ,sBAAsB;AACjD,SAASC,QAAQ,QAAQ,UAAU;AACnC,OAAOC,KAAK,IAAIC,WAAW,EAAEC,OAAO,EAAEC,MAAM,EAAEC,QAAQ,QAAQ,OAAO;AAAC,SAAAC,GAAA,IAAAC,aAAA;AAEtE,IAAMC,UAAU,GAAG;EACjBC,OAAO,EAAE;IACPC,KAAK,EAAE;EACT;AACF,CAAC;AAAC,IAAAC,IAAA,GAAAC,OAAA,CAAAC,GAAA,CAAAC,QAAA;EAAAC,IAAA;EAAAC,MAAA;AAAA;EAAAD,IAAA;EAAAC,MAAA;EAAAC,QAAA,EAAAC;AAAA;AAAA,IAAAC,KAAA,GAAAP,OAAA,CAAAC,GAAA,CAAAC,QAAA;EAAAC,IAAA;EAAAC,MAAA;AAAA;EAAAD,IAAA;EAAAC,MAAA;EAAAC,QAAA,EAAAC;AAAA;AAmBF,OAAO,IAAME,OAAO,GAAGC,KAAA,IAMH;EAAA,IANI;IACtBC,QAAQ;IACRC,KAAK;IACLC,SAAS;IACTd,KAAK;IACLe,IAAI,EAAEC;EACM,CAAC,GAAAL,KAAA;EACb,IAAM,CAACM,IAAI,EAAEC,OAAO,CAAC,GAAGvB,QAAQ,CAAqB,IAAI,CAAC;EAE1D,IAAMwB,KAAK,GAAG7B,QAAQ,CAAC,CAAC;EAExB,IAAM8B,YAAY,GAAG3B,OAAO,CAAC,MAAMuB,QAAQ,KAAKK,SAAS,EAAE,CAACL,QAAQ,CAAC,CAAC;EAEtE,IAAM,CAACD,IAAI,EAAEO,OAAO,CAAC,GAAG3B,QAAQ,CAAC,KAAK,CAAC;EACvC,IAAM4B,QAAQ,GAAG7B,MAAM,CAAU2B,SAAS,CAAC;EAC3C,IAAM,CAACG,MAAM,EAAEC,SAAS,CAAC,GAAG9B,QAAQ,CAAC,IAAI,CAAC;EAE1C,IAAIyB,YAAY,IAAIJ,QAAQ,KAAKO,QAAQ,CAACG,OAAO,EAAE;IACjDH,QAAQ,CAACG,OAAO,GAAGV,QAAQ;IAC3B,IAAIA,QAAQ,EAAE;MACZM,OAAO,CAAC,IAAI,CAAC;MACbG,SAAS,CAAC,KAAK,CAAC;IAClB,CAAC,MAAM;MACLA,SAAS,CAAC,IAAI,CAAC;IACjB;EACF;EAEA,IAAME,gBAAgB,GAAGnC,WAAW,CACjCoC,QAA4C,IAC1CC,KAAuB,IAAK;IAC3B,IAAI,CAACT,YAAY,EAAE;MACjBE,OAAO,CAAC,IAAI,CAAC;MACbG,SAAS,CAAC,KAAK,CAAC;IAClB;IAEA,IAAIG,QAAQ,EAAE;MACZA,QAAQ,CAACC,KAAK,CAAC;IACjB;EACF,CAAC,EACH,CAACT,YAAY,CACf,CAAC;EAED,IAAMU,gBAAgB,GAAGtC,WAAW,CACjCoC,QAA4C,IAC1CC,KAAuB,IAAK;IAC3B,IAAI,CAACT,YAAY,EAAE;MACjBK,SAAS,CAAC,IAAI,CAAC;IACjB;IAEA,IAAIG,QAAQ,EAAE;MACZA,QAAQ,CAACC,KAAK,CAAC;IACjB;EACF,CAAC,EACH,CAACT,YAAY,CACf,CAAC;EAED,OACEvB,aAAA,CAACN,KAAK,CAACwC,QAAQ,QACZ,OAAOnB,QAAQ,KAAK,QAAQ,GAC3Bf,aAAA;IACEmC,GAAG,EAAEd,OAAQ;IACbe,YAAY,EAAEN,gBAAgB,CAAC,CAAE;IACjCO,YAAY,EAAEJ,gBAAgB,CAAC;EAAE,GAEhClB,QACG,CAAC,iBAEPrB,KAAK,CAAC4C,YAAY,CAACvB,QAAQ,EAAE;IAC3BoB,GAAG,EAAEd,OAAO;IACZe,YAAY,EAAEN,gBAAgB,CAC5BtC,UAAU,CAACuB,QAAQ,CAACwB,KAAK,EAAE,cAAc,CAAC,GACrCxB,QAAQ,CAACwB,KAAK,CAACH,YAAY,GAC5BZ,SACN,CAAC;IACDa,YAAY,EAAEJ,gBAAgB,CAC5BzC,UAAU,CAACuB,QAAQ,CAACwB,KAAK,EAAE,cAAc,CAAC,GACrCxB,QAAQ,CAACwB,KAAK,CAACF,YAAY,GAC5Bb,SACN;EACF,CAAC,CAAC,CACH,EACDxB,aAAA,CAACV,MAAM;IACLkD,QAAQ,EAAEpB,IAAK;IACfH,SAAS,EAAEA,SAAU;IACrBC,IAAI,EAAEA,IAAK;IACX,eAAaS,MAAO;IACpBc,aAAa;IACbC,eAAe,EAAEA,CAAA,KAAM;MACrB,IAAIf,MAAM,EAAE;QACVF,OAAO,CAAC,KAAK,CAAC;MAChB;IACF,CAAE;IACFlC,GAAG,eAAEA,GAAG,iHAODU,UAAU,CAACC,OAAO,CAACC,KAAK,0NAgBxBF,UAAU,CAACC,OAAO,CAACC,KAAK,qOAgBxBF,UAAU,CAACC,OAAO,CAACC,KAAK,6NAgBxBF,UAAU,CAACC,OAAO,CAACC,KAAK,8LAAAE,OAAA,CAAAC,GAAA,CAAAC,QAAA,6CAAAF,OAAA,CAAAC,GAAA,CAAAC,QAAA;EAe7B,GAEFP,aAAA;IACET,GAAG,GACD+B,KAAK,CAACqB,UAAU,CAACC,OAAO,EAAAhC,KAAA,EAAAP,OAAA,CAAAC,GAAA,CAAAC,QAAA,4CAAAF,OAAA,CAAAC,GAAA,CAAAC,QAAA;EAWxB,GAEDS,KAAK,EACLb,KAAK,GACJH,aAAA;IACE6C,SAAS,EAAE5C,UAAU,CAACC,OAAO,CAACC,KAAM;IACpCZ,GAAG,EAAAa;EAWD,CACH,CAAC,GACA,IACD,CACC,CACM,CAAC;AAErB,CAAC","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"Tooltip.js","names":["Popper","css","hasOwnProp","useTheme","React","useCallback","useMemo","useRef","useState","jsx","___EmotionJSX","classNames","tooltip","arrow","_ref","process","env","NODE_ENV","name","styles","toString","_EMOTION_STRINGIFIED_CSS_ERROR__","_ref2","Tooltip","_ref3","children","title","placement","open","openProp","node","setNode","theme","isControlled","undefined","setOpen","prevOpen","hidden","setHidden","current","handleMouseEnter","original","event","handleMouseLeave","Fragment","ref","onMouseEnter","onMouseLeave","cloneElement","props","anchorEl","disablePortal","onTransitionEnd","typography","caption","className"],"sources":["../../../src/Tooltip/Tooltip.tsx"],"sourcesContent":["import { Popper, PopperBaseProps } from \"../Popper\";\nimport { css } from \"@emotion/react\";\nimport { hasOwnProp } from \"../@utils/hasOwnProp\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useMemo, useRef, useState } from \"react\";\n\nconst classNames = {\n tooltip: {\n arrow: \"m2mui_Tooltip_arrow\",\n },\n};\n\nexport interface TooltipProps extends Pick<PopperBaseProps, \"placement\"> {\n /**\n * Tooltipに表示するテキスト\n */\n title: string;\n /**\n * Tooltipを表示する要素\n * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません\n */\n children: React.ReactElement<any> | string;\n /**\n * 矢印を表示します。\n *\n * @default false\n */\n arrow?: boolean;\n /**\n * デフォルトの子要素にホバーした際に表示する機能を無視して、表示するかどうかを指定します。\n *\n * @default undefined\n */\n open?: boolean;\n}\n\nexport const Tooltip = ({\n children,\n title,\n placement,\n arrow,\n open: openProp,\n}: TooltipProps) => {\n const [node, setNode] = useState<HTMLElement | null>(null);\n\n const theme = useTheme();\n\n const isControlled = useMemo(() => openProp !== undefined, [openProp]);\n\n const [open, setOpen] = useState(false);\n const prevOpen = useRef<boolean>(undefined);\n const [hidden, setHidden] = useState(true);\n\n if (isControlled && openProp !== prevOpen.current) {\n prevOpen.current = openProp;\n if (openProp) {\n setOpen(true);\n setHidden(false);\n } else {\n setHidden(true);\n }\n }\n\n const handleMouseEnter = useCallback(\n (original?: (event: React.MouseEvent) => void) =>\n (event: React.MouseEvent) => {\n if (!isControlled) {\n setOpen(true);\n setHidden(false);\n }\n\n if (original) {\n original(event);\n }\n },\n [isControlled],\n );\n\n const handleMouseLeave = useCallback(\n (original?: (event: React.MouseEvent) => void) =>\n (event: React.MouseEvent) => {\n if (!isControlled) {\n setHidden(true);\n }\n\n if (original) {\n original(event);\n }\n },\n [isControlled],\n );\n\n return (\n <React.Fragment>\n {typeof children === \"string\" ? (\n <span\n ref={setNode}\n onMouseEnter={handleMouseEnter()}\n onMouseLeave={handleMouseLeave()}\n >\n {children}\n </span>\n ) : (\n React.cloneElement(children, {\n ref: setNode,\n onMouseEnter: handleMouseEnter(\n hasOwnProp(children.props, \"onMouseEnter\")\n ? (children.props.onMouseEnter as React.MouseEventHandler)\n : undefined,\n ),\n onMouseLeave: handleMouseLeave(\n hasOwnProp(children.props, \"onMouseLeave\")\n ? (children.props.onMouseLeave as React.MouseEventHandler)\n : undefined,\n ),\n })\n )}\n <Popper\n anchorEl={node}\n placement={placement}\n open={open}\n aria-hidden={hidden}\n disablePortal\n onTransitionEnd={() => {\n if (hidden) {\n setOpen(false);\n }\n }}\n css={css`\n opacity: 1;\n transition: opacity 200ms;\n &[aria-hidden=\"true\"] {\n opacity: 0;\n }\n &[data-popper-placement*=\"bottom\"] {\n .${classNames.tooltip.arrow} {\n top: 0;\n left: 12px;\n width: 12px;\n height: 6px;\n margin-top: -6px;\n &::before {\n border-color: transparent transparent currentcolor transparent;\n border-width: 0 6px 6px 6px;\n }\n }\n & > * {\n margin-top: 8px;\n }\n }\n &[data-popper-placement*=\"top\"] {\n .${classNames.tooltip.arrow} {\n bottom: 0;\n left: 12px;\n width: 12px;\n height: 6px;\n margin-bottom: -6px;\n &::before {\n border-color: currentcolor transparent transparent transparent;\n border-width: 6px 6px 0 6px;\n }\n }\n & > * {\n margin-bottom: 8px;\n }\n }\n &[data-popper-placement*=\"right\"] {\n .${classNames.tooltip.arrow} {\n top: 12px;\n left: 0;\n width: 6px;\n height: 12px;\n margin-left: -6px;\n &::before {\n border-color: transparent currentcolor transparent transparent;\n border-width: 6px 6px 6px 0;\n }\n }\n & > * {\n margin-left: 8px;\n }\n }\n &[data-popper-placement*=\"left\"] {\n .${classNames.tooltip.arrow} {\n top: 12px;\n right: 0;\n width: 6px;\n height: 12px;\n margin-right: -6px;\n &::before {\n border-color: transparent transparent transparent currentcolor;\n border-width: 6px 0 6px 6px;\n }\n }\n & > * {\n margin-right: 8px;\n }\n }\n `}\n >\n <div\n css={[\n theme.typography.caption,\n css`\n position: relative;\n max-width: 300px;\n padding: 6px 10px;\n color: #fff;\n text-align: left;\n word-wrap: break-word;\n background-color: rgba(97, 97, 97, 0.9);\n border-radius: 4px;\n `,\n ]}\n >\n {title}\n {arrow ? (\n <div\n className={classNames.tooltip.arrow}\n css={css`\n position: absolute;\n color: rgba(97, 97, 97, 0.9);\n &::before {\n display: block;\n width: 0px;\n height: 0px;\n margin: auto;\n content: \"\";\n border-style: solid;\n }\n `}\n />\n ) : null}\n </div>\n </Popper>\n </React.Fragment>\n );\n};\n"],"mappings":"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","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -43,6 +43,12 @@ export interface CSVImportUIProps<Columns extends CSVImportUIColumns, Row extend
|
|
|
43
43
|
* 行ごとにデータを処理する。
|
|
44
44
|
*
|
|
45
45
|
* onPreUploadDataが指定されている場合、こちらは無視される。
|
|
46
|
+
*
|
|
47
|
+
* この関数内でsetStateを使用すると、行ごとの処理で過剰なレンダリングを引き起こす可能性があります。
|
|
48
|
+
* 状態更新が必要な場合は、以下の方法を検討してください:
|
|
49
|
+
* - onPreUploadDataを使用して一括でデータを処理する
|
|
50
|
+
* - 複数の更新をバッチ処理して、すべての行の処理後に一度だけ状態を更新する
|
|
51
|
+
* - レンダリングを必要としない中間値にはuseRefを使用する
|
|
46
52
|
*/
|
|
47
53
|
onPreUploadDataByRow?: (args: {
|
|
48
54
|
index: number;
|
|
@@ -76,6 +82,12 @@ export interface CSVImportUIProps<Columns extends CSVImportUIColumns, Row extend
|
|
|
76
82
|
* 行ごとにデータをアップロードする。
|
|
77
83
|
*
|
|
78
84
|
* onUploadDataが指定されている場合、こちらは無視される。
|
|
85
|
+
*
|
|
86
|
+
* この関数内でsetStateを使用すると、行ごとの処理で過剰なレンダリングを引き起こす可能性があります。
|
|
87
|
+
* 状態更新が必要な場合は、以下の方法を検討してください:
|
|
88
|
+
* - onUploadDataを使用して一括でデータを処理する
|
|
89
|
+
* - 複数の更新をバッチ処理して、すべての行の処理後に一度だけ状態を更新する
|
|
90
|
+
* - レンダリングを必要としない中間値にはuseRefを使用する
|
|
79
91
|
*/
|
|
80
92
|
onUploadDataByRow?: (args: {
|
|
81
93
|
index: number;
|
|
@@ -1,7 +1,14 @@
|
|
|
1
1
|
import { PopperBaseProps } from "../Popper";
|
|
2
2
|
import React from "react";
|
|
3
3
|
export interface TooltipProps extends Pick<PopperBaseProps, "placement"> {
|
|
4
|
+
/**
|
|
5
|
+
* Tooltipに表示するテキスト
|
|
6
|
+
*/
|
|
4
7
|
title: string;
|
|
8
|
+
/**
|
|
9
|
+
* Tooltipを表示する要素
|
|
10
|
+
* 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません
|
|
11
|
+
*/
|
|
5
12
|
children: React.ReactElement<any> | string;
|
|
6
13
|
/**
|
|
7
14
|
* 矢印を表示します。
|