matsuri-ui 17.1.4-alpha-1755492118981-23aa02c.0 → 17.1.4-alpha-1756105889243-c6b2c2b.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.
Files changed (51) hide show
  1. package/Calendar/CalendarDaysInMonth.js +5 -5
  2. package/Calendar/CalendarDaysInMonth.js.map +1 -1
  3. package/RadioButton/RadioButtonGroup.d.ts +1 -1
  4. package/RadioButton/RadioButtonGroup.js +1 -0
  5. package/RadioButton/RadioButtonGroup.js.map +1 -1
  6. package/SortArea/index.d.ts +1 -1
  7. package/SortArea/index.js +1 -1
  8. package/SortArea/index.js.map +1 -1
  9. package/Tabs/TabGroup.js +4 -3
  10. package/Tabs/TabGroup.js.map +1 -1
  11. package/Tabs/TabPanelGroup.js +1 -0
  12. package/Tabs/TabPanelGroup.js.map +1 -1
  13. package/Tabs/TabUI.d.ts +1 -1
  14. package/Tabs/TabUI.js +10 -10
  15. package/Tabs/TabUI.js.map +1 -1
  16. package/Tooltip/Tooltip.d.ts +1 -1
  17. package/Tooltip/Tooltip.js +8 -5
  18. package/Tooltip/Tooltip.js.map +1 -1
  19. package/cjs/Calendar/CalendarDaysInMonth.js +5 -5
  20. package/cjs/Calendar/CalendarDaysInMonth.js.map +1 -1
  21. package/cjs/RadioButton/RadioButtonGroup.js +1 -0
  22. package/cjs/RadioButton/RadioButtonGroup.js.map +1 -1
  23. package/cjs/SortArea/index.js +2 -1
  24. package/cjs/SortArea/index.js.map +1 -1
  25. package/cjs/Tabs/TabGroup.js +4 -3
  26. package/cjs/Tabs/TabGroup.js.map +1 -1
  27. package/cjs/Tabs/TabPanelGroup.js +1 -0
  28. package/cjs/Tabs/TabPanelGroup.js.map +1 -1
  29. package/cjs/Tabs/TabUI.js +10 -10
  30. package/cjs/Tabs/TabUI.js.map +1 -1
  31. package/cjs/Tooltip/Tooltip.js +8 -5
  32. package/cjs/Tooltip/Tooltip.js.map +1 -1
  33. package/esm/Calendar/CalendarDaysInMonth.js +5 -5
  34. package/esm/Calendar/CalendarDaysInMonth.js.map +1 -1
  35. package/esm/RadioButton/RadioButtonGroup.js +1 -0
  36. package/esm/RadioButton/RadioButtonGroup.js.map +1 -1
  37. package/esm/SortArea/index.js +1 -1
  38. package/esm/SortArea/index.js.map +1 -1
  39. package/esm/Tabs/TabGroup.js +4 -3
  40. package/esm/Tabs/TabGroup.js.map +1 -1
  41. package/esm/Tabs/TabPanelGroup.js +1 -0
  42. package/esm/Tabs/TabPanelGroup.js.map +1 -1
  43. package/esm/Tabs/TabUI.js +10 -10
  44. package/esm/Tabs/TabUI.js.map +1 -1
  45. package/esm/Tooltip/Tooltip.js +8 -5
  46. package/esm/Tooltip/Tooltip.js.map +1 -1
  47. package/package.json +2 -2
  48. package/types/RadioButton/RadioButtonGroup.d.ts +1 -1
  49. package/types/SortArea/index.d.ts +1 -1
  50. package/types/Tabs/TabUI.d.ts +1 -1
  51. package/types/Tooltip/Tooltip.d.ts +1 -1
