matsuri-ui 10.2.4 → 10.3.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.
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/NumberField/NumberField.tsx"],"names":["toLocaleValue","value","locale","options","undefined","toLocaleString","NumberField","React","forwardRef","props","rootRef","validationMessages","customValidations","style","className","label","onChange","defaultValue","disabled","propsValue","readOnly","propsReadOnly","loading","propsLoading","bottomGutter","helperText","invalid","max","Number","MAX_SAFE_INTEGER","min","MIN_SAFE_INTEGER","step","others","LocaleContext","ref","_value","setValue","validation","touched","touchedProps","handleChange","event","currentTarget","handleWheel","blur","required","valid","message"],"mappings":";;;;;;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AACA;;AACA;;;;;;;;;;AA0BA,MAAMA,aAAa,GAAG,CAACC,KAAD,EAAiBC,MAAjB,EAAkCC,OAAlC,KAAwF;AAC1G,SAAOF,KAAK,KAAKG,SAAV,GAAsB,EAAtB,GAA2BH,KAAK,CAACI,cAAN,CAAqBH,MAArB,EAA6BC,OAA7B,CAAlC;AACH,CAFD;;AAIO,MAAMG,WAAW,gBAAGC,eAAMC,UAAN,CAA6D,CAACC,KAAD,EAAQC,OAAR,KAAoB;AACxG,QAAM;AACFC,IAAAA,kBADE;AAEFC,IAAAA,iBAFE;AAGFC,IAAAA,KAHE;AAIFC,IAAAA,SAJE;AAKFC,IAAAA,KALE;AAMFZ,IAAAA,OANE;AAOFa,IAAAA,QAPE;AAQFC,IAAAA,YARE;AASFC,IAAAA,QATE;AAUFjB,IAAAA,KAAK,EAAEkB,UAVL;AAWFC,IAAAA,QAAQ,EAAEC,aAXR;AAYFC,IAAAA,OAAO,EAAEC,YAZP;AAaFC,IAAAA,YAbE;AAcFC,IAAAA,UAdE;AAeFC,IAAAA,OAfE;AAgBFC,IAAAA,GAAG,GAAGC,MAAM,CAACC,gBAhBX;AAiBFC,IAAAA,GAAG,GAAGF,MAAM,CAACG,gBAjBX;AAkBFC,IAAAA,IAAI,GAAG,CAlBL;AAmBF,OAAGC;AAnBD,MAoBFxB,KApBJ;AAqBA,QAAMP,MAAM,GAAG,uBAAWgC,6BAAX,CAAf;AACA,QAAMC,GAAG,GAAG,mBAAyB,IAAzB,CAAZ;AACA,QAAM,CAACC,MAAD,EAASC,QAAT,IAAqB,qBAASlB,UAAU,IAAIF,YAAvB,CAA3B;AAEA,QAAMhB,KAAK,GAAG,oBAAQ,MAAM;AACxB,QAAIgB,YAAY,KAAKb,SAArB,EAAgC;AAC5B,aAAOgC,MAAP;AACH;;AACD,WAAOA,MAAM,KAAKjB,UAAX,GAAwBiB,MAAxB,GAAiCjB,UAAxC;AACH,GALa,EAKX,CAACiB,MAAD,EAASnB,YAAT,EAAuBE,UAAvB,CALW,CAAd;AAOA,QAAMmB,UAAU,GAAG,kCAAc;AAC7BH,IAAAA,GAD6B;AAE7BxB,IAAAA,kBAF6B;AAG7BC,IAAAA,iBAH6B;AAI7BX,IAAAA;AAJ6B,GAAd,CAAnB;AAOA,QAAM,CAACsC,OAAD,EAAUC,YAAV,IAA0B,mDAAhC;AAEA,QAAMC,YAAY,GAAG,wBAChBC,KAAD,IAAgD;AAC5C,UAAM;AAAEzC,MAAAA;AAAF,QAAYyC,KAAK,CAACC,aAAxB;AACAN,IAAAA,QAAQ,CAACpC,KAAK,GAAG2B,MAAM,CAAC3B,KAAD,CAAT,GAAmB,CAAzB,CAAR;;AACA,QAAIe,QAAJ,EAAc;AACVA,MAAAA,QAAQ,CAACf,KAAK,GAAG2B,MAAM,CAAC3B,KAAD,CAAT,GAAmB,CAAzB,EAA4ByC,KAA5B,CAAR;AACH;AACJ,GAPgB,EAQjB,CAAC1B,QAAD,EAAWqB,QAAX,CARiB,CAArB;AAWA,QAAMO,WAAsD,GAAG,wBAAaF,KAAD,IAAW;AAClFA,IAAAA,KAAK,CAACC,aAAN,CAAoBE,IAApB;AACH,GAF8D,EAE5D,EAF4D,CAA/D;AAIA,QAAM;AAAEvB,IAAAA,OAAF;AAAWF,IAAAA;AAAX,MAAwB,+BAAc;AAAEE,IAAAA,OAAO,EAAEC,YAAX;AAAyBH,IAAAA,QAAQ,EAAEC;AAAnC,GAAd,CAA9B;AAEA,SACI,iBAAC,wBAAD;AAAa,IAAA,KAAK,EAAER,KAApB;AAA2B,IAAA,SAAS,EAAEC,SAAtC;AAAiD,IAAA,GAAG,EAAEJ;AAAtD,KACI,iBAAC,sBAAD;AAAY,qBAAeQ,QAA3B;AAAqC,IAAA,QAAQ,EAAET,KAAK,CAACqC,QAArD;AAA+D,IAAA,OAAO,EAAExB;AAAxE,KACKP,KADL,CADJ,EAII,iBAAC,oBAAD;AACI,IAAA,OAAO,EAAEO,OADb;AAEI,IAAA,QAAQ,EAAEJ,QAFd;AAGI,IAAA,GAAG,EAAEiB,GAHT;AAII,IAAA,IAAI,EAAC,QAJT;AAKI,IAAA,YAAY,EAAEnC,aAAa,CAACC,KAAD,EAAQC,MAAR,EAAgBC,OAAhB,CAL/B;AAMI,IAAA,KAAK,EAAEF,KANX;AAOI,IAAA,QAAQ,EAAEwC,YAPd;AAQI,IAAA,OAAO,EAAEG,WARb;AASI,IAAA,QAAQ,EAAExB,QATd;AAUI,oBAAc,CAACkB,UAAU,CAACS,KAV9B;AAWI,IAAA,GAAG,EAAEpB,GAXT;AAYI,IAAA,GAAG,EAAEG,GAZT;AAaI,IAAA,IAAI,EAAEE;AAbV,KAcQC,MAdR,EAeQO,YAfR,EAJJ,EAqBKD,OAAO,IAAID,UAAU,CAACU,OAAtB,GACG,iBAAC,8BAAD;AAAgB,IAAA,YAAY,EAAExB,YAA9B;AAA4C,IAAA,OAAO,EAAE,CAACc,UAAU,CAACS;AAAjE,KACKT,UAAU,CAACU,OADhB,CADH,GAKG,iBAAC,8BAAD;AAAgB,IAAA,YAAY,EAAExB,YAA9B;AAA4C,IAAA,OAAO,EAAEE,OAArD;AAA8D,IAAA,OAAO,EAAEJ;AAAvE,KACK,OAAOG,UAAP,KAAsB,UAAtB,GAAmCA,UAAU,CAAC;AAAExB,IAAAA;AAAF,GAAD,CAA7C,GAA2DwB,UADhE,CA1BR,CADJ;AAiCH,CA5F0B,CAApB","sourcesContent":["import { FieldProps } from \"../TextField\"\nimport { FormControl } from \"../FormControl\"\nimport { FormHelperText, InputBottomGutterProps } from \"../FormHelperText\"\nimport { InputBase, InputBaseProps } from \"../InputBase\"\nimport { InputLabel } from \"../InputLabel\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { NumberFormatOptions } from \"./NumberFormatOptions\"\nimport { useDitectInputTouched } from \"../TextField/useDitectInputTouched\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useValidation } from \"../TextField/useValidation\"\nimport React, { useCallback, useContext, useMemo, useRef, useState } from \"react\"\n\nexport interface NumberFieldProps\n extends FieldProps<number>,\n Omit<InputBaseProps, \"defaultValue\" | \"value\" | \"onChange\">,\n InputBottomGutterProps {\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/NumberFormat\n */\n options?: NumberFormatOptions\n type?: never\n children?: never\n /**\n * 入力が受け付ける最大値を指定します。\n *\n * @default Number.MAX_SAFE_INTEGER\n */\n max?: number\n /**\n * 入力が受け付ける最小値を指定します。\n *\n * @default Number.MIN_SAFE_INTEGER\n */\n min?: number\n}\n\nconst toLocaleValue = (value?: number, locale?: string, options?: NumberFormatOptions): string | undefined => {\n return value === undefined ? \"\" : value.toLocaleString(locale, options)\n}\n\nexport const NumberField = React.forwardRef<HTMLDivElement, Readonly<NumberFieldProps>>((props, rootRef) => {\n const {\n validationMessages,\n customValidations,\n style,\n className,\n label,\n options,\n onChange,\n defaultValue,\n disabled,\n value: propsValue,\n readOnly: propsReadOnly,\n loading: propsLoading,\n bottomGutter,\n helperText,\n invalid,\n max = Number.MAX_SAFE_INTEGER,\n min = Number.MIN_SAFE_INTEGER,\n step = 1,\n ...others\n } = props\n const locale = useContext(LocaleContext)\n const ref = useRef<HTMLInputElement>(null)\n const [_value, setValue] = useState(propsValue || defaultValue)\n\n const value = useMemo(() => {\n if (defaultValue !== undefined) {\n return _value\n }\n return _value === propsValue ? _value : propsValue\n }, [_value, defaultValue, propsValue])\n\n const validation = useValidation({\n ref,\n validationMessages,\n customValidations,\n value\n })\n\n const [touched, touchedProps] = useDitectInputTouched()\n\n const handleChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n const { value } = event.currentTarget\n setValue(value ? Number(value) : 0)\n if (onChange) {\n onChange(value ? Number(value) : 0, event)\n }\n },\n [onChange, setValue]\n )\n\n const handleWheel: React.WheelEventHandler<HTMLInputElement> = useCallback((event) => {\n event.currentTarget.blur()\n }, [])\n\n const { loading, readOnly } = useFieldGroup({ loading: propsLoading, readOnly: propsReadOnly })\n\n return (\n <FormControl style={style} className={className} ref={rootRef}>\n <InputLabel aria-disabled={disabled} required={props.required} loading={loading}>\n {label}\n </InputLabel>\n <InputBase\n loading={loading}\n disabled={disabled}\n ref={ref}\n type=\"number\"\n displayValue={toLocaleValue(value, locale, options)}\n value={value}\n onChange={handleChange}\n onWheel={handleWheel}\n readOnly={readOnly}\n data-invalid={!validation.valid}\n max={max}\n min={min}\n step={step}\n {...others}\n {...touchedProps}\n />\n {touched && validation.message ? (\n <FormHelperText bottomGutter={bottomGutter} invalid={!validation.valid}>\n {validation.message}\n </FormHelperText>\n ) : (\n <FormHelperText bottomGutter={bottomGutter} invalid={invalid} loading={loading}>\n {typeof helperText === \"function\" ? helperText({ value }) : helperText}\n </FormHelperText>\n )}\n </FormControl>\n )\n})\n"],"file":"NumberField.js"}
1
+ {"version":3,"sources":["../../../src/NumberField/NumberField.tsx"],"names":["toLocaleValue","value","locale","options","undefined","toLocaleString","NumberField","React","forwardRef","props","rootRef","validationMessages","customValidations","style","className","label","onChange","defaultValue","disabled","propsValue","readOnly","propsReadOnly","loading","propsLoading","bottomGutter","helperText","invalid","max","Number","MAX_SAFE_INTEGER","min","MIN_SAFE_INTEGER","step","others","LocaleContext","ref","_value","setValue","validation","touched","touchedProps","handleChange","event","currentTarget","handleWheel","blur","required","valid","message"],"mappings":"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","sourcesContent":["import { ContolledFieldProps, UncontolledFieldProps } from \"../TextField\"\nimport { FormControl } from \"../FormControl\"\nimport { FormHelperText, InputBottomGutterProps } from \"../FormHelperText\"\nimport { InputBase, InputBaseProps } from \"../InputBase\"\nimport { InputLabel } from \"../InputLabel\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { NumberFormatOptions } from \"./NumberFormatOptions\"\nimport { useDitectInputTouched } from \"../TextField/useDitectInputTouched\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useValidation } from \"../TextField/useValidation\"\nimport React, { useCallback, useContext, useMemo, useRef, useState } from \"react\"\n\ninterface CommonNumberFieldProps\n extends Omit<InputBaseProps, \"defaultValue\" | \"value\" | \"onChange\">,\n InputBottomGutterProps {\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/NumberFormat\n */\n options?: NumberFormatOptions\n type?: never\n children?: never\n /**\n * 入力が受け付ける最大値を指定します。\n *\n * @default Number.MAX_SAFE_INTEGER\n */\n max?: number\n /**\n * 入力が受け付ける最小値を指定します。\n *\n * @default Number.MIN_SAFE_INTEGER\n */\n min?: number\n}\n\nexport interface ControlledNumberFieldProps extends CommonNumberFieldProps, ContolledFieldProps<number> {}\nexport interface UncontrolledNumberFieldProps extends CommonNumberFieldProps, UncontolledFieldProps<number> {}\n\nexport type NumberFieldProps = ControlledNumberFieldProps | UncontrolledNumberFieldProps\n\nconst toLocaleValue = (value?: number, locale?: string, options?: NumberFormatOptions): string | undefined => {\n return value === undefined ? \"\" : value.toLocaleString(locale, options)\n}\n\nexport const NumberField = React.forwardRef<HTMLDivElement, Readonly<NumberFieldProps>>((props, rootRef) => {\n const {\n validationMessages,\n customValidations,\n style,\n className,\n label,\n options,\n onChange,\n defaultValue,\n disabled,\n value: propsValue,\n readOnly: propsReadOnly,\n loading: propsLoading,\n bottomGutter,\n helperText,\n invalid,\n max = Number.MAX_SAFE_INTEGER,\n min = Number.MIN_SAFE_INTEGER,\n step = 1,\n ...others\n } = props\n const locale = useContext(LocaleContext)\n const ref = useRef<HTMLInputElement>(null)\n const [_value, setValue] = useState(propsValue || defaultValue)\n\n const value = useMemo(() => {\n if (defaultValue !== undefined) {\n return _value\n }\n return _value === propsValue ? _value : propsValue\n }, [_value, defaultValue, propsValue])\n\n const validation = useValidation({\n ref,\n validationMessages,\n customValidations,\n value\n })\n\n const [touched, touchedProps] = useDitectInputTouched()\n\n const handleChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n const { value } = event.currentTarget\n setValue(value ? Number(value) : 0)\n if (onChange) {\n onChange(value ? Number(value) : 0, event)\n }\n },\n [onChange, setValue]\n )\n\n const handleWheel: React.WheelEventHandler<HTMLInputElement> = useCallback((event) => {\n event.currentTarget.blur()\n }, [])\n\n const { loading, readOnly } = useFieldGroup({ loading: propsLoading, readOnly: propsReadOnly })\n\n return (\n <FormControl style={style} className={className} ref={rootRef}>\n <InputLabel aria-disabled={disabled} required={props.required} loading={loading}>\n {label}\n </InputLabel>\n <InputBase\n loading={loading}\n disabled={disabled}\n ref={ref}\n type=\"number\"\n displayValue={toLocaleValue(value, locale, options)}\n value={value}\n onChange={handleChange}\n onWheel={handleWheel}\n readOnly={readOnly}\n data-invalid={!validation.valid}\n max={max}\n min={min}\n step={step}\n {...others}\n {...touchedProps}\n />\n {touched && validation.message ? (\n <FormHelperText bottomGutter={bottomGutter} invalid={!validation.valid}>\n {validation.message}\n </FormHelperText>\n ) : (\n <FormHelperText bottomGutter={bottomGutter} invalid={invalid} loading={loading}>\n {typeof helperText === \"function\" ? helperText({ value }) : helperText}\n </FormHelperText>\n )}\n </FormControl>\n )\n})\n"],"file":"NumberField.js"}
@@ -24,13 +24,12 @@ const Paper = /*#__PURE__*/_react2.default.forwardRef(({
24
24
  return (0, _react.jsx)("div", _extends({
25
25
  css: /*#__PURE__*/(0, _react.css)({
26
26
  position: "relative",
27
- zIndex: elevation,
28
27
  boxSizing: "border-box",
29
28
  boxShadow: theme.shadows[elevation],
30
29
  backgroundColor: theme.palette.background.paper,
31
30
  color: theme.palette.text.primary,
32
31
  borderRadius: square ? "none" : "5px"
33
- }, process.env.NODE_ENV === "production" ? "" : ";label:Paper;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9QYXBlci9QYXBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0JxQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvUGFwZXIvUGFwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCJcbmltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSBcIi4uL3RoZW1lXCJcbmltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIlxuXG5leHBvcnQgaW50ZXJmYWNlIFBhcGVyUHJvcHMgZXh0ZW5kcyBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4ge1xuICAgIC8qKlxuICAgICAqIFBhcGVy44Gu6KeS44Gr5Li444G/44KS5oyB44Gf44Gb44KL44GL44KS5oyH5a6a44GX44G+44GZ44CCXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgICAqL1xuICAgIHNxdWFyZT86IGJvb2xlYW5cbiAgICAvKipcbiAgICAgKiBQYXBlcuOBruW9seOBrua/g+OBleOBqOmHjeOBquOCiuOCkuaVtOaVsOOBp+aMh+WumuOBl+OBvuOBmeOAguaVsOWApOOBjOmrmOOBhOOBu+OBqeS4iuOBq+mHjeOBquOCiuOAgeW9seOBr+a/g+OBj+OBquOCiuOBvuOBmeOAglxuICAgICAqXG4gICAgICogQGRlZmF1bHQgMVxuICAgICAqL1xuICAgIGVsZXZhdGlvbj86IG51bWJlclxufVxuXG5leHBvcnQgY29uc3QgUGFwZXIgPSBSZWFjdC5mb3J3YXJkUmVmPEhUTUxEaXZFbGVtZW50LCBQYXBlclByb3BzPihcbiAgICAoeyBlbGV2YXRpb24gPSAxLCBzcXVhcmUgPSBmYWxzZSwgLi4ucHJvcHMgfSwgcmVmKSA9PiB7XG4gICAgICAgIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKVxuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICAgIGNzcz17Y3NzKHtcbiAgICAgICAgICAgICAgICAgICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICAgICAgICAgICAgICAgICAgekluZGV4OiBlbGV2YXRpb24sXG4gICAgICAgICAgICAgICAgICAgIGJveFNpemluZzogXCJib3JkZXItYm94XCIsXG4gICAgICAgICAgICAgICAgICAgIGJveFNoYWRvdzogdGhlbWUuc2hhZG93c1tlbGV2YXRpb25dLFxuICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnBhbGV0dGUuYmFja2dyb3VuZC5wYXBlcixcbiAgICAgICAgICAgICAgICAgICAgY29sb3I6IHRoZW1lLnBhbGV0dGUudGV4dC5wcmltYXJ5LFxuICAgICAgICAgICAgICAgICAgICBib3JkZXJSYWRpdXM6IHNxdWFyZSA/IFwibm9uZVwiIDogXCI1cHhcIlxuICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgIHsuLi5wcm9wc31cbiAgICAgICAgICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgICAgIC8+XG4gICAgICAgIClcbiAgICB9XG4pXG4iXX0= */")
32
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Paper;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9QYXBlci9QYXBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0JxQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvUGFwZXIvUGFwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCJcbmltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSBcIi4uL3RoZW1lXCJcbmltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIlxuXG5leHBvcnQgaW50ZXJmYWNlIFBhcGVyUHJvcHMgZXh0ZW5kcyBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4ge1xuICAgIC8qKlxuICAgICAqIFBhcGVy44Gu6KeS44Gr5Li444G/44KS5oyB44Gf44Gb44KL44GL44KS5oyH5a6a44GX44G+44GZ44CCXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgICAqL1xuICAgIHNxdWFyZT86IGJvb2xlYW5cbiAgICAvKipcbiAgICAgKiBQYXBlcuOBruW9seOBrua/g+OBleOBqOmHjeOBquOCiuOCkuaVtOaVsOOBp+aMh+WumuOBl+OBvuOBmeOAguaVsOWApOOBjOmrmOOBhOOBu+OBqeS4iuOBq+mHjeOBquOCiuOAgeW9seOBr+a/g+OBj+OBquOCiuOBvuOBmeOAglxuICAgICAqXG4gICAgICogQGRlZmF1bHQgMVxuICAgICAqL1xuICAgIGVsZXZhdGlvbj86IG51bWJlclxufVxuXG5leHBvcnQgY29uc3QgUGFwZXIgPSBSZWFjdC5mb3J3YXJkUmVmPEhUTUxEaXZFbGVtZW50LCBQYXBlclByb3BzPihcbiAgICAoeyBlbGV2YXRpb24gPSAxLCBzcXVhcmUgPSBmYWxzZSwgLi4ucHJvcHMgfSwgcmVmKSA9PiB7XG4gICAgICAgIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKVxuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICAgIGNzcz17Y3NzKHtcbiAgICAgICAgICAgICAgICAgICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICAgICAgICAgICAgICAgICAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgICAgICAgICAgICAgICAgICAgYm94U2hhZG93OiB0aGVtZS5zaGFkb3dzW2VsZXZhdGlvbl0sXG4gICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUucGFsZXR0ZS5iYWNrZ3JvdW5kLnBhcGVyLFxuICAgICAgICAgICAgICAgICAgICBjb2xvcjogdGhlbWUucGFsZXR0ZS50ZXh0LnByaW1hcnksXG4gICAgICAgICAgICAgICAgICAgIGJvcmRlclJhZGl1czogc3F1YXJlID8gXCJub25lXCIgOiBcIjVweFwiXG4gICAgICAgICAgICAgICAgfSl9XG4gICAgICAgICAgICAgICAgey4uLnByb3BzfVxuICAgICAgICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgKVxuICAgIH1cbilcbiJdfQ== */")
34
33
  }, props, {
35
34
  ref: ref
36
35
  }));
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/Paper/Paper.tsx"],"names":["Paper","React","forwardRef","elevation","square","props","ref","theme","position","zIndex","boxSizing","boxShadow","shadows","backgroundColor","palette","background","paper","color","text","primary","borderRadius"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;;;;;AAiBO,MAAMA,KAAK,gBAAGC,gBAAMC,UAAN,CACjB,CAAC;AAAEC,EAAAA,SAAS,GAAG,CAAd;AAAiBC,EAAAA,MAAM,GAAG,KAA1B;AAAiC,KAAGC;AAApC,CAAD,EAA8CC,GAA9C,KAAsD;AAClD,QAAMC,KAAK,GAAG,sBAAd;AACA,SACI;AACI,IAAA,GAAG,eAAE,gBAAI;AACLC,MAAAA,QAAQ,EAAE,UADL;AAELC,MAAAA,MAAM,EAAEN,SAFH;AAGLO,MAAAA,SAAS,EAAE,YAHN;AAILC,MAAAA,SAAS,EAAEJ,KAAK,CAACK,OAAN,CAAcT,SAAd,CAJN;AAKLU,MAAAA,eAAe,EAAEN,KAAK,CAACO,OAAN,CAAcC,UAAd,CAAyBC,KALrC;AAMLC,MAAAA,KAAK,EAAEV,KAAK,CAACO,OAAN,CAAcI,IAAd,CAAmBC,OANrB;AAOLC,MAAAA,YAAY,EAAEhB,MAAM,GAAG,MAAH,GAAY;AAP3B,KAAJ;AADT,KAUQC,KAVR;AAWI,IAAA,GAAG,EAAEC;AAXT,KADJ;AAeH,CAlBgB,CAAd","sourcesContent":["import { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React from \"react\"\n\nexport interface PaperProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Paperの角に丸みを持たせるかを指定します。\n *\n * @default false\n */\n square?: boolean\n /**\n * Paperの影の濃さと重なりを整数で指定します。数値が高いほど上に重なり、影は濃くなります。\n *\n * @default 1\n */\n elevation?: number\n}\n\nexport const Paper = React.forwardRef<HTMLDivElement, PaperProps>(\n ({ elevation = 1, square = false, ...props }, ref) => {\n const theme = useTheme()\n return (\n <div\n css={css({\n position: \"relative\",\n zIndex: elevation,\n boxSizing: \"border-box\",\n boxShadow: theme.shadows[elevation],\n backgroundColor: theme.palette.background.paper,\n color: theme.palette.text.primary,\n borderRadius: square ? \"none\" : \"5px\"\n })}\n {...props}\n ref={ref}\n />\n )\n }\n)\n"],"file":"Paper.js"}
1
+ {"version":3,"sources":["../../../src/Paper/Paper.tsx"],"names":["Paper","React","forwardRef","elevation","square","props","ref","theme","position","boxSizing","boxShadow","shadows","backgroundColor","palette","background","paper","color","text","primary","borderRadius"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;;;;;AAiBO,MAAMA,KAAK,gBAAGC,gBAAMC,UAAN,CACjB,CAAC;AAAEC,EAAAA,SAAS,GAAG,CAAd;AAAiBC,EAAAA,MAAM,GAAG,KAA1B;AAAiC,KAAGC;AAApC,CAAD,EAA8CC,GAA9C,KAAsD;AAClD,QAAMC,KAAK,GAAG,sBAAd;AACA,SACI;AACI,IAAA,GAAG,eAAE,gBAAI;AACLC,MAAAA,QAAQ,EAAE,UADL;AAELC,MAAAA,SAAS,EAAE,YAFN;AAGLC,MAAAA,SAAS,EAAEH,KAAK,CAACI,OAAN,CAAcR,SAAd,CAHN;AAILS,MAAAA,eAAe,EAAEL,KAAK,CAACM,OAAN,CAAcC,UAAd,CAAyBC,KAJrC;AAKLC,MAAAA,KAAK,EAAET,KAAK,CAACM,OAAN,CAAcI,IAAd,CAAmBC,OALrB;AAMLC,MAAAA,YAAY,EAAEf,MAAM,GAAG,MAAH,GAAY;AAN3B,KAAJ;AADT,KASQC,KATR;AAUI,IAAA,GAAG,EAAEC;AAVT,KADJ;AAcH,CAjBgB,CAAd","sourcesContent":["import { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React from \"react\"\n\nexport interface PaperProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Paperの角に丸みを持たせるかを指定します。\n *\n * @default false\n */\n square?: boolean\n /**\n * Paperの影の濃さと重なりを整数で指定します。数値が高いほど上に重なり、影は濃くなります。\n *\n * @default 1\n */\n elevation?: number\n}\n\nexport const Paper = React.forwardRef<HTMLDivElement, PaperProps>(\n ({ elevation = 1, square = false, ...props }, ref) => {\n const theme = useTheme()\n return (\n <div\n css={css({\n position: \"relative\",\n boxSizing: \"border-box\",\n boxShadow: theme.shadows[elevation],\n backgroundColor: theme.palette.background.paper,\n color: theme.palette.text.primary,\n borderRadius: square ? \"none\" : \"5px\"\n })}\n {...props}\n ref={ref}\n />\n )\n }\n)\n"],"file":"Paper.js"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/TextField/index.tsx"],"names":["TextField","React","forwardRef","label","style","className","onChange","disabled","validationMessages","customValidations","type","bottomGutter","helperText","invalid","loading","propsLoading","readOnly","propsReadonly","props","rootRef","ref","value","setValue","defaultValue","validation","handleChange","event","currentTarget","touched","inputProps","required","valid","message"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;AAyCO,MAAMA,SAAS,gBAAGC,eAAMC,UAAN,CACrB,CACI;AACIC,EAAAA,KADJ;AAEIC,EAAAA,KAFJ;AAGIC,EAAAA,SAHJ;AAIIC,EAAAA,QAJJ;AAKIC,EAAAA,QALJ;AAMIC,EAAAA,kBANJ;AAOIC,EAAAA,iBAPJ;AAQIC,EAAAA,IAAI,GAAG,MARX;AASIC,EAAAA,YATJ;AAUIC,EAAAA,UAVJ;AAWIC,EAAAA,OAXJ;AAYIC,EAAAA,OAAO,EAAEC,YAZb;AAaIC,EAAAA,QAAQ,EAAEC,aAbd;AAcI,KAAGC;AAdP,CADJ,EAiBIC,OAjBJ,KAkBK;AACD,QAAMC,GAAG,GAAG,mBAAyB,IAAzB,CAAZ;AACA,QAAM,CAACC,KAAD,EAAQC,QAAR,IAAoB,qBAASJ,KAAK,CAACG,KAAN,IAAeH,KAAK,CAACK,YAA9B,CAA1B;AACA,QAAMC,UAAU,GAAG,kCAAc;AAC7BJ,IAAAA,GAD6B;AAE7BZ,IAAAA,kBAF6B;AAG7BC,IAAAA,iBAH6B;AAI7BY,IAAAA;AAJ6B,GAAd,CAAnB;AAMA,QAAMI,YAAY,GAAG,wBAChBC,KAAD,IAAgD;AAC5C,UAAM;AAAEL,MAAAA;AAAF,QAAYK,KAAK,CAACC,aAAxB;AACAL,IAAAA,QAAQ,CAACD,KAAD,CAAR;;AACA,QAAIf,QAAJ,EAAc;AACVA,MAAAA,QAAQ,CAACe,KAAD,EAAQK,KAAR,CAAR;AACH;AACJ,GAPgB,EAQjB,CAACpB,QAAD,CARiB,CAArB;AAUA,QAAM,CAACsB,OAAD,EAAUC,UAAV,IAAwB,mDAA9B;AAEA,QAAM;AAAEf,IAAAA,OAAF;AAAWE,IAAAA;AAAX,MAAwB,+BAAc;AAAEF,IAAAA,OAAO,EAAEC,YAAX;AAAyBC,IAAAA,QAAQ,EAAEC;AAAnC,GAAd,CAA9B;AAEA,SACI,iBAAC,wBAAD;AAAa,IAAA,KAAK,EAAEb,KAApB;AAA2B,IAAA,SAAS,EAAEC,SAAtC;AAAiD,IAAA,GAAG,EAAEc;AAAtD,KACI,iBAAC,sBAAD;AAAY,qBAAeZ,QAA3B;AAAqC,IAAA,QAAQ,EAAEW,KAAK,CAACY,QAArD;AAA+D,IAAA,OAAO,EAAEhB;AAAxE,KACKX,KADL,CADJ,EAII,iBAAC,oBAAD;AACI,IAAA,QAAQ,EAAEI,QADd;AAEI,IAAA,OAAO,EAAEO,OAFb;AAGI,IAAA,QAAQ,EAAEE,QAHd;AAII,IAAA,IAAI,EAAEN;AAJV,KAKQQ,KALR;AAMI,IAAA,QAAQ,EAAEO,YANd;AAOI,oBAAc,CAACD,UAAU,CAACO,KAP9B;AAQI,IAAA,GAAG,EAAEX;AART,KASQS,UATR,EAJJ,EAeKD,OAAO,IAAIJ,UAAU,CAACQ,OAAtB,GACG,iBAAC,8BAAD;AAAgB,IAAA,YAAY,EAAErB,YAA9B;AAA4C,IAAA,OAAO,EAAE,CAACa,UAAU,CAACO;AAAjE,KACKP,UAAU,CAACQ,OADhB,CADH,GAKG,iBAAC,8BAAD;AAAgB,IAAA,YAAY,EAAErB,YAA9B;AAA4C,IAAA,OAAO,EAAEE,OAArD;AAA8D,IAAA,OAAO,EAAEC;AAAvE,KACK,OAAOF,UAAP,KAAsB,UAAtB,GAAmCA,UAAU,CAAC;AAAES,IAAAA;AAAF,GAAD,CAA7C,GAA2DT,UADhE,CApBR,CADJ;AA2BH,CArEoB,CAAlB","sourcesContent":["import { FieldGroupProps, useFieldGroup } from \"../FieldGroup\"\nimport { FormControl } from \"../FormControl\"\nimport { FormHelperText, InputBottomGutterProps } from \"../FormHelperText\"\nimport { InputBase, InputBaseProps } from \"../InputBase\"\nimport { InputLabel } from \"../InputLabel\"\nimport { useDitectInputTouched } from \"./useDitectInputTouched\"\nimport { useValidation } from \"./useValidation\"\nimport React, { useCallback, useRef, useState } from \"react\"\n\nexport interface FieldProps<T> extends FieldGroupProps {\n value?: T\n defaultValue?: T\n /**\n * ラベルの文字列を指定します。ラベルは左上に表示されます。\n */\n label?: string\n /**\n * input要素本来のバリデーションに任意のバリデーションを追加することができます。\n */\n customValidations?: Array<(value?: T) => string | undefined | false>\n /**\n * input要素本来のバリーデーションメッセージを変更することができます。\n */\n validationMessages?: {\n [key in keyof ValidityState]?: string\n }\n /**\n * inputの値が更新された場合に発火します。\n *\n * onChangeが呼ばれるタイミングと内部実装の値が変更されるタイミングは異なります。\n * そのため、onChange発火直後にformなどのrefから値を取得しようとするとズレが発生する場合があります。\n */\n onChange?: (value: T, event?: React.SyntheticEvent<HTMLElement>) => void\n /**\n * 任意のヘルパーテキストを挿入できます。ただしinput要素本来のバリデーションの方が優先されます。\n */\n helperText?: React.ReactNode | ((props: { value?: T }) => React.ReactNode)\n /**\n * 任意のヘルパーテキストをinvalidなものとして扱いたい場合に使用できます。\n */\n invalid?: boolean\n}\n\nexport interface TextFieldProps\n extends FieldProps<string>,\n Omit<InputBaseProps, \"value\" | \"onChange\" | \"defaultValue\">,\n InputBottomGutterProps {}\n\nexport const TextField = React.forwardRef<HTMLDivElement, TextFieldProps>(\n (\n {\n label,\n style,\n className,\n onChange,\n disabled,\n validationMessages,\n customValidations,\n type = \"text\",\n bottomGutter,\n helperText,\n invalid,\n loading: propsLoading,\n readOnly: propsReadonly,\n ...props\n },\n rootRef\n ) => {\n const ref = useRef<HTMLInputElement>(null)\n const [value, setValue] = useState(props.value || props.defaultValue)\n const validation = useValidation({\n ref,\n validationMessages,\n customValidations,\n value\n })\n const handleChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n const { value } = event.currentTarget\n setValue(value)\n if (onChange) {\n onChange(value, event)\n }\n },\n [onChange]\n )\n const [touched, inputProps] = useDitectInputTouched()\n\n const { loading, readOnly } = useFieldGroup({ loading: propsLoading, readOnly: propsReadonly })\n\n return (\n <FormControl style={style} className={className} ref={rootRef}>\n <InputLabel aria-disabled={disabled} required={props.required} loading={loading}>\n {label}\n </InputLabel>\n <InputBase\n disabled={disabled}\n loading={loading}\n readOnly={readOnly}\n type={type}\n {...props}\n onChange={handleChange}\n data-invalid={!validation.valid}\n ref={ref}\n {...inputProps}\n />\n {touched && validation.message ? (\n <FormHelperText bottomGutter={bottomGutter} invalid={!validation.valid}>\n {validation.message}\n </FormHelperText>\n ) : (\n <FormHelperText bottomGutter={bottomGutter} invalid={invalid} loading={loading}>\n {typeof helperText === \"function\" ? helperText({ value }) : helperText}\n </FormHelperText>\n )}\n </FormControl>\n )\n }\n)\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../src/TextField/index.tsx"],"names":["TextField","React","forwardRef","label","style","className","onChange","disabled","validationMessages","customValidations","type","bottomGutter","helperText","invalid","loading","propsLoading","readOnly","propsReadonly","props","rootRef","ref","value","setValue","defaultValue","validation","handleChange","event","currentTarget","touched","inputProps","required","valid","message"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;AA+DO,MAAMA,SAAS,gBAAGC,eAAMC,UAAN,CACrB,CACI;AACIC,EAAAA,KADJ;AAEIC,EAAAA,KAFJ;AAGIC,EAAAA,SAHJ;AAIIC,EAAAA,QAJJ;AAKIC,EAAAA,QALJ;AAMIC,EAAAA,kBANJ;AAOIC,EAAAA,iBAPJ;AAQIC,EAAAA,IAAI,GAAG,MARX;AASIC,EAAAA,YATJ;AAUIC,EAAAA,UAVJ;AAWIC,EAAAA,OAXJ;AAYIC,EAAAA,OAAO,EAAEC,YAZb;AAaIC,EAAAA,QAAQ,EAAEC,aAbd;AAcI,KAAGC;AAdP,CADJ,EAiBIC,OAjBJ,KAkBK;AACD,QAAMC,GAAG,GAAG,mBAAyB,IAAzB,CAAZ;AACA,QAAM,CAACC,KAAD,EAAQC,QAAR,IAAoB,qBAASJ,KAAK,CAACG,KAAN,IAAeH,KAAK,CAACK,YAA9B,CAA1B;AACA,QAAMC,UAAU,GAAG,kCAAc;AAC7BJ,IAAAA,GAD6B;AAE7BZ,IAAAA,kBAF6B;AAG7BC,IAAAA,iBAH6B;AAI7BY,IAAAA;AAJ6B,GAAd,CAAnB;AAMA,QAAMI,YAAY,GAAG,wBAChBC,KAAD,IAAgD;AAC5C,UAAM;AAAEL,MAAAA;AAAF,QAAYK,KAAK,CAACC,aAAxB;AACAL,IAAAA,QAAQ,CAACD,KAAD,CAAR;;AACA,QAAIf,QAAJ,EAAc;AACVA,MAAAA,QAAQ,CAACe,KAAD,EAAQK,KAAR,CAAR;AACH;AACJ,GAPgB,EAQjB,CAACpB,QAAD,CARiB,CAArB;AAUA,QAAM,CAACsB,OAAD,EAAUC,UAAV,IAAwB,mDAA9B;AAEA,QAAM;AAAEf,IAAAA,OAAF;AAAWE,IAAAA;AAAX,MAAwB,+BAAc;AAAEF,IAAAA,OAAO,EAAEC,YAAX;AAAyBC,IAAAA,QAAQ,EAAEC;AAAnC,GAAd,CAA9B;AAEA,SACI,iBAAC,wBAAD;AAAa,IAAA,KAAK,EAAEb,KAApB;AAA2B,IAAA,SAAS,EAAEC,SAAtC;AAAiD,IAAA,GAAG,EAAEc;AAAtD,KACI,iBAAC,sBAAD;AAAY,qBAAeZ,QAA3B;AAAqC,IAAA,QAAQ,EAAEW,KAAK,CAACY,QAArD;AAA+D,IAAA,OAAO,EAAEhB;AAAxE,KACKX,KADL,CADJ,EAII,iBAAC,oBAAD;AACI,IAAA,QAAQ,EAAEI,QADd;AAEI,IAAA,OAAO,EAAEO,OAFb;AAGI,IAAA,QAAQ,EAAEE,QAHd;AAII,IAAA,IAAI,EAAEN;AAJV,KAKQQ,KALR;AAMI,IAAA,QAAQ,EAAEO,YANd;AAOI,oBAAc,CAACD,UAAU,CAACO,KAP9B;AAQI,IAAA,GAAG,EAAEX;AART,KASQS,UATR,EAJJ,EAeKD,OAAO,IAAIJ,UAAU,CAACQ,OAAtB,GACG,iBAAC,8BAAD;AAAgB,IAAA,YAAY,EAAErB,YAA9B;AAA4C,IAAA,OAAO,EAAE,CAACa,UAAU,CAACO;AAAjE,KACKP,UAAU,CAACQ,OADhB,CADH,GAKG,iBAAC,8BAAD;AAAgB,IAAA,YAAY,EAAErB,YAA9B;AAA4C,IAAA,OAAO,EAAEE,OAArD;AAA8D,IAAA,OAAO,EAAEC;AAAvE,KACK,OAAOF,UAAP,KAAsB,UAAtB,GAAmCA,UAAU,CAAC;AAAES,IAAAA;AAAF,GAAD,CAA7C,GAA2DT,UADhE,CApBR,CADJ;AA2BH,CArEoB,CAAlB","sourcesContent":["import { FieldGroupProps, useFieldGroup } from \"../FieldGroup\"\nimport { FormControl } from \"../FormControl\"\nimport { FormHelperText, InputBottomGutterProps } from \"../FormHelperText\"\nimport { InputBase, InputBaseProps } from \"../InputBase\"\nimport { InputLabel } from \"../InputLabel\"\nimport { useDitectInputTouched } from \"./useDitectInputTouched\"\nimport { useValidation } from \"./useValidation\"\nimport React, { useCallback, useRef, useState } from \"react\"\n\ninterface CommonFieldProps<T> extends FieldGroupProps {\n /**\n * ラベルの文字列を指定します。ラベルは左上に表示されます。\n */\n label?: string\n /**\n * input要素本来のバリデーションに任意のバリデーションを追加することができます。\n */\n customValidations?: Array<(value?: T) => string | undefined | false>\n /**\n * input要素本来のバリーデーションメッセージを変更することができます。\n */\n validationMessages?: {\n [key in keyof ValidityState]?: string\n }\n\n /**\n * 任意のヘルパーテキストを挿入できます。ただしinput要素本来のバリデーションの方が優先されます。\n */\n helperText?: React.ReactNode | ((props: { value?: T }) => React.ReactNode)\n /**\n * 任意のヘルパーテキストをinvalidなものとして扱いたい場合に使用できます。\n */\n invalid?: boolean\n}\n\n/**\n * 厳密にUncontrolledなFieldコンポーネントとして扱いたい場合は、この型を利用してください。\n */\nexport interface UncontolledFieldProps<T> extends CommonFieldProps<T> {\n defaultValue: T\n value?: never\n onChange?: (value: T, event?: React.SyntheticEvent<HTMLElement>) => void\n}\n\n/**\n * 厳密にControlledなFieldコンポーネントとして扱いたい場合は、この型を利用してください。\n */\nexport interface ContolledFieldProps<T> extends CommonFieldProps<T> {\n defaultValue?: never\n value: T\n onChange: (value: T, event?: React.SyntheticEvent<HTMLElement>) => void\n}\n\nexport interface FieldProps<T> extends CommonFieldProps<T> {\n value?: T\n defaultValue?: T\n /**\n * inputの値が更新された場合に発火します。\n *\n * onChangeが呼ばれるタイミングと内部実装の値が変更されるタイミングは異なります。\n * そのため、onChange発火直後にformなどのrefから値を取得しようとするとズレが発生する場合があります。\n */\n onChange?: (value: T, event?: React.SyntheticEvent<HTMLElement>) => void\n}\n\nexport interface TextFieldProps\n extends FieldProps<string>,\n Omit<InputBaseProps, \"value\" | \"onChange\" | \"defaultValue\">,\n InputBottomGutterProps {}\n\nexport const TextField = React.forwardRef<HTMLDivElement, TextFieldProps>(\n (\n {\n label,\n style,\n className,\n onChange,\n disabled,\n validationMessages,\n customValidations,\n type = \"text\",\n bottomGutter,\n helperText,\n invalid,\n loading: propsLoading,\n readOnly: propsReadonly,\n ...props\n },\n rootRef\n ) => {\n const ref = useRef<HTMLInputElement>(null)\n const [value, setValue] = useState(props.value || props.defaultValue)\n const validation = useValidation({\n ref,\n validationMessages,\n customValidations,\n value\n })\n const handleChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n const { value } = event.currentTarget\n setValue(value)\n if (onChange) {\n onChange(value, event)\n }\n },\n [onChange]\n )\n const [touched, inputProps] = useDitectInputTouched()\n\n const { loading, readOnly } = useFieldGroup({ loading: propsLoading, readOnly: propsReadonly })\n\n return (\n <FormControl style={style} className={className} ref={rootRef}>\n <InputLabel aria-disabled={disabled} required={props.required} loading={loading}>\n {label}\n </InputLabel>\n <InputBase\n disabled={disabled}\n loading={loading}\n readOnly={readOnly}\n type={type}\n {...props}\n onChange={handleChange}\n data-invalid={!validation.valid}\n ref={ref}\n {...inputProps}\n />\n {touched && validation.message ? (\n <FormHelperText bottomGutter={bottomGutter} invalid={!validation.valid}>\n {validation.message}\n </FormHelperText>\n ) : (\n <FormHelperText bottomGutter={bottomGutter} invalid={invalid} loading={loading}>\n {typeof helperText === \"function\" ? helperText({ value }) : helperText}\n </FormHelperText>\n )}\n </FormControl>\n )\n }\n)\n"],"file":"index.js"}
@@ -129,7 +129,7 @@ const Timeline = ({
129
129
  } = getDatesEntries(dates, separators, now);
130
130
  const renderItems = (0, _react2.useMemo)(() => makeRenderItems(item), [item]);
131
131
  return datesEntries.length > 0 ? (0, _react.jsx)("div", props, prevPropsArray.length > 0 && (0, _react.jsx)("div", {
132
- css: /*#__PURE__*/(0, _react.css)("margin-top:", theme.spacing * 2, "px;margin-bottom:", theme.spacing * 2, "px;&:first-of-type{margin-top:0px;}&:last-of-type{margin-bottom:0px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:Timeline;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":[],"mappings":"AA2M4B","file":"../../../src/Timeline/Timeline.tsx","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n    /**\n     * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n     */\n    item: (\n        props: Props & {\n            date: string\n            index: number\n        }\n    ) => JSX.Element\n    /**\n     * 日付と、日付に対応するデータ群を指定します。\n     *\n     * 昇順でkeyがソートされていることを前提としている点に注意してください。\n     *\n     * ソート処理が面倒な場合はUI側での処理を検討します。\n     *\n     * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n     *\n     * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n     *\n     * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n     *\n     */\n    dates: {\n        [date: string]: Props[]\n    }\n    /**\n     * 区分ごとのラベルの表記を指定します。\n     *\n     * @default {year: numeric ,month: numeric, day: numeric}\n     */\n    format?: \"relative\" | Intl.DateTimeFormatOptions\n    /**\n     * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n     *\n     * 原点のデフォルトは\"今日\"。\n     *\n     * 過去から未来へ昇順でソートされていることを前提にしています。\n     * ソート処理が難しい場合はUI側での処理を検討します。\n     *\n     * @default []\n     */\n    separators?: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[]\n    /**\n     * 未対応。このコンポーネントのルート要素を指定する。\n     * @default div\n     */\n    container?: React.ElementType\n    /**\n     * 未対応。区分ごとに表示されるラベル要素を指定する。\n     * @default div\n     */\n    label?: (props: { date: string }) => JSX.Element\n    /**\n     * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n     */\n    labelProps?: BaseTypographyProps\n    /**\n     * 未対応。原点を指定する。\n     *\n     * フォーマットはYYYYMMDDまたは`today`\n     *\n     * number (ms) | Date には対応予定。\n     *\n     * @default today\n     */\n    origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n    dates: {\n        [date: string]: E[]\n    },\n    separators: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[],\n    origin: dayjs.Dayjs\n) => {\n    if (separators.length === 0) {\n        return {\n            prevPropsArray: [],\n            datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n                const diff = dayjs(date).diff(origin, \"day\")\n                return [\n                    date,\n                    propsArray.map((props) => ({\n                        ...props,\n                        date\n                    })),\n                    {\n                        unit: \"day\",\n                        diff\n                    }\n                ] as const\n            })\n        }\n    }\n\n    const copy = { ...dates }\n    // prevProps\n    let prevProps: (E & { date: string })[] = []\n    const min = origin.add(separators[0].value, separators[0].unit)\n    for (const date in copy) {\n        if (dayjs(date).isBefore(min, \"day\")) {\n            const add = copy[date].map((props) => ({ ...props, date }))\n            prevProps = prevProps.concat(add)\n            delete copy[date]\n        } else {\n            break\n        }\n    }\n    let results: (readonly [\n        string,\n        (E & {\n            date: string\n        })[],\n        {\n            unit: string\n            diff: number\n        }\n    ])[] = []\n    separators.map(({ unit, value }, index, original) => {\n        const min = origin.add(value, unit)\n        const max =\n            separators.length - 1 === index\n                ? dayjs(\"9999/12/24\")\n                : origin.add(original[index + 1].value, original[index + 1].unit)\n        let propsArray: (E & { date: string })[] = []\n        for (const date in copy) {\n            if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n                const add = copy[date].map((props) => ({ ...props, date }))\n                propsArray = propsArray.concat(add)\n                delete copy[date]\n            } else {\n                break\n            }\n        }\n        if (propsArray.length > 0) {\n            results = results.concat([\n                [\n                    min.format(\"YYYYMMDD\"),\n                    propsArray,\n                    {\n                        unit,\n                        diff: value\n                    }\n                ]\n            ])\n        }\n    })\n    return {\n        prevPropsArray: prevProps,\n        datesEntries: results\n    }\n}\n\nconst makeRenderItems =\n    <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n    (propsArray: (E & { date: string })[]) => {\n        return propsArray.map((props, index) =>\n            React.cloneElement(renderItem({ ...props, index }), {\n                key: `${props.date}.${index}`\n            })\n        )\n    }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n    item,\n    dates,\n    format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n    separators = [],\n    labelProps,\n    ...props\n}: TimelineProps<E>) => {\n    const locale = useContext(LocaleContext)\n    const rtf = useMemo(() => {\n        return RelativeTimeFormat(locale, {\n            numeric: \"auto\"\n        })\n    }, [locale])\n    const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n    const theme = useTheme()\n    const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n    const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n    return datesEntries.length > 0 ? (\n        <div {...props}>\n            {prevPropsArray.length > 0 && (\n                <div\n                    css={css`\n                        margin-top: ${theme.spacing * 2}px;\n                        margin-bottom: ${theme.spacing * 2}px;\n                        &:first-of-type {\n                            margin-top: 0px;\n                        }\n                        &:last-of-type {\n                            margin-bottom: 0px;\n                        }\n                    `}\n                >\n                    {renderItems(prevPropsArray)}\n                </div>\n            )}\n            {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n                const formatedDate =\n                    format === \"relative\"\n                        ? rtf.format(diff, unit)\n                        : dayjs(value).toDate().toLocaleDateString(locale, format)\n                return (\n                    <React.Fragment key={formatedDate}>\n                        <Typography\n                            css={css`\n                                display: flex;\n                                align-items: center;\n                                margin-top: ${theme.spacing}px;\n                                margin-bottom: ${theme.spacing}px;\n                                &::before,\n                                &::after {\n                                    flex-grow: 1;\n                                    height: 1px;\n                                    content: \"\";\n                                    background-color: currentColor;\n                                }\n                                &::before {\n                                    margin-right: 1rem;\n                                }\n                                &::after {\n                                    margin-left: 1rem;\n                                }\n                            `}\n                            {...labelProps}\n                        >\n                            {formatedDate}\n                        </Typography>\n                        <div\n                            css={css`\n                                margin-top: ${theme.spacing * 2}px;\n                                margin-bottom: ${theme.spacing * 2}px;\n                                &:first-of-type {\n                                    margin-top: 0px;\n                                }\n                                &:last-of-type {\n                                    margin-bottom: 0px;\n                                }\n                            `}\n                        >\n                            {renderItems(propsArray)}\n                        </div>\n                    </React.Fragment>\n                )\n            })}\n        </div>\n    ) : null\n}\n"]} */")
132
+ css: /*#__PURE__*/(0, _react.css)("margin-top:", theme.spacing * 2, "px;margin-bottom:", theme.spacing * 2, "px;&:first-of-type{margin-top:0px;}&:last-of-type{margin-bottom:0px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:Timeline;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":[],"mappings":"AA4M4B","file":"../../../src/Timeline/Timeline.tsx","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\nimport type { Unit } from \"relative-time-format\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n    /**\n     * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n     */\n    item: (\n        props: Props & {\n            date: string\n            index: number\n        }\n    ) => JSX.Element\n    /**\n     * 日付と、日付に対応するデータ群を指定します。\n     *\n     * 昇順でkeyがソートされていることを前提としている点に注意してください。\n     *\n     * ソート処理が面倒な場合はUI側での処理を検討します。\n     *\n     * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n     *\n     * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n     *\n     * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n     *\n     */\n    dates: {\n        [date: string]: Props[]\n    }\n    /**\n     * 区分ごとのラベルの表記を指定します。\n     *\n     * @default {year: numeric ,month: numeric, day: numeric}\n     */\n    format?: \"relative\" | Intl.DateTimeFormatOptions\n    /**\n     * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n     *\n     * 原点のデフォルトは\"今日\"。\n     *\n     * 過去から未来へ昇順でソートされていることを前提にしています。\n     * ソート処理が難しい場合はUI側での処理を検討します。\n     *\n     * @default []\n     */\n    separators?: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[]\n    /**\n     * 未対応。このコンポーネントのルート要素を指定する。\n     * @default div\n     */\n    container?: React.ElementType\n    /**\n     * 未対応。区分ごとに表示されるラベル要素を指定する。\n     * @default div\n     */\n    label?: (props: { date: string }) => JSX.Element\n    /**\n     * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n     */\n    labelProps?: BaseTypographyProps\n    /**\n     * 未対応。原点を指定する。\n     *\n     * フォーマットはYYYYMMDDまたは`today`\n     *\n     * number (ms) | Date には対応予定。\n     *\n     * @default today\n     */\n    origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n    dates: {\n        [date: string]: E[]\n    },\n    separators: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[],\n    origin: dayjs.Dayjs\n) => {\n    if (separators.length === 0) {\n        return {\n            prevPropsArray: [],\n            datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n                const diff = dayjs(date).diff(origin, \"day\")\n                return [\n                    date,\n                    propsArray.map((props) => ({\n                        ...props,\n                        date\n                    })),\n                    {\n                        unit: \"day\",\n                        diff\n                    }\n                ] as const\n            })\n        }\n    }\n\n    const copy = { ...dates }\n    // prevProps\n    let prevProps: (E & { date: string })[] = []\n    const min = origin.add(separators[0].value, separators[0].unit)\n    for (const date in copy) {\n        if (dayjs(date).isBefore(min, \"day\")) {\n            const add = copy[date].map((props) => ({ ...props, date }))\n            prevProps = prevProps.concat(add)\n            delete copy[date]\n        } else {\n            break\n        }\n    }\n    let results: (readonly [\n        string,\n        (E & {\n            date: string\n        })[],\n        {\n            unit: string\n            diff: number\n        }\n    ])[] = []\n    separators.map(({ unit, value }, index, original) => {\n        const min = origin.add(value, unit)\n        const max =\n            separators.length - 1 === index\n                ? dayjs(\"9999/12/24\")\n                : origin.add(original[index + 1].value, original[index + 1].unit)\n        let propsArray: (E & { date: string })[] = []\n        for (const date in copy) {\n            if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n                const add = copy[date].map((props) => ({ ...props, date }))\n                propsArray = propsArray.concat(add)\n                delete copy[date]\n            } else {\n                break\n            }\n        }\n        if (propsArray.length > 0) {\n            results = results.concat([\n                [\n                    min.format(\"YYYYMMDD\"),\n                    propsArray,\n                    {\n                        unit,\n                        diff: value\n                    }\n                ]\n            ])\n        }\n    })\n    return {\n        prevPropsArray: prevProps,\n        datesEntries: results\n    }\n}\n\nconst makeRenderItems =\n    <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n    (propsArray: (E & { date: string })[]) => {\n        return propsArray.map((props, index) =>\n            React.cloneElement(renderItem({ ...props, index }), {\n                key: `${props.date}.${index}`\n            })\n        )\n    }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n    item,\n    dates,\n    format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n    separators = [],\n    labelProps,\n    ...props\n}: TimelineProps<E>) => {\n    const locale = useContext(LocaleContext)\n    const rtf = useMemo(() => {\n        return RelativeTimeFormat(locale, {\n            numeric: \"auto\"\n        })\n    }, [locale])\n    const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n    const theme = useTheme()\n    const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n    const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n    return datesEntries.length > 0 ? (\n        <div {...props}>\n            {prevPropsArray.length > 0 && (\n                <div\n                    css={css`\n                        margin-top: ${theme.spacing * 2}px;\n                        margin-bottom: ${theme.spacing * 2}px;\n                        &:first-of-type {\n                            margin-top: 0px;\n                        }\n                        &:last-of-type {\n                            margin-bottom: 0px;\n                        }\n                    `}\n                >\n                    {renderItems(prevPropsArray)}\n                </div>\n            )}\n            {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n                const formatedDate =\n                    format === \"relative\"\n                        ? rtf.format(diff, unit as Unit)\n                        : dayjs(value).toDate().toLocaleDateString(locale, format)\n                return (\n                    <React.Fragment key={formatedDate}>\n                        <Typography\n                            css={css`\n                                display: flex;\n                                align-items: center;\n                                margin-top: ${theme.spacing}px;\n                                margin-bottom: ${theme.spacing}px;\n                                &::before,\n                                &::after {\n                                    flex-grow: 1;\n                                    height: 1px;\n                                    content: \"\";\n                                    background-color: currentColor;\n                                }\n                                &::before {\n                                    margin-right: 1rem;\n                                }\n                                &::after {\n                                    margin-left: 1rem;\n                                }\n                            `}\n                            {...labelProps}\n                        >\n                            {formatedDate}\n                        </Typography>\n                        <div\n                            css={css`\n                                margin-top: ${theme.spacing * 2}px;\n                                margin-bottom: ${theme.spacing * 2}px;\n                                &:first-of-type {\n                                    margin-top: 0px;\n                                }\n                                &:last-of-type {\n                                    margin-bottom: 0px;\n                                }\n                            `}\n                        >\n                            {renderItems(propsArray)}\n                        </div>\n                    </React.Fragment>\n                )\n            })}\n        </div>\n    ) : null\n}\n"]} */")
133
133
  }, renderItems(prevPropsArray)), datesEntries.map(([value, propsArray, {
134
134
  unit,
135
135
  diff
@@ -138,9 +138,9 @@ const Timeline = ({
138
138
  return (0, _react.jsx)(_react2.default.Fragment, {
139
139
  key: formatedDate
140
140
  }, (0, _react.jsx)(_Typography.Typography, _extends({
141
- css: /*#__PURE__*/(0, _react.css)("display:flex;align-items:center;margin-top:", theme.spacing, "px;margin-bottom:", theme.spacing, "px;&::before,&::after{flex-grow:1;height:1px;content:\"\";background-color:currentColor;}&::before{margin-right:1rem;}&::after{margin-left:1rem;}" + (process.env.NODE_ENV === "production" ? "" : ";label:Timeline;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":[],"mappings":"AAiOoC","file":"../../../src/Timeline/Timeline.tsx","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n    /**\n     * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n     */\n    item: (\n        props: Props & {\n            date: string\n            index: number\n        }\n    ) => JSX.Element\n    /**\n     * 日付と、日付に対応するデータ群を指定します。\n     *\n     * 昇順でkeyがソートされていることを前提としている点に注意してください。\n     *\n     * ソート処理が面倒な場合はUI側での処理を検討します。\n     *\n     * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n     *\n     * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n     *\n     * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n     *\n     */\n    dates: {\n        [date: string]: Props[]\n    }\n    /**\n     * 区分ごとのラベルの表記を指定します。\n     *\n     * @default {year: numeric ,month: numeric, day: numeric}\n     */\n    format?: \"relative\" | Intl.DateTimeFormatOptions\n    /**\n     * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n     *\n     * 原点のデフォルトは\"今日\"。\n     *\n     * 過去から未来へ昇順でソートされていることを前提にしています。\n     * ソート処理が難しい場合はUI側での処理を検討します。\n     *\n     * @default []\n     */\n    separators?: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[]\n    /**\n     * 未対応。このコンポーネントのルート要素を指定する。\n     * @default div\n     */\n    container?: React.ElementType\n    /**\n     * 未対応。区分ごとに表示されるラベル要素を指定する。\n     * @default div\n     */\n    label?: (props: { date: string }) => JSX.Element\n    /**\n     * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n     */\n    labelProps?: BaseTypographyProps\n    /**\n     * 未対応。原点を指定する。\n     *\n     * フォーマットはYYYYMMDDまたは`today`\n     *\n     * number (ms) | Date には対応予定。\n     *\n     * @default today\n     */\n    origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n    dates: {\n        [date: string]: E[]\n    },\n    separators: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[],\n    origin: dayjs.Dayjs\n) => {\n    if (separators.length === 0) {\n        return {\n            prevPropsArray: [],\n            datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n                const diff = dayjs(date).diff(origin, \"day\")\n                return [\n                    date,\n                    propsArray.map((props) => ({\n                        ...props,\n                        date\n                    })),\n                    {\n                        unit: \"day\",\n                        diff\n                    }\n                ] as const\n            })\n        }\n    }\n\n    const copy = { ...dates }\n    // prevProps\n    let prevProps: (E & { date: string })[] = []\n    const min = origin.add(separators[0].value, separators[0].unit)\n    for (const date in copy) {\n        if (dayjs(date).isBefore(min, \"day\")) {\n            const add = copy[date].map((props) => ({ ...props, date }))\n            prevProps = prevProps.concat(add)\n            delete copy[date]\n        } else {\n            break\n        }\n    }\n    let results: (readonly [\n        string,\n        (E & {\n            date: string\n        })[],\n        {\n            unit: string\n            diff: number\n        }\n    ])[] = []\n    separators.map(({ unit, value }, index, original) => {\n        const min = origin.add(value, unit)\n        const max =\n            separators.length - 1 === index\n                ? dayjs(\"9999/12/24\")\n                : origin.add(original[index + 1].value, original[index + 1].unit)\n        let propsArray: (E & { date: string })[] = []\n        for (const date in copy) {\n            if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n                const add = copy[date].map((props) => ({ ...props, date }))\n                propsArray = propsArray.concat(add)\n                delete copy[date]\n            } else {\n                break\n            }\n        }\n        if (propsArray.length > 0) {\n            results = results.concat([\n                [\n                    min.format(\"YYYYMMDD\"),\n                    propsArray,\n                    {\n                        unit,\n                        diff: value\n                    }\n                ]\n            ])\n        }\n    })\n    return {\n        prevPropsArray: prevProps,\n        datesEntries: results\n    }\n}\n\nconst makeRenderItems =\n    <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n    (propsArray: (E & { date: string })[]) => {\n        return propsArray.map((props, index) =>\n            React.cloneElement(renderItem({ ...props, index }), {\n                key: `${props.date}.${index}`\n            })\n        )\n    }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n    item,\n    dates,\n    format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n    separators = [],\n    labelProps,\n    ...props\n}: TimelineProps<E>) => {\n    const locale = useContext(LocaleContext)\n    const rtf = useMemo(() => {\n        return RelativeTimeFormat(locale, {\n            numeric: \"auto\"\n        })\n    }, [locale])\n    const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n    const theme = useTheme()\n    const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n    const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n    return datesEntries.length > 0 ? (\n        <div {...props}>\n            {prevPropsArray.length > 0 && (\n                <div\n                    css={css`\n                        margin-top: ${theme.spacing * 2}px;\n                        margin-bottom: ${theme.spacing * 2}px;\n                        &:first-of-type {\n                            margin-top: 0px;\n                        }\n                        &:last-of-type {\n                            margin-bottom: 0px;\n                        }\n                    `}\n                >\n                    {renderItems(prevPropsArray)}\n                </div>\n            )}\n            {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n                const formatedDate =\n                    format === \"relative\"\n                        ? rtf.format(diff, unit)\n                        : dayjs(value).toDate().toLocaleDateString(locale, format)\n                return (\n                    <React.Fragment key={formatedDate}>\n                        <Typography\n                            css={css`\n                                display: flex;\n                                align-items: center;\n                                margin-top: ${theme.spacing}px;\n                                margin-bottom: ${theme.spacing}px;\n                                &::before,\n                                &::after {\n                                    flex-grow: 1;\n                                    height: 1px;\n                                    content: \"\";\n                                    background-color: currentColor;\n                                }\n                                &::before {\n                                    margin-right: 1rem;\n                                }\n                                &::after {\n                                    margin-left: 1rem;\n                                }\n                            `}\n                            {...labelProps}\n                        >\n                            {formatedDate}\n                        </Typography>\n                        <div\n                            css={css`\n                                margin-top: ${theme.spacing * 2}px;\n                                margin-bottom: ${theme.spacing * 2}px;\n                                &:first-of-type {\n                                    margin-top: 0px;\n                                }\n                                &:last-of-type {\n                                    margin-bottom: 0px;\n                                }\n                            `}\n                        >\n                            {renderItems(propsArray)}\n                        </div>\n                    </React.Fragment>\n                )\n            })}\n        </div>\n    ) : null\n}\n"]} */")
141
+ css: /*#__PURE__*/(0, _react.css)("display:flex;align-items:center;margin-top:", theme.spacing, "px;margin-bottom:", theme.spacing, "px;&::before,&::after{flex-grow:1;height:1px;content:\"\";background-color:currentColor;}&::before{margin-right:1rem;}&::after{margin-left:1rem;}" + (process.env.NODE_ENV === "production" ? "" : ";label:Timeline;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":[],"mappings":"AAkOoC","file":"../../../src/Timeline/Timeline.tsx","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\nimport type { Unit } from \"relative-time-format\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n    /**\n     * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n     */\n    item: (\n        props: Props & {\n            date: string\n            index: number\n        }\n    ) => JSX.Element\n    /**\n     * 日付と、日付に対応するデータ群を指定します。\n     *\n     * 昇順でkeyがソートされていることを前提としている点に注意してください。\n     *\n     * ソート処理が面倒な場合はUI側での処理を検討します。\n     *\n     * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n     *\n     * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n     *\n     * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n     *\n     */\n    dates: {\n        [date: string]: Props[]\n    }\n    /**\n     * 区分ごとのラベルの表記を指定します。\n     *\n     * @default {year: numeric ,month: numeric, day: numeric}\n     */\n    format?: \"relative\" | Intl.DateTimeFormatOptions\n    /**\n     * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n     *\n     * 原点のデフォルトは\"今日\"。\n     *\n     * 過去から未来へ昇順でソートされていることを前提にしています。\n     * ソート処理が難しい場合はUI側での処理を検討します。\n     *\n     * @default []\n     */\n    separators?: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[]\n    /**\n     * 未対応。このコンポーネントのルート要素を指定する。\n     * @default div\n     */\n    container?: React.ElementType\n    /**\n     * 未対応。区分ごとに表示されるラベル要素を指定する。\n     * @default div\n     */\n    label?: (props: { date: string }) => JSX.Element\n    /**\n     * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n     */\n    labelProps?: BaseTypographyProps\n    /**\n     * 未対応。原点を指定する。\n     *\n     * フォーマットはYYYYMMDDまたは`today`\n     *\n     * number (ms) | Date には対応予定。\n     *\n     * @default today\n     */\n    origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n    dates: {\n        [date: string]: E[]\n    },\n    separators: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[],\n    origin: dayjs.Dayjs\n) => {\n    if (separators.length === 0) {\n        return {\n            prevPropsArray: [],\n            datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n                const diff = dayjs(date).diff(origin, \"day\")\n                return [\n                    date,\n                    propsArray.map((props) => ({\n                        ...props,\n                        date\n                    })),\n                    {\n                        unit: \"day\",\n                        diff\n                    }\n                ] as const\n            })\n        }\n    }\n\n    const copy = { ...dates }\n    // prevProps\n    let prevProps: (E & { date: string })[] = []\n    const min = origin.add(separators[0].value, separators[0].unit)\n    for (const date in copy) {\n        if (dayjs(date).isBefore(min, \"day\")) {\n            const add = copy[date].map((props) => ({ ...props, date }))\n            prevProps = prevProps.concat(add)\n            delete copy[date]\n        } else {\n            break\n        }\n    }\n    let results: (readonly [\n        string,\n        (E & {\n            date: string\n        })[],\n        {\n            unit: string\n            diff: number\n        }\n    ])[] = []\n    separators.map(({ unit, value }, index, original) => {\n        const min = origin.add(value, unit)\n        const max =\n            separators.length - 1 === index\n                ? dayjs(\"9999/12/24\")\n                : origin.add(original[index + 1].value, original[index + 1].unit)\n        let propsArray: (E & { date: string })[] = []\n        for (const date in copy) {\n            if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n                const add = copy[date].map((props) => ({ ...props, date }))\n                propsArray = propsArray.concat(add)\n                delete copy[date]\n            } else {\n                break\n            }\n        }\n        if (propsArray.length > 0) {\n            results = results.concat([\n                [\n                    min.format(\"YYYYMMDD\"),\n                    propsArray,\n                    {\n                        unit,\n                        diff: value\n                    }\n                ]\n            ])\n        }\n    })\n    return {\n        prevPropsArray: prevProps,\n        datesEntries: results\n    }\n}\n\nconst makeRenderItems =\n    <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n    (propsArray: (E & { date: string })[]) => {\n        return propsArray.map((props, index) =>\n            React.cloneElement(renderItem({ ...props, index }), {\n                key: `${props.date}.${index}`\n            })\n        )\n    }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n    item,\n    dates,\n    format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n    separators = [],\n    labelProps,\n    ...props\n}: TimelineProps<E>) => {\n    const locale = useContext(LocaleContext)\n    const rtf = useMemo(() => {\n        return RelativeTimeFormat(locale, {\n            numeric: \"auto\"\n        })\n    }, [locale])\n    const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n    const theme = useTheme()\n    const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n    const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n    return datesEntries.length > 0 ? (\n        <div {...props}>\n            {prevPropsArray.length > 0 && (\n                <div\n                    css={css`\n                        margin-top: ${theme.spacing * 2}px;\n                        margin-bottom: ${theme.spacing * 2}px;\n                        &:first-of-type {\n                            margin-top: 0px;\n                        }\n                        &:last-of-type {\n                            margin-bottom: 0px;\n                        }\n                    `}\n                >\n                    {renderItems(prevPropsArray)}\n                </div>\n            )}\n            {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n                const formatedDate =\n                    format === \"relative\"\n                        ? rtf.format(diff, unit as Unit)\n                        : dayjs(value).toDate().toLocaleDateString(locale, format)\n                return (\n                    <React.Fragment key={formatedDate}>\n                        <Typography\n                            css={css`\n                                display: flex;\n                                align-items: center;\n                                margin-top: ${theme.spacing}px;\n                                margin-bottom: ${theme.spacing}px;\n                                &::before,\n                                &::after {\n                                    flex-grow: 1;\n                                    height: 1px;\n                                    content: \"\";\n                                    background-color: currentColor;\n                                }\n                                &::before {\n                                    margin-right: 1rem;\n                                }\n                                &::after {\n                                    margin-left: 1rem;\n                                }\n                            `}\n                            {...labelProps}\n                        >\n                            {formatedDate}\n                        </Typography>\n                        <div\n                            css={css`\n                                margin-top: ${theme.spacing * 2}px;\n                                margin-bottom: ${theme.spacing * 2}px;\n                                &:first-of-type {\n                                    margin-top: 0px;\n                                }\n                                &:last-of-type {\n                                    margin-bottom: 0px;\n                                }\n                            `}\n                        >\n                            {renderItems(propsArray)}\n                        </div>\n                    </React.Fragment>\n                )\n            })}\n        </div>\n    ) : null\n}\n"]} */")
142
142
  }, labelProps), formatedDate), (0, _react.jsx)("div", {
143
- css: /*#__PURE__*/(0, _react.css)("margin-top:", theme.spacing * 2, "px;margin-bottom:", theme.spacing * 2, "px;&:first-of-type{margin-top:0px;}&:last-of-type{margin-bottom:0px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:Timeline;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":[],"mappings":"AAyPoC","file":"../../../src/Timeline/Timeline.tsx","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n    /**\n     * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n     */\n    item: (\n        props: Props & {\n            date: string\n            index: number\n        }\n    ) => JSX.Element\n    /**\n     * 日付と、日付に対応するデータ群を指定します。\n     *\n     * 昇順でkeyがソートされていることを前提としている点に注意してください。\n     *\n     * ソート処理が面倒な場合はUI側での処理を検討します。\n     *\n     * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n     *\n     * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n     *\n     * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n     *\n     */\n    dates: {\n        [date: string]: Props[]\n    }\n    /**\n     * 区分ごとのラベルの表記を指定します。\n     *\n     * @default {year: numeric ,month: numeric, day: numeric}\n     */\n    format?: \"relative\" | Intl.DateTimeFormatOptions\n    /**\n     * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n     *\n     * 原点のデフォルトは\"今日\"。\n     *\n     * 過去から未来へ昇順でソートされていることを前提にしています。\n     * ソート処理が難しい場合はUI側での処理を検討します。\n     *\n     * @default []\n     */\n    separators?: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[]\n    /**\n     * 未対応。このコンポーネントのルート要素を指定する。\n     * @default div\n     */\n    container?: React.ElementType\n    /**\n     * 未対応。区分ごとに表示されるラベル要素を指定する。\n     * @default div\n     */\n    label?: (props: { date: string }) => JSX.Element\n    /**\n     * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n     */\n    labelProps?: BaseTypographyProps\n    /**\n     * 未対応。原点を指定する。\n     *\n     * フォーマットはYYYYMMDDまたは`today`\n     *\n     * number (ms) | Date には対応予定。\n     *\n     * @default today\n     */\n    origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n    dates: {\n        [date: string]: E[]\n    },\n    separators: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[],\n    origin: dayjs.Dayjs\n) => {\n    if (separators.length === 0) {\n        return {\n            prevPropsArray: [],\n            datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n                const diff = dayjs(date).diff(origin, \"day\")\n                return [\n                    date,\n                    propsArray.map((props) => ({\n                        ...props,\n                        date\n                    })),\n                    {\n                        unit: \"day\",\n                        diff\n                    }\n                ] as const\n            })\n        }\n    }\n\n    const copy = { ...dates }\n    // prevProps\n    let prevProps: (E & { date: string })[] = []\n    const min = origin.add(separators[0].value, separators[0].unit)\n    for (const date in copy) {\n        if (dayjs(date).isBefore(min, \"day\")) {\n            const add = copy[date].map((props) => ({ ...props, date }))\n            prevProps = prevProps.concat(add)\n            delete copy[date]\n        } else {\n            break\n        }\n    }\n    let results: (readonly [\n        string,\n        (E & {\n            date: string\n        })[],\n        {\n            unit: string\n            diff: number\n        }\n    ])[] = []\n    separators.map(({ unit, value }, index, original) => {\n        const min = origin.add(value, unit)\n        const max =\n            separators.length - 1 === index\n                ? dayjs(\"9999/12/24\")\n                : origin.add(original[index + 1].value, original[index + 1].unit)\n        let propsArray: (E & { date: string })[] = []\n        for (const date in copy) {\n            if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n                const add = copy[date].map((props) => ({ ...props, date }))\n                propsArray = propsArray.concat(add)\n                delete copy[date]\n            } else {\n                break\n            }\n        }\n        if (propsArray.length > 0) {\n            results = results.concat([\n                [\n                    min.format(\"YYYYMMDD\"),\n                    propsArray,\n                    {\n                        unit,\n                        diff: value\n                    }\n                ]\n            ])\n        }\n    })\n    return {\n        prevPropsArray: prevProps,\n        datesEntries: results\n    }\n}\n\nconst makeRenderItems =\n    <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n    (propsArray: (E & { date: string })[]) => {\n        return propsArray.map((props, index) =>\n            React.cloneElement(renderItem({ ...props, index }), {\n                key: `${props.date}.${index}`\n            })\n        )\n    }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n    item,\n    dates,\n    format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n    separators = [],\n    labelProps,\n    ...props\n}: TimelineProps<E>) => {\n    const locale = useContext(LocaleContext)\n    const rtf = useMemo(() => {\n        return RelativeTimeFormat(locale, {\n            numeric: \"auto\"\n        })\n    }, [locale])\n    const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n    const theme = useTheme()\n    const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n    const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n    return datesEntries.length > 0 ? (\n        <div {...props}>\n            {prevPropsArray.length > 0 && (\n                <div\n                    css={css`\n                        margin-top: ${theme.spacing * 2}px;\n                        margin-bottom: ${theme.spacing * 2}px;\n                        &:first-of-type {\n                            margin-top: 0px;\n                        }\n                        &:last-of-type {\n                            margin-bottom: 0px;\n                        }\n                    `}\n                >\n                    {renderItems(prevPropsArray)}\n                </div>\n            )}\n            {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n                const formatedDate =\n                    format === \"relative\"\n                        ? rtf.format(diff, unit)\n                        : dayjs(value).toDate().toLocaleDateString(locale, format)\n                return (\n                    <React.Fragment key={formatedDate}>\n                        <Typography\n                            css={css`\n                                display: flex;\n                                align-items: center;\n                                margin-top: ${theme.spacing}px;\n                                margin-bottom: ${theme.spacing}px;\n                                &::before,\n                                &::after {\n                                    flex-grow: 1;\n                                    height: 1px;\n                                    content: \"\";\n                                    background-color: currentColor;\n                                }\n                                &::before {\n                                    margin-right: 1rem;\n                                }\n                                &::after {\n                                    margin-left: 1rem;\n                                }\n                            `}\n                            {...labelProps}\n                        >\n                            {formatedDate}\n                        </Typography>\n                        <div\n                            css={css`\n                                margin-top: ${theme.spacing * 2}px;\n                                margin-bottom: ${theme.spacing * 2}px;\n                                &:first-of-type {\n                                    margin-top: 0px;\n                                }\n                                &:last-of-type {\n                                    margin-bottom: 0px;\n                                }\n                            `}\n                        >\n                            {renderItems(propsArray)}\n                        </div>\n                    </React.Fragment>\n                )\n            })}\n        </div>\n    ) : null\n}\n"]} */")
143
+ css: /*#__PURE__*/(0, _react.css)("margin-top:", theme.spacing * 2, "px;margin-bottom:", theme.spacing * 2, "px;&:first-of-type{margin-top:0px;}&:last-of-type{margin-bottom:0px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:Timeline;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":[],"mappings":"AA0PoC","file":"../../../src/Timeline/Timeline.tsx","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\nimport type { Unit } from \"relative-time-format\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n    /**\n     * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n     */\n    item: (\n        props: Props & {\n            date: string\n            index: number\n        }\n    ) => JSX.Element\n    /**\n     * 日付と、日付に対応するデータ群を指定します。\n     *\n     * 昇順でkeyがソートされていることを前提としている点に注意してください。\n     *\n     * ソート処理が面倒な場合はUI側での処理を検討します。\n     *\n     * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n     *\n     * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n     *\n     * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n     *\n     */\n    dates: {\n        [date: string]: Props[]\n    }\n    /**\n     * 区分ごとのラベルの表記を指定します。\n     *\n     * @default {year: numeric ,month: numeric, day: numeric}\n     */\n    format?: \"relative\" | Intl.DateTimeFormatOptions\n    /**\n     * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n     *\n     * 原点のデフォルトは\"今日\"。\n     *\n     * 過去から未来へ昇順でソートされていることを前提にしています。\n     * ソート処理が難しい場合はUI側での処理を検討します。\n     *\n     * @default []\n     */\n    separators?: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[]\n    /**\n     * 未対応。このコンポーネントのルート要素を指定する。\n     * @default div\n     */\n    container?: React.ElementType\n    /**\n     * 未対応。区分ごとに表示されるラベル要素を指定する。\n     * @default div\n     */\n    label?: (props: { date: string }) => JSX.Element\n    /**\n     * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n     */\n    labelProps?: BaseTypographyProps\n    /**\n     * 未対応。原点を指定する。\n     *\n     * フォーマットはYYYYMMDDまたは`today`\n     *\n     * number (ms) | Date には対応予定。\n     *\n     * @default today\n     */\n    origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n    dates: {\n        [date: string]: E[]\n    },\n    separators: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[],\n    origin: dayjs.Dayjs\n) => {\n    if (separators.length === 0) {\n        return {\n            prevPropsArray: [],\n            datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n                const diff = dayjs(date).diff(origin, \"day\")\n                return [\n                    date,\n                    propsArray.map((props) => ({\n                        ...props,\n                        date\n                    })),\n                    {\n                        unit: \"day\",\n                        diff\n                    }\n                ] as const\n            })\n        }\n    }\n\n    const copy = { ...dates }\n    // prevProps\n    let prevProps: (E & { date: string })[] = []\n    const min = origin.add(separators[0].value, separators[0].unit)\n    for (const date in copy) {\n        if (dayjs(date).isBefore(min, \"day\")) {\n            const add = copy[date].map((props) => ({ ...props, date }))\n            prevProps = prevProps.concat(add)\n            delete copy[date]\n        } else {\n            break\n        }\n    }\n    let results: (readonly [\n        string,\n        (E & {\n            date: string\n        })[],\n        {\n            unit: string\n            diff: number\n        }\n    ])[] = []\n    separators.map(({ unit, value }, index, original) => {\n        const min = origin.add(value, unit)\n        const max =\n            separators.length - 1 === index\n                ? dayjs(\"9999/12/24\")\n                : origin.add(original[index + 1].value, original[index + 1].unit)\n        let propsArray: (E & { date: string })[] = []\n        for (const date in copy) {\n            if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n                const add = copy[date].map((props) => ({ ...props, date }))\n                propsArray = propsArray.concat(add)\n                delete copy[date]\n            } else {\n                break\n            }\n        }\n        if (propsArray.length > 0) {\n            results = results.concat([\n                [\n                    min.format(\"YYYYMMDD\"),\n                    propsArray,\n                    {\n                        unit,\n                        diff: value\n                    }\n                ]\n            ])\n        }\n    })\n    return {\n        prevPropsArray: prevProps,\n        datesEntries: results\n    }\n}\n\nconst makeRenderItems =\n    <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n    (propsArray: (E & { date: string })[]) => {\n        return propsArray.map((props, index) =>\n            React.cloneElement(renderItem({ ...props, index }), {\n                key: `${props.date}.${index}`\n            })\n        )\n    }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n    item,\n    dates,\n    format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n    separators = [],\n    labelProps,\n    ...props\n}: TimelineProps<E>) => {\n    const locale = useContext(LocaleContext)\n    const rtf = useMemo(() => {\n        return RelativeTimeFormat(locale, {\n            numeric: \"auto\"\n        })\n    }, [locale])\n    const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n    const theme = useTheme()\n    const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n    const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n    return datesEntries.length > 0 ? (\n        <div {...props}>\n            {prevPropsArray.length > 0 && (\n                <div\n                    css={css`\n                        margin-top: ${theme.spacing * 2}px;\n                        margin-bottom: ${theme.spacing * 2}px;\n                        &:first-of-type {\n                            margin-top: 0px;\n                        }\n                        &:last-of-type {\n                            margin-bottom: 0px;\n                        }\n                    `}\n                >\n                    {renderItems(prevPropsArray)}\n                </div>\n            )}\n            {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n                const formatedDate =\n                    format === \"relative\"\n                        ? rtf.format(diff, unit as Unit)\n                        : dayjs(value).toDate().toLocaleDateString(locale, format)\n                return (\n                    <React.Fragment key={formatedDate}>\n                        <Typography\n                            css={css`\n                                display: flex;\n                                align-items: center;\n                                margin-top: ${theme.spacing}px;\n                                margin-bottom: ${theme.spacing}px;\n                                &::before,\n                                &::after {\n                                    flex-grow: 1;\n                                    height: 1px;\n                                    content: \"\";\n                                    background-color: currentColor;\n                                }\n                                &::before {\n                                    margin-right: 1rem;\n                                }\n                                &::after {\n                                    margin-left: 1rem;\n                                }\n                            `}\n                            {...labelProps}\n                        >\n                            {formatedDate}\n                        </Typography>\n                        <div\n                            css={css`\n                                margin-top: ${theme.spacing * 2}px;\n                                margin-bottom: ${theme.spacing * 2}px;\n                                &:first-of-type {\n                                    margin-top: 0px;\n                                }\n                                &:last-of-type {\n                                    margin-bottom: 0px;\n                                }\n                            `}\n                        >\n                            {renderItems(propsArray)}\n                        </div>\n                    </React.Fragment>\n                )\n            })}\n        </div>\n    ) : null\n}\n"]} */")
144
144
  }, renderItems(propsArray)));
145
145
  })) : null;
146
146
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":["getDatesEntries","dates","separators","origin","length","prevPropsArray","datesEntries","Object","entries","map","date","propsArray","diff","props","unit","copy","prevProps","min","add","value","isBefore","concat","results","index","original","max","isBetween","format","makeRenderItems","renderItem","React","cloneElement","key","Timeline","item","year","month","day","labelProps","locale","LocaleContext","rtf","numeric","now","theme","renderItems","css","spacing","formatedDate","toDate","toLocaleDateString"],"mappings":"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","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n */\n item: (\n props: Props & {\n date: string\n index: number\n }\n ) => JSX.Element\n /**\n * 日付と、日付に対応するデータ群を指定します。\n *\n * 昇順でkeyがソートされていることを前提としている点に注意してください。\n *\n * ソート処理が面倒な場合はUI側での処理を検討します。\n *\n * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n *\n * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n *\n * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n *\n */\n dates: {\n [date: string]: Props[]\n }\n /**\n * 区分ごとのラベルの表記を指定します。\n *\n * @default {year: numeric ,month: numeric, day: numeric}\n */\n format?: \"relative\" | Intl.DateTimeFormatOptions\n /**\n * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n *\n * 原点のデフォルトは\"今日\"。\n *\n * 過去から未来へ昇順でソートされていることを前提にしています。\n * ソート処理が難しい場合はUI側での処理を検討します。\n *\n * @default []\n */\n separators?: {\n unit: \"day\" | \"month\" | \"year\" | \"week\"\n value: number\n }[]\n /**\n * 未対応。このコンポーネントのルート要素を指定する。\n * @default div\n */\n container?: React.ElementType\n /**\n * 未対応。区分ごとに表示されるラベル要素を指定する。\n * @default div\n */\n label?: (props: { date: string }) => JSX.Element\n /**\n * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n */\n labelProps?: BaseTypographyProps\n /**\n * 未対応。原点を指定する。\n *\n * フォーマットはYYYYMMDDまたは`today`\n *\n * number (ms) | Date には対応予定。\n *\n * @default today\n */\n origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n dates: {\n [date: string]: E[]\n },\n separators: {\n unit: \"day\" | \"month\" | \"year\" | \"week\"\n value: number\n }[],\n origin: dayjs.Dayjs\n) => {\n if (separators.length === 0) {\n return {\n prevPropsArray: [],\n datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n const diff = dayjs(date).diff(origin, \"day\")\n return [\n date,\n propsArray.map((props) => ({\n ...props,\n date\n })),\n {\n unit: \"day\",\n diff\n }\n ] as const\n })\n }\n }\n\n const copy = { ...dates }\n // prevProps\n let prevProps: (E & { date: string })[] = []\n const min = origin.add(separators[0].value, separators[0].unit)\n for (const date in copy) {\n if (dayjs(date).isBefore(min, \"day\")) {\n const add = copy[date].map((props) => ({ ...props, date }))\n prevProps = prevProps.concat(add)\n delete copy[date]\n } else {\n break\n }\n }\n let results: (readonly [\n string,\n (E & {\n date: string\n })[],\n {\n unit: string\n diff: number\n }\n ])[] = []\n separators.map(({ unit, value }, index, original) => {\n const min = origin.add(value, unit)\n const max =\n separators.length - 1 === index\n ? dayjs(\"9999/12/24\")\n : origin.add(original[index + 1].value, original[index + 1].unit)\n let propsArray: (E & { date: string })[] = []\n for (const date in copy) {\n if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n const add = copy[date].map((props) => ({ ...props, date }))\n propsArray = propsArray.concat(add)\n delete copy[date]\n } else {\n break\n }\n }\n if (propsArray.length > 0) {\n results = results.concat([\n [\n min.format(\"YYYYMMDD\"),\n propsArray,\n {\n unit,\n diff: value\n }\n ]\n ])\n }\n })\n return {\n prevPropsArray: prevProps,\n datesEntries: results\n }\n}\n\nconst makeRenderItems =\n <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n (propsArray: (E & { date: string })[]) => {\n return propsArray.map((props, index) =>\n React.cloneElement(renderItem({ ...props, index }), {\n key: `${props.date}.${index}`\n })\n )\n }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n item,\n dates,\n format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n separators = [],\n labelProps,\n ...props\n}: TimelineProps<E>) => {\n const locale = useContext(LocaleContext)\n const rtf = useMemo(() => {\n return RelativeTimeFormat(locale, {\n numeric: \"auto\"\n })\n }, [locale])\n const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n const theme = useTheme()\n const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n return datesEntries.length > 0 ? (\n <div {...props}>\n {prevPropsArray.length > 0 && (\n <div\n css={css`\n margin-top: ${theme.spacing * 2}px;\n margin-bottom: ${theme.spacing * 2}px;\n &:first-of-type {\n margin-top: 0px;\n }\n &:last-of-type {\n margin-bottom: 0px;\n }\n `}\n >\n {renderItems(prevPropsArray)}\n </div>\n )}\n {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n const formatedDate =\n format === \"relative\"\n ? rtf.format(diff, unit)\n : dayjs(value).toDate().toLocaleDateString(locale, format)\n return (\n <React.Fragment key={formatedDate}>\n <Typography\n css={css`\n display: flex;\n align-items: center;\n margin-top: ${theme.spacing}px;\n margin-bottom: ${theme.spacing}px;\n &::before,\n &::after {\n flex-grow: 1;\n height: 1px;\n content: \"\";\n background-color: currentColor;\n }\n &::before {\n margin-right: 1rem;\n }\n &::after {\n margin-left: 1rem;\n }\n `}\n {...labelProps}\n >\n {formatedDate}\n </Typography>\n <div\n css={css`\n margin-top: ${theme.spacing * 2}px;\n margin-bottom: ${theme.spacing * 2}px;\n &:first-of-type {\n margin-top: 0px;\n }\n &:last-of-type {\n margin-bottom: 0px;\n }\n `}\n >\n {renderItems(propsArray)}\n </div>\n </React.Fragment>\n )\n })}\n </div>\n ) : null\n}\n"],"file":"Timeline.js"}
1
+ {"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":["getDatesEntries","dates","separators","origin","length","prevPropsArray","datesEntries","Object","entries","map","date","propsArray","diff","props","unit","copy","prevProps","min","add","value","isBefore","concat","results","index","original","max","isBetween","format","makeRenderItems","renderItem","React","cloneElement","key","Timeline","item","year","month","day","labelProps","locale","LocaleContext","rtf","numeric","now","theme","renderItems","css","spacing","formatedDate","toDate","toLocaleDateString"],"mappings":"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","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\nimport type { Unit } from \"relative-time-format\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n */\n item: (\n props: Props & {\n date: string\n index: number\n }\n ) => JSX.Element\n /**\n * 日付と、日付に対応するデータ群を指定します。\n *\n * 昇順でkeyがソートされていることを前提としている点に注意してください。\n *\n * ソート処理が面倒な場合はUI側での処理を検討します。\n *\n * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n *\n * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n *\n * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n *\n */\n dates: {\n [date: string]: Props[]\n }\n /**\n * 区分ごとのラベルの表記を指定します。\n *\n * @default {year: numeric ,month: numeric, day: numeric}\n */\n format?: \"relative\" | Intl.DateTimeFormatOptions\n /**\n * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n *\n * 原点のデフォルトは\"今日\"。\n *\n * 過去から未来へ昇順でソートされていることを前提にしています。\n * ソート処理が難しい場合はUI側での処理を検討します。\n *\n * @default []\n */\n separators?: {\n unit: \"day\" | \"month\" | \"year\" | \"week\"\n value: number\n }[]\n /**\n * 未対応。このコンポーネントのルート要素を指定する。\n * @default div\n */\n container?: React.ElementType\n /**\n * 未対応。区分ごとに表示されるラベル要素を指定する。\n * @default div\n */\n label?: (props: { date: string }) => JSX.Element\n /**\n * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n */\n labelProps?: BaseTypographyProps\n /**\n * 未対応。原点を指定する。\n *\n * フォーマットはYYYYMMDDまたは`today`\n *\n * number (ms) | Date には対応予定。\n *\n * @default today\n */\n origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n dates: {\n [date: string]: E[]\n },\n separators: {\n unit: \"day\" | \"month\" | \"year\" | \"week\"\n value: number\n }[],\n origin: dayjs.Dayjs\n) => {\n if (separators.length === 0) {\n return {\n prevPropsArray: [],\n datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n const diff = dayjs(date).diff(origin, \"day\")\n return [\n date,\n propsArray.map((props) => ({\n ...props,\n date\n })),\n {\n unit: \"day\",\n diff\n }\n ] as const\n })\n }\n }\n\n const copy = { ...dates }\n // prevProps\n let prevProps: (E & { date: string })[] = []\n const min = origin.add(separators[0].value, separators[0].unit)\n for (const date in copy) {\n if (dayjs(date).isBefore(min, \"day\")) {\n const add = copy[date].map((props) => ({ ...props, date }))\n prevProps = prevProps.concat(add)\n delete copy[date]\n } else {\n break\n }\n }\n let results: (readonly [\n string,\n (E & {\n date: string\n })[],\n {\n unit: string\n diff: number\n }\n ])[] = []\n separators.map(({ unit, value }, index, original) => {\n const min = origin.add(value, unit)\n const max =\n separators.length - 1 === index\n ? dayjs(\"9999/12/24\")\n : origin.add(original[index + 1].value, original[index + 1].unit)\n let propsArray: (E & { date: string })[] = []\n for (const date in copy) {\n if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n const add = copy[date].map((props) => ({ ...props, date }))\n propsArray = propsArray.concat(add)\n delete copy[date]\n } else {\n break\n }\n }\n if (propsArray.length > 0) {\n results = results.concat([\n [\n min.format(\"YYYYMMDD\"),\n propsArray,\n {\n unit,\n diff: value\n }\n ]\n ])\n }\n })\n return {\n prevPropsArray: prevProps,\n datesEntries: results\n }\n}\n\nconst makeRenderItems =\n <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n (propsArray: (E & { date: string })[]) => {\n return propsArray.map((props, index) =>\n React.cloneElement(renderItem({ ...props, index }), {\n key: `${props.date}.${index}`\n })\n )\n }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n item,\n dates,\n format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n separators = [],\n labelProps,\n ...props\n}: TimelineProps<E>) => {\n const locale = useContext(LocaleContext)\n const rtf = useMemo(() => {\n return RelativeTimeFormat(locale, {\n numeric: \"auto\"\n })\n }, [locale])\n const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n const theme = useTheme()\n const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n return datesEntries.length > 0 ? (\n <div {...props}>\n {prevPropsArray.length > 0 && (\n <div\n css={css`\n margin-top: ${theme.spacing * 2}px;\n margin-bottom: ${theme.spacing * 2}px;\n &:first-of-type {\n margin-top: 0px;\n }\n &:last-of-type {\n margin-bottom: 0px;\n }\n `}\n >\n {renderItems(prevPropsArray)}\n </div>\n )}\n {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n const formatedDate =\n format === \"relative\"\n ? rtf.format(diff, unit as Unit)\n : dayjs(value).toDate().toLocaleDateString(locale, format)\n return (\n <React.Fragment key={formatedDate}>\n <Typography\n css={css`\n display: flex;\n align-items: center;\n margin-top: ${theme.spacing}px;\n margin-bottom: ${theme.spacing}px;\n &::before,\n &::after {\n flex-grow: 1;\n height: 1px;\n content: \"\";\n background-color: currentColor;\n }\n &::before {\n margin-right: 1rem;\n }\n &::after {\n margin-left: 1rem;\n }\n `}\n {...labelProps}\n >\n {formatedDate}\n </Typography>\n <div\n css={css`\n margin-top: ${theme.spacing * 2}px;\n margin-bottom: ${theme.spacing * 2}px;\n &:first-of-type {\n margin-top: 0px;\n }\n &:last-of-type {\n margin-bottom: 0px;\n }\n `}\n >\n {renderItems(propsArray)}\n </div>\n </React.Fragment>\n )\n })}\n </div>\n ) : null\n}\n"],"file":"Timeline.js"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/NumberField/NumberField.tsx"],"names":["FormControl","FormHelperText","InputBase","InputLabel","LocaleContext","useDitectInputTouched","useFieldGroup","useValidation","React","useCallback","useContext","useMemo","useRef","useState","toLocaleValue","value","locale","options","undefined","toLocaleString","NumberField","forwardRef","props","rootRef","validationMessages","customValidations","style","className","label","onChange","defaultValue","disabled","propsValue","readOnly","propsReadOnly","loading","propsLoading","bottomGutter","helperText","invalid","max","Number","MAX_SAFE_INTEGER","min","MIN_SAFE_INTEGER","step","others","ref","_value","setValue","validation","touched","touchedProps","handleChange","event","currentTarget","handleWheel","blur","required","valid","message"],"mappings":"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","sourcesContent":["import { FieldProps } from \"../TextField\"\nimport { FormControl } from \"../FormControl\"\nimport { FormHelperText, InputBottomGutterProps } from \"../FormHelperText\"\nimport { InputBase, InputBaseProps } from \"../InputBase\"\nimport { InputLabel } from \"../InputLabel\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { NumberFormatOptions } from \"./NumberFormatOptions\"\nimport { useDitectInputTouched } from \"../TextField/useDitectInputTouched\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useValidation } from \"../TextField/useValidation\"\nimport React, { useCallback, useContext, useMemo, useRef, useState } from \"react\"\n\nexport interface NumberFieldProps\n extends FieldProps<number>,\n Omit<InputBaseProps, \"defaultValue\" | \"value\" | \"onChange\">,\n InputBottomGutterProps {\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/NumberFormat\n */\n options?: NumberFormatOptions\n type?: never\n children?: never\n /**\n * 入力が受け付ける最大値を指定します。\n *\n * @default Number.MAX_SAFE_INTEGER\n */\n max?: number\n /**\n * 入力が受け付ける最小値を指定します。\n *\n * @default Number.MIN_SAFE_INTEGER\n */\n min?: number\n}\n\nconst toLocaleValue = (value?: number, locale?: string, options?: NumberFormatOptions): string | undefined => {\n return value === undefined ? \"\" : value.toLocaleString(locale, options)\n}\n\nexport const NumberField = React.forwardRef<HTMLDivElement, Readonly<NumberFieldProps>>((props, rootRef) => {\n const {\n validationMessages,\n customValidations,\n style,\n className,\n label,\n options,\n onChange,\n defaultValue,\n disabled,\n value: propsValue,\n readOnly: propsReadOnly,\n loading: propsLoading,\n bottomGutter,\n helperText,\n invalid,\n max = Number.MAX_SAFE_INTEGER,\n min = Number.MIN_SAFE_INTEGER,\n step = 1,\n ...others\n } = props\n const locale = useContext(LocaleContext)\n const ref = useRef<HTMLInputElement>(null)\n const [_value, setValue] = useState(propsValue || defaultValue)\n\n const value = useMemo(() => {\n if (defaultValue !== undefined) {\n return _value\n }\n return _value === propsValue ? _value : propsValue\n }, [_value, defaultValue, propsValue])\n\n const validation = useValidation({\n ref,\n validationMessages,\n customValidations,\n value\n })\n\n const [touched, touchedProps] = useDitectInputTouched()\n\n const handleChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n const { value } = event.currentTarget\n setValue(value ? Number(value) : 0)\n if (onChange) {\n onChange(value ? Number(value) : 0, event)\n }\n },\n [onChange, setValue]\n )\n\n const handleWheel: React.WheelEventHandler<HTMLInputElement> = useCallback((event) => {\n event.currentTarget.blur()\n }, [])\n\n const { loading, readOnly } = useFieldGroup({ loading: propsLoading, readOnly: propsReadOnly })\n\n return (\n <FormControl style={style} className={className} ref={rootRef}>\n <InputLabel aria-disabled={disabled} required={props.required} loading={loading}>\n {label}\n </InputLabel>\n <InputBase\n loading={loading}\n disabled={disabled}\n ref={ref}\n type=\"number\"\n displayValue={toLocaleValue(value, locale, options)}\n value={value}\n onChange={handleChange}\n onWheel={handleWheel}\n readOnly={readOnly}\n data-invalid={!validation.valid}\n max={max}\n min={min}\n step={step}\n {...others}\n {...touchedProps}\n />\n {touched && validation.message ? (\n <FormHelperText bottomGutter={bottomGutter} invalid={!validation.valid}>\n {validation.message}\n </FormHelperText>\n ) : (\n <FormHelperText bottomGutter={bottomGutter} invalid={invalid} loading={loading}>\n {typeof helperText === \"function\" ? helperText({ value }) : helperText}\n </FormHelperText>\n )}\n </FormControl>\n )\n})\n"],"file":"NumberField.js"}
1
+ {"version":3,"sources":["../../../src/NumberField/NumberField.tsx"],"names":["FormControl","FormHelperText","InputBase","InputLabel","LocaleContext","useDitectInputTouched","useFieldGroup","useValidation","React","useCallback","useContext","useMemo","useRef","useState","toLocaleValue","value","locale","options","undefined","toLocaleString","NumberField","forwardRef","props","rootRef","validationMessages","customValidations","style","className","label","onChange","defaultValue","disabled","propsValue","readOnly","propsReadOnly","loading","propsLoading","bottomGutter","helperText","invalid","max","Number","MAX_SAFE_INTEGER","min","MIN_SAFE_INTEGER","step","others","ref","_value","setValue","validation","touched","touchedProps","handleChange","event","currentTarget","handleWheel","blur","required","valid","message"],"mappings":"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","sourcesContent":["import { ContolledFieldProps, UncontolledFieldProps } from \"../TextField\"\nimport { FormControl } from \"../FormControl\"\nimport { FormHelperText, InputBottomGutterProps } from \"../FormHelperText\"\nimport { InputBase, InputBaseProps } from \"../InputBase\"\nimport { InputLabel } from \"../InputLabel\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { NumberFormatOptions } from \"./NumberFormatOptions\"\nimport { useDitectInputTouched } from \"../TextField/useDitectInputTouched\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useValidation } from \"../TextField/useValidation\"\nimport React, { useCallback, useContext, useMemo, useRef, useState } from \"react\"\n\ninterface CommonNumberFieldProps\n extends Omit<InputBaseProps, \"defaultValue\" | \"value\" | \"onChange\">,\n InputBottomGutterProps {\n /**\n * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/NumberFormat\n */\n options?: NumberFormatOptions\n type?: never\n children?: never\n /**\n * 入力が受け付ける最大値を指定します。\n *\n * @default Number.MAX_SAFE_INTEGER\n */\n max?: number\n /**\n * 入力が受け付ける最小値を指定します。\n *\n * @default Number.MIN_SAFE_INTEGER\n */\n min?: number\n}\n\nexport interface ControlledNumberFieldProps extends CommonNumberFieldProps, ContolledFieldProps<number> {}\nexport interface UncontrolledNumberFieldProps extends CommonNumberFieldProps, UncontolledFieldProps<number> {}\n\nexport type NumberFieldProps = ControlledNumberFieldProps | UncontrolledNumberFieldProps\n\nconst toLocaleValue = (value?: number, locale?: string, options?: NumberFormatOptions): string | undefined => {\n return value === undefined ? \"\" : value.toLocaleString(locale, options)\n}\n\nexport const NumberField = React.forwardRef<HTMLDivElement, Readonly<NumberFieldProps>>((props, rootRef) => {\n const {\n validationMessages,\n customValidations,\n style,\n className,\n label,\n options,\n onChange,\n defaultValue,\n disabled,\n value: propsValue,\n readOnly: propsReadOnly,\n loading: propsLoading,\n bottomGutter,\n helperText,\n invalid,\n max = Number.MAX_SAFE_INTEGER,\n min = Number.MIN_SAFE_INTEGER,\n step = 1,\n ...others\n } = props\n const locale = useContext(LocaleContext)\n const ref = useRef<HTMLInputElement>(null)\n const [_value, setValue] = useState(propsValue || defaultValue)\n\n const value = useMemo(() => {\n if (defaultValue !== undefined) {\n return _value\n }\n return _value === propsValue ? _value : propsValue\n }, [_value, defaultValue, propsValue])\n\n const validation = useValidation({\n ref,\n validationMessages,\n customValidations,\n value\n })\n\n const [touched, touchedProps] = useDitectInputTouched()\n\n const handleChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n const { value } = event.currentTarget\n setValue(value ? Number(value) : 0)\n if (onChange) {\n onChange(value ? Number(value) : 0, event)\n }\n },\n [onChange, setValue]\n )\n\n const handleWheel: React.WheelEventHandler<HTMLInputElement> = useCallback((event) => {\n event.currentTarget.blur()\n }, [])\n\n const { loading, readOnly } = useFieldGroup({ loading: propsLoading, readOnly: propsReadOnly })\n\n return (\n <FormControl style={style} className={className} ref={rootRef}>\n <InputLabel aria-disabled={disabled} required={props.required} loading={loading}>\n {label}\n </InputLabel>\n <InputBase\n loading={loading}\n disabled={disabled}\n ref={ref}\n type=\"number\"\n displayValue={toLocaleValue(value, locale, options)}\n value={value}\n onChange={handleChange}\n onWheel={handleWheel}\n readOnly={readOnly}\n data-invalid={!validation.valid}\n max={max}\n min={min}\n step={step}\n {...others}\n {...touchedProps}\n />\n {touched && validation.message ? (\n <FormHelperText bottomGutter={bottomGutter} invalid={!validation.valid}>\n {validation.message}\n </FormHelperText>\n ) : (\n <FormHelperText bottomGutter={bottomGutter} invalid={invalid} loading={loading}>\n {typeof helperText === \"function\" ? helperText({ value }) : helperText}\n </FormHelperText>\n )}\n </FormControl>\n )\n})\n"],"file":"NumberField.js"}
@@ -21,13 +21,12 @@ export var Paper = /*#__PURE__*/React.forwardRef((_ref, ref) => {
21
21
  return ___EmotionJSX("div", _extends({
22
22
  css: /*#__PURE__*/css({
23
23
  position: "relative",
24
- zIndex: elevation,
25
24
  boxSizing: "border-box",
26
25
  boxShadow: theme.shadows[elevation],
27
26
  backgroundColor: theme.palette.background.paper,
28
27
  color: theme.palette.text.primary,
29
28
  borderRadius: square ? "none" : "5px"
30
- }, process.env.NODE_ENV === "production" ? "" : ";label:Paper;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9QYXBlci9QYXBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0JxQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvUGFwZXIvUGFwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCJcbmltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSBcIi4uL3RoZW1lXCJcbmltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIlxuXG5leHBvcnQgaW50ZXJmYWNlIFBhcGVyUHJvcHMgZXh0ZW5kcyBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4ge1xuICAgIC8qKlxuICAgICAqIFBhcGVy44Gu6KeS44Gr5Li444G/44KS5oyB44Gf44Gb44KL44GL44KS5oyH5a6a44GX44G+44GZ44CCXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgICAqL1xuICAgIHNxdWFyZT86IGJvb2xlYW5cbiAgICAvKipcbiAgICAgKiBQYXBlcuOBruW9seOBrua/g+OBleOBqOmHjeOBquOCiuOCkuaVtOaVsOOBp+aMh+WumuOBl+OBvuOBmeOAguaVsOWApOOBjOmrmOOBhOOBu+OBqeS4iuOBq+mHjeOBquOCiuOAgeW9seOBr+a/g+OBj+OBquOCiuOBvuOBmeOAglxuICAgICAqXG4gICAgICogQGRlZmF1bHQgMVxuICAgICAqL1xuICAgIGVsZXZhdGlvbj86IG51bWJlclxufVxuXG5leHBvcnQgY29uc3QgUGFwZXIgPSBSZWFjdC5mb3J3YXJkUmVmPEhUTUxEaXZFbGVtZW50LCBQYXBlclByb3BzPihcbiAgICAoeyBlbGV2YXRpb24gPSAxLCBzcXVhcmUgPSBmYWxzZSwgLi4ucHJvcHMgfSwgcmVmKSA9PiB7XG4gICAgICAgIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKVxuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICAgIGNzcz17Y3NzKHtcbiAgICAgICAgICAgICAgICAgICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICAgICAgICAgICAgICAgICAgekluZGV4OiBlbGV2YXRpb24sXG4gICAgICAgICAgICAgICAgICAgIGJveFNpemluZzogXCJib3JkZXItYm94XCIsXG4gICAgICAgICAgICAgICAgICAgIGJveFNoYWRvdzogdGhlbWUuc2hhZG93c1tlbGV2YXRpb25dLFxuICAgICAgICAgICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnBhbGV0dGUuYmFja2dyb3VuZC5wYXBlcixcbiAgICAgICAgICAgICAgICAgICAgY29sb3I6IHRoZW1lLnBhbGV0dGUudGV4dC5wcmltYXJ5LFxuICAgICAgICAgICAgICAgICAgICBib3JkZXJSYWRpdXM6IHNxdWFyZSA/IFwibm9uZVwiIDogXCI1cHhcIlxuICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgIHsuLi5wcm9wc31cbiAgICAgICAgICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgICAgIC8+XG4gICAgICAgIClcbiAgICB9XG4pXG4iXX0= */")
29
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Paper;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9QYXBlci9QYXBlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0JxQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvUGFwZXIvUGFwZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCJcbmltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSBcIi4uL3RoZW1lXCJcbmltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIlxuXG5leHBvcnQgaW50ZXJmYWNlIFBhcGVyUHJvcHMgZXh0ZW5kcyBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4ge1xuICAgIC8qKlxuICAgICAqIFBhcGVy44Gu6KeS44Gr5Li444G/44KS5oyB44Gf44Gb44KL44GL44KS5oyH5a6a44GX44G+44GZ44CCXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgICAqL1xuICAgIHNxdWFyZT86IGJvb2xlYW5cbiAgICAvKipcbiAgICAgKiBQYXBlcuOBruW9seOBrua/g+OBleOBqOmHjeOBquOCiuOCkuaVtOaVsOOBp+aMh+WumuOBl+OBvuOBmeOAguaVsOWApOOBjOmrmOOBhOOBu+OBqeS4iuOBq+mHjeOBquOCiuOAgeW9seOBr+a/g+OBj+OBquOCiuOBvuOBmeOAglxuICAgICAqXG4gICAgICogQGRlZmF1bHQgMVxuICAgICAqL1xuICAgIGVsZXZhdGlvbj86IG51bWJlclxufVxuXG5leHBvcnQgY29uc3QgUGFwZXIgPSBSZWFjdC5mb3J3YXJkUmVmPEhUTUxEaXZFbGVtZW50LCBQYXBlclByb3BzPihcbiAgICAoeyBlbGV2YXRpb24gPSAxLCBzcXVhcmUgPSBmYWxzZSwgLi4ucHJvcHMgfSwgcmVmKSA9PiB7XG4gICAgICAgIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKVxuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICAgIGNzcz17Y3NzKHtcbiAgICAgICAgICAgICAgICAgICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICAgICAgICAgICAgICAgICAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgICAgICAgICAgICAgICAgICAgYm94U2hhZG93OiB0aGVtZS5zaGFkb3dzW2VsZXZhdGlvbl0sXG4gICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUucGFsZXR0ZS5iYWNrZ3JvdW5kLnBhcGVyLFxuICAgICAgICAgICAgICAgICAgICBjb2xvcjogdGhlbWUucGFsZXR0ZS50ZXh0LnByaW1hcnksXG4gICAgICAgICAgICAgICAgICAgIGJvcmRlclJhZGl1czogc3F1YXJlID8gXCJub25lXCIgOiBcIjVweFwiXG4gICAgICAgICAgICAgICAgfSl9XG4gICAgICAgICAgICAgICAgey4uLnByb3BzfVxuICAgICAgICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgKVxuICAgIH1cbilcbiJdfQ== */")
31
30
  }, props, {
32
31
  ref: ref
33
32
  }));
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/Paper/Paper.tsx"],"names":["css","useTheme","React","Paper","forwardRef","ref","elevation","square","props","theme","position","zIndex","boxSizing","boxShadow","shadows","backgroundColor","palette","background","paper","color","text","primary","borderRadius"],"mappings":";;;;;;;;AAAA,SAASA,GAAT,QAAoB,gBAApB;AACA,SAASC,QAAT,QAAyB,UAAzB;AACA,OAAOC,KAAP,MAAkB,OAAlB;;AAiBA,OAAO,IAAMC,KAAK,gBAAGD,KAAK,CAACE,UAAN,CACjB,OAA8CC,GAA9C,KAAsD;AAAA,MAArD;AAAEC,IAAAA,SAAS,GAAG,CAAd;AAAiBC,IAAAA,MAAM,GAAG;AAA1B,GAAqD;AAAA,MAAjBC,KAAiB;;AAClD,MAAMC,KAAK,GAAGR,QAAQ,EAAtB;AACA,SACI;AACI,IAAA,GAAG,eAAED,GAAG,CAAC;AACLU,MAAAA,QAAQ,EAAE,UADL;AAELC,MAAAA,MAAM,EAAEL,SAFH;AAGLM,MAAAA,SAAS,EAAE,YAHN;AAILC,MAAAA,SAAS,EAAEJ,KAAK,CAACK,OAAN,CAAcR,SAAd,CAJN;AAKLS,MAAAA,eAAe,EAAEN,KAAK,CAACO,OAAN,CAAcC,UAAd,CAAyBC,KALrC;AAMLC,MAAAA,KAAK,EAAEV,KAAK,CAACO,OAAN,CAAcI,IAAd,CAAmBC,OANrB;AAOLC,MAAAA,YAAY,EAAEf,MAAM,GAAG,MAAH,GAAY;AAP3B,KAAD;AADZ,KAUQC,KAVR;AAWI,IAAA,GAAG,EAAEH;AAXT,KADJ;AAeH,CAlBgB,CAAd","sourcesContent":["import { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React from \"react\"\n\nexport interface PaperProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Paperの角に丸みを持たせるかを指定します。\n *\n * @default false\n */\n square?: boolean\n /**\n * Paperの影の濃さと重なりを整数で指定します。数値が高いほど上に重なり、影は濃くなります。\n *\n * @default 1\n */\n elevation?: number\n}\n\nexport const Paper = React.forwardRef<HTMLDivElement, PaperProps>(\n ({ elevation = 1, square = false, ...props }, ref) => {\n const theme = useTheme()\n return (\n <div\n css={css({\n position: \"relative\",\n zIndex: elevation,\n boxSizing: \"border-box\",\n boxShadow: theme.shadows[elevation],\n backgroundColor: theme.palette.background.paper,\n color: theme.palette.text.primary,\n borderRadius: square ? \"none\" : \"5px\"\n })}\n {...props}\n ref={ref}\n />\n )\n }\n)\n"],"file":"Paper.js"}
1
+ {"version":3,"sources":["../../../src/Paper/Paper.tsx"],"names":["css","useTheme","React","Paper","forwardRef","ref","elevation","square","props","theme","position","boxSizing","boxShadow","shadows","backgroundColor","palette","background","paper","color","text","primary","borderRadius"],"mappings":";;;;;;;;AAAA,SAASA,GAAT,QAAoB,gBAApB;AACA,SAASC,QAAT,QAAyB,UAAzB;AACA,OAAOC,KAAP,MAAkB,OAAlB;;AAiBA,OAAO,IAAMC,KAAK,gBAAGD,KAAK,CAACE,UAAN,CACjB,OAA8CC,GAA9C,KAAsD;AAAA,MAArD;AAAEC,IAAAA,SAAS,GAAG,CAAd;AAAiBC,IAAAA,MAAM,GAAG;AAA1B,GAAqD;AAAA,MAAjBC,KAAiB;;AAClD,MAAMC,KAAK,GAAGR,QAAQ,EAAtB;AACA,SACI;AACI,IAAA,GAAG,eAAED,GAAG,CAAC;AACLU,MAAAA,QAAQ,EAAE,UADL;AAELC,MAAAA,SAAS,EAAE,YAFN;AAGLC,MAAAA,SAAS,EAAEH,KAAK,CAACI,OAAN,CAAcP,SAAd,CAHN;AAILQ,MAAAA,eAAe,EAAEL,KAAK,CAACM,OAAN,CAAcC,UAAd,CAAyBC,KAJrC;AAKLC,MAAAA,KAAK,EAAET,KAAK,CAACM,OAAN,CAAcI,IAAd,CAAmBC,OALrB;AAMLC,MAAAA,YAAY,EAAEd,MAAM,GAAG,MAAH,GAAY;AAN3B,KAAD;AADZ,KASQC,KATR;AAUI,IAAA,GAAG,EAAEH;AAVT,KADJ;AAcH,CAjBgB,CAAd","sourcesContent":["import { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React from \"react\"\n\nexport interface PaperProps extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * Paperの角に丸みを持たせるかを指定します。\n *\n * @default false\n */\n square?: boolean\n /**\n * Paperの影の濃さと重なりを整数で指定します。数値が高いほど上に重なり、影は濃くなります。\n *\n * @default 1\n */\n elevation?: number\n}\n\nexport const Paper = React.forwardRef<HTMLDivElement, PaperProps>(\n ({ elevation = 1, square = false, ...props }, ref) => {\n const theme = useTheme()\n return (\n <div\n css={css({\n position: \"relative\",\n boxSizing: \"border-box\",\n boxShadow: theme.shadows[elevation],\n backgroundColor: theme.palette.background.paper,\n color: theme.palette.text.primary,\n borderRadius: square ? \"none\" : \"5px\"\n })}\n {...props}\n ref={ref}\n />\n )\n }\n)\n"],"file":"Paper.js"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/TextField/index.tsx"],"names":["useFieldGroup","FormControl","FormHelperText","InputBase","InputLabel","useDitectInputTouched","useValidation","React","useCallback","useRef","useState","TextField","forwardRef","rootRef","label","style","className","onChange","disabled","validationMessages","customValidations","type","bottomGutter","helperText","invalid","loading","propsLoading","readOnly","propsReadonly","props","ref","value","setValue","defaultValue","validation","handleChange","event","currentTarget","touched","inputProps","required","valid","message"],"mappings":"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","sourcesContent":["import { FieldGroupProps, useFieldGroup } from \"../FieldGroup\"\nimport { FormControl } from \"../FormControl\"\nimport { FormHelperText, InputBottomGutterProps } from \"../FormHelperText\"\nimport { InputBase, InputBaseProps } from \"../InputBase\"\nimport { InputLabel } from \"../InputLabel\"\nimport { useDitectInputTouched } from \"./useDitectInputTouched\"\nimport { useValidation } from \"./useValidation\"\nimport React, { useCallback, useRef, useState } from \"react\"\n\nexport interface FieldProps<T> extends FieldGroupProps {\n value?: T\n defaultValue?: T\n /**\n * ラベルの文字列を指定します。ラベルは左上に表示されます。\n */\n label?: string\n /**\n * input要素本来のバリデーションに任意のバリデーションを追加することができます。\n */\n customValidations?: Array<(value?: T) => string | undefined | false>\n /**\n * input要素本来のバリーデーションメッセージを変更することができます。\n */\n validationMessages?: {\n [key in keyof ValidityState]?: string\n }\n /**\n * inputの値が更新された場合に発火します。\n *\n * onChangeが呼ばれるタイミングと内部実装の値が変更されるタイミングは異なります。\n * そのため、onChange発火直後にformなどのrefから値を取得しようとするとズレが発生する場合があります。\n */\n onChange?: (value: T, event?: React.SyntheticEvent<HTMLElement>) => void\n /**\n * 任意のヘルパーテキストを挿入できます。ただしinput要素本来のバリデーションの方が優先されます。\n */\n helperText?: React.ReactNode | ((props: { value?: T }) => React.ReactNode)\n /**\n * 任意のヘルパーテキストをinvalidなものとして扱いたい場合に使用できます。\n */\n invalid?: boolean\n}\n\nexport interface TextFieldProps\n extends FieldProps<string>,\n Omit<InputBaseProps, \"value\" | \"onChange\" | \"defaultValue\">,\n InputBottomGutterProps {}\n\nexport const TextField = React.forwardRef<HTMLDivElement, TextFieldProps>(\n (\n {\n label,\n style,\n className,\n onChange,\n disabled,\n validationMessages,\n customValidations,\n type = \"text\",\n bottomGutter,\n helperText,\n invalid,\n loading: propsLoading,\n readOnly: propsReadonly,\n ...props\n },\n rootRef\n ) => {\n const ref = useRef<HTMLInputElement>(null)\n const [value, setValue] = useState(props.value || props.defaultValue)\n const validation = useValidation({\n ref,\n validationMessages,\n customValidations,\n value\n })\n const handleChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n const { value } = event.currentTarget\n setValue(value)\n if (onChange) {\n onChange(value, event)\n }\n },\n [onChange]\n )\n const [touched, inputProps] = useDitectInputTouched()\n\n const { loading, readOnly } = useFieldGroup({ loading: propsLoading, readOnly: propsReadonly })\n\n return (\n <FormControl style={style} className={className} ref={rootRef}>\n <InputLabel aria-disabled={disabled} required={props.required} loading={loading}>\n {label}\n </InputLabel>\n <InputBase\n disabled={disabled}\n loading={loading}\n readOnly={readOnly}\n type={type}\n {...props}\n onChange={handleChange}\n data-invalid={!validation.valid}\n ref={ref}\n {...inputProps}\n />\n {touched && validation.message ? (\n <FormHelperText bottomGutter={bottomGutter} invalid={!validation.valid}>\n {validation.message}\n </FormHelperText>\n ) : (\n <FormHelperText bottomGutter={bottomGutter} invalid={invalid} loading={loading}>\n {typeof helperText === \"function\" ? helperText({ value }) : helperText}\n </FormHelperText>\n )}\n </FormControl>\n )\n }\n)\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../../../src/TextField/index.tsx"],"names":["useFieldGroup","FormControl","FormHelperText","InputBase","InputLabel","useDitectInputTouched","useValidation","React","useCallback","useRef","useState","TextField","forwardRef","rootRef","label","style","className","onChange","disabled","validationMessages","customValidations","type","bottomGutter","helperText","invalid","loading","propsLoading","readOnly","propsReadonly","props","ref","value","setValue","defaultValue","validation","handleChange","event","currentTarget","touched","inputProps","required","valid","message"],"mappings":"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","sourcesContent":["import { FieldGroupProps, useFieldGroup } from \"../FieldGroup\"\nimport { FormControl } from \"../FormControl\"\nimport { FormHelperText, InputBottomGutterProps } from \"../FormHelperText\"\nimport { InputBase, InputBaseProps } from \"../InputBase\"\nimport { InputLabel } from \"../InputLabel\"\nimport { useDitectInputTouched } from \"./useDitectInputTouched\"\nimport { useValidation } from \"./useValidation\"\nimport React, { useCallback, useRef, useState } from \"react\"\n\ninterface CommonFieldProps<T> extends FieldGroupProps {\n /**\n * ラベルの文字列を指定します。ラベルは左上に表示されます。\n */\n label?: string\n /**\n * input要素本来のバリデーションに任意のバリデーションを追加することができます。\n */\n customValidations?: Array<(value?: T) => string | undefined | false>\n /**\n * input要素本来のバリーデーションメッセージを変更することができます。\n */\n validationMessages?: {\n [key in keyof ValidityState]?: string\n }\n\n /**\n * 任意のヘルパーテキストを挿入できます。ただしinput要素本来のバリデーションの方が優先されます。\n */\n helperText?: React.ReactNode | ((props: { value?: T }) => React.ReactNode)\n /**\n * 任意のヘルパーテキストをinvalidなものとして扱いたい場合に使用できます。\n */\n invalid?: boolean\n}\n\n/**\n * 厳密にUncontrolledなFieldコンポーネントとして扱いたい場合は、この型を利用してください。\n */\nexport interface UncontolledFieldProps<T> extends CommonFieldProps<T> {\n defaultValue: T\n value?: never\n onChange?: (value: T, event?: React.SyntheticEvent<HTMLElement>) => void\n}\n\n/**\n * 厳密にControlledなFieldコンポーネントとして扱いたい場合は、この型を利用してください。\n */\nexport interface ContolledFieldProps<T> extends CommonFieldProps<T> {\n defaultValue?: never\n value: T\n onChange: (value: T, event?: React.SyntheticEvent<HTMLElement>) => void\n}\n\nexport interface FieldProps<T> extends CommonFieldProps<T> {\n value?: T\n defaultValue?: T\n /**\n * inputの値が更新された場合に発火します。\n *\n * onChangeが呼ばれるタイミングと内部実装の値が変更されるタイミングは異なります。\n * そのため、onChange発火直後にformなどのrefから値を取得しようとするとズレが発生する場合があります。\n */\n onChange?: (value: T, event?: React.SyntheticEvent<HTMLElement>) => void\n}\n\nexport interface TextFieldProps\n extends FieldProps<string>,\n Omit<InputBaseProps, \"value\" | \"onChange\" | \"defaultValue\">,\n InputBottomGutterProps {}\n\nexport const TextField = React.forwardRef<HTMLDivElement, TextFieldProps>(\n (\n {\n label,\n style,\n className,\n onChange,\n disabled,\n validationMessages,\n customValidations,\n type = \"text\",\n bottomGutter,\n helperText,\n invalid,\n loading: propsLoading,\n readOnly: propsReadonly,\n ...props\n },\n rootRef\n ) => {\n const ref = useRef<HTMLInputElement>(null)\n const [value, setValue] = useState(props.value || props.defaultValue)\n const validation = useValidation({\n ref,\n validationMessages,\n customValidations,\n value\n })\n const handleChange = useCallback(\n (event: React.ChangeEvent<HTMLInputElement>) => {\n const { value } = event.currentTarget\n setValue(value)\n if (onChange) {\n onChange(value, event)\n }\n },\n [onChange]\n )\n const [touched, inputProps] = useDitectInputTouched()\n\n const { loading, readOnly } = useFieldGroup({ loading: propsLoading, readOnly: propsReadonly })\n\n return (\n <FormControl style={style} className={className} ref={rootRef}>\n <InputLabel aria-disabled={disabled} required={props.required} loading={loading}>\n {label}\n </InputLabel>\n <InputBase\n disabled={disabled}\n loading={loading}\n readOnly={readOnly}\n type={type}\n {...props}\n onChange={handleChange}\n data-invalid={!validation.valid}\n ref={ref}\n {...inputProps}\n />\n {touched && validation.message ? (\n <FormHelperText bottomGutter={bottomGutter} invalid={!validation.valid}>\n {validation.message}\n </FormHelperText>\n ) : (\n <FormHelperText bottomGutter={bottomGutter} invalid={invalid} loading={loading}>\n {typeof helperText === \"function\" ? helperText({ value }) : helperText}\n </FormHelperText>\n )}\n </FormControl>\n )\n }\n)\n"],"file":"index.js"}
@@ -141,7 +141,7 @@ export var Timeline = _ref3 => {
141
141
  } = getDatesEntries(dates, separators, now);