package/Tabs/TabUI.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"TabUI.js","names":["css","keyframes","resetButtonStyle","useTheme","React","useCallback","useRef","useState","jsx","___EmotionJSX","Tab","_ref6","children","rest","_objectWithoutPropertiesLoose","_excluded","theme","_extends","role","tabIndex","typography","body","position","boxSizing","color","border","margin","display","outline","padding","userSelect","borderRadius","verticalAlign","justifyContent","textDecoration","backgroundColor","appearance","WebkitTapHighlightColor","textRendering","wordSpacing","textIndent","textShadow","flexShrink","cursor","whiteSpace","gridRow","transitions","duration","shortest","palette","intentions","primary","main","action","hover","spacing","process","env","NODE_ENV","slideIn","_templateObject","_taggedTemplateLiteralLoose","underlineHeight","DefaultTabContent","props","Fragment","_ref3","name","styles","toString","_EMOTION_STRINGIFIED_CSS_ERROR__","_ref4","_ref5","TabUIUnderlineHeader","_ref7","tabs","underline","tabPosition","onChange","currentIndex","renderTab","TabContent","prevCurrentIndex","handleUpdateIndex","event","nextIndex","parseInt","currentTarget","dataset","index","current","boxShadow","shadows","text","background","paper","gray","undefined","map","_ref8","title","data","icon","onClick","key","style","gridColumn","transform","standard","easing","sharp","_ref","_ref2","TabUI","_ref9","variant","defaultIndex","setCurrentIndex","length","_ref0","contrastText","screen"],"sources":["../../../src/Tabs/TabUI.tsx"],"sourcesContent":["import { css, keyframes } from \"@emotion/react\";\nimport { resetButtonStyle } from \"../Button\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useRef, useState } from \"react\";\n\nconst Tab = ({ children, ...rest }: React.ComponentPropsWithoutRef<\"div\">) => {\n const theme = useTheme();\n\n return (\n <div\n role=\"button\"\n tabIndex={0}\n {...rest}\n css={css([\n theme.typography.body,\n {\n position: \"relative\",\n boxSizing: \"border-box\",\n color: \"inherit\",\n border: \"1px solid transparent\",\n margin: 0,\n display: \"block\",\n outline: 0,\n padding: 0,\n userSelect: \"none\",\n borderRadius: 0,\n verticalAlign: \"middle\",\n justifyContent: \"center\",\n textDecoration: \"none\",\n backgroundColor: \"transparent\",\n appearance: \"none\",\n WebkitTapHighlightColor: \"transparent\",\n textRendering: \"auto\",\n wordSpacing: \"nomral\",\n textIndent: \"0px\",\n textShadow: \"none\",\n flexShrink: 0,\n cursor: \"pointer\",\n whiteSpace: \"nowrap\",\n gridRow: \"1\",\n },\n css`\n border-radius: 8px 8px 0px 0px;\n transition: background-color ${theme.transitions.duration.shortest};\n &:focus-visible {\n border-color: ${theme.palette.intentions.primary.main};\n }\n &:hover {\n background-color: ${theme.palette.action.hover};\n }\n & > * {\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: center;\n min-height: ${theme.spacing * 5}px;\n padding-right: ${theme.spacing * 3}px;\n padding-left: ${theme.spacing * 3}px;\n }\n a {\n color: inherit;\n text-decoration: none;\n }\n `,\n ])}\n >\n {typeof children === \"string\" ? <div>{children}</div> : children}\n </div>\n );\n};\n\nexport interface BaseTabUIProps<T> {\n variant?: \"underline\" | \"buttons\";\n\n /**\n * 表示されるスクリーンとタブの見出しを指定します。\n *\n * 非同期でスクリーンの数は増減するような、このpropが後から変更されるケースは想定していません。\n * もしそういったケースが発生したら、Issueを立ててください。\n *\n * @default []\n */\n tabs?: {\n title: React.ReactNode;\n screen: React.ReactNode;\n icon?: React.ReactNode;\n data?: T;\n }[];\n /**\n * Tabの描画に利用するコンポーネントを指定します。\n * 基本的にスタイルの指定は行わないでください。\n */\n renderTab?: (\n props: T & { children: React.ReactNode },\n ) => React.ReactElement<any> | null;\n /**\n * タブをどのような位置に表示するかを指定します。\n * @default \"start\"\n */\n tabPosition?: \"start\" | \"center\" | \"end\" | \"evenly\";\n /**\n * タブの下に付く装飾を指定します。\n * @default \"default\"\n */\n underline?: \"default\" | \"shadow\";\n /**\n * 最初に表示するタブのインデックスを指定します。\n *\n * インデックスはtabs propに指定された配列のうち、現在表示されているスクリーンのインデックスです。\n * @default 0\n */\n defaultIndex?: number;\n /**\n * タブがクリックされるなどしてインデックスが更新された際に発火するメソッドを指定します。\n *\n * 例えば、これが返すインデックスをローカルストレージなどに保存しておいて、\n * defaultIndexに渡すような実装をしておくとルーターライブラリを使わず、\n * 再読み込み時に前回表示していたタブを表示することができます。\n *\n * ただしURLのシェアなどで他のユーザーと同じタブを見るといったことはルーターライブラリを使う必要があります。詳しい実装はサンプルとなるStoryが用意されているので見てください。\n */\n onChange?: (index: number) => void;\n}\n\nexport interface TabUIProps<T> extends BaseTabUIProps<T> {\n children?: never;\n}\n\nexport interface TabUIHasChildrenProps<T>\n extends Omit<BaseTabUIProps<T>, \"tabs\"> {\n tabs?: {\n title: React.ReactNode;\n screen?: never;\n icon?: React.ReactNode;\n data?: T;\n }[];\n children: React.ReactNode;\n}\n\nconst slideIn = keyframes`\n to {\n transform: translateX(0px);\n }\n`;\n\nconst underlineHeight = 4;\n\ninterface TabUIUnderlineHeaderProps<T> {\n tabs: TabUIHasChildrenProps<T>[\"tabs\"] | TabUIProps<T>[\"tabs\"];\n underline: BaseTabUIProps<T>[\"underline\"];\n tabPosition: BaseTabUIProps<T>[\"tabPosition\"];\n onChange: BaseTabUIProps<T>[\"onChange\"];\n currentIndex: number;\n renderTab?: BaseTabUIProps<T>[\"renderTab\"];\n}\n\nconst DefaultTabContent = (props: React.PropsWithChildren) => {\n return <>{props.children}</>;\n};\n\nexport const TabUIUnderlineHeader = <T,>({\n tabs = [],\n underline,\n tabPosition,\n onChange,\n currentIndex,\n renderTab: TabContent = DefaultTabContent,\n}: TabUIUnderlineHeaderProps<T>) => {\n const theme = useTheme();\n const prevCurrentIndex = useRef(currentIndex);\n\n const handleUpdateIndex = useCallback(\n (event: React.MouseEvent<HTMLDivElement>) => {\n // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n const nextIndex = parseInt(event.currentTarget.dataset.index || \"0\", 10);\n prevCurrentIndex.current = currentIndex;\n onChange?.(nextIndex);\n },\n [currentIndex, onChange],\n );\n return (\n <div\n css={css`\n position: relative;\n `}\n >\n <div\n css={[\n css`\n box-sizing: border-box;\n display: grid;\n grid-auto-flow: column;\n overflow-x: auto;\n `,\n {\n justifyContent:\n tabPosition === \"start\"\n ? \"flex-start\"\n : tabPosition === \"end\"\n ? \"flex-end\"\n : tabPosition === \"evenly\"\n ? \"initial\"\n : \"center\",\n },\n underline === \"shadow\"\n ? {\n boxShadow: theme.shadows[1],\n color: theme.palette.text.primary,\n backgroundColor: theme.palette.background.paper,\n }\n : underline === \"default\"\n ? {\n boxShadow: `0px -${underlineHeight}px 0px 0px ${theme.palette.gray[300]} inset`,\n }\n : undefined,\n ]}\n >\n {tabs.map(({ title, data, icon }, index) => {\n return (\n <Tab onClick={handleUpdateIndex} data-index={index} key={index}>\n {/*\n // @ts-expect-error @emotion/reactの変更により型安全でなくなった https://github.com/emotion-js/emotion/compare/%40emotion/react%4011.13.0...%40emotion/react%4011.13.3#diff-a3e371cc2c719626107c869dcf5a0fad82d9ea99d37c727c96b3baf3c016fffdL89-R91*/}\n <TabContent {...(data as T)}>\n <span\n css={css`\n display: flex;\n gap: 8px;\n `}\n >\n {icon}\n {title}\n </span>\n </TabContent>\n </Tab>\n );\n })}\n <div\n key={currentIndex}\n style={{\n gridRow: 2,\n gridColumn: currentIndex + 1,\n transform: `translateX(${\n prevCurrentIndex.current === currentIndex\n ? 0\n : prevCurrentIndex.current > currentIndex\n ? 100\n : -100\n }%)`,\n }}\n css={css`\n height: ${underlineHeight}px;\n background-color: ${theme.palette.intentions.primary.main};\n border-radius: 8px;\n animation: ${slideIn} ${theme.transitions.duration.standard}\n ${theme.transitions.easing.sharp} forwards;\n `}\n />\n </div>\n </div>\n );\n};\n\nexport const TabUI = <T,>({\n tabs = [],\n variant = \"underline\",\n underline = \"default\",\n tabPosition = \"start\",\n defaultIndex = 0,\n onChange,\n children,\n renderTab,\n}: TabUIProps<T> | TabUIHasChildrenProps<T>) => {\n const [currentIndex, setCurrentIndex] = useState(defaultIndex);\n const theme = useTheme();\n\n if (tabs === undefined || tabs.length === 0) {\n return null;\n }\n\n return (\n <div>\n {variant === \"underline\" ? (\n <TabUIUnderlineHeader\n tabs={tabs}\n currentIndex={currentIndex}\n underline={underline}\n tabPosition={tabPosition}\n onChange={(index) => {\n setCurrentIndex(index);\n onChange?.(index);\n }}\n renderTab={renderTab}\n />\n ) : (\n <div\n css={[\n css`\n display: grid;\n grid-auto-flow: column;\n gap: 8px;\n padding-bottom: 8px;\n overflow-x: auto;\n overflow-y: hidden;\n `,\n {\n justifyContent:\n tabPosition === \"start\"\n ? \"flex-start\"\n : tabPosition === \"end\"\n ? \"flex-end\"\n : tabPosition === \"evenly\"\n ? \"initial\"\n : \"center\",\n },\n ]}\n >\n {tabs.map(({ title }, index) => {\n return (\n <div\n key={index}\n role=\"button\"\n tabIndex={0}\n onClick={() => {\n setCurrentIndex(index);\n onChange?.(index);\n }}\n css={[\n resetButtonStyle,\n theme.typography.body,\n currentIndex === index\n ? css`\n color: ${theme.palette.intentions.primary.contrastText};\n background-color: ${theme.palette.intentions.primary\n .main};\n `\n : css`\n color: ${theme.palette.text.primary};\n background-color: ${theme.palette.gray[100]};\n transition: background-color\n ${theme.transitions.duration.shortest};\n &:hover {\n background-color: ${theme.palette.gray[300]};\n }\n `,\n css`\n border-radius: 4px;\n & > * {\n padding: 6px 8px;\n }\n `,\n ]}\n >\n {typeof title === \"string\" ? <div>{title}</div> : title}\n </div>\n );\n })}\n </div>\n )}\n {children ?? tabs[currentIndex].screen}\n </div>\n );\n};\n"],"mappings":";;;;;;AAAA,SAASA,GAAG,EAAEC,SAAS,QAAQ,gBAAgB;AAC/C,SAASC,gBAAgB,QAAQ,WAAW;AAC5C,SAASC,QAAQ,QAAQ,UAAU;AACnC,OAAOC,KAAK,IAAIC,WAAW,EAAEC,MAAM,EAAEC,QAAQ,QAAQ,OAAO;AAAC,SAAAC,GAAA,IAAAC,aAAA;AAE7D,IAAMC,GAAG,GAAGC,KAAA,IAAkE;EAAA,IAAjE;MAAEC;IAAyD,CAAC,GAAAD,KAAA;IAA7CE,IAAI,GAAAC,6BAAA,CAAAH,KAAA,EAAAI,SAAA;EAC9B,IAAMC,KAAK,GAAGb,QAAQ,CAAC,CAAC;EAExB,OACEM,aAAA,QAAAQ,QAAA;IACEC,IAAI,EAAC,QAAQ;IACbC,QAAQ,EAAE;EAAE,GACRN,IAAI;IACRb,GAAG,eAAEA,GAAG,CAAC,CACPgB,KAAK,CAACI,UAAU,CAACC,IAAI,EACrB;MACEC,QAAQ,EAAE,UAAU;MACpBC,SAAS,EAAE,YAAY;MACvBC,KAAK,EAAE,SAAS;MAChBC,MAAM,EAAE,uBAAuB;MAC/BC,MAAM,EAAE,CAAC;MACTC,OAAO,EAAE,OAAO;MAChBC,OAAO,EAAE,CAAC;MACVC,OAAO,EAAE,CAAC;MACVC,UAAU,EAAE,MAAM;MAClBC,YAAY,EAAE,CAAC;MACfC,aAAa,EAAE,QAAQ;MACvBC,cAAc,EAAE,QAAQ;MACxBC,cAAc,EAAE,MAAM;MACtBC,eAAe,EAAE,aAAa;MAC9BC,UAAU,EAAE,MAAM;MAClBC,uBAAuB,EAAE,aAAa;MACtCC,aAAa,EAAE,MAAM;MACrBC,WAAW,EAAE,QAAQ;MACrBC,UAAU,EAAE,KAAK;MACjBC,UAAU,EAAE,MAAM;MAClBC,UAAU,EAAE,CAAC;MACbC,MAAM,EAAE,SAAS;MACjBC,UAAU,EAAE,QAAQ;MACpBC,OAAO,EAAE;IACX,CAAC,eACD7C,GAAG,+DAE8BgB,KAAK,CAAC8B,WAAW,CAACC,QAAQ,CAACC,QAAQ,oCAEhDhC,KAAK,CAACiC,OAAO,CAACC,UAAU,CAACC,OAAO,CAACC,IAAI,iCAGjCpC,KAAK,CAACiC,OAAO,CAACI,MAAM,CAACC,KAAK,oGAOhCtC,KAAK,CAACuC,OAAO,GAAG,CAAC,uBACdvC,KAAK,CAACuC,OAAO,GAAG,CAAC,sBAClBvC,KAAK,CAACuC,OAAO,GAAG,CAAC,kDAAAC,OAAA,CAAAC,GAAA,CAAAC,QAAA,yCAAAF,OAAA,CAAAC,GAAA,CAAAC,QAAA,o4eAOtC,EAAAF,OAAA,CAAAC,GAAA,CAAAC,QAAA,wCAAAF,OAAA,CAAAC,GAAA,CAAAC,QAAA;EAAE,IAEF,OAAO9C,QAAQ,KAAK,QAAQ,GAAGH,aAAA,cAAMG,QAAc,CAAC,GAAGA,QACrD,CAAC;AAEV,CAAC;AAsED,IAAM+C,OAAO,GAAG1D,SAAS,CAAA2D,eAAA,KAAAA,eAAA,GAAAC,2BAAA,wDAIxB;AAED,IAAMC,eAAe,GAAG,CAAC;AAWzB,IAAMC,iBAAiB,GAAIC,KAA8B,IAAK;EAC5D,OAAOvD,aAAA,CAAAL,KAAA,CAAA6D,QAAA,QAAGD,KAAK,CAACpD,QAAW,CAAC;AAC9B,CAAC;AAAC,IAAAsD,KAAA,GAAAV,OAAA,CAAAC,GAAA,CAAAC,QAAA;EAAAS,IAAA;EAAAC,MAAA;AAAA;EAAAD,IAAA;EAAAC,MAAA;EAAAC,QAAA,EAAAC;AAAA;AAAA,IAAAC,KAAA,GAAAf,OAAA,CAAAC,GAAA,CAAAC,QAAA;EAAAS,IAAA;EAAAC,MAAA;AAAA;EAAAD,IAAA;EAAAC,MAAA;EAAAC,QAAA,EAAAC;AAAA;AAAA,IAAAE,KAAA,GAAAhB,OAAA,CAAAC,GAAA,CAAAC,QAAA;EAAAS,IAAA;EAAAC,MAAA;AAAA;EAAAD,IAAA;EAAAC,MAAA;EAAAC,QAAA,EAAAC;AAAA;AAEF,OAAO,IAAMG,oBAAoB,GAAGC,KAAA,IAOA;EAAA,IAPK;IACvCC,IAAI,GAAG,EAAE;IACTC,SAAS;IACTC,WAAW;IACXC,QAAQ;IACRC,YAAY;IACZC,SAAS,EAAEC,UAAU,GAAGlB;EACI,CAAC,GAAAW,KAAA;EAC7B,IAAM1D,KAAK,GAAGb,QAAQ,CAAC,CAAC;EACxB,IAAM+E,gBAAgB,GAAG5E,MAAM,CAACyE,YAAY,CAAC;EAE7C,IAAMI,iBAAiB,GAAG9E,WAAW,CAClC+E,KAAuC,IAAK;IAC3C;IACA,IAAMC,SAAS,GAAGC,QAAQ,CAACF,KAAK,CAACG,aAAa,CAACC,OAAO,CAACC,KAAK,IAAI,GAAG,EAAE,EAAE,CAAC;IACxEP,gBAAgB,CAACQ,OAAO,GAAGX,YAAY;IACvCD,QAAQ,YAARA,QAAQ,CAAGO,SAAS,CAAC;EACvB,CAAC,EACD,CAACN,YAAY,EAAED,QAAQ,CACzB,CAAC;EACD,OACErE,aAAA;IACET,GAAG,EAAAwE;EAED,GAEF/D,aAAA;IACET,GAAG,GAAAuE,KAAA,EAOD;MACEtC,cAAc,EACZ4C,WAAW,KAAK,OAAO,GACnB,YAAY,GACZA,WAAW,KAAK,KAAK,GACnB,UAAU,GACVA,WAAW,KAAK,QAAQ,GACtB,SAAS,GACT;IACZ,CAAC,EACDD,SAAS,KAAK,QAAQ,GAClB;MACEe,SAAS,EAAE3E,KAAK,CAAC4E,OAAO,CAAC,CAAC,CAAC;MAC3BpE,KAAK,EAAER,KAAK,CAACiC,OAAO,CAAC4C,IAAI,CAAC1C,OAAO;MACjChB,eAAe,EAAEnB,KAAK,CAACiC,OAAO,CAAC6C,UAAU,CAACC;IAC5C,CAAC,GACDnB,SAAS,KAAK,SAAS,GACrB;MACEe,SAAS,YAAU7B,eAAe,mBAAc9C,KAAK,CAACiC,OAAO,CAAC+C,IAAI,CAAC,GAAG,CAAC;IACzE,CAAC,GACDC,SAAS,EAAAzC,OAAA,CAAAC,GAAA,CAAAC,QAAA,yDAAAF,OAAA,CAAAC,GAAA,CAAAC,QAAA;EACf,GAEDiB,IAAI,CAACuB,GAAG,CAAC,CAAAC,KAAA,EAAwBV,KAAK,KAAK;IAAA,IAAjC;MAAEW,KAAK;MAAEC,IAAI;MAAEC;IAAK,CAAC,GAAAH,KAAA;IAC9B,OACE1F,aAAA,CAACC,GAAG;MAAC6F,OAAO,EAAEpB,iBAAkB;MAAC,cAAYM,KAAM;MAACe,GAAG,EAAEf;IAAM,GAG7DhF,aAAA,CAACwE,UAAU,EAAMoB,IAAI,EACnB5F,aAAA;MACET,GAAG,EAAAkE;IAGD,GAEDoC,IAAI,EACJF,KACG,CACI,CACT,CAAC;EAEV,CAAC,CAAC,EACF3F,aAAA;IACE+F,GAAG,EAAEzB,YAAa;IAClB0B,KAAK,EAAE;MACL5D,OAAO,EAAE,CAAC;MACV6D,UAAU,EAAE3B,YAAY,GAAG,CAAC;MAC5B4B,SAAS,mBACPzB,gBAAgB,CAACQ,OAAO,KAAKX,YAAY,GACrC,CAAC,GACDG,gBAAgB,CAACQ,OAAO,GAAGX,YAAY,GACrC,GAAG,GACH,CAAC,GAAG;IAEd,CAAE;IACF/E,GAAG,eAAEA,GAAG,YACI8D,eAAe,0BACL9C,KAAK,CAACiC,OAAO,CAACC,UAAU,CAACC,OAAO,CAACC,IAAI,mCAE5CO,OAAO,OAAI3C,KAAK,CAAC8B,WAAW,CAACC,QAAQ,CAAC6D,QAAQ,OACvD5F,KAAK,CAAC8B,WAAW,CAAC+D,MAAM,CAACC,KAAK,kBAAAtD,OAAA,CAAAC,GAAA,CAAAC,QAAA,0DAAAF,OAAA,CAAAC,GAAA,CAAAC,QAAA;EAClC,CACH,CACE,CACF,CAAC;AAEV,CAAC;AAAC,IAAAqD,IAAA,GAAAvD,OAAA,CAAAC,GAAA,CAAAC,QAAA;EAAAS,IAAA;EAAAC,MAAA;AAAA;EAAAD,IAAA;EAAAC,MAAA;EAAAC,QAAA,EAAAC;AAAA;AAAA,IAAA0C,KAAA,GAAAxD,OAAA,CAAAC,GAAA,CAAAC,QAAA;EAAAS,IAAA;EAAAC,MAAA;AAAA;EAAAD,IAAA;EAAAC,MAAA;EAAAC,QAAA,EAAAC;AAAA;AAEF,OAAO,IAAM2C,KAAK,GAAGC,KAAA,IAS2B;EAAA,IATtB;IACxBvC,IAAI,GAAG,EAAE;IACTwC,OAAO,GAAG,WAAW;IACrBvC,SAAS,GAAG,SAAS;IACrBC,WAAW,GAAG,OAAO;IACrBuC,YAAY,GAAG,CAAC;IAChBtC,QAAQ,EAARA,SAAQ;IACRlE,QAAQ;IACRoE;EACwC,CAAC,GAAAkC,KAAA;EACzC,IAAM,CAACnC,YAAY,EAAEsC,eAAe,CAAC,GAAG9G,QAAQ,CAAC6G,YAAY,CAAC;EAC9D,IAAMpG,KAAK,GAAGb,QAAQ,CAAC,CAAC;EAExB,IAAIwE,IAAI,KAAKsB,SAAS,IAAItB,IAAI,CAAC2C,MAAM,KAAK,CAAC,EAAE;IAC3C,OAAO,IAAI;EACb;EAEA,OACE7G,aAAA,cACG0G,OAAO,KAAK,WAAW,GACtB1G,aAAA,CAACgE,oBAAoB;IACnBE,IAAI,EAAEA,IAAK;IACXI,YAAY,EAAEA,YAAa;IAC3BH,SAAS,EAAEA,SAAU;IACrBC,WAAW,EAAEA,WAAY;IACzBC,QAAQ,EAAGW,KAAK,IAAK;MACnB4B,eAAe,CAAC5B,KAAK,CAAC;MACtBX,SAAQ,YAARA,SAAQ,CAAGW,KAAK,CAAC;IACnB,CAAE;IACFT,SAAS,EAAEA;EAAU,CACtB,CAAC,GAEFvE,aAAA;IACET,GAAG,GAAAgH,KAAA,EASD;MACE/E,cAAc,EACZ4C,WAAW,KAAK,OAAO,GACnB,YAAY,GACZA,WAAW,KAAK,KAAK,GACnB,UAAU,GACVA,WAAW,KAAK,QAAQ,GACtB,SAAS,GACT;IACZ,CAAC,EAAArB,OAAA,CAAAC,GAAA,CAAAC,QAAA,0CAAAF,OAAA,CAAAC,GAAA,CAAAC,QAAA;EACD,GAEDiB,IAAI,CAACuB,GAAG,CAAC,CAAAqB,KAAA,EAAY9B,KAAK,KAAK;IAAA,IAArB;MAAEW;IAAM,CAAC,GAAAmB,KAAA;IAClB,OACE9G,aAAA;MACE+F,GAAG,EAAEf,KAAM;MACXvE,IAAI,EAAC,QAAQ;MACbC,QAAQ,EAAE,CAAE;MACZoF,OAAO,EAAEA,CAAA,KAAM;QACbc,eAAe,CAAC5B,KAAK,CAAC;QACtBX,SAAQ,YAARA,SAAQ,CAAGW,KAAK,CAAC;MACnB,CAAE;MACFzF,GAAG,GACDE,gBAAgB,EAChBc,KAAK,CAACI,UAAU,CAACC,IAAI,EACrB0D,YAAY,KAAKU,KAAK,gBAClBzF,GAAG,WACQgB,KAAK,CAACiC,OAAO,CAACC,UAAU,CAACC,OAAO,CAACqE,YAAY,wBAClCxG,KAAK,CAACiC,OAAO,CAACC,UAAU,CAACC,OAAO,CACjDC,IAAI,SAAAI,OAAA,CAAAC,GAAA,CAAAC,QAAA,2CAAAF,OAAA,CAAAC,GAAA,CAAAC,QAAA,m5eAET1D,GAAG,WACQgB,KAAK,CAACiC,OAAO,CAAC4C,IAAI,CAAC1C,OAAO,wBACfnC,KAAK,CAACiC,OAAO,CAAC+C,IAAI,CAAC,GAAG,CAAC,mCAEvChF,KAAK,CAAC8B,WAAW,CAACC,QAAQ,CAACC,QAAQ,gCAEjBhC,KAAK,CAACiC,OAAO,CAAC+C,IAAI,CAAC,GAAG,CAAC,UAAAxC,OAAA,CAAAC,GAAA,CAAAC,QAAA,2CAAAF,OAAA,CAAAC,GAAA,CAAAC,QAAA,m4eAE9C,EAAAqD,IAAA,EAAAvD,OAAA,CAAAC,GAAA,CAAAC,QAAA,0CAAAF,OAAA,CAAAC,GAAA,CAAAC,QAAA;IAOL,GAED,OAAO0C,KAAK,KAAK,QAAQ,GAAG3F,aAAA,cAAM2F,KAAW,CAAC,GAAGA,KAC/C,CAAC;EAEV,CAAC,CACE,CACN,EACAxF,QAAQ,WAARA,QAAQ,GAAI+D,IAAI,CAACI,YAAY,CAAC,CAAC0C,MAC7B,CAAC;AAEV,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"TabUI.js","names":["css","keyframes","resetButtonStyle","useTheme","React","useCallback","useRef","useState","jsx","___EmotionJSX","Tab","_ref6","children","rest","_objectWithoutPropertiesLoose","_excluded","theme","_extends","role","tabIndex","typography","body","position","boxSizing","color","border","margin","display","outline","padding","userSelect","borderRadius","verticalAlign","justifyContent","textDecoration","backgroundColor","appearance","WebkitTapHighlightColor","textRendering","wordSpacing","textIndent","textShadow","flexShrink","cursor","whiteSpace","gridRow","transitions","duration","shortest","palette","intentions","primary","main","action","hover","spacing","process","env","NODE_ENV","slideIn","_templateObject","_taggedTemplateLiteralLoose","underlineHeight","DefaultTabContent","props","Fragment","_ref3","name","styles","toString","_EMOTION_STRINGIFIED_CSS_ERROR__","_ref4","_ref5","TabUIUnderlineHeader","_ref7","tabs","underline","tabPosition","onChange","currentIndex","renderTab","TabContent","prevCurrentIndex","handleUpdateIndex","event","nextIndex","parseInt","currentTarget","dataset","index","current","boxShadow","shadows","text","background","paper","gray","undefined","map","_ref8","title","data","icon","onClick","key","style","gridColumn","transform","standard","easing","sharp","_ref","_ref2","TabUI","_ref9","variant","defaultIndex","setCurrentIndex","length","_ref0","contrastText","screen"],"sources":["../../../src/Tabs/TabUI.tsx"],"sourcesContent":["import { css, keyframes } from \"@emotion/react\";\nimport { resetButtonStyle } from \"../Button\";\nimport { useTheme } from \"../theme\";\nimport React, { useCallback, useRef, useState } from \"react\";\n\nconst Tab = ({ children, ...rest }: React.ComponentPropsWithoutRef<\"div\">) => {\n const theme = useTheme();\n\n return (\n <div\n role=\"button\"\n tabIndex={0}\n {...rest}\n css={css([\n theme.typography.body,\n {\n position: \"relative\",\n boxSizing: \"border-box\",\n color: \"inherit\",\n border: \"1px solid transparent\",\n margin: 0,\n display: \"block\",\n outline: 0,\n padding: 0,\n userSelect: \"none\",\n borderRadius: 0,\n verticalAlign: \"middle\",\n justifyContent: \"center\",\n textDecoration: \"none\",\n backgroundColor: \"transparent\",\n appearance: \"none\",\n WebkitTapHighlightColor: \"transparent\",\n textRendering: \"auto\",\n wordSpacing: \"nomral\",\n textIndent: \"0px\",\n textShadow: \"none\",\n flexShrink: 0,\n cursor: \"pointer\",\n whiteSpace: \"nowrap\",\n gridRow: \"1\",\n },\n css`\n border-radius: 8px 8px 0px 0px;\n transition: background-color ${theme.transitions.duration.shortest};\n &:focus-visible {\n border-color: ${theme.palette.intentions.primary.main};\n }\n &:hover {\n background-color: ${theme.palette.action.hover};\n }\n & > * {\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: center;\n min-height: ${theme.spacing * 5}px;\n padding-right: ${theme.spacing * 3}px;\n padding-left: ${theme.spacing * 3}px;\n }\n a {\n color: inherit;\n text-decoration: none;\n }\n `,\n ])}\n >\n {typeof children === \"string\" ? <div>{children}</div> : children}\n </div>\n );\n};\n\nexport interface BaseTabUIProps<T> {\n variant?: \"underline\" | \"buttons\";\n\n /**\n * 表示されるスクリーンとタブの見出しを指定します。\n *\n * 非同期でスクリーンの数は増減するような、このpropが後から変更されるケースは想定していません。\n * もしそういったケースが発生したら、Issueを立ててください。\n *\n * @default []\n */\n tabs?: {\n title: React.ReactNode;\n screen: React.ReactNode;\n icon?: React.ReactNode;\n data?: T;\n }[];\n /**\n * Tabの描画に利用するコンポーネントを指定します。\n * 基本的にスタイルの指定は行わないでください。\n */\n renderTab?: (\n props: T & { children: React.ReactNode },\n ) => React.ReactElement | null;\n /**\n * タブをどのような位置に表示するかを指定します。\n * @default \"start\"\n */\n tabPosition?: \"start\" | \"center\" | \"end\" | \"evenly\";\n /**\n * タブの下に付く装飾を指定します。\n * @default \"default\"\n */\n underline?: \"default\" | \"shadow\";\n /**\n * 最初に表示するタブのインデックスを指定します。\n *\n * インデックスはtabs propに指定された配列のうち、現在表示されているスクリーンのインデックスです。\n * @default 0\n */\n defaultIndex?: number;\n /**\n * タブがクリックされるなどしてインデックスが更新された際に発火するメソッドを指定します。\n *\n * 例えば、これが返すインデックスをローカルストレージなどに保存しておいて、\n * defaultIndexに渡すような実装をしておくとルーターライブラリを使わず、\n * 再読み込み時に前回表示していたタブを表示することができます。\n *\n * ただしURLのシェアなどで他のユーザーと同じタブを見るといったことはルーターライブラリを使う必要があります。詳しい実装はサンプルとなるStoryが用意されているので見てください。\n */\n onChange?: (index: number) => void;\n}\n\nexport interface TabUIProps<T> extends BaseTabUIProps<T> {\n children?: never;\n}\n\nexport interface TabUIHasChildrenProps<T>\n extends Omit<BaseTabUIProps<T>, \"tabs\"> {\n tabs?: {\n title: React.ReactNode;\n screen?: never;\n icon?: React.ReactNode;\n data?: T;\n }[];\n children: React.ReactNode;\n}\n\nconst slideIn = keyframes`\n to {\n transform: translateX(0px);\n }\n`;\n\nconst underlineHeight = 4;\n\ninterface TabUIUnderlineHeaderProps<T> {\n tabs: TabUIHasChildrenProps<T>[\"tabs\"] | TabUIProps<T>[\"tabs\"];\n underline: BaseTabUIProps<T>[\"underline\"];\n tabPosition: BaseTabUIProps<T>[\"tabPosition\"];\n onChange: BaseTabUIProps<T>[\"onChange\"];\n currentIndex: number;\n renderTab?: BaseTabUIProps<T>[\"renderTab\"];\n}\n\nconst DefaultTabContent = (props: React.PropsWithChildren) => {\n return <>{props.children}</>;\n};\n\nexport const TabUIUnderlineHeader = <T,>({\n tabs = [],\n underline,\n tabPosition,\n onChange,\n currentIndex,\n renderTab: TabContent = DefaultTabContent,\n}: TabUIUnderlineHeaderProps<T>) => {\n const theme = useTheme();\n const prevCurrentIndex = useRef(currentIndex);\n\n const handleUpdateIndex = useCallback(\n (event: React.MouseEvent<HTMLDivElement>) => {\n // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n const nextIndex = parseInt(event.currentTarget.dataset.index || \"0\", 10);\n prevCurrentIndex.current = currentIndex;\n onChange?.(nextIndex);\n },\n [currentIndex, onChange],\n );\n return (\n <div\n css={css`\n position: relative;\n `}\n >\n <div\n css={[\n css`\n box-sizing: border-box;\n display: grid;\n grid-auto-flow: column;\n overflow-x: auto;\n `,\n {\n justifyContent:\n tabPosition === \"start\"\n ? \"flex-start\"\n : tabPosition === \"end\"\n ? \"flex-end\"\n : tabPosition === \"evenly\"\n ? \"initial\"\n : \"center\",\n },\n underline === \"shadow\"\n ? {\n boxShadow: theme.shadows[1],\n color: theme.palette.text.primary,\n backgroundColor: theme.palette.background.paper,\n }\n : underline === \"default\"\n ? {\n boxShadow: `0px -${underlineHeight}px 0px 0px ${theme.palette.gray[300]} inset`,\n }\n : undefined,\n ]}\n >\n {tabs.map(({ title, data, icon }, index) => {\n return (\n <Tab onClick={handleUpdateIndex} data-index={index} key={index}>\n {/*\n // @ts-expect-error @emotion/reactの変更により型安全でなくなった https://github.com/emotion-js/emotion/compare/%40emotion/react%4011.13.0...%40emotion/react%4011.13.3#diff-a3e371cc2c719626107c869dcf5a0fad82d9ea99d37c727c96b3baf3c016fffdL89-R91*/}\n <TabContent {...(data as T)}>\n <span\n css={css`\n display: flex;\n gap: 8px;\n `}\n >\n {icon}\n {title}\n </span>\n </TabContent>\n </Tab>\n );\n })}\n <div\n key={currentIndex}\n style={{\n gridRow: 2,\n gridColumn: currentIndex + 1,\n transform: `translateX(${\n prevCurrentIndex.current === currentIndex\n ? 0\n : prevCurrentIndex.current > currentIndex\n ? 100\n : -100\n }%)`,\n }}\n css={css`\n height: ${underlineHeight}px;\n background-color: ${theme.palette.intentions.primary.main};\n border-radius: 8px;\n animation: ${slideIn} ${theme.transitions.duration.standard}\n ${theme.transitions.easing.sharp} forwards;\n `}\n />\n </div>\n </div>\n );\n};\n\nexport const TabUI = <T,>({\n tabs = [],\n variant = \"underline\",\n underline = \"default\",\n tabPosition = \"start\",\n defaultIndex = 0,\n onChange,\n children,\n renderTab,\n}: TabUIProps<T> | TabUIHasChildrenProps<T>) => {\n const [currentIndex, setCurrentIndex] = useState(defaultIndex);\n const theme = useTheme();\n\n if (tabs === undefined || tabs.length === 0) {\n return null;\n }\n\n return (\n <div>\n {variant === \"underline\" ? (\n <TabUIUnderlineHeader\n tabs={tabs}\n currentIndex={currentIndex}\n underline={underline}\n tabPosition={tabPosition}\n onChange={(index) => {\n setCurrentIndex(index);\n onChange?.(index);\n }}\n renderTab={renderTab}\n />\n ) : (\n <div\n css={[\n css`\n display: grid;\n grid-auto-flow: column;\n gap: 8px;\n padding-bottom: 8px;\n overflow-x: auto;\n overflow-y: hidden;\n `,\n {\n justifyContent:\n tabPosition === \"start\"\n ? \"flex-start\"\n : tabPosition === \"end\"\n ? \"flex-end\"\n : tabPosition === \"evenly\"\n ? \"initial\"\n : \"center\",\n },\n ]}\n >\n {tabs.map(({ title }, index) => {\n return (\n <div\n key={index}\n role=\"button\"\n tabIndex={0}\n onClick={() => {\n setCurrentIndex(index);\n onChange?.(index);\n }}\n css={[\n resetButtonStyle,\n theme.typography.body,\n currentIndex === index\n ? css`\n color: ${theme.palette.intentions.primary.contrastText};\n background-color: ${theme.palette.intentions.primary\n .main};\n `\n : css`\n color: ${theme.palette.text.primary};\n background-color: ${theme.palette.gray[100]};\n transition: background-color\n ${theme.transitions.duration.shortest};\n &:hover {\n background-color: ${theme.palette.gray[300]};\n }\n `,\n css`\n border-radius: 4px;\n & > * {\n padding: 6px 8px;\n }\n `,\n ]}\n >\n {typeof title === \"string\" ? <div>{title}</div> : title}\n </div>\n );\n })}\n </div>\n )}\n {children ?? tabs[currentIndex].screen}\n </div>\n );\n};\n"],"mappings":"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","ignoreList":[]}
@@ -9,7 +9,7 @@ export interface TooltipProps extends Pick<PopperBaseProps, "placement"> {
9
9
  * Tooltipを表示する要素
10
10
  * 注意: disabledなボタン要素ではマウスイベントが発火しないため、Tooltipは機能しません
11
11
  */
12
- children: React.ReactElement<any> | string;
12
+ children: React.ReactElement | string;
13
13
  /**
14
14
  * 矢印を表示します。
15
15
  *
@@ -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,{"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"]} */",
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":"AA4NsB","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 | 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        // eslint-disable-next-line @typescript-eslint/no-unsafe-argument, @typescript-eslint/no-explicit-any\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        } as any)\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,{"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"]} */",
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":"AA4Me","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 | 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        // eslint-disable-next-line @typescript-eslint/no-unsafe-argument, @typescript-eslint/no-explicit-any\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        } as any)\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 => {
@@ -70,7 +70,10 @@ export var Tooltip = _ref3 => {
70
70
  ref: setNode,
71
71
  onMouseEnter: handleMouseEnter(),
72
72
  onMouseLeave: handleMouseLeave()
73
- }, children) : (/*#__PURE__*/React.cloneElement(children, {
73
+ }, children) : (
74
+ /*#__PURE__*/
75
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-argument, @typescript-eslint/no-explicit-any
76
+ React.cloneElement(children, {
74
77
  ref: setNode,
75
78
  onMouseEnter: handleMouseEnter(hasOwnProp(children.props, "onMouseEnter") ? children.props.onMouseEnter : undefined),
76
79
  onMouseLeave: handleMouseLeave(hasOwnProp(children.props, "onMouseLeave") ? children.props.onMouseLeave : undefined)
@@ -85,9 +88,9 @@ export var Tooltip = _ref3 => {
85
88
  setOpen(false);
86
89
  }
87
90
  },
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"]} */")
91
+ 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":"AAiIgB","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 | 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        // eslint-disable-next-line @typescript-eslint/no-unsafe-argument, @typescript-eslint/no-explicit-any\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        } as any)\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
92
  }, ___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,{"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"]} */"]
93
+ 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":"AA0MU","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 | 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        // eslint-disable-next-line @typescript-eslint/no-unsafe-argument, @typescript-eslint/no-explicit-any\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        } as any)\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
94
  }, title, arrow ? ___EmotionJSX("div", {
92
95
  className: classNames.tooltip.arrow,
93
96
  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 /**\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
+ {"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 | 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 // eslint-disable-next-line @typescript-eslint/no-unsafe-argument, @typescript-eslint/no-explicit-any\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 } as any)\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":[]}
@@ -43,7 +43,7 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
43
43
  styles: "margin:0 auto"
44
44
  } : {
45
45
  name: "rvyoxd-defaultRenderCell",
46
- styles: "margin:0 auto;label:defaultRenderCell;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Calendar/CalendarDaysInMonth.tsx"],"names":[],"mappings":"AA6FY","file":"../../../src/Calendar/CalendarDaysInMonth.tsx","sourcesContent":["import { CalendarDay } from \"./CalendarDay\";\nimport { CalendarDayEvent } from \"./CalendarDayEvent\";\nimport { CalendarDayProps } from \"./CalendarDay\";\nimport { css } from \"@emotion/react\";\nimport { range } from \"../@utils/range\";\nimport React, { useMemo } from \"react\";\nimport dayjs from \"dayjs\";\nimport isSameOrAfter from \"dayjs/plugin/isSameOrAfter\";\nimport isSameOrBefore from \"dayjs/plugin/isSameOrBefore\";\n\ndayjs.extend(isSameOrAfter);\ndayjs.extend(isSameOrBefore);\n\nconst isDateOutsidePeriod = (\n  date: dayjs.Dayjs,\n  min?: dayjs.ConfigType,\n  max?: dayjs.ConfigType,\n) => {\n  return (\n    (min !== undefined && min !== null && date.isSameOrBefore(min, \"date\")) ||\n    (max !== undefined && max !== undefined && date.isSameOrAfter(max, \"date\"))\n  );\n};\n\nconst getEvent = (date: dayjs.Dayjs, events?: CalendarEvent[]) => {\n  return events?.find((event) => {\n    if (event.start === undefined) {\n      return date.isSameOrBefore(event.end, \"date\");\n    }\n    if (event.end === undefined) {\n      return date.isSameOrAfter(event.start, \"date\");\n    }\n    return (\n      date.isSameOrAfter(event.start, \"date\") &&\n      date.isSameOrBefore(event.end, \"date\")\n    );\n  });\n};\n\nexport interface CalendarDaysProps\n  extends Omit<CalendarDayProps, \"date\" | \"disabled\" | \"event\"> {\n  children?: React.ReactNode;\n}\n\nexport interface CalendarEvent {\n  start?: dayjs.ConfigType;\n  end?: dayjs.ConfigType;\n  // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n  type?: \"default\" | \"disabled\" | string;\n  props?: CalendarDaysProps;\n}\n\nexport interface CalendarDaysInMonthProps<T> {\n  children?: never;\n  events?: CalendarEvent[];\n  /**\n   * datesで渡されたデータをどのようにレンダリングするかを指定します\n   * @default \"(message: string) => <Centering>{new String(message)}</Centering>\"\"\n   */\n  renderCell?: (props: T) => React.ReactNode;\n  /**\n   * keyに対応するカレンダーのセルに任意の子要素を入れることができます。\n   * keyのフォーマットはYYYYMMDDでなければなりません。\n   */\n  dates?: Record<string, T>;\n  daysProps?: CalendarDaysProps;\n  date?: dayjs.ConfigType;\n  min?: dayjs.ConfigType;\n  max?: dayjs.ConfigType;\n  /**\n   * カレンダーのセルの高さを指定します。\n   * これが指定されていない場合、カレンダーのセルは正方形になります。\n   */\n  cellHeight?: number | string;\n  /**\n   * 日付がクリックされた場合に、その日付とイベントを返す。\n   */\n  onClickDay?: (\n    value: Date,\n    event: React.MouseEvent<HTMLDivElement, MouseEvent>,\n  ) => void;\n}\n\nconst getFirstWeekday = (date: dayjs.ConfigType) => {\n  return dayjs(date).startOf(\"month\").day();\n};\nconst getDaysCount = (date: dayjs.ConfigType) => {\n  return dayjs(date).daysInMonth() + 1;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst defaultRenderCell = (message: any) => (\n  <div\n    css={css`\n      margin: 0 auto;\n    `}\n  >\n    {message}\n  </div>\n);\n\nexport const CalendarDaysInMonth = <T,>({\n  dates,\n  events = [],\n  daysProps = {},\n  date = dayjs(),\n  min,\n  max,\n  cellHeight,\n  renderCell = defaultRenderCell,\n  onClickDay,\n  ...props\n}: Readonly<CalendarDaysInMonthProps<T>>) => {\n  const firstWeekday = useMemo(() => getFirstWeekday(date), [date]);\n  const days = useMemo(() => getDaysCount(date), [date]);\n  const reversedEvents = useMemo(() => events.slice().reverse(), [events]);\n  return (\n    <div\n      css={[\n        css`\n          display: grid;\n          grid-template-columns: repeat(7, minmax(42px, 1fr));\n        `,\n        {\n          gridAutoRows: cellHeight ?? \"1fr\",\n        },\n        cellHeight === undefined\n          ? css`\n              & > *:first-of-type {\n                aspect-ratio: 1;\n              }\n            `\n          : null,\n      ]}\n      {...props}\n    >\n      {range(firstWeekday).map((i) => (\n        <div key={`empty__${i}`} />\n      ))}\n      {range(1, days).map((day) => {\n        const d = dayjs(date).date(day);\n        const event = getEvent(d, reversedEvents);\n        const disabled = isDateOutsidePeriod(d, min, max);\n        // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n        const { props: eventProps } = event || ({ props: {} } as CalendarEvent);\n\n        const dateProps = dates && dates[d.format(\"YYYYMMDD\")];\n        const dateChildren =\n          dateProps !== undefined &&\n          dateProps !== null &&\n          renderCell(dateProps);\n        if (\n          eventProps?.children !== undefined &&\n          eventProps?.children !== null\n        ) {\n          const { children, ...eventProps_ } = eventProps;\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps_}\n            >\n              <CalendarDayEvent\n                start={dayjs(event?.start)}\n                end={dayjs(event?.end)}\n                date={d}\n                title={typeof children === \"string\" ? children : undefined}\n              >\n                {children}\n              </CalendarDayEvent>\n              {dateChildren}\n            </CalendarDay>\n          );\n        } else {\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps}\n            >\n              {dateChildren}\n            </CalendarDay>\n          );\n        }\n      })}\n    </div>\n  );\n};\n"]} */",
46
+ styles: "margin:0 auto;label:defaultRenderCell;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Calendar/CalendarDaysInMonth.tsx"],"names":[],"mappings":"AA6FY","file":"../../../src/Calendar/CalendarDaysInMonth.tsx","sourcesContent":["import { CalendarDay } from \"./CalendarDay\";\nimport { CalendarDayEvent } from \"./CalendarDayEvent\";\nimport { CalendarDayProps } from \"./CalendarDay\";\nimport { css } from \"@emotion/react\";\nimport { range } from \"../@utils/range\";\nimport React, { useMemo } from \"react\";\nimport dayjs from \"dayjs\";\nimport isSameOrAfter from \"dayjs/plugin/isSameOrAfter\";\nimport isSameOrBefore from \"dayjs/plugin/isSameOrBefore\";\n\ndayjs.extend(isSameOrAfter);\ndayjs.extend(isSameOrBefore);\n\nconst isDateOutsidePeriod = (\n  date: dayjs.Dayjs,\n  min?: dayjs.ConfigType,\n  max?: dayjs.ConfigType,\n) => {\n  return (\n    (min !== undefined && min !== null && date.isSameOrBefore(min, \"date\")) ||\n    (max !== undefined && max !== undefined && date.isSameOrAfter(max, \"date\"))\n  );\n};\n\nconst getEvent = (date: dayjs.Dayjs, events?: CalendarEvent[]) => {\n  return events?.find((event) => {\n    if (event.start === undefined) {\n      return date.isSameOrBefore(event.end, \"date\");\n    }\n    if (event.end === undefined) {\n      return date.isSameOrAfter(event.start, \"date\");\n    }\n    return (\n      date.isSameOrAfter(event.start, \"date\") &&\n      date.isSameOrBefore(event.end, \"date\")\n    );\n  });\n};\n\nexport interface CalendarDaysProps\n  extends Omit<CalendarDayProps, \"date\" | \"disabled\" | \"event\"> {\n  children?: React.ReactNode;\n}\n\nexport interface CalendarEvent {\n  start?: dayjs.ConfigType;\n  end?: dayjs.ConfigType;\n  // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n  type?: \"default\" | \"disabled\" | string;\n  props?: CalendarDaysProps;\n}\n\nexport interface CalendarDaysInMonthProps<T> {\n  children?: never;\n  events?: CalendarEvent[];\n  /**\n   * datesで渡されたデータをどのようにレンダリングするかを指定します\n   * @default \"(message: string) => <Centering>{new String(message)}</Centering>\"\"\n   */\n  renderCell?: (props: T) => React.ReactNode;\n  /**\n   * keyに対応するカレンダーのセルに任意の子要素を入れることができます。\n   * keyのフォーマットはYYYYMMDDでなければなりません。\n   */\n  dates?: Record<string, T>;\n  daysProps?: CalendarDaysProps;\n  date?: dayjs.ConfigType;\n  min?: dayjs.ConfigType;\n  max?: dayjs.ConfigType;\n  /**\n   * カレンダーのセルの高さを指定します。\n   * これが指定されていない場合、カレンダーのセルは正方形になります。\n   */\n  cellHeight?: number | string;\n  /**\n   * 日付がクリックされた場合に、その日付とイベントを返す。\n   */\n  onClickDay?: (\n    value: Date,\n    event: React.MouseEvent<HTMLDivElement, MouseEvent>,\n  ) => void;\n}\n\nconst getFirstWeekday = (date: dayjs.ConfigType) => {\n  return dayjs(date).startOf(\"month\").day();\n};\nconst getDaysCount = (date: dayjs.ConfigType) => {\n  return dayjs(date).daysInMonth() + 1;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst defaultRenderCell = (message: any) => (\n  <div\n    css={css`\n      margin: 0 auto;\n    `}\n  >\n    {message}\n  </div>\n);\n\nexport const CalendarDaysInMonth = <T,>({\n  dates,\n  events = [],\n  daysProps = {},\n  date = dayjs(),\n  min,\n  max,\n  cellHeight,\n  renderCell = defaultRenderCell,\n  onClickDay,\n  ...props\n}: Readonly<CalendarDaysInMonthProps<T>>) => {\n  const firstWeekday = useMemo(() => getFirstWeekday(date), [date]);\n  const days = useMemo(() => getDaysCount(date), [date]);\n  const reversedEvents = useMemo(() => events.slice().reverse(), [events]);\n  return (\n    <div\n      css={[\n        css`\n          display: grid;\n          grid-template-columns: repeat(7, minmax(42px, 1fr));\n        `,\n        {\n          gridAutoRows: cellHeight ?? \"1fr\",\n        },\n        cellHeight === undefined\n          ? css`\n              & > *:first-of-type {\n                aspect-ratio: 1;\n              }\n            `\n          : null,\n      ]}\n      {...props}\n    >\n      {range(firstWeekday).map((i) => (\n        <div key={`empty__${i}`} />\n      ))}\n      {range(1, days).map((day) => {\n        const d = dayjs(date).date(day);\n        const event = getEvent(d, reversedEvents);\n        const disabled = isDateOutsidePeriod(d, min, max);\n        // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n        const { props: eventProps } = event || ({ props: {} } as CalendarEvent);\n\n        const dateProps = dates?.[d.format(\"YYYYMMDD\")];\n        const dateChildren =\n          dateProps !== undefined &&\n          dateProps !== null &&\n          renderCell(dateProps);\n        if (\n          eventProps?.children !== undefined &&\n          eventProps?.children !== null\n        ) {\n          const { children, ...eventProps_ } = eventProps;\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps_}\n            >\n              <CalendarDayEvent\n                start={dayjs(event?.start)}\n                end={dayjs(event?.end)}\n                date={d}\n                title={typeof children === \"string\" ? children : undefined}\n              >\n                {children}\n              </CalendarDayEvent>\n              {dateChildren}\n            </CalendarDay>\n          );\n        } else {\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps}\n            >\n              {dateChildren}\n            </CalendarDay>\n          );\n        }\n      })}\n    </div>\n  );\n};\n"]} */",
47
47
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
48
48
  };