142
142
  var renderItems = useMemo(() => makeRenderItems(item), [item]);
143
143
  return datesEntries.length > 0 ? ___EmotionJSX("div", props, prevPropsArray.length > 0 && ___EmotionJSX("div", {
144
- css: /*#__PURE__*/css("margin-top:", theme.spacing * 2, "px;margin-bottom:", theme.spacing * 2, "px;&:first-of-type{margin-top:0px;}&:last-of-type{margin-bottom:0px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:Timeline;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":[],"mappings":"AA2M4B","file":"../../../src/Timeline/Timeline.tsx","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n    /**\n     * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n     */\n    item: (\n        props: Props & {\n            date: string\n            index: number\n        }\n    ) => JSX.Element\n    /**\n     * 日付と、日付に対応するデータ群を指定します。\n     *\n     * 昇順でkeyがソートされていることを前提としている点に注意してください。\n     *\n     * ソート処理が面倒な場合はUI側での処理を検討します。\n     *\n     * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n     *\n     * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n     *\n     * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n     *\n     */\n    dates: {\n        [date: string]: Props[]\n    }\n    /**\n     * 区分ごとのラベルの表記を指定します。\n     *\n     * @default {year: numeric ,month: numeric, day: numeric}\n     */\n    format?: \"relative\" | Intl.DateTimeFormatOptions\n    /**\n     * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n     *\n     * 原点のデフォルトは\"今日\"。\n     *\n     * 過去から未来へ昇順でソートされていることを前提にしています。\n     * ソート処理が難しい場合はUI側での処理を検討します。\n     *\n     * @default []\n     */\n    separators?: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[]\n    /**\n     * 未対応。このコンポーネントのルート要素を指定する。\n     * @default div\n     */\n    container?: React.ElementType\n    /**\n     * 未対応。区分ごとに表示されるラベル要素を指定する。\n     * @default div\n     */\n    label?: (props: { date: string }) => JSX.Element\n    /**\n     * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n     */\n    labelProps?: BaseTypographyProps\n    /**\n     * 未対応。原点を指定する。\n     *\n     * フォーマットはYYYYMMDDまたは`today`\n     *\n     * number (ms) | Date には対応予定。\n     *\n     * @default today\n     */\n    origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n    dates: {\n        [date: string]: E[]\n    },\n    separators: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[],\n    origin: dayjs.Dayjs\n) => {\n    if (separators.length === 0) {\n        return {\n            prevPropsArray: [],\n            datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n                const diff = dayjs(date).diff(origin, \"day\")\n                return [\n                    date,\n                    propsArray.map((props) => ({\n                        ...props,\n                        date\n                    })),\n                    {\n                        unit: \"day\",\n                        diff\n                    }\n                ] as const\n            })\n        }\n    }\n\n    const copy = { ...dates }\n    // prevProps\n    let prevProps: (E & { date: string })[] = []\n    const min = origin.add(separators[0].value, separators[0].unit)\n    for (const date in copy) {\n        if (dayjs(date).isBefore(min, \"day\")) {\n            const add = copy[date].map((props) => ({ ...props, date }))\n            prevProps = prevProps.concat(add)\n            delete copy[date]\n        } else {\n            break\n        }\n    }\n    let results: (readonly [\n        string,\n        (E & {\n            date: string\n        })[],\n        {\n            unit: string\n            diff: number\n        }\n    ])[] = []\n    separators.map(({ unit, value }, index, original) => {\n        const min = origin.add(value, unit)\n        const max =\n            separators.length - 1 === index\n                ? dayjs(\"9999/12/24\")\n                : origin.add(original[index + 1].value, original[index + 1].unit)\n        let propsArray: (E & { date: string })[] = []\n        for (const date in copy) {\n            if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n                const add = copy[date].map((props) => ({ ...props, date }))\n                propsArray = propsArray.concat(add)\n                delete copy[date]\n            } else {\n                break\n            }\n        }\n        if (propsArray.length > 0) {\n            results = results.concat([\n                [\n                    min.format(\"YYYYMMDD\"),\n                    propsArray,\n                    {\n                        unit,\n                        diff: value\n                    }\n                ]\n            ])\n        }\n    })\n    return {\n        prevPropsArray: prevProps,\n        datesEntries: results\n    }\n}\n\nconst makeRenderItems =\n    <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n    (propsArray: (E & { date: string })[]) => {\n        return propsArray.map((props, index) =>\n            React.cloneElement(renderItem({ ...props, index }), {\n                key: `${props.date}.${index}`\n            })\n        )\n    }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n    item,\n    dates,\n    format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n    separators = [],\n    labelProps,\n    ...props\n}: TimelineProps<E>) => {\n    const locale = useContext(LocaleContext)\n    const rtf = useMemo(() => {\n        return RelativeTimeFormat(locale, {\n            numeric: \"auto\"\n        })\n    }, [locale])\n    const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n    const theme = useTheme()\n    const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n    const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n    return datesEntries.length > 0 ? (\n        <div {...props}>\n            {prevPropsArray.length > 0 && (\n                <div\n                    css={css`\n                        margin-top: ${theme.spacing * 2}px;\n                        margin-bottom: ${theme.spacing * 2}px;\n                        &:first-of-type {\n                            margin-top: 0px;\n                        }\n                        &:last-of-type {\n                            margin-bottom: 0px;\n                        }\n                    `}\n                >\n                    {renderItems(prevPropsArray)}\n                </div>\n            )}\n            {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n                const formatedDate =\n                    format === \"relative\"\n                        ? rtf.format(diff, unit)\n                        : dayjs(value).toDate().toLocaleDateString(locale, format)\n                return (\n                    <React.Fragment key={formatedDate}>\n                        <Typography\n                            css={css`\n                                display: flex;\n                                align-items: center;\n                                margin-top: ${theme.spacing}px;\n                                margin-bottom: ${theme.spacing}px;\n                                &::before,\n                                &::after {\n                                    flex-grow: 1;\n                                    height: 1px;\n                                    content: \"\";\n                                    background-color: currentColor;\n                                }\n                                &::before {\n                                    margin-right: 1rem;\n                                }\n                                &::after {\n                                    margin-left: 1rem;\n                                }\n                            `}\n                            {...labelProps}\n                        >\n                            {formatedDate}\n                        </Typography>\n                        <div\n                            css={css`\n                                margin-top: ${theme.spacing * 2}px;\n                                margin-bottom: ${theme.spacing * 2}px;\n                                &:first-of-type {\n                                    margin-top: 0px;\n                                }\n                                &:last-of-type {\n                                    margin-bottom: 0px;\n                                }\n                            `}\n                        >\n                            {renderItems(propsArray)}\n                        </div>\n                    </React.Fragment>\n                )\n            })}\n        </div>\n    ) : null\n}\n"]} */")
144
+ css: /*#__PURE__*/css("margin-top:", theme.spacing * 2, "px;margin-bottom:", theme.spacing * 2, "px;&:first-of-type{margin-top:0px;}&:last-of-type{margin-bottom:0px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:Timeline;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":[],"mappings":"AA4M4B","file":"../../../src/Timeline/Timeline.tsx","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\nimport type { Unit } from \"relative-time-format\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n    /**\n     * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n     */\n    item: (\n        props: Props & {\n            date: string\n            index: number\n        }\n    ) => JSX.Element\n    /**\n     * 日付と、日付に対応するデータ群を指定します。\n     *\n     * 昇順でkeyがソートされていることを前提としている点に注意してください。\n     *\n     * ソート処理が面倒な場合はUI側での処理を検討します。\n     *\n     * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n     *\n     * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n     *\n     * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n     *\n     */\n    dates: {\n        [date: string]: Props[]\n    }\n    /**\n     * 区分ごとのラベルの表記を指定します。\n     *\n     * @default {year: numeric ,month: numeric, day: numeric}\n     */\n    format?: \"relative\" | Intl.DateTimeFormatOptions\n    /**\n     * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n     *\n     * 原点のデフォルトは\"今日\"。\n     *\n     * 過去から未来へ昇順でソートされていることを前提にしています。\n     * ソート処理が難しい場合はUI側での処理を検討します。\n     *\n     * @default []\n     */\n    separators?: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[]\n    /**\n     * 未対応。このコンポーネントのルート要素を指定する。\n     * @default div\n     */\n    container?: React.ElementType\n    /**\n     * 未対応。区分ごとに表示されるラベル要素を指定する。\n     * @default div\n     */\n    label?: (props: { date: string }) => JSX.Element\n    /**\n     * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n     */\n    labelProps?: BaseTypographyProps\n    /**\n     * 未対応。原点を指定する。\n     *\n     * フォーマットはYYYYMMDDまたは`today`\n     *\n     * number (ms) | Date には対応予定。\n     *\n     * @default today\n     */\n    origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n    dates: {\n        [date: string]: E[]\n    },\n    separators: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[],\n    origin: dayjs.Dayjs\n) => {\n    if (separators.length === 0) {\n        return {\n            prevPropsArray: [],\n            datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n                const diff = dayjs(date).diff(origin, \"day\")\n                return [\n                    date,\n                    propsArray.map((props) => ({\n                        ...props,\n                        date\n                    })),\n                    {\n                        unit: \"day\",\n                        diff\n                    }\n                ] as const\n            })\n        }\n    }\n\n    const copy = { ...dates }\n    // prevProps\n    let prevProps: (E & { date: string })[] = []\n    const min = origin.add(separators[0].value, separators[0].unit)\n    for (const date in copy) {\n        if (dayjs(date).isBefore(min, \"day\")) {\n            const add = copy[date].map((props) => ({ ...props, date }))\n            prevProps = prevProps.concat(add)\n            delete copy[date]\n        } else {\n            break\n        }\n    }\n    let results: (readonly [\n        string,\n        (E & {\n            date: string\n        })[],\n        {\n            unit: string\n            diff: number\n        }\n    ])[] = []\n    separators.map(({ unit, value }, index, original) => {\n        const min = origin.add(value, unit)\n        const max =\n            separators.length - 1 === index\n                ? dayjs(\"9999/12/24\")\n                : origin.add(original[index + 1].value, original[index + 1].unit)\n        let propsArray: (E & { date: string })[] = []\n        for (const date in copy) {\n            if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n                const add = copy[date].map((props) => ({ ...props, date }))\n                propsArray = propsArray.concat(add)\n                delete copy[date]\n            } else {\n                break\n            }\n        }\n        if (propsArray.length > 0) {\n            results = results.concat([\n                [\n                    min.format(\"YYYYMMDD\"),\n                    propsArray,\n                    {\n                        unit,\n                        diff: value\n                    }\n                ]\n            ])\n        }\n    })\n    return {\n        prevPropsArray: prevProps,\n        datesEntries: results\n    }\n}\n\nconst makeRenderItems =\n    <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n    (propsArray: (E & { date: string })[]) => {\n        return propsArray.map((props, index) =>\n            React.cloneElement(renderItem({ ...props, index }), {\n                key: `${props.date}.${index}`\n            })\n        )\n    }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n    item,\n    dates,\n    format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n    separators = [],\n    labelProps,\n    ...props\n}: TimelineProps<E>) => {\n    const locale = useContext(LocaleContext)\n    const rtf = useMemo(() => {\n        return RelativeTimeFormat(locale, {\n            numeric: \"auto\"\n        })\n    }, [locale])\n    const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n    const theme = useTheme()\n    const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n    const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n    return datesEntries.length > 0 ? (\n        <div {...props}>\n            {prevPropsArray.length > 0 && (\n                <div\n                    css={css`\n                        margin-top: ${theme.spacing * 2}px;\n                        margin-bottom: ${theme.spacing * 2}px;\n                        &:first-of-type {\n                            margin-top: 0px;\n                        }\n                        &:last-of-type {\n                            margin-bottom: 0px;\n                        }\n                    `}\n                >\n                    {renderItems(prevPropsArray)}\n                </div>\n            )}\n            {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n                const formatedDate =\n                    format === \"relative\"\n                        ? rtf.format(diff, unit as Unit)\n                        : dayjs(value).toDate().toLocaleDateString(locale, format)\n                return (\n                    <React.Fragment key={formatedDate}>\n                        <Typography\n                            css={css`\n                                display: flex;\n                                align-items: center;\n                                margin-top: ${theme.spacing}px;\n                                margin-bottom: ${theme.spacing}px;\n                                &::before,\n                                &::after {\n                                    flex-grow: 1;\n                                    height: 1px;\n                                    content: \"\";\n                                    background-color: currentColor;\n                                }\n                                &::before {\n                                    margin-right: 1rem;\n                                }\n                                &::after {\n                                    margin-left: 1rem;\n                                }\n                            `}\n                            {...labelProps}\n                        >\n                            {formatedDate}\n                        </Typography>\n                        <div\n                            css={css`\n                                margin-top: ${theme.spacing * 2}px;\n                                margin-bottom: ${theme.spacing * 2}px;\n                                &:first-of-type {\n                                    margin-top: 0px;\n                                }\n                                &:last-of-type {\n                                    margin-bottom: 0px;\n                                }\n                            `}\n                        >\n                            {renderItems(propsArray)}\n                        </div>\n                    </React.Fragment>\n                )\n            })}\n        </div>\n    ) : null\n}\n"]} */")
145
145
  }, renderItems(prevPropsArray)), datesEntries.map(_ref4 => {
146
146
  var [value, propsArray, {
147
147
  unit,
@@ -151,9 +151,9 @@ export var Timeline = _ref3 => {
151
151
  return ___EmotionJSX(React.Fragment, {
152
152
  key: formatedDate
153
153
  }, ___EmotionJSX(Typography, _extends({
154
- css: /*#__PURE__*/css("display:flex;align-items:center;margin-top:", theme.spacing, "px;margin-bottom:", theme.spacing, "px;&::before,&::after{flex-grow:1;height:1px;content:\"\";background-color:currentColor;}&::before{margin-right:1rem;}&::after{margin-left:1rem;}" + (process.env.NODE_ENV === "production" ? "" : ";label:Timeline;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":[],"mappings":"AAiOoC","file":"../../../src/Timeline/Timeline.tsx","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n    /**\n     * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n     */\n    item: (\n        props: Props & {\n            date: string\n            index: number\n        }\n    ) => JSX.Element\n    /**\n     * 日付と、日付に対応するデータ群を指定します。\n     *\n     * 昇順でkeyがソートされていることを前提としている点に注意してください。\n     *\n     * ソート処理が面倒な場合はUI側での処理を検討します。\n     *\n     * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n     *\n     * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n     *\n     * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n     *\n     */\n    dates: {\n        [date: string]: Props[]\n    }\n    /**\n     * 区分ごとのラベルの表記を指定します。\n     *\n     * @default {year: numeric ,month: numeric, day: numeric}\n     */\n    format?: \"relative\" | Intl.DateTimeFormatOptions\n    /**\n     * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n     *\n     * 原点のデフォルトは\"今日\"。\n     *\n     * 過去から未来へ昇順でソートされていることを前提にしています。\n     * ソート処理が難しい場合はUI側での処理を検討します。\n     *\n     * @default []\n     */\n    separators?: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[]\n    /**\n     * 未対応。このコンポーネントのルート要素を指定する。\n     * @default div\n     */\n    container?: React.ElementType\n    /**\n     * 未対応。区分ごとに表示されるラベル要素を指定する。\n     * @default div\n     */\n    label?: (props: { date: string }) => JSX.Element\n    /**\n     * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n     */\n    labelProps?: BaseTypographyProps\n    /**\n     * 未対応。原点を指定する。\n     *\n     * フォーマットはYYYYMMDDまたは`today`\n     *\n     * number (ms) | Date には対応予定。\n     *\n     * @default today\n     */\n    origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n    dates: {\n        [date: string]: E[]\n    },\n    separators: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[],\n    origin: dayjs.Dayjs\n) => {\n    if (separators.length === 0) {\n        return {\n            prevPropsArray: [],\n            datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n                const diff = dayjs(date).diff(origin, \"day\")\n                return [\n                    date,\n                    propsArray.map((props) => ({\n                        ...props,\n                        date\n                    })),\n                    {\n                        unit: \"day\",\n                        diff\n                    }\n                ] as const\n            })\n        }\n    }\n\n    const copy = { ...dates }\n    // prevProps\n    let prevProps: (E & { date: string })[] = []\n    const min = origin.add(separators[0].value, separators[0].unit)\n    for (const date in copy) {\n        if (dayjs(date).isBefore(min, \"day\")) {\n            const add = copy[date].map((props) => ({ ...props, date }))\n            prevProps = prevProps.concat(add)\n            delete copy[date]\n        } else {\n            break\n        }\n    }\n    let results: (readonly [\n        string,\n        (E & {\n            date: string\n        })[],\n        {\n            unit: string\n            diff: number\n        }\n    ])[] = []\n    separators.map(({ unit, value }, index, original) => {\n        const min = origin.add(value, unit)\n        const max =\n            separators.length - 1 === index\n                ? dayjs(\"9999/12/24\")\n                : origin.add(original[index + 1].value, original[index + 1].unit)\n        let propsArray: (E & { date: string })[] = []\n        for (const date in copy) {\n            if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n                const add = copy[date].map((props) => ({ ...props, date }))\n                propsArray = propsArray.concat(add)\n                delete copy[date]\n            } else {\n                break\n            }\n        }\n        if (propsArray.length > 0) {\n            results = results.concat([\n                [\n                    min.format(\"YYYYMMDD\"),\n                    propsArray,\n                    {\n                        unit,\n                        diff: value\n                    }\n                ]\n            ])\n        }\n    })\n    return {\n        prevPropsArray: prevProps,\n        datesEntries: results\n    }\n}\n\nconst makeRenderItems =\n    <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n    (propsArray: (E & { date: string })[]) => {\n        return propsArray.map((props, index) =>\n            React.cloneElement(renderItem({ ...props, index }), {\n                key: `${props.date}.${index}`\n            })\n        )\n    }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n    item,\n    dates,\n    format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n    separators = [],\n    labelProps,\n    ...props\n}: TimelineProps<E>) => {\n    const locale = useContext(LocaleContext)\n    const rtf = useMemo(() => {\n        return RelativeTimeFormat(locale, {\n            numeric: \"auto\"\n        })\n    }, [locale])\n    const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n    const theme = useTheme()\n    const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n    const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n    return datesEntries.length > 0 ? (\n        <div {...props}>\n            {prevPropsArray.length > 0 && (\n                <div\n                    css={css`\n                        margin-top: ${theme.spacing * 2}px;\n                        margin-bottom: ${theme.spacing * 2}px;\n                        &:first-of-type {\n                            margin-top: 0px;\n                        }\n                        &:last-of-type {\n                            margin-bottom: 0px;\n                        }\n                    `}\n                >\n                    {renderItems(prevPropsArray)}\n                </div>\n            )}\n            {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n                const formatedDate =\n                    format === \"relative\"\n                        ? rtf.format(diff, unit)\n                        : dayjs(value).toDate().toLocaleDateString(locale, format)\n                return (\n                    <React.Fragment key={formatedDate}>\n                        <Typography\n                            css={css`\n                                display: flex;\n                                align-items: center;\n                                margin-top: ${theme.spacing}px;\n                                margin-bottom: ${theme.spacing}px;\n                                &::before,\n                                &::after {\n                                    flex-grow: 1;\n                                    height: 1px;\n                                    content: \"\";\n                                    background-color: currentColor;\n                                }\n                                &::before {\n                                    margin-right: 1rem;\n                                }\n                                &::after {\n                                    margin-left: 1rem;\n                                }\n                            `}\n                            {...labelProps}\n                        >\n                            {formatedDate}\n                        </Typography>\n                        <div\n                            css={css`\n                                margin-top: ${theme.spacing * 2}px;\n                                margin-bottom: ${theme.spacing * 2}px;\n                                &:first-of-type {\n                                    margin-top: 0px;\n                                }\n                                &:last-of-type {\n                                    margin-bottom: 0px;\n                                }\n                            `}\n                        >\n                            {renderItems(propsArray)}\n                        </div>\n                    </React.Fragment>\n                )\n            })}\n        </div>\n    ) : null\n}\n"]} */")
154
+ css: /*#__PURE__*/css("display:flex;align-items:center;margin-top:", theme.spacing, "px;margin-bottom:", theme.spacing, "px;&::before,&::after{flex-grow:1;height:1px;content:\"\";background-color:currentColor;}&::before{margin-right:1rem;}&::after{margin-left:1rem;}" + (process.env.NODE_ENV === "production" ? "" : ";label:Timeline;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":[],"mappings":"AAkOoC","file":"../../../src/Timeline/Timeline.tsx","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\nimport type { Unit } from \"relative-time-format\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n    /**\n     * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n     */\n    item: (\n        props: Props & {\n            date: string\n            index: number\n        }\n    ) => JSX.Element\n    /**\n     * 日付と、日付に対応するデータ群を指定します。\n     *\n     * 昇順でkeyがソートされていることを前提としている点に注意してください。\n     *\n     * ソート処理が面倒な場合はUI側での処理を検討します。\n     *\n     * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n     *\n     * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n     *\n     * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n     *\n     */\n    dates: {\n        [date: string]: Props[]\n    }\n    /**\n     * 区分ごとのラベルの表記を指定します。\n     *\n     * @default {year: numeric ,month: numeric, day: numeric}\n     */\n    format?: \"relative\" | Intl.DateTimeFormatOptions\n    /**\n     * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n     *\n     * 原点のデフォルトは\"今日\"。\n     *\n     * 過去から未来へ昇順でソートされていることを前提にしています。\n     * ソート処理が難しい場合はUI側での処理を検討します。\n     *\n     * @default []\n     */\n    separators?: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[]\n    /**\n     * 未対応。このコンポーネントのルート要素を指定する。\n     * @default div\n     */\n    container?: React.ElementType\n    /**\n     * 未対応。区分ごとに表示されるラベル要素を指定する。\n     * @default div\n     */\n    label?: (props: { date: string }) => JSX.Element\n    /**\n     * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n     */\n    labelProps?: BaseTypographyProps\n    /**\n     * 未対応。原点を指定する。\n     *\n     * フォーマットはYYYYMMDDまたは`today`\n     *\n     * number (ms) | Date には対応予定。\n     *\n     * @default today\n     */\n    origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n    dates: {\n        [date: string]: E[]\n    },\n    separators: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[],\n    origin: dayjs.Dayjs\n) => {\n    if (separators.length === 0) {\n        return {\n            prevPropsArray: [],\n            datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n                const diff = dayjs(date).diff(origin, \"day\")\n                return [\n                    date,\n                    propsArray.map((props) => ({\n                        ...props,\n                        date\n                    })),\n                    {\n                        unit: \"day\",\n                        diff\n                    }\n                ] as const\n            })\n        }\n    }\n\n    const copy = { ...dates }\n    // prevProps\n    let prevProps: (E & { date: string })[] = []\n    const min = origin.add(separators[0].value, separators[0].unit)\n    for (const date in copy) {\n        if (dayjs(date).isBefore(min, \"day\")) {\n            const add = copy[date].map((props) => ({ ...props, date }))\n            prevProps = prevProps.concat(add)\n            delete copy[date]\n        } else {\n            break\n        }\n    }\n    let results: (readonly [\n        string,\n        (E & {\n            date: string\n        })[],\n        {\n            unit: string\n            diff: number\n        }\n    ])[] = []\n    separators.map(({ unit, value }, index, original) => {\n        const min = origin.add(value, unit)\n        const max =\n            separators.length - 1 === index\n                ? dayjs(\"9999/12/24\")\n                : origin.add(original[index + 1].value, original[index + 1].unit)\n        let propsArray: (E & { date: string })[] = []\n        for (const date in copy) {\n            if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n                const add = copy[date].map((props) => ({ ...props, date }))\n                propsArray = propsArray.concat(add)\n                delete copy[date]\n            } else {\n                break\n            }\n        }\n        if (propsArray.length > 0) {\n            results = results.concat([\n                [\n                    min.format(\"YYYYMMDD\"),\n                    propsArray,\n                    {\n                        unit,\n                        diff: value\n                    }\n                ]\n            ])\n        }\n    })\n    return {\n        prevPropsArray: prevProps,\n        datesEntries: results\n    }\n}\n\nconst makeRenderItems =\n    <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n    (propsArray: (E & { date: string })[]) => {\n        return propsArray.map((props, index) =>\n            React.cloneElement(renderItem({ ...props, index }), {\n                key: `${props.date}.${index}`\n            })\n        )\n    }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n    item,\n    dates,\n    format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n    separators = [],\n    labelProps,\n    ...props\n}: TimelineProps<E>) => {\n    const locale = useContext(LocaleContext)\n    const rtf = useMemo(() => {\n        return RelativeTimeFormat(locale, {\n            numeric: \"auto\"\n        })\n    }, [locale])\n    const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n    const theme = useTheme()\n    const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n    const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n    return datesEntries.length > 0 ? (\n        <div {...props}>\n            {prevPropsArray.length > 0 && (\n                <div\n                    css={css`\n                        margin-top: ${theme.spacing * 2}px;\n                        margin-bottom: ${theme.spacing * 2}px;\n                        &:first-of-type {\n                            margin-top: 0px;\n                        }\n                        &:last-of-type {\n                            margin-bottom: 0px;\n                        }\n                    `}\n                >\n                    {renderItems(prevPropsArray)}\n                </div>\n            )}\n            {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n                const formatedDate =\n                    format === \"relative\"\n                        ? rtf.format(diff, unit as Unit)\n                        : dayjs(value).toDate().toLocaleDateString(locale, format)\n                return (\n                    <React.Fragment key={formatedDate}>\n                        <Typography\n                            css={css`\n                                display: flex;\n                                align-items: center;\n                                margin-top: ${theme.spacing}px;\n                                margin-bottom: ${theme.spacing}px;\n                                &::before,\n                                &::after {\n                                    flex-grow: 1;\n                                    height: 1px;\n                                    content: \"\";\n                                    background-color: currentColor;\n                                }\n                                &::before {\n                                    margin-right: 1rem;\n                                }\n                                &::after {\n                                    margin-left: 1rem;\n                                }\n                            `}\n                            {...labelProps}\n                        >\n                            {formatedDate}\n                        </Typography>\n                        <div\n                            css={css`\n                                margin-top: ${theme.spacing * 2}px;\n                                margin-bottom: ${theme.spacing * 2}px;\n                                &:first-of-type {\n                                    margin-top: 0px;\n                                }\n                                &:last-of-type {\n                                    margin-bottom: 0px;\n                                }\n                            `}\n                        >\n                            {renderItems(propsArray)}\n                        </div>\n                    </React.Fragment>\n                )\n            })}\n        </div>\n    ) : null\n}\n"]} */")
155
155
  }, labelProps), formatedDate), ___EmotionJSX("div", {
156
- css: /*#__PURE__*/css("margin-top:", theme.spacing * 2, "px;margin-bottom:", theme.spacing * 2, "px;&:first-of-type{margin-top:0px;}&:last-of-type{margin-bottom:0px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:Timeline;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":[],"mappings":"AAyPoC","file":"../../../src/Timeline/Timeline.tsx","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n    /**\n     * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n     */\n    item: (\n        props: Props & {\n            date: string\n            index: number\n        }\n    ) => JSX.Element\n    /**\n     * 日付と、日付に対応するデータ群を指定します。\n     *\n     * 昇順でkeyがソートされていることを前提としている点に注意してください。\n     *\n     * ソート処理が面倒な場合はUI側での処理を検討します。\n     *\n     * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n     *\n     * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n     *\n     * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n     *\n     */\n    dates: {\n        [date: string]: Props[]\n    }\n    /**\n     * 区分ごとのラベルの表記を指定します。\n     *\n     * @default {year: numeric ,month: numeric, day: numeric}\n     */\n    format?: \"relative\" | Intl.DateTimeFormatOptions\n    /**\n     * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n     *\n     * 原点のデフォルトは\"今日\"。\n     *\n     * 過去から未来へ昇順でソートされていることを前提にしています。\n     * ソート処理が難しい場合はUI側での処理を検討します。\n     *\n     * @default []\n     */\n    separators?: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[]\n    /**\n     * 未対応。このコンポーネントのルート要素を指定する。\n     * @default div\n     */\n    container?: React.ElementType\n    /**\n     * 未対応。区分ごとに表示されるラベル要素を指定する。\n     * @default div\n     */\n    label?: (props: { date: string }) => JSX.Element\n    /**\n     * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n     */\n    labelProps?: BaseTypographyProps\n    /**\n     * 未対応。原点を指定する。\n     *\n     * フォーマットはYYYYMMDDまたは`today`\n     *\n     * number (ms) | Date には対応予定。\n     *\n     * @default today\n     */\n    origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n    dates: {\n        [date: string]: E[]\n    },\n    separators: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[],\n    origin: dayjs.Dayjs\n) => {\n    if (separators.length === 0) {\n        return {\n            prevPropsArray: [],\n            datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n                const diff = dayjs(date).diff(origin, \"day\")\n                return [\n                    date,\n                    propsArray.map((props) => ({\n                        ...props,\n                        date\n                    })),\n                    {\n                        unit: \"day\",\n                        diff\n                    }\n                ] as const\n            })\n        }\n    }\n\n    const copy = { ...dates }\n    // prevProps\n    let prevProps: (E & { date: string })[] = []\n    const min = origin.add(separators[0].value, separators[0].unit)\n    for (const date in copy) {\n        if (dayjs(date).isBefore(min, \"day\")) {\n            const add = copy[date].map((props) => ({ ...props, date }))\n            prevProps = prevProps.concat(add)\n            delete copy[date]\n        } else {\n            break\n        }\n    }\n    let results: (readonly [\n        string,\n        (E & {\n            date: string\n        })[],\n        {\n            unit: string\n            diff: number\n        }\n    ])[] = []\n    separators.map(({ unit, value }, index, original) => {\n        const min = origin.add(value, unit)\n        const max =\n            separators.length - 1 === index\n                ? dayjs(\"9999/12/24\")\n                : origin.add(original[index + 1].value, original[index + 1].unit)\n        let propsArray: (E & { date: string })[] = []\n        for (const date in copy) {\n            if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n                const add = copy[date].map((props) => ({ ...props, date }))\n                propsArray = propsArray.concat(add)\n                delete copy[date]\n            } else {\n                break\n            }\n        }\n        if (propsArray.length > 0) {\n            results = results.concat([\n                [\n                    min.format(\"YYYYMMDD\"),\n                    propsArray,\n                    {\n                        unit,\n                        diff: value\n                    }\n                ]\n            ])\n        }\n    })\n    return {\n        prevPropsArray: prevProps,\n        datesEntries: results\n    }\n}\n\nconst makeRenderItems =\n    <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n    (propsArray: (E & { date: string })[]) => {\n        return propsArray.map((props, index) =>\n            React.cloneElement(renderItem({ ...props, index }), {\n                key: `${props.date}.${index}`\n            })\n        )\n    }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n    item,\n    dates,\n    format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n    separators = [],\n    labelProps,\n    ...props\n}: TimelineProps<E>) => {\n    const locale = useContext(LocaleContext)\n    const rtf = useMemo(() => {\n        return RelativeTimeFormat(locale, {\n            numeric: \"auto\"\n        })\n    }, [locale])\n    const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n    const theme = useTheme()\n    const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n    const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n    return datesEntries.length > 0 ? (\n        <div {...props}>\n            {prevPropsArray.length > 0 && (\n                <div\n                    css={css`\n                        margin-top: ${theme.spacing * 2}px;\n                        margin-bottom: ${theme.spacing * 2}px;\n                        &:first-of-type {\n                            margin-top: 0px;\n                        }\n                        &:last-of-type {\n                            margin-bottom: 0px;\n                        }\n                    `}\n                >\n                    {renderItems(prevPropsArray)}\n                </div>\n            )}\n            {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n                const formatedDate =\n                    format === \"relative\"\n                        ? rtf.format(diff, unit)\n                        : dayjs(value).toDate().toLocaleDateString(locale, format)\n                return (\n                    <React.Fragment key={formatedDate}>\n                        <Typography\n                            css={css`\n                                display: flex;\n                                align-items: center;\n                                margin-top: ${theme.spacing}px;\n                                margin-bottom: ${theme.spacing}px;\n                                &::before,\n                                &::after {\n                                    flex-grow: 1;\n                                    height: 1px;\n                                    content: \"\";\n                                    background-color: currentColor;\n                                }\n                                &::before {\n                                    margin-right: 1rem;\n                                }\n                                &::after {\n                                    margin-left: 1rem;\n                                }\n                            `}\n                            {...labelProps}\n                        >\n                            {formatedDate}\n                        </Typography>\n                        <div\n                            css={css`\n                                margin-top: ${theme.spacing * 2}px;\n                                margin-bottom: ${theme.spacing * 2}px;\n                                &:first-of-type {\n                                    margin-top: 0px;\n                                }\n                                &:last-of-type {\n                                    margin-bottom: 0px;\n                                }\n                            `}\n                        >\n                            {renderItems(propsArray)}\n                        </div>\n                    </React.Fragment>\n                )\n            })}\n        </div>\n    ) : null\n}\n"]} */")
156
+ css: /*#__PURE__*/css("margin-top:", theme.spacing * 2, "px;margin-bottom:", theme.spacing * 2, "px;&:first-of-type{margin-top:0px;}&:last-of-type{margin-bottom:0px;}" + (process.env.NODE_ENV === "production" ? "" : ";label:Timeline;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":[],"mappings":"AA0PoC","file":"../../../src/Timeline/Timeline.tsx","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\nimport type { Unit } from \"relative-time-format\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n    /**\n     * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n     */\n    item: (\n        props: Props & {\n            date: string\n            index: number\n        }\n    ) => JSX.Element\n    /**\n     * 日付と、日付に対応するデータ群を指定します。\n     *\n     * 昇順でkeyがソートされていることを前提としている点に注意してください。\n     *\n     * ソート処理が面倒な場合はUI側での処理を検討します。\n     *\n     * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n     *\n     * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n     *\n     * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n     *\n     */\n    dates: {\n        [date: string]: Props[]\n    }\n    /**\n     * 区分ごとのラベルの表記を指定します。\n     *\n     * @default {year: numeric ,month: numeric, day: numeric}\n     */\n    format?: \"relative\" | Intl.DateTimeFormatOptions\n    /**\n     * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n     *\n     * 原点のデフォルトは\"今日\"。\n     *\n     * 過去から未来へ昇順でソートされていることを前提にしています。\n     * ソート処理が難しい場合はUI側での処理を検討します。\n     *\n     * @default []\n     */\n    separators?: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[]\n    /**\n     * 未対応。このコンポーネントのルート要素を指定する。\n     * @default div\n     */\n    container?: React.ElementType\n    /**\n     * 未対応。区分ごとに表示されるラベル要素を指定する。\n     * @default div\n     */\n    label?: (props: { date: string }) => JSX.Element\n    /**\n     * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n     */\n    labelProps?: BaseTypographyProps\n    /**\n     * 未対応。原点を指定する。\n     *\n     * フォーマットはYYYYMMDDまたは`today`\n     *\n     * number (ms) | Date には対応予定。\n     *\n     * @default today\n     */\n    origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n    dates: {\n        [date: string]: E[]\n    },\n    separators: {\n        unit: \"day\" | \"month\" | \"year\" | \"week\"\n        value: number\n    }[],\n    origin: dayjs.Dayjs\n) => {\n    if (separators.length === 0) {\n        return {\n            prevPropsArray: [],\n            datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n                const diff = dayjs(date).diff(origin, \"day\")\n                return [\n                    date,\n                    propsArray.map((props) => ({\n                        ...props,\n                        date\n                    })),\n                    {\n                        unit: \"day\",\n                        diff\n                    }\n                ] as const\n            })\n        }\n    }\n\n    const copy = { ...dates }\n    // prevProps\n    let prevProps: (E & { date: string })[] = []\n    const min = origin.add(separators[0].value, separators[0].unit)\n    for (const date in copy) {\n        if (dayjs(date).isBefore(min, \"day\")) {\n            const add = copy[date].map((props) => ({ ...props, date }))\n            prevProps = prevProps.concat(add)\n            delete copy[date]\n        } else {\n            break\n        }\n    }\n    let results: (readonly [\n        string,\n        (E & {\n            date: string\n        })[],\n        {\n            unit: string\n            diff: number\n        }\n    ])[] = []\n    separators.map(({ unit, value }, index, original) => {\n        const min = origin.add(value, unit)\n        const max =\n            separators.length - 1 === index\n                ? dayjs(\"9999/12/24\")\n                : origin.add(original[index + 1].value, original[index + 1].unit)\n        let propsArray: (E & { date: string })[] = []\n        for (const date in copy) {\n            if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n                const add = copy[date].map((props) => ({ ...props, date }))\n                propsArray = propsArray.concat(add)\n                delete copy[date]\n            } else {\n                break\n            }\n        }\n        if (propsArray.length > 0) {\n            results = results.concat([\n                [\n                    min.format(\"YYYYMMDD\"),\n                    propsArray,\n                    {\n                        unit,\n                        diff: value\n                    }\n                ]\n            ])\n        }\n    })\n    return {\n        prevPropsArray: prevProps,\n        datesEntries: results\n    }\n}\n\nconst makeRenderItems =\n    <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n    (propsArray: (E & { date: string })[]) => {\n        return propsArray.map((props, index) =>\n            React.cloneElement(renderItem({ ...props, index }), {\n                key: `${props.date}.${index}`\n            })\n        )\n    }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n    item,\n    dates,\n    format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n    separators = [],\n    labelProps,\n    ...props\n}: TimelineProps<E>) => {\n    const locale = useContext(LocaleContext)\n    const rtf = useMemo(() => {\n        return RelativeTimeFormat(locale, {\n            numeric: \"auto\"\n        })\n    }, [locale])\n    const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n    const theme = useTheme()\n    const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n    const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n    return datesEntries.length > 0 ? (\n        <div {...props}>\n            {prevPropsArray.length > 0 && (\n                <div\n                    css={css`\n                        margin-top: ${theme.spacing * 2}px;\n                        margin-bottom: ${theme.spacing * 2}px;\n                        &:first-of-type {\n                            margin-top: 0px;\n                        }\n                        &:last-of-type {\n                            margin-bottom: 0px;\n                        }\n                    `}\n                >\n                    {renderItems(prevPropsArray)}\n                </div>\n            )}\n            {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n                const formatedDate =\n                    format === \"relative\"\n                        ? rtf.format(diff, unit as Unit)\n                        : dayjs(value).toDate().toLocaleDateString(locale, format)\n                return (\n                    <React.Fragment key={formatedDate}>\n                        <Typography\n                            css={css`\n                                display: flex;\n                                align-items: center;\n                                margin-top: ${theme.spacing}px;\n                                margin-bottom: ${theme.spacing}px;\n                                &::before,\n                                &::after {\n                                    flex-grow: 1;\n                                    height: 1px;\n                                    content: \"\";\n                                    background-color: currentColor;\n                                }\n                                &::before {\n                                    margin-right: 1rem;\n                                }\n                                &::after {\n                                    margin-left: 1rem;\n                                }\n                            `}\n                            {...labelProps}\n                        >\n                            {formatedDate}\n                        </Typography>\n                        <div\n                            css={css`\n                                margin-top: ${theme.spacing * 2}px;\n                                margin-bottom: ${theme.spacing * 2}px;\n                                &:first-of-type {\n                                    margin-top: 0px;\n                                }\n                                &:last-of-type {\n                                    margin-bottom: 0px;\n                                }\n                            `}\n                        >\n                            {renderItems(propsArray)}\n                        </div>\n                    </React.Fragment>\n                )\n            })}\n        </div>\n    ) : null\n}\n"]} */")
157
157
  }, renderItems(propsArray)));
158
158
  })) : null;
159
159
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":["Typography","LocaleContext","RelativeTimeFormat","css","useTheme","React","useContext","useMemo","dayjs","getDatesEntries","dates","separators","origin","length","prevPropsArray","datesEntries","Object","entries","map","date","propsArray","diff","props","unit","copy","prevProps","min","add","value","isBefore","concat","results","index","original","max","isBetween","format","makeRenderItems","renderItem","cloneElement","key","Timeline","item","year","month","day","labelProps","locale","rtf","numeric","now","theme","renderItems","spacing","formatedDate","toDate","toLocaleDateString"],"mappings":";;;;;;;;;;;;;;AAAA,SAA8BA,UAA9B,QAAgD,eAAhD;AACA,SAASC,aAAT,QAA8B,mBAA9B;AACA,SAASC,kBAAT,QAAmC,WAAnC;AACA,SAASC,GAAT,QAAoB,gBAApB;AACA,SAASC,QAAT,QAAyB,UAAzB;AACA,OAAOC,KAAP,IAAgBC,UAAhB,EAA4BC,OAA5B,QAA2C,OAA3C;AACA,OAAOC,KAAP,MAAkB,UAAlB;;;AA2EA,IAAMC,eAAe,GAAG,CACpBC,KADoB,EAIpBC,UAJoB,EAQpBC,MARoB,KASnB;AACD,MAAID,UAAU,CAACE,MAAX,KAAsB,CAA1B,EAA6B;AACzB,WAAO;AACHC,MAAAA,cAAc,EAAE,EADb;AAEHC,MAAAA,YAAY,EAAEC,MAAM,CAACC,OAAP,CAAeP,KAAf,EAAsBQ,GAAtB,CAA0B,QAAwB;AAAA,YAAvB,CAACC,IAAD,EAAOC,UAAP,CAAuB;AAC5D,YAAMC,IAAI,GAAGb,KAAK,CAACW,IAAD,CAAL,CAAYE,IAAZ,CAAiBT,MAAjB,EAAyB,KAAzB,CAAb;AACA,eAAO,CACHO,IADG,EAEHC,UAAU,CAACF,GAAX,CAAgBI,KAAD,oCACRA,KADQ;AAEXH,UAAAA;AAFW,UAAf,CAFG,EAMH;AACII,UAAAA,IAAI,EAAE,KADV;AAEIF,UAAAA;AAFJ,SANG,CAAP;AAWH,OAba;AAFX,KAAP;AAiBH;;AAED,MAAMG,IAAI,qBAAQd,KAAR,CAAV,CArBC,CAsBD;;;AACA,MAAIe,SAAmC,GAAG,EAA1C;AACA,MAAMC,GAAG,GAAGd,MAAM,CAACe,GAAP,CAAWhB,UAAU,CAAC,CAAD,CAAV,CAAciB,KAAzB,EAAgCjB,UAAU,CAAC,CAAD,CAAV,CAAcY,IAA9C,CAAZ;;AAxBC,6BAyBUJ,KAzBV;AA0BG,QAAIX,KAAK,CAACW,KAAD,CAAL,CAAYU,QAAZ,CAAqBH,GAArB,EAA0B,KAA1B,CAAJ,EAAsC;AAClC,UAAMC,GAAG,GAAGH,IAAI,CAACL,KAAD,CAAJ,CAAWD,GAAX,CAAgBI,KAAD,oCAAiBA,KAAjB;AAAwBH,QAAAA,IAAI,EAAJA;AAAxB,QAAf,CAAZ;;AACAM,MAAAA,SAAS,GAAGA,SAAS,CAACK,MAAV,CAAiBH,GAAjB,CAAZ;AACA,aAAOH,IAAI,CAACL,KAAD,CAAX;AACH,KAJD,MAIO;AACH;AACH;AAhCJ;;AAyBD,OAAK,IAAMA,KAAX,IAAmBK,IAAnB,EAAyB;AAAA,qBAAdL,KAAc;;AAAA,0BAMjB;AAEP;;AACD,MAAIY,OASA,GAAG,EATP;AAUApB,EAAAA,UAAU,CAACO,GAAX,CAAe,QAAkBc,KAAlB,EAAyBC,QAAzB,KAAsC;AAAA,QAArC;AAAEV,MAAAA,IAAF;AAAQK,MAAAA;AAAR,KAAqC;AACjD,QAAMF,GAAG,GAAGd,MAAM,CAACe,GAAP,CAAWC,KAAX,EAAkBL,IAAlB,CAAZ;AACA,QAAMW,GAAG,GACLvB,UAAU,CAACE,MAAX,GAAoB,CAApB,KAA0BmB,KAA1B,GACMxB,KAAK,CAAC,YAAD,CADX,GAEMI,MAAM,CAACe,GAAP,CAAWM,QAAQ,CAACD,KAAK,GAAG,CAAT,CAAR,CAAoBJ,KAA/B,EAAsCK,QAAQ,CAACD,KAAK,GAAG,CAAT,CAAR,CAAoBT,IAA1D,CAHV;AAIA,QAAIH,UAAoC,GAAG,EAA3C;;AANiD,iCAOtCD,MAPsC;AAQ7C,UAAIX,KAAK,CAACW,MAAD,CAAL,CAAYgB,SAAZ,CAAsBT,GAAtB,EAA2BQ,GAA3B,EAAgC,KAAhC,EAAuC,IAAvC,CAAJ,EAAkD;AAC9C,YAAMP,GAAG,GAAGH,IAAI,CAACL,MAAD,CAAJ,CAAWD,GAAX,CAAgBI,KAAD,oCAAiBA,KAAjB;AAAwBH,UAAAA,IAAI,EAAJA;AAAxB,UAAf,CAAZ;;AACAC,QAAAA,UAAU,GAAGA,UAAU,CAACU,MAAX,CAAkBH,GAAlB,CAAb;AACA,eAAOH,IAAI,CAACL,MAAD,CAAX;AACH,OAJD,MAIO;AACH;AACH;AAd4C;;AAOjD,SAAK,IAAMA,MAAX,IAAmBK,IAAnB,EAAyB;AAAA,yBAAdL,MAAc;;AAAA,6BAMjB;AAEP;;AACD,QAAIC,UAAU,CAACP,MAAX,GAAoB,CAAxB,EAA2B;AACvBkB,MAAAA,OAAO,GAAGA,OAAO,CAACD,MAAR,CAAe,CACrB,CACIJ,GAAG,CAACU,MAAJ,CAAW,UAAX,CADJ,EAEIhB,UAFJ,EAGI;AACIG,QAAAA,IADJ;AAEIF,QAAAA,IAAI,EAAEO;AAFV,OAHJ,CADqB,CAAf,CAAV;AAUH;AACJ,GA5BD;AA6BA,SAAO;AACHd,IAAAA,cAAc,EAAEW,SADb;AAEHV,IAAAA,YAAY,EAAEgB;AAFX,GAAP;AAIH,CAtFD;;AAwFA,IAAMM,eAAe,GACuBC,UAAxC,IACClB,UAAD,IAA0C;AACtC,SAAOA,UAAU,CAACF,GAAX,CAAe,CAACI,KAAD,EAAQU,KAAR,kBAClB3B,KAAK,CAACkC,YAAN,CAAmBD,UAAU,iCAAMhB,KAAN;AAAaU,IAAAA;AAAb,KAA7B,EAAoD;AAChDQ,IAAAA,GAAG,YAAKlB,KAAK,CAACH,IAAX,cAAmBa,KAAnB;AAD6C,GAApD,CADG,CAAP;AAKH,CARL;;AAUA,OAAO,IAAMS,QAAQ,GAAG,SAOA;AAAA,MAPwC;AAC5DC,IAAAA,IAD4D;AAE5DhC,IAAAA,KAF4D;AAG5D0B,IAAAA,MAAM,GAAG;AAAEO,MAAAA,IAAI,EAAE,SAAR;AAAmBC,MAAAA,KAAK,EAAE,SAA1B;AAAqCC,MAAAA,GAAG,EAAE;AAA1C,KAHmD;AAI5DlC,IAAAA,UAAU,GAAG,EAJ+C;AAK5DmC,IAAAA;AAL4D,GAOxC;AAAA,MADjBxB,KACiB;;AACpB,MAAMyB,MAAM,GAAGzC,UAAU,CAACL,aAAD,CAAzB;AACA,MAAM+C,GAAG,GAAGzC,OAAO,CAAC,MAAM;AACtB,WAAOL,kBAAkB,CAAC6C,MAAD,EAAS;AAC9BE,MAAAA,OAAO,EAAE;AADqB,KAAT,CAAzB;AAGH,GAJkB,EAIhB,CAACF,MAAD,CAJgB,CAAnB;AAKA,MAAMG,GAAG,GAAG3C,OAAO,CAAC,MAAMC,KAAK,CAACA,KAAK,GAAG4B,MAAR,CAAe,UAAf,CAAD,CAAZ,EAA0C,EAA1C,CAAnB;AACA,MAAMe,KAAK,GAAG/C,QAAQ,EAAtB;AACA,MAAM;AAAEU,IAAAA,cAAF;AAAkBC,IAAAA;AAAlB,MAAmCN,eAAe,CAAIC,KAAJ,EAAWC,UAAX,EAAuBuC,GAAvB,CAAxD;AAEA,MAAME,WAAW,GAAG7C,OAAO,CAAC,MAAM8B,eAAe,CAAIK,IAAJ,CAAtB,EAAiC,CAACA,IAAD,CAAjC,CAA3B;AAEA,SAAO3B,YAAY,CAACF,MAAb,GAAsB,CAAtB,GACH,qBAASS,KAAT,EACKR,cAAc,CAACD,MAAf,GAAwB,CAAxB,IACG;AACI,IAAA,GAAG,eAAEV,GAAF,gBACegD,KAAK,CAACE,OAAN,GAAgB,CAD/B,uBAEkBF,KAAK,CAACE,OAAN,GAAgB,CAFlC;AADP,KAYKD,WAAW,CAACtC,cAAD,CAZhB,CAFR,EAiBKC,YAAY,CAACG,GAAb,CAAiB,SAAyC;AAAA,QAAxC,CAACU,KAAD,EAAQR,UAAR,EAAoB;AAAEG,MAAAA,IAAF;AAAQF,MAAAA;AAAR,KAApB,CAAwC;AACvD,QAAMiC,YAAY,GACdlB,MAAM,KAAK,UAAX,GACMY,GAAG,CAACZ,MAAJ,CAAWf,IAAX,EAAiBE,IAAjB,CADN,GAEMf,KAAK,CAACoB,KAAD,CAAL,CAAa2B,MAAb,GAAsBC,kBAAtB,CAAyCT,MAAzC,EAAiDX,MAAjD,CAHV;AAIA,WACI,cAAC,KAAD,CAAO,QAAP;AAAgB,MAAA,GAAG,EAAEkB;AAArB,OACI,cAAC,UAAD;AACI,MAAA,GAAG,eAAEnD,GAAF,gDAGegD,KAAK,CAACE,OAHrB,uBAIkBF,KAAK,CAACE,OAJxB;AADP,OAoBQP,UApBR,GAsBKQ,YAtBL,CADJ,EAyBI;AACI,MAAA,GAAG,eAAEnD,GAAF,gBACegD,KAAK,CAACE,OAAN,GAAgB,CAD/B,uBAEkBF,KAAK,CAACE,OAAN,GAAgB,CAFlC;AADP,OAYKD,WAAW,CAAChC,UAAD,CAZhB,CAzBJ,CADJ;AA0CH,GA/CA,CAjBL,CADG,GAmEH,IAnEJ;AAoEH,CAxFM","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n */\n item: (\n props: Props & {\n date: string\n index: number\n }\n ) => JSX.Element\n /**\n * 日付と、日付に対応するデータ群を指定します。\n *\n * 昇順でkeyがソートされていることを前提としている点に注意してください。\n *\n * ソート処理が面倒な場合はUI側での処理を検討します。\n *\n * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n *\n * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n *\n * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n *\n */\n dates: {\n [date: string]: Props[]\n }\n /**\n * 区分ごとのラベルの表記を指定します。\n *\n * @default {year: numeric ,month: numeric, day: numeric}\n */\n format?: \"relative\" | Intl.DateTimeFormatOptions\n /**\n * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n *\n * 原点のデフォルトは\"今日\"。\n *\n * 過去から未来へ昇順でソートされていることを前提にしています。\n * ソート処理が難しい場合はUI側での処理を検討します。\n *\n * @default []\n */\n separators?: {\n unit: \"day\" | \"month\" | \"year\" | \"week\"\n value: number\n }[]\n /**\n * 未対応。このコンポーネントのルート要素を指定する。\n * @default div\n */\n container?: React.ElementType\n /**\n * 未対応。区分ごとに表示されるラベル要素を指定する。\n * @default div\n */\n label?: (props: { date: string }) => JSX.Element\n /**\n * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n */\n labelProps?: BaseTypographyProps\n /**\n * 未対応。原点を指定する。\n *\n * フォーマットはYYYYMMDDまたは`today`\n *\n * number (ms) | Date には対応予定。\n *\n * @default today\n */\n origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n dates: {\n [date: string]: E[]\n },\n separators: {\n unit: \"day\" | \"month\" | \"year\" | \"week\"\n value: number\n }[],\n origin: dayjs.Dayjs\n) => {\n if (separators.length === 0) {\n return {\n prevPropsArray: [],\n datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n const diff = dayjs(date).diff(origin, \"day\")\n return [\n date,\n propsArray.map((props) => ({\n ...props,\n date\n })),\n {\n unit: \"day\",\n diff\n }\n ] as const\n })\n }\n }\n\n const copy = { ...dates }\n // prevProps\n let prevProps: (E & { date: string })[] = []\n const min = origin.add(separators[0].value, separators[0].unit)\n for (const date in copy) {\n if (dayjs(date).isBefore(min, \"day\")) {\n const add = copy[date].map((props) => ({ ...props, date }))\n prevProps = prevProps.concat(add)\n delete copy[date]\n } else {\n break\n }\n }\n let results: (readonly [\n string,\n (E & {\n date: string\n })[],\n {\n unit: string\n diff: number\n }\n ])[] = []\n separators.map(({ unit, value }, index, original) => {\n const min = origin.add(value, unit)\n const max =\n separators.length - 1 === index\n ? dayjs(\"9999/12/24\")\n : origin.add(original[index + 1].value, original[index + 1].unit)\n let propsArray: (E & { date: string })[] = []\n for (const date in copy) {\n if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n const add = copy[date].map((props) => ({ ...props, date }))\n propsArray = propsArray.concat(add)\n delete copy[date]\n } else {\n break\n }\n }\n if (propsArray.length > 0) {\n results = results.concat([\n [\n min.format(\"YYYYMMDD\"),\n propsArray,\n {\n unit,\n diff: value\n }\n ]\n ])\n }\n })\n return {\n prevPropsArray: prevProps,\n datesEntries: results\n }\n}\n\nconst makeRenderItems =\n <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n (propsArray: (E & { date: string })[]) => {\n return propsArray.map((props, index) =>\n React.cloneElement(renderItem({ ...props, index }), {\n key: `${props.date}.${index}`\n })\n )\n }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n item,\n dates,\n format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n separators = [],\n labelProps,\n ...props\n}: TimelineProps<E>) => {\n const locale = useContext(LocaleContext)\n const rtf = useMemo(() => {\n return RelativeTimeFormat(locale, {\n numeric: \"auto\"\n })\n }, [locale])\n const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n const theme = useTheme()\n const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n return datesEntries.length > 0 ? (\n <div {...props}>\n {prevPropsArray.length > 0 && (\n <div\n css={css`\n margin-top: ${theme.spacing * 2}px;\n margin-bottom: ${theme.spacing * 2}px;\n &:first-of-type {\n margin-top: 0px;\n }\n &:last-of-type {\n margin-bottom: 0px;\n }\n `}\n >\n {renderItems(prevPropsArray)}\n </div>\n )}\n {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n const formatedDate =\n format === \"relative\"\n ? rtf.format(diff, unit)\n : dayjs(value).toDate().toLocaleDateString(locale, format)\n return (\n <React.Fragment key={formatedDate}>\n <Typography\n css={css`\n display: flex;\n align-items: center;\n margin-top: ${theme.spacing}px;\n margin-bottom: ${theme.spacing}px;\n &::before,\n &::after {\n flex-grow: 1;\n height: 1px;\n content: \"\";\n background-color: currentColor;\n }\n &::before {\n margin-right: 1rem;\n }\n &::after {\n margin-left: 1rem;\n }\n `}\n {...labelProps}\n >\n {formatedDate}\n </Typography>\n <div\n css={css`\n margin-top: ${theme.spacing * 2}px;\n margin-bottom: ${theme.spacing * 2}px;\n &:first-of-type {\n margin-top: 0px;\n }\n &:last-of-type {\n margin-bottom: 0px;\n }\n `}\n >\n {renderItems(propsArray)}\n </div>\n </React.Fragment>\n )\n })}\n </div>\n ) : null\n}\n"],"file":"Timeline.js"}
1
+ {"version":3,"sources":["../../../src/Timeline/Timeline.tsx"],"names":["Typography","LocaleContext","RelativeTimeFormat","css","useTheme","React","useContext","useMemo","dayjs","getDatesEntries","dates","separators","origin","length","prevPropsArray","datesEntries","Object","entries","map","date","propsArray","diff","props","unit","copy","prevProps","min","add","value","isBefore","concat","results","index","original","max","isBetween","format","makeRenderItems","renderItem","cloneElement","key","Timeline","item","year","month","day","labelProps","locale","rtf","numeric","now","theme","renderItems","spacing","formatedDate","toDate","toLocaleDateString"],"mappings":"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","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { LocaleContext } from \"../LocaleProvider\"\nimport { RelativeTimeFormat } from \"../@utils\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport React, { useContext, useMemo } from \"react\"\nimport dayjs from \"../dayjs\"\nimport type { Unit } from \"relative-time-format\"\n\nexport interface TimelineProps<Props extends { [key: string]: any }> extends React.HTMLAttributes<HTMLDivElement> {\n /**\n * TimelineProps.datesで指定されたデータをpropsとして受け取り表示するためのコンポーネントを指定します。\n */\n item: (\n props: Props & {\n date: string\n index: number\n }\n ) => JSX.Element\n /**\n * 日付と、日付に対応するデータ群を指定します。\n *\n * 昇順でkeyがソートされていることを前提としている点に注意してください。\n *\n * ソート処理が面倒な場合はUI側での処理を検討します。\n *\n * ここで値として指定された配列の型はTimelineProps.itemの引数に用いられます。\n *\n * dateのフォーマットはYYYYMMDDまたはYYYY-MM-DDです。number(ms)には後に対応するかもしれません。\n *\n * Date型を利用したいという強い要望があった場合はMapに切り替えることを検討します。\n *\n */\n dates: {\n [date: string]: Props[]\n }\n /**\n * 区分ごとのラベルの表記を指定します。\n *\n * @default {year: numeric ,month: numeric, day: numeric}\n */\n format?: \"relative\" | Intl.DateTimeFormatOptions\n /**\n * 区分を指定する。原点を中心として両側に、順に指定された区分点を配置していく。\n *\n * 原点のデフォルトは\"今日\"。\n *\n * 過去から未来へ昇順でソートされていることを前提にしています。\n * ソート処理が難しい場合はUI側での処理を検討します。\n *\n * @default []\n */\n separators?: {\n unit: \"day\" | \"month\" | \"year\" | \"week\"\n value: number\n }[]\n /**\n * 未対応。このコンポーネントのルート要素を指定する。\n * @default div\n */\n container?: React.ElementType\n /**\n * 未対応。区分ごとに表示されるラベル要素を指定する。\n * @default div\n */\n label?: (props: { date: string }) => JSX.Element\n /**\n * 区分ごとに表示されるラベル要素に渡すPropsを指定する。\n */\n labelProps?: BaseTypographyProps\n /**\n * 未対応。原点を指定する。\n *\n * フォーマットはYYYYMMDDまたは`today`\n *\n * number (ms) | Date には対応予定。\n *\n * @default today\n */\n origin?: string\n}\n\nconst getDatesEntries = <E extends { [key: string]: any }>(\n dates: {\n [date: string]: E[]\n },\n separators: {\n unit: \"day\" | \"month\" | \"year\" | \"week\"\n value: number\n }[],\n origin: dayjs.Dayjs\n) => {\n if (separators.length === 0) {\n return {\n prevPropsArray: [],\n datesEntries: Object.entries(dates).map(([date, propsArray]) => {\n const diff = dayjs(date).diff(origin, \"day\")\n return [\n date,\n propsArray.map((props) => ({\n ...props,\n date\n })),\n {\n unit: \"day\",\n diff\n }\n ] as const\n })\n }\n }\n\n const copy = { ...dates }\n // prevProps\n let prevProps: (E & { date: string })[] = []\n const min = origin.add(separators[0].value, separators[0].unit)\n for (const date in copy) {\n if (dayjs(date).isBefore(min, \"day\")) {\n const add = copy[date].map((props) => ({ ...props, date }))\n prevProps = prevProps.concat(add)\n delete copy[date]\n } else {\n break\n }\n }\n let results: (readonly [\n string,\n (E & {\n date: string\n })[],\n {\n unit: string\n diff: number\n }\n ])[] = []\n separators.map(({ unit, value }, index, original) => {\n const min = origin.add(value, unit)\n const max =\n separators.length - 1 === index\n ? dayjs(\"9999/12/24\")\n : origin.add(original[index + 1].value, original[index + 1].unit)\n let propsArray: (E & { date: string })[] = []\n for (const date in copy) {\n if (dayjs(date).isBetween(min, max, \"day\", \"[)\")) {\n const add = copy[date].map((props) => ({ ...props, date }))\n propsArray = propsArray.concat(add)\n delete copy[date]\n } else {\n break\n }\n }\n if (propsArray.length > 0) {\n results = results.concat([\n [\n min.format(\"YYYYMMDD\"),\n propsArray,\n {\n unit,\n diff: value\n }\n ]\n ])\n }\n })\n return {\n prevPropsArray: prevProps,\n datesEntries: results\n }\n}\n\nconst makeRenderItems =\n <E extends { [key: string]: any } = {}>(renderItem: (props: E & { date: string; index: number }) => JSX.Element) =>\n (propsArray: (E & { date: string })[]) => {\n return propsArray.map((props, index) =>\n React.cloneElement(renderItem({ ...props, index }), {\n key: `${props.date}.${index}`\n })\n )\n }\n\nexport const Timeline = <E extends { [key: string]: any } = {}>({\n item,\n dates,\n format = { year: \"numeric\", month: \"numeric\", day: \"numeric\" },\n separators = [],\n labelProps,\n ...props\n}: TimelineProps<E>) => {\n const locale = useContext(LocaleContext)\n const rtf = useMemo(() => {\n return RelativeTimeFormat(locale, {\n numeric: \"auto\"\n })\n }, [locale])\n const now = useMemo(() => dayjs(dayjs().format(\"YYYYMMDD\")), [])\n const theme = useTheme()\n const { prevPropsArray, datesEntries } = getDatesEntries<E>(dates, separators, now)\n\n const renderItems = useMemo(() => makeRenderItems<E>(item), [item])\n\n return datesEntries.length > 0 ? (\n <div {...props}>\n {prevPropsArray.length > 0 && (\n <div\n css={css`\n margin-top: ${theme.spacing * 2}px;\n margin-bottom: ${theme.spacing * 2}px;\n &:first-of-type {\n margin-top: 0px;\n }\n &:last-of-type {\n margin-bottom: 0px;\n }\n `}\n >\n {renderItems(prevPropsArray)}\n </div>\n )}\n {datesEntries.map(([value, propsArray, { unit, diff }]) => {\n const formatedDate =\n format === \"relative\"\n ? rtf.format(diff, unit as Unit)\n : dayjs(value).toDate().toLocaleDateString(locale, format)\n return (\n <React.Fragment key={formatedDate}>\n <Typography\n css={css`\n display: flex;\n align-items: center;\n margin-top: ${theme.spacing}px;\n margin-bottom: ${theme.spacing}px;\n &::before,\n &::after {\n flex-grow: 1;\n height: 1px;\n content: \"\";\n background-color: currentColor;\n }\n &::before {\n margin-right: 1rem;\n }\n &::after {\n margin-left: 1rem;\n }\n `}\n {...labelProps}\n >\n {formatedDate}\n </Typography>\n <div\n css={css`\n margin-top: ${theme.spacing * 2}px;\n margin-bottom: ${theme.spacing * 2}px;\n &:first-of-type {\n margin-top: 0px;\n }\n &:last-of-type {\n margin-bottom: 0px;\n }\n `}\n >\n {renderItems(propsArray)}\n </div>\n </React.Fragment>\n )\n })}\n </div>\n ) : null\n}\n"],"file":"Timeline.js"}
@@ -1,3 +1,4 @@
1
+ import { default as _RelativeTimeFormat } from "relative-time-format";
1
2
  export interface RelativeTimeFormatOptions {
2
3
  /**
3
4
  * The locale matching algorithm to use. Possible values are "lookup" and "best fit"
@@ -19,7 +20,4 @@ export interface RelativeTimeFormatOptions {
19
20
  */
20
21
  style?: "long" | "short" | "narrow";
21
22
  }