49
49
  const defaultRenderCell = message => (0, _react.jsx)("div", {
@@ -54,7 +54,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
54
54
  styles: "&>*:first-of-type{aspect-ratio:1;}"
55
55
  } : {
56
56
  name: "xu85ll-CalendarDaysInMonth",
57
- styles: "&>*:first-of-type{aspect-ratio:1;};label:CalendarDaysInMonth;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Calendar/CalendarDaysInMonth.tsx"],"names":[],"mappings":"AA+He","file":"../../../src/Calendar/CalendarDaysInMonth.tsx","sourcesContent":["import { CalendarDay } from \"./CalendarDay\";\nimport { CalendarDayEvent } from \"./CalendarDayEvent\";\nimport { CalendarDayProps } from \"./CalendarDay\";\nimport { css } from \"@emotion/react\";\nimport { range } from \"../@utils/range\";\nimport React, { useMemo } from \"react\";\nimport dayjs from \"dayjs\";\nimport isSameOrAfter from \"dayjs/plugin/isSameOrAfter\";\nimport isSameOrBefore from \"dayjs/plugin/isSameOrBefore\";\n\ndayjs.extend(isSameOrAfter);\ndayjs.extend(isSameOrBefore);\n\nconst isDateOutsidePeriod = (\n  date: dayjs.Dayjs,\n  min?: dayjs.ConfigType,\n  max?: dayjs.ConfigType,\n) => {\n  return (\n    (min !== undefined && min !== null && date.isSameOrBefore(min, \"date\")) ||\n    (max !== undefined && max !== undefined && date.isSameOrAfter(max, \"date\"))\n  );\n};\n\nconst getEvent = (date: dayjs.Dayjs, events?: CalendarEvent[]) => {\n  return events?.find((event) => {\n    if (event.start === undefined) {\n      return date.isSameOrBefore(event.end, \"date\");\n    }\n    if (event.end === undefined) {\n      return date.isSameOrAfter(event.start, \"date\");\n    }\n    return (\n      date.isSameOrAfter(event.start, \"date\") &&\n      date.isSameOrBefore(event.end, \"date\")\n    );\n  });\n};\n\nexport interface CalendarDaysProps\n  extends Omit<CalendarDayProps, \"date\" | \"disabled\" | \"event\"> {\n  children?: React.ReactNode;\n}\n\nexport interface CalendarEvent {\n  start?: dayjs.ConfigType;\n  end?: dayjs.ConfigType;\n  // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n  type?: \"default\" | \"disabled\" | string;\n  props?: CalendarDaysProps;\n}\n\nexport interface CalendarDaysInMonthProps<T> {\n  children?: never;\n  events?: CalendarEvent[];\n  /**\n   * datesで渡されたデータをどのようにレンダリングするかを指定します\n   * @default \"(message: string) => <Centering>{new String(message)}</Centering>\"\"\n   */\n  renderCell?: (props: T) => React.ReactNode;\n  /**\n   * keyに対応するカレンダーのセルに任意の子要素を入れることができます。\n   * keyのフォーマットはYYYYMMDDでなければなりません。\n   */\n  dates?: Record<string, T>;\n  daysProps?: CalendarDaysProps;\n  date?: dayjs.ConfigType;\n  min?: dayjs.ConfigType;\n  max?: dayjs.ConfigType;\n  /**\n   * カレンダーのセルの高さを指定します。\n   * これが指定されていない場合、カレンダーのセルは正方形になります。\n   */\n  cellHeight?: number | string;\n  /**\n   * 日付がクリックされた場合に、その日付とイベントを返す。\n   */\n  onClickDay?: (\n    value: Date,\n    event: React.MouseEvent<HTMLDivElement, MouseEvent>,\n  ) => void;\n}\n\nconst getFirstWeekday = (date: dayjs.ConfigType) => {\n  return dayjs(date).startOf(\"month\").day();\n};\nconst getDaysCount = (date: dayjs.ConfigType) => {\n  return dayjs(date).daysInMonth() + 1;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst defaultRenderCell = (message: any) => (\n  <div\n    css={css`\n      margin: 0 auto;\n    `}\n  >\n    {message}\n  </div>\n);\n\nexport const CalendarDaysInMonth = <T,>({\n  dates,\n  events = [],\n  daysProps = {},\n  date = dayjs(),\n  min,\n  max,\n  cellHeight,\n  renderCell = defaultRenderCell,\n  onClickDay,\n  ...props\n}: Readonly<CalendarDaysInMonthProps<T>>) => {\n  const firstWeekday = useMemo(() => getFirstWeekday(date), [date]);\n  const days = useMemo(() => getDaysCount(date), [date]);\n  const reversedEvents = useMemo(() => events.slice().reverse(), [events]);\n  return (\n    <div\n      css={[\n        css`\n          display: grid;\n          grid-template-columns: repeat(7, minmax(42px, 1fr));\n        `,\n        {\n          gridAutoRows: cellHeight ?? \"1fr\",\n        },\n        cellHeight === undefined\n          ? css`\n              & > *:first-of-type {\n                aspect-ratio: 1;\n              }\n            `\n          : null,\n      ]}\n      {...props}\n    >\n      {range(firstWeekday).map((i) => (\n        <div key={`empty__${i}`} />\n      ))}\n      {range(1, days).map((day) => {\n        const d = dayjs(date).date(day);\n        const event = getEvent(d, reversedEvents);\n        const disabled = isDateOutsidePeriod(d, min, max);\n        // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n        const { props: eventProps } = event || ({ props: {} } as CalendarEvent);\n\n        const dateProps = dates && dates[d.format(\"YYYYMMDD\")];\n        const dateChildren =\n          dateProps !== undefined &&\n          dateProps !== null &&\n          renderCell(dateProps);\n        if (\n          eventProps?.children !== undefined &&\n          eventProps?.children !== null\n        ) {\n          const { children, ...eventProps_ } = eventProps;\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps_}\n            >\n              <CalendarDayEvent\n                start={dayjs(event?.start)}\n                end={dayjs(event?.end)}\n                date={d}\n                title={typeof children === \"string\" ? children : undefined}\n              >\n                {children}\n              </CalendarDayEvent>\n              {dateChildren}\n            </CalendarDay>\n          );\n        } else {\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps}\n            >\n              {dateChildren}\n            </CalendarDay>\n          );\n        }\n      })}\n    </div>\n  );\n};\n"]} */",
57
+ styles: "&>*:first-of-type{aspect-ratio:1;};label:CalendarDaysInMonth;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Calendar/CalendarDaysInMonth.tsx"],"names":[],"mappings":"AA+He","file":"../../../src/Calendar/CalendarDaysInMonth.tsx","sourcesContent":["import { CalendarDay } from \"./CalendarDay\";\nimport { CalendarDayEvent } from \"./CalendarDayEvent\";\nimport { CalendarDayProps } from \"./CalendarDay\";\nimport { css } from \"@emotion/react\";\nimport { range } from \"../@utils/range\";\nimport React, { useMemo } from \"react\";\nimport dayjs from \"dayjs\";\nimport isSameOrAfter from \"dayjs/plugin/isSameOrAfter\";\nimport isSameOrBefore from \"dayjs/plugin/isSameOrBefore\";\n\ndayjs.extend(isSameOrAfter);\ndayjs.extend(isSameOrBefore);\n\nconst isDateOutsidePeriod = (\n  date: dayjs.Dayjs,\n  min?: dayjs.ConfigType,\n  max?: dayjs.ConfigType,\n) => {\n  return (\n    (min !== undefined && min !== null && date.isSameOrBefore(min, \"date\")) ||\n    (max !== undefined && max !== undefined && date.isSameOrAfter(max, \"date\"))\n  );\n};\n\nconst getEvent = (date: dayjs.Dayjs, events?: CalendarEvent[]) => {\n  return events?.find((event) => {\n    if (event.start === undefined) {\n      return date.isSameOrBefore(event.end, \"date\");\n    }\n    if (event.end === undefined) {\n      return date.isSameOrAfter(event.start, \"date\");\n    }\n    return (\n      date.isSameOrAfter(event.start, \"date\") &&\n      date.isSameOrBefore(event.end, \"date\")\n    );\n  });\n};\n\nexport interface CalendarDaysProps\n  extends Omit<CalendarDayProps, \"date\" | \"disabled\" | \"event\"> {\n  children?: React.ReactNode;\n}\n\nexport interface CalendarEvent {\n  start?: dayjs.ConfigType;\n  end?: dayjs.ConfigType;\n  // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n  type?: \"default\" | \"disabled\" | string;\n  props?: CalendarDaysProps;\n}\n\nexport interface CalendarDaysInMonthProps<T> {\n  children?: never;\n  events?: CalendarEvent[];\n  /**\n   * datesで渡されたデータをどのようにレンダリングするかを指定します\n   * @default \"(message: string) => <Centering>{new String(message)}</Centering>\"\"\n   */\n  renderCell?: (props: T) => React.ReactNode;\n  /**\n   * keyに対応するカレンダーのセルに任意の子要素を入れることができます。\n   * keyのフォーマットはYYYYMMDDでなければなりません。\n   */\n  dates?: Record<string, T>;\n  daysProps?: CalendarDaysProps;\n  date?: dayjs.ConfigType;\n  min?: dayjs.ConfigType;\n  max?: dayjs.ConfigType;\n  /**\n   * カレンダーのセルの高さを指定します。\n   * これが指定されていない場合、カレンダーのセルは正方形になります。\n   */\n  cellHeight?: number | string;\n  /**\n   * 日付がクリックされた場合に、その日付とイベントを返す。\n   */\n  onClickDay?: (\n    value: Date,\n    event: React.MouseEvent<HTMLDivElement, MouseEvent>,\n  ) => void;\n}\n\nconst getFirstWeekday = (date: dayjs.ConfigType) => {\n  return dayjs(date).startOf(\"month\").day();\n};\nconst getDaysCount = (date: dayjs.ConfigType) => {\n  return dayjs(date).daysInMonth() + 1;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst defaultRenderCell = (message: any) => (\n  <div\n    css={css`\n      margin: 0 auto;\n    `}\n  >\n    {message}\n  </div>\n);\n\nexport const CalendarDaysInMonth = <T,>({\n  dates,\n  events = [],\n  daysProps = {},\n  date = dayjs(),\n  min,\n  max,\n  cellHeight,\n  renderCell = defaultRenderCell,\n  onClickDay,\n  ...props\n}: Readonly<CalendarDaysInMonthProps<T>>) => {\n  const firstWeekday = useMemo(() => getFirstWeekday(date), [date]);\n  const days = useMemo(() => getDaysCount(date), [date]);\n  const reversedEvents = useMemo(() => events.slice().reverse(), [events]);\n  return (\n    <div\n      css={[\n        css`\n          display: grid;\n          grid-template-columns: repeat(7, minmax(42px, 1fr));\n        `,\n        {\n          gridAutoRows: cellHeight ?? \"1fr\",\n        },\n        cellHeight === undefined\n          ? css`\n              & > *:first-of-type {\n                aspect-ratio: 1;\n              }\n            `\n          : null,\n      ]}\n      {...props}\n    >\n      {range(firstWeekday).map((i) => (\n        <div key={`empty__${i}`} />\n      ))}\n      {range(1, days).map((day) => {\n        const d = dayjs(date).date(day);\n        const event = getEvent(d, reversedEvents);\n        const disabled = isDateOutsidePeriod(d, min, max);\n        // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n        const { props: eventProps } = event || ({ props: {} } as CalendarEvent);\n\n        const dateProps = dates?.[d.format(\"YYYYMMDD\")];\n        const dateChildren =\n          dateProps !== undefined &&\n          dateProps !== null &&\n          renderCell(dateProps);\n        if (\n          eventProps?.children !== undefined &&\n          eventProps?.children !== null\n        ) {\n          const { children, ...eventProps_ } = eventProps;\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps_}\n            >\n              <CalendarDayEvent\n                start={dayjs(event?.start)}\n                end={dayjs(event?.end)}\n                date={d}\n                title={typeof children === \"string\" ? children : undefined}\n              >\n                {children}\n              </CalendarDayEvent>\n              {dateChildren}\n            </CalendarDay>\n          );\n        } else {\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps}\n            >\n              {dateChildren}\n            </CalendarDay>\n          );\n        }\n      })}\n    </div>\n  );\n};\n"]} */",
58
58
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
59
59
  };
60
60
  var _ref2 = process.env.NODE_ENV === "production" ? {
@@ -62,7 +62,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
62
62
  styles: "display:grid;grid-template-columns:repeat(7, minmax(42px, 1fr))"
63
63
  } : {
64
64
  name: "26pcxi-CalendarDaysInMonth",
65
- styles: "display:grid;grid-template-columns:repeat(7, minmax(42px, 1fr));label:CalendarDaysInMonth;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Calendar/CalendarDaysInMonth.tsx"],"names":[],"mappings":"AAuHW","file":"../../../src/Calendar/CalendarDaysInMonth.tsx","sourcesContent":["import { CalendarDay } from \"./CalendarDay\";\nimport { CalendarDayEvent } from \"./CalendarDayEvent\";\nimport { CalendarDayProps } from \"./CalendarDay\";\nimport { css } from \"@emotion/react\";\nimport { range } from \"../@utils/range\";\nimport React, { useMemo } from \"react\";\nimport dayjs from \"dayjs\";\nimport isSameOrAfter from \"dayjs/plugin/isSameOrAfter\";\nimport isSameOrBefore from \"dayjs/plugin/isSameOrBefore\";\n\ndayjs.extend(isSameOrAfter);\ndayjs.extend(isSameOrBefore);\n\nconst isDateOutsidePeriod = (\n  date: dayjs.Dayjs,\n  min?: dayjs.ConfigType,\n  max?: dayjs.ConfigType,\n) => {\n  return (\n    (min !== undefined && min !== null && date.isSameOrBefore(min, \"date\")) ||\n    (max !== undefined && max !== undefined && date.isSameOrAfter(max, \"date\"))\n  );\n};\n\nconst getEvent = (date: dayjs.Dayjs, events?: CalendarEvent[]) => {\n  return events?.find((event) => {\n    if (event.start === undefined) {\n      return date.isSameOrBefore(event.end, \"date\");\n    }\n    if (event.end === undefined) {\n      return date.isSameOrAfter(event.start, \"date\");\n    }\n    return (\n      date.isSameOrAfter(event.start, \"date\") &&\n      date.isSameOrBefore(event.end, \"date\")\n    );\n  });\n};\n\nexport interface CalendarDaysProps\n  extends Omit<CalendarDayProps, \"date\" | \"disabled\" | \"event\"> {\n  children?: React.ReactNode;\n}\n\nexport interface CalendarEvent {\n  start?: dayjs.ConfigType;\n  end?: dayjs.ConfigType;\n  // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n  type?: \"default\" | \"disabled\" | string;\n  props?: CalendarDaysProps;\n}\n\nexport interface CalendarDaysInMonthProps<T> {\n  children?: never;\n  events?: CalendarEvent[];\n  /**\n   * datesで渡されたデータをどのようにレンダリングするかを指定します\n   * @default \"(message: string) => <Centering>{new String(message)}</Centering>\"\"\n   */\n  renderCell?: (props: T) => React.ReactNode;\n  /**\n   * keyに対応するカレンダーのセルに任意の子要素を入れることができます。\n   * keyのフォーマットはYYYYMMDDでなければなりません。\n   */\n  dates?: Record<string, T>;\n  daysProps?: CalendarDaysProps;\n  date?: dayjs.ConfigType;\n  min?: dayjs.ConfigType;\n  max?: dayjs.ConfigType;\n  /**\n   * カレンダーのセルの高さを指定します。\n   * これが指定されていない場合、カレンダーのセルは正方形になります。\n   */\n  cellHeight?: number | string;\n  /**\n   * 日付がクリックされた場合に、その日付とイベントを返す。\n   */\n  onClickDay?: (\n    value: Date,\n    event: React.MouseEvent<HTMLDivElement, MouseEvent>,\n  ) => void;\n}\n\nconst getFirstWeekday = (date: dayjs.ConfigType) => {\n  return dayjs(date).startOf(\"month\").day();\n};\nconst getDaysCount = (date: dayjs.ConfigType) => {\n  return dayjs(date).daysInMonth() + 1;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst defaultRenderCell = (message: any) => (\n  <div\n    css={css`\n      margin: 0 auto;\n    `}\n  >\n    {message}\n  </div>\n);\n\nexport const CalendarDaysInMonth = <T,>({\n  dates,\n  events = [],\n  daysProps = {},\n  date = dayjs(),\n  min,\n  max,\n  cellHeight,\n  renderCell = defaultRenderCell,\n  onClickDay,\n  ...props\n}: Readonly<CalendarDaysInMonthProps<T>>) => {\n  const firstWeekday = useMemo(() => getFirstWeekday(date), [date]);\n  const days = useMemo(() => getDaysCount(date), [date]);\n  const reversedEvents = useMemo(() => events.slice().reverse(), [events]);\n  return (\n    <div\n      css={[\n        css`\n          display: grid;\n          grid-template-columns: repeat(7, minmax(42px, 1fr));\n        `,\n        {\n          gridAutoRows: cellHeight ?? \"1fr\",\n        },\n        cellHeight === undefined\n          ? css`\n              & > *:first-of-type {\n                aspect-ratio: 1;\n              }\n            `\n          : null,\n      ]}\n      {...props}\n    >\n      {range(firstWeekday).map((i) => (\n        <div key={`empty__${i}`} />\n      ))}\n      {range(1, days).map((day) => {\n        const d = dayjs(date).date(day);\n        const event = getEvent(d, reversedEvents);\n        const disabled = isDateOutsidePeriod(d, min, max);\n        // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n        const { props: eventProps } = event || ({ props: {} } as CalendarEvent);\n\n        const dateProps = dates && dates[d.format(\"YYYYMMDD\")];\n        const dateChildren =\n          dateProps !== undefined &&\n          dateProps !== null &&\n          renderCell(dateProps);\n        if (\n          eventProps?.children !== undefined &&\n          eventProps?.children !== null\n        ) {\n          const { children, ...eventProps_ } = eventProps;\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps_}\n            >\n              <CalendarDayEvent\n                start={dayjs(event?.start)}\n                end={dayjs(event?.end)}\n                date={d}\n                title={typeof children === \"string\" ? children : undefined}\n              >\n                {children}\n              </CalendarDayEvent>\n              {dateChildren}\n            </CalendarDay>\n          );\n        } else {\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps}\n            >\n              {dateChildren}\n            </CalendarDay>\n          );\n        }\n      })}\n    </div>\n  );\n};\n"]} */",
65
+ styles: "display:grid;grid-template-columns:repeat(7, minmax(42px, 1fr));label:CalendarDaysInMonth;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Calendar/CalendarDaysInMonth.tsx"],"names":[],"mappings":"AAuHW","file":"../../../src/Calendar/CalendarDaysInMonth.tsx","sourcesContent":["import { CalendarDay } from \"./CalendarDay\";\nimport { CalendarDayEvent } from \"./CalendarDayEvent\";\nimport { CalendarDayProps } from \"./CalendarDay\";\nimport { css } from \"@emotion/react\";\nimport { range } from \"../@utils/range\";\nimport React, { useMemo } from \"react\";\nimport dayjs from \"dayjs\";\nimport isSameOrAfter from \"dayjs/plugin/isSameOrAfter\";\nimport isSameOrBefore from \"dayjs/plugin/isSameOrBefore\";\n\ndayjs.extend(isSameOrAfter);\ndayjs.extend(isSameOrBefore);\n\nconst isDateOutsidePeriod = (\n  date: dayjs.Dayjs,\n  min?: dayjs.ConfigType,\n  max?: dayjs.ConfigType,\n) => {\n  return (\n    (min !== undefined && min !== null && date.isSameOrBefore(min, \"date\")) ||\n    (max !== undefined && max !== undefined && date.isSameOrAfter(max, \"date\"))\n  );\n};\n\nconst getEvent = (date: dayjs.Dayjs, events?: CalendarEvent[]) => {\n  return events?.find((event) => {\n    if (event.start === undefined) {\n      return date.isSameOrBefore(event.end, \"date\");\n    }\n    if (event.end === undefined) {\n      return date.isSameOrAfter(event.start, \"date\");\n    }\n    return (\n      date.isSameOrAfter(event.start, \"date\") &&\n      date.isSameOrBefore(event.end, \"date\")\n    );\n  });\n};\n\nexport interface CalendarDaysProps\n  extends Omit<CalendarDayProps, \"date\" | \"disabled\" | \"event\"> {\n  children?: React.ReactNode;\n}\n\nexport interface CalendarEvent {\n  start?: dayjs.ConfigType;\n  end?: dayjs.ConfigType;\n  // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n  type?: \"default\" | \"disabled\" | string;\n  props?: CalendarDaysProps;\n}\n\nexport interface CalendarDaysInMonthProps<T> {\n  children?: never;\n  events?: CalendarEvent[];\n  /**\n   * datesで渡されたデータをどのようにレンダリングするかを指定します\n   * @default \"(message: string) => <Centering>{new String(message)}</Centering>\"\"\n   */\n  renderCell?: (props: T) => React.ReactNode;\n  /**\n   * keyに対応するカレンダーのセルに任意の子要素を入れることができます。\n   * keyのフォーマットはYYYYMMDDでなければなりません。\n   */\n  dates?: Record<string, T>;\n  daysProps?: CalendarDaysProps;\n  date?: dayjs.ConfigType;\n  min?: dayjs.ConfigType;\n  max?: dayjs.ConfigType;\n  /**\n   * カレンダーのセルの高さを指定します。\n   * これが指定されていない場合、カレンダーのセルは正方形になります。\n   */\n  cellHeight?: number | string;\n  /**\n   * 日付がクリックされた場合に、その日付とイベントを返す。\n   */\n  onClickDay?: (\n    value: Date,\n    event: React.MouseEvent<HTMLDivElement, MouseEvent>,\n  ) => void;\n}\n\nconst getFirstWeekday = (date: dayjs.ConfigType) => {\n  return dayjs(date).startOf(\"month\").day();\n};\nconst getDaysCount = (date: dayjs.ConfigType) => {\n  return dayjs(date).daysInMonth() + 1;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst defaultRenderCell = (message: any) => (\n  <div\n    css={css`\n      margin: 0 auto;\n    `}\n  >\n    {message}\n  </div>\n);\n\nexport const CalendarDaysInMonth = <T,>({\n  dates,\n  events = [],\n  daysProps = {},\n  date = dayjs(),\n  min,\n  max,\n  cellHeight,\n  renderCell = defaultRenderCell,\n  onClickDay,\n  ...props\n}: Readonly<CalendarDaysInMonthProps<T>>) => {\n  const firstWeekday = useMemo(() => getFirstWeekday(date), [date]);\n  const days = useMemo(() => getDaysCount(date), [date]);\n  const reversedEvents = useMemo(() => events.slice().reverse(), [events]);\n  return (\n    <div\n      css={[\n        css`\n          display: grid;\n          grid-template-columns: repeat(7, minmax(42px, 1fr));\n        `,\n        {\n          gridAutoRows: cellHeight ?? \"1fr\",\n        },\n        cellHeight === undefined\n          ? css`\n              & > *:first-of-type {\n                aspect-ratio: 1;\n              }\n            `\n          : null,\n      ]}\n      {...props}\n    >\n      {range(firstWeekday).map((i) => (\n        <div key={`empty__${i}`} />\n      ))}\n      {range(1, days).map((day) => {\n        const d = dayjs(date).date(day);\n        const event = getEvent(d, reversedEvents);\n        const disabled = isDateOutsidePeriod(d, min, max);\n        // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n        const { props: eventProps } = event || ({ props: {} } as CalendarEvent);\n\n        const dateProps = dates?.[d.format(\"YYYYMMDD\")];\n        const dateChildren =\n          dateProps !== undefined &&\n          dateProps !== null &&\n          renderCell(dateProps);\n        if (\n          eventProps?.children !== undefined &&\n          eventProps?.children !== null\n        ) {\n          const { children, ...eventProps_ } = eventProps;\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps_}\n            >\n              <CalendarDayEvent\n                start={dayjs(event?.start)}\n                end={dayjs(event?.end)}\n                date={d}\n                title={typeof children === \"string\" ? children : undefined}\n              >\n                {children}\n              </CalendarDayEvent>\n              {dateChildren}\n            </CalendarDay>\n          );\n        } else {\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps}\n            >\n              {dateChildren}\n            </CalendarDay>\n          );\n        }\n      })}\n    </div>\n  );\n};\n"]} */",
66
66
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
67
67
  };