22
- export declare const RelativeTimeFormat: (locale: string, options: object) => {
23
- format(day: number, unit: string): string;
24
- getRule(day: number, unit: string): string;
25
- };
23
+ export declare const RelativeTimeFormat: (locale: string, options: object) => _RelativeTimeFormat;
@@ -1,9 +1,9 @@
1
- import { FieldProps } from "../TextField";
1
+ import { ContolledFieldProps, UncontolledFieldProps } from "../TextField";
2
2
  import { InputBottomGutterProps } from "../FormHelperText";
3
3
  import { InputBaseProps } from "../InputBase";
4
4
  import { NumberFormatOptions } from "./NumberFormatOptions";
5
5
  import React from "react";
6
- export interface NumberFieldProps extends FieldProps<number>, Omit<InputBaseProps, "defaultValue" | "value" | "onChange">, InputBottomGutterProps {
6
+ interface CommonNumberFieldProps extends Omit<InputBaseProps, "defaultValue" | "value" | "onChange">, InputBottomGutterProps {
7
7
  /**
8
8
  * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/NumberFormat
9
9
  */
@@ -23,4 +23,10 @@ export interface NumberFieldProps extends FieldProps<number>, Omit<InputBaseProp
23
23
  */
24
24
  min?: number;
25
25
  }
26
+ export interface ControlledNumberFieldProps extends CommonNumberFieldProps, ContolledFieldProps<number> {
27
+ }
28
+ export interface UncontrolledNumberFieldProps extends CommonNumberFieldProps, UncontolledFieldProps<number> {
29
+ }
30
+ export declare type NumberFieldProps = ControlledNumberFieldProps | UncontrolledNumberFieldProps;
26
31
  export declare const NumberField: React.ForwardRefExoticComponent<Readonly<NumberFieldProps> & React.RefAttributes<HTMLDivElement>>;
32
+ export {};
@@ -2,9 +2,7 @@ import { FieldGroupProps } from "../FieldGroup";
2
2
  import { InputBottomGutterProps } from "../FormHelperText";
3
3
  import { InputBaseProps } from "../InputBase";
4
4
  import React from "react";
5
- export interface FieldProps<T> extends FieldGroupProps {
6
- value?: T;
7
- defaultValue?: T;
5
+ interface CommonFieldProps<T> extends FieldGroupProps {
8
6
  /**
9
7
  * ラベルの文字列を指定します。ラベルは左上に表示されます。
10
8
  */
@@ -19,13 +17,6 @@ export interface FieldProps<T> extends FieldGroupProps {
19
17
  validationMessages?: {
20
18
  [key in keyof ValidityState]?: string;
21
19
  };
22
- /**
23
- * inputの値が更新された場合に発火します。
24
- *
25
- * onChangeが呼ばれるタイミングと内部実装の値が変更されるタイミングは異なります。
26
- * そのため、onChange発火直後にformなどのrefから値を取得しようとするとズレが発生する場合があります。
27
- */
28
- onChange?: (value: T, event?: React.SyntheticEvent<HTMLElement>) => void;
29
20
  /**
30
21
  * 任意のヘルパーテキストを挿入できます。ただしinput要素本来のバリデーションの方が優先されます。
31
22
  */
@@ -37,6 +28,34 @@ export interface FieldProps<T> extends FieldGroupProps {
37
28
  */
38
29
  invalid?: boolean;
39
30
  }
31
+ /**
32
+ * 厳密にUncontrolledなFieldコンポーネントとして扱いたい場合は、この型を利用してください。
33
+ */
34
+ export interface UncontolledFieldProps<T> extends CommonFieldProps<T> {
35
+ defaultValue: T;
36
+ value?: never;
37
+ onChange?: (value: T, event?: React.SyntheticEvent<HTMLElement>) => void;
38
+ }
39
+ /**
40
+ * 厳密にControlledなFieldコンポーネントとして扱いたい場合は、この型を利用してください。
41
+ */
42
+ export interface ContolledFieldProps<T> extends CommonFieldProps<T> {
43
+ defaultValue?: never;
44
+ value: T;
45
+ onChange: (value: T, event?: React.SyntheticEvent<HTMLElement>) => void;
46
+ }
47
+ export interface FieldProps<T> extends CommonFieldProps<T> {
48
+ value?: T;
49
+ defaultValue?: T;
50
+ /**
51
+ * inputの値が更新された場合に発火します。
52
+ *
53
+ * onChangeが呼ばれるタイミングと内部実装の値が変更されるタイミングは異なります。
54
+ * そのため、onChange発火直後にformなどのrefから値を取得しようとするとズレが発生する場合があります。
55
+ */
56
+ onChange?: (value: T, event?: React.SyntheticEvent<HTMLElement>) => void;
57
+ }
40
58
  export interface TextFieldProps extends FieldProps<string>, Omit<InputBaseProps, "value" | "onChange" | "defaultValue">, InputBottomGutterProps {
41
59
  }
42
60
  export declare const TextField: React.ForwardRefExoticComponent<TextFieldProps & React.RefAttributes<HTMLDivElement>>;
61
+ export {};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "matsuri-ui",
3
- "version": "10.2.4",
3
+ "version": "10.3.0",
4
4
  "repository": "https://github.com/matsuri-tech/matsuri-ui.git",
5
5
  "license": "GPL-3.0",
6
6
  "sideEffects": false,
@@ -26,19 +26,19 @@
26
26
  ],
27
27
  "dependencies": {
28
28
  "@emotion/styled": "^11.8.1",
29
- "@mui/icons-material": "^5.5.0",
30
- "@mui/material": "^5.5.0",
29
+ "@mui/icons-material": "^5.5.1",
30
+ "@mui/material": "^5.5.3",
31
31
  "@popperjs/core": "^2.11.4",
32
32
  "clsx": "^1.1.1",
33
- "dayjs": "^1.10.8",
33
+ "dayjs": "^1.11.0",
34
34
  "react-spring": "^8.0.27",
35
35
  "relative-time-format": "^1.0.7",
36
36
  "resize-observer-polyfill": "^1.5.1"
37
37
  },
38
38
  "peerDependencies": {
39
39
  "@emotion/react": "11.8.2",
40
- "@types/react": "17.0.40",
41
- "@types/react-dom": "17.0.13",
40
+ "@types/react": "17.0.43",
41
+ "@types/react-dom": "17.0.14",
42
42
  "react": "17.0.2",
43
43
  "react-dom": "17.0.2"
44
44
  },
@@ -55,35 +55,35 @@
55
55
  },
56
56
  "devDependencies": {
57
57
  "@babel/cli": "7.17.6",
58
- "@babel/core": "7.17.5",
58
+ "@babel/core": "7.17.8",
59
59
  "@babel/preset-env": "7.16.11",
60
60
  "@babel/preset-react": "7.16.7",
61
61
  "@babel/preset-typescript": "^7.16.7",
62
62
  "@emotion/babel-preset-css-prop": "11.2.0",
63
63
  "@emotion/react": "11.8.2",
64
- "@storybook/addon-essentials": "^6.4.19",
65
- "@storybook/addon-links": "6.4.19",
66
- "@storybook/react": "6.4.19",
64
+ "@storybook/addon-essentials": "^6.4.20",
65
+ "@storybook/addon-links": "6.4.20",
66
+ "@storybook/react": "6.4.20",
67
67
  "@testing-library/react": "12.1.4",
68
68
  "@types/jest": "27.4.1",
69
- "@types/react": "17.0.40",
70
- "@types/react-dom": "17.0.13",
69
+ "@types/react": "17.0.43",
70
+ "@types/react-dom": "17.0.14",
71
71
  "@types/react-router": "5.1.18",
72
72
  "@types/react-router-dom": "5.3.3",
73
73
  "@types/react-transition-group": "4.4.4",
74
- "@typescript-eslint/eslint-plugin": "5.15.0",
75
- "@typescript-eslint/parser": "5.15.0",
76
- "concurrently": "^7.0.0",
77
- "eslint": "7.32.0",
74
+ "@typescript-eslint/eslint-plugin": "5.18.0",
75
+ "@typescript-eslint/parser": "5.18.0",
76
+ "concurrently": "^7.1.0",
77
+ "eslint": "8.12.0",
78
78
  "eslint-config-prettier": "8.5.0",
79
79
  "eslint-plugin-react": "7.29.4",
80
- "eslint-plugin-react-hooks": "4.3.0",
80
+ "eslint-plugin-react-hooks": "4.4.0",
81
81
  "eslint-plugin-sort-imports-es6-autofix": "0.6.0",
82
82
  "husky": "^7.0.4",
83
83
  "jest": "27.5.1",
84
- "lint-staged": "12.3.5",
85
- "next": "12.1.0",
86
- "prettier": "2.5.1",
84
+ "lint-staged": "12.3.7",
85
+ "next": "12.1.4",
86
+ "prettier": "2.6.2",
87
87
  "react": "17.0.2",
88
88
  "react-docgen-typescript-loader": "3.7.2",
89
89
  "react-dom": "17.0.2",
@@ -94,7 +94,7 @@
94
94
  "ress": "^5.0.2",
95
95
  "rimraf": "3.0.2",
96
96
  "tslib": "^2.3.1",
97
- "typescript": "4.6.2"
97
+ "typescript": "4.6.3"
98
98
  },
99
99
  "scripts": {
100
100
  "start": "yarn clear && yarn build",