68
68
  const CalendarDaysInMonth = ({
@@ -83,7 +83,7 @@ const CalendarDaysInMonth = ({
83
83
  return (0, _react.jsx)("div", _extends({
84
84
  css: [_ref2, {
85
85
  gridAutoRows: cellHeight ?? "1fr"
86
- }, cellHeight === undefined ? _ref : null, process.env.NODE_ENV === "production" ? "" : ";label:CalendarDaysInMonth;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Calendar/CalendarDaysInMonth.tsx"],"names":[],"mappings":"AAsHM","file":"../../../src/Calendar/CalendarDaysInMonth.tsx","sourcesContent":["import { CalendarDay } from \"./CalendarDay\";\nimport { CalendarDayEvent } from \"./CalendarDayEvent\";\nimport { CalendarDayProps } from \"./CalendarDay\";\nimport { css } from \"@emotion/react\";\nimport { range } from \"../@utils/range\";\nimport React, { useMemo } from \"react\";\nimport dayjs from \"dayjs\";\nimport isSameOrAfter from \"dayjs/plugin/isSameOrAfter\";\nimport isSameOrBefore from \"dayjs/plugin/isSameOrBefore\";\n\ndayjs.extend(isSameOrAfter);\ndayjs.extend(isSameOrBefore);\n\nconst isDateOutsidePeriod = (\n  date: dayjs.Dayjs,\n  min?: dayjs.ConfigType,\n  max?: dayjs.ConfigType,\n) => {\n  return (\n    (min !== undefined && min !== null && date.isSameOrBefore(min, \"date\")) ||\n    (max !== undefined && max !== undefined && date.isSameOrAfter(max, \"date\"))\n  );\n};\n\nconst getEvent = (date: dayjs.Dayjs, events?: CalendarEvent[]) => {\n  return events?.find((event) => {\n    if (event.start === undefined) {\n      return date.isSameOrBefore(event.end, \"date\");\n    }\n    if (event.end === undefined) {\n      return date.isSameOrAfter(event.start, \"date\");\n    }\n    return (\n      date.isSameOrAfter(event.start, \"date\") &&\n      date.isSameOrBefore(event.end, \"date\")\n    );\n  });\n};\n\nexport interface CalendarDaysProps\n  extends Omit<CalendarDayProps, \"date\" | \"disabled\" | \"event\"> {\n  children?: React.ReactNode;\n}\n\nexport interface CalendarEvent {\n  start?: dayjs.ConfigType;\n  end?: dayjs.ConfigType;\n  // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n  type?: \"default\" | \"disabled\" | string;\n  props?: CalendarDaysProps;\n}\n\nexport interface CalendarDaysInMonthProps<T> {\n  children?: never;\n  events?: CalendarEvent[];\n  /**\n   * datesで渡されたデータをどのようにレンダリングするかを指定します\n   * @default \"(message: string) => <Centering>{new String(message)}</Centering>\"\"\n   */\n  renderCell?: (props: T) => React.ReactNode;\n  /**\n   * keyに対応するカレンダーのセルに任意の子要素を入れることができます。\n   * keyのフォーマットはYYYYMMDDでなければなりません。\n   */\n  dates?: Record<string, T>;\n  daysProps?: CalendarDaysProps;\n  date?: dayjs.ConfigType;\n  min?: dayjs.ConfigType;\n  max?: dayjs.ConfigType;\n  /**\n   * カレンダーのセルの高さを指定します。\n   * これが指定されていない場合、カレンダーのセルは正方形になります。\n   */\n  cellHeight?: number | string;\n  /**\n   * 日付がクリックされた場合に、その日付とイベントを返す。\n   */\n  onClickDay?: (\n    value: Date,\n    event: React.MouseEvent<HTMLDivElement, MouseEvent>,\n  ) => void;\n}\n\nconst getFirstWeekday = (date: dayjs.ConfigType) => {\n  return dayjs(date).startOf(\"month\").day();\n};\nconst getDaysCount = (date: dayjs.ConfigType) => {\n  return dayjs(date).daysInMonth() + 1;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst defaultRenderCell = (message: any) => (\n  <div\n    css={css`\n      margin: 0 auto;\n    `}\n  >\n    {message}\n  </div>\n);\n\nexport const CalendarDaysInMonth = <T,>({\n  dates,\n  events = [],\n  daysProps = {},\n  date = dayjs(),\n  min,\n  max,\n  cellHeight,\n  renderCell = defaultRenderCell,\n  onClickDay,\n  ...props\n}: Readonly<CalendarDaysInMonthProps<T>>) => {\n  const firstWeekday = useMemo(() => getFirstWeekday(date), [date]);\n  const days = useMemo(() => getDaysCount(date), [date]);\n  const reversedEvents = useMemo(() => events.slice().reverse(), [events]);\n  return (\n    <div\n      css={[\n        css`\n          display: grid;\n          grid-template-columns: repeat(7, minmax(42px, 1fr));\n        `,\n        {\n          gridAutoRows: cellHeight ?? \"1fr\",\n        },\n        cellHeight === undefined\n          ? css`\n              & > *:first-of-type {\n                aspect-ratio: 1;\n              }\n            `\n          : null,\n      ]}\n      {...props}\n    >\n      {range(firstWeekday).map((i) => (\n        <div key={`empty__${i}`} />\n      ))}\n      {range(1, days).map((day) => {\n        const d = dayjs(date).date(day);\n        const event = getEvent(d, reversedEvents);\n        const disabled = isDateOutsidePeriod(d, min, max);\n        // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n        const { props: eventProps } = event || ({ props: {} } as CalendarEvent);\n\n        const dateProps = dates && dates[d.format(\"YYYYMMDD\")];\n        const dateChildren =\n          dateProps !== undefined &&\n          dateProps !== null &&\n          renderCell(dateProps);\n        if (\n          eventProps?.children !== undefined &&\n          eventProps?.children !== null\n        ) {\n          const { children, ...eventProps_ } = eventProps;\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps_}\n            >\n              <CalendarDayEvent\n                start={dayjs(event?.start)}\n                end={dayjs(event?.end)}\n                date={d}\n                title={typeof children === \"string\" ? children : undefined}\n              >\n                {children}\n              </CalendarDayEvent>\n              {dateChildren}\n            </CalendarDay>\n          );\n        } else {\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps}\n            >\n              {dateChildren}\n            </CalendarDay>\n          );\n        }\n      })}\n    </div>\n  );\n};\n"]} */"]
86
+ }, cellHeight === undefined ? _ref : null, process.env.NODE_ENV === "production" ? "" : ";label:CalendarDaysInMonth;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Calendar/CalendarDaysInMonth.tsx"],"names":[],"mappings":"AAsHM","file":"../../../src/Calendar/CalendarDaysInMonth.tsx","sourcesContent":["import { CalendarDay } from \"./CalendarDay\";\nimport { CalendarDayEvent } from \"./CalendarDayEvent\";\nimport { CalendarDayProps } from \"./CalendarDay\";\nimport { css } from \"@emotion/react\";\nimport { range } from \"../@utils/range\";\nimport React, { useMemo } from \"react\";\nimport dayjs from \"dayjs\";\nimport isSameOrAfter from \"dayjs/plugin/isSameOrAfter\";\nimport isSameOrBefore from \"dayjs/plugin/isSameOrBefore\";\n\ndayjs.extend(isSameOrAfter);\ndayjs.extend(isSameOrBefore);\n\nconst isDateOutsidePeriod = (\n  date: dayjs.Dayjs,\n  min?: dayjs.ConfigType,\n  max?: dayjs.ConfigType,\n) => {\n  return (\n    (min !== undefined && min !== null && date.isSameOrBefore(min, \"date\")) ||\n    (max !== undefined && max !== undefined && date.isSameOrAfter(max, \"date\"))\n  );\n};\n\nconst getEvent = (date: dayjs.Dayjs, events?: CalendarEvent[]) => {\n  return events?.find((event) => {\n    if (event.start === undefined) {\n      return date.isSameOrBefore(event.end, \"date\");\n    }\n    if (event.end === undefined) {\n      return date.isSameOrAfter(event.start, \"date\");\n    }\n    return (\n      date.isSameOrAfter(event.start, \"date\") &&\n      date.isSameOrBefore(event.end, \"date\")\n    );\n  });\n};\n\nexport interface CalendarDaysProps\n  extends Omit<CalendarDayProps, \"date\" | \"disabled\" | \"event\"> {\n  children?: React.ReactNode;\n}\n\nexport interface CalendarEvent {\n  start?: dayjs.ConfigType;\n  end?: dayjs.ConfigType;\n  // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n  type?: \"default\" | \"disabled\" | string;\n  props?: CalendarDaysProps;\n}\n\nexport interface CalendarDaysInMonthProps<T> {\n  children?: never;\n  events?: CalendarEvent[];\n  /**\n   * datesで渡されたデータをどのようにレンダリングするかを指定します\n   * @default \"(message: string) => <Centering>{new String(message)}</Centering>\"\"\n   */\n  renderCell?: (props: T) => React.ReactNode;\n  /**\n   * keyに対応するカレンダーのセルに任意の子要素を入れることができます。\n   * keyのフォーマットはYYYYMMDDでなければなりません。\n   */\n  dates?: Record<string, T>;\n  daysProps?: CalendarDaysProps;\n  date?: dayjs.ConfigType;\n  min?: dayjs.ConfigType;\n  max?: dayjs.ConfigType;\n  /**\n   * カレンダーのセルの高さを指定します。\n   * これが指定されていない場合、カレンダーのセルは正方形になります。\n   */\n  cellHeight?: number | string;\n  /**\n   * 日付がクリックされた場合に、その日付とイベントを返す。\n   */\n  onClickDay?: (\n    value: Date,\n    event: React.MouseEvent<HTMLDivElement, MouseEvent>,\n  ) => void;\n}\n\nconst getFirstWeekday = (date: dayjs.ConfigType) => {\n  return dayjs(date).startOf(\"month\").day();\n};\nconst getDaysCount = (date: dayjs.ConfigType) => {\n  return dayjs(date).daysInMonth() + 1;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst defaultRenderCell = (message: any) => (\n  <div\n    css={css`\n      margin: 0 auto;\n    `}\n  >\n    {message}\n  </div>\n);\n\nexport const CalendarDaysInMonth = <T,>({\n  dates,\n  events = [],\n  daysProps = {},\n  date = dayjs(),\n  min,\n  max,\n  cellHeight,\n  renderCell = defaultRenderCell,\n  onClickDay,\n  ...props\n}: Readonly<CalendarDaysInMonthProps<T>>) => {\n  const firstWeekday = useMemo(() => getFirstWeekday(date), [date]);\n  const days = useMemo(() => getDaysCount(date), [date]);\n  const reversedEvents = useMemo(() => events.slice().reverse(), [events]);\n  return (\n    <div\n      css={[\n        css`\n          display: grid;\n          grid-template-columns: repeat(7, minmax(42px, 1fr));\n        `,\n        {\n          gridAutoRows: cellHeight ?? \"1fr\",\n        },\n        cellHeight === undefined\n          ? css`\n              & > *:first-of-type {\n                aspect-ratio: 1;\n              }\n            `\n          : null,\n      ]}\n      {...props}\n    >\n      {range(firstWeekday).map((i) => (\n        <div key={`empty__${i}`} />\n      ))}\n      {range(1, days).map((day) => {\n        const d = dayjs(date).date(day);\n        const event = getEvent(d, reversedEvents);\n        const disabled = isDateOutsidePeriod(d, min, max);\n        // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n        const { props: eventProps } = event || ({ props: {} } as CalendarEvent);\n\n        const dateProps = dates?.[d.format(\"YYYYMMDD\")];\n        const dateChildren =\n          dateProps !== undefined &&\n          dateProps !== null &&\n          renderCell(dateProps);\n        if (\n          eventProps?.children !== undefined &&\n          eventProps?.children !== null\n        ) {\n          const { children, ...eventProps_ } = eventProps;\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps_}\n            >\n              <CalendarDayEvent\n                start={dayjs(event?.start)}\n                end={dayjs(event?.end)}\n                date={d}\n                title={typeof children === \"string\" ? children : undefined}\n              >\n                {children}\n              </CalendarDayEvent>\n              {dateChildren}\n            </CalendarDay>\n          );\n        } else {\n          return (\n            <CalendarDay\n              date={d}\n              key={d.format()}\n              disabled={disabled}\n              event={event}\n              onClickDay={onClickDay}\n              {...daysProps}\n              {...eventProps}\n            >\n              {dateChildren}\n            </CalendarDay>\n          );\n        }\n      })}\n    </div>\n  );\n};\n"]} */"]
87
87
  }, props), (0, _range.range)(firstWeekday).map(i => (0, _react.jsx)("div", {
88
88
  key: `empty__${i}`
89
89
  })), (0, _range.range)(1, days).map(day => {
@@ -96,7 +96,7 @@ const CalendarDaysInMonth = ({
96
96
  } = event || {
97
97
  props: {}
98
98
  };
99
- const dateProps = dates && dates[d.format("YYYYMMDD")];
99
+ const dateProps = dates?.[d.format("YYYYMMDD")];
100
100
  const dateChildren = dateProps !== undefined && dateProps !== null && renderCell(dateProps);
101
101
  if (eventProps?.children !== undefined && eventProps?.children !== null) {
102
102
  const {