matsuri-ui 10.2.2 → 10.2.3

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.
@@ -41,7 +41,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
41
41
  } : {
42
42
  name: "d2k9xu-Select",
43
43
  styles: "width:100%;label:Select;",
44
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AAiSwB","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */",
44
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AAkSwB","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n            setOpen(false)\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */",
45
45
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
46
46
  };
47
47
 
@@ -51,7 +51,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
51
51
  } : {
52
52
  name: "1ukhufr-Select",
53
53
  styles: "position:absolute;top:50%;left:50%;z-index:-1;width:1px;height:1px;opacity:0;label:Select;",
54
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AA4QgC","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */",
54
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AA6QgC","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n            setOpen(false)\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */",
55
55
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
56
56
  };
57
57
 
@@ -129,6 +129,7 @@ const Select = ({
129
129
  updateValue({
130
130
  value: valueProp
131
131
  });
132
+ setOpen(false);
132
133
  }
133
134
  }, [valueProp, defaultValue]);
134
135
  const [subOptions, setSubOptions] = (0, _react2.useState)();
@@ -220,7 +221,7 @@ const Select = ({
220
221
  "data-open": open,
221
222
  "aria-readonly": readOnly,
222
223
  "aria-placeholder": label ? undefined : placeholder,
223
- css: /*#__PURE__*/(0, _react.css)("position:relative;box-sizing:border-box;display:flex;align-items:center;justify-content:space-between;background-color:white;min-height:", theme.spacing * 6, "px;padding:9px 12px;", /*#__PURE__*/(0, _react.css)(theme.typography.body, process.env.NODE_ENV === "production" ? "" : ";label:Select;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AA4O0B","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */"), " color:", theme.palette.text.primary, ";cursor:pointer;resize:none;border:1px solid ", theme.palette.text.secondary, ";border-radius:4px;outline:0px;&[data-open=\"true\"]{border-color:", theme.palette.intentions.primary.main, ";}&[aria-disabled=\"true\"]{color:", theme.palette.action.disabled, ";cursor:not-allowed;background-color:", theme.palette.action.disabledBackground, ";border-color:", theme.palette.action.disabled, ";}&[aria-readonly=\"true\"]{cursor:text;background-color:", _InputBase.readonlyFieldBackgroundColor, ";border-color:", _InputBase.readonlyFieldBorderColor, ";}&[aria-placeholder]::before{color:", theme.palette.text.secondary, ";content:attr(aria-placeholder);}" + (process.env.NODE_ENV === "production" ? "" : ";label:Select;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AAmO4B","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */")
224
+ css: /*#__PURE__*/(0, _react.css)("position:relative;box-sizing:border-box;display:flex;align-items:center;justify-content:space-between;background-color:white;min-height:", theme.spacing * 6, "px;padding:9px 12px;", /*#__PURE__*/(0, _react.css)(theme.typography.body, process.env.NODE_ENV === "production" ? "" : ";label:Select;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AA6O0B","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n            setOpen(false)\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */"), " color:", theme.palette.text.primary, ";cursor:pointer;resize:none;border:1px solid ", theme.palette.text.secondary, ";border-radius:4px;outline:0px;&[data-open=\"true\"]{border-color:", theme.palette.intentions.primary.main, ";}&[aria-disabled=\"true\"]{color:", theme.palette.action.disabled, ";cursor:not-allowed;background-color:", theme.palette.action.disabledBackground, ";border-color:", theme.palette.action.disabled, ";}&[aria-readonly=\"true\"]{cursor:text;background-color:", _InputBase.readonlyFieldBackgroundColor, ";border-color:", _InputBase.readonlyFieldBorderColor, ";}&[aria-placeholder]::before{color:", theme.palette.text.secondary, ";content:attr(aria-placeholder);}" + (process.env.NODE_ENV === "production" ? "" : ";label:Select;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AAoO4B","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n            setOpen(false)\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */")
224
225
  }, props), (0, _react.jsx)("div", null, label), (0, _react.jsx)("input", {
225
226
  key: value,
226
227
  type: "text",
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":["Select","name","data","dataProp","placeholder","onChange","required","value","valueProp","defaultValue","disabled","readOnly","propsReadOnly","children","loading","propsLoading","onChangeValue","props","open","setOpen","ref","map","notUpdatedValue","label","updateValue","prev","current","find","item","undefined","mounted","subOptions","setSubOptions","subAnchorEl","setSubAnchorEl","selectedPath","setSelectedPath","handleClick","makeOption","source","path","render","Option","isExpanded","getProps","key","onClick","event","options","currentTarget","option","index","persist","Object","defineProperty","writable","theme","listRef","css","spacing","typography","body","palette","text","primary","secondary","intentions","main","action","disabledBackground","readonlyFieldBackgroundColor","readonlyFieldBorderColor","React","Children","toArray","child","i","minWidth","subOption"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkDO,MAAMA,MAA6B,GAAG,CAAC;AAC1CC,EAAAA,IAD0C;AAE1CC,EAAAA,IAAI,EAAEC,QAFoC;AAG1CC,EAAAA,WAH0C;AAI1CC,EAAAA,QAJ0C;AAK1CC,EAAAA,QAL0C;AAM1CC,EAAAA,KAAK,EAAEC,SANmC;AAO1CC,EAAAA,YAP0C;AAQ1CC,EAAAA,QAR0C;AAS1CC,EAAAA,QAAQ,EAAEC,aATgC;AAU1CC,EAAAA,QAV0C;AAW1CC,EAAAA,OAAO,EAAEC,YAXiC;AAY1CC,EAAAA,aAZ0C;AAa1C,KAAGC;AAbuC,CAAD,KAcvC;AACF,QAAM,CAACC,IAAD,EAAOC,OAAP,IAAkB,sBAAS,KAAT,CAAxB;AACA,QAAMC,GAAG,GAAG,oBAAuB,IAAvB,CAAZ;AAEA,QAAMlB,IAAgB,GAAG,qBAAQ,MAAM;AACnC,QAAI,OAAOC,QAAQ,CAAC,CAAD,CAAf,KAAuB,QAA3B,EAAqC;AACjC,aAAQA,QAAD,CAAuBkB,GAAvB,CAA4Bd,KAAD,KAAY;AAAEA,QAAAA;AAAF,OAAZ,CAA3B,CAAP;AACH,KAFD,MAEO;AACH,aAAOJ,QAAP;AACH;AACJ,GANwB,EAMtB,CAACA,QAAD,CANsB,CAAzB;AAQA,QAAMmB,eAAe,GAAG,oBAAO,IAAP,CAAxB;AAEA,QAAM,CAAC;AAAEf,IAAAA,KAAF;AAASgB,IAAAA;AAAT,GAAD,EAAmBC,WAAnB,IAAkC,wBACpC,CAACC,IAAD,EAAoD;AAAElB,IAAAA;AAAF,GAApD,KAAsF;AAClF,QAAIkB,IAAI,CAAClB,KAAL,KAAeA,KAAf,IAAwBe,eAAe,CAACI,OAA5C,EAAqD;AACjD,aAAOD,IAAP;AACH,KAFD,MAEO;AACH,aAAO;AACHlB,QAAAA,KADG;AAEHgB,QAAAA,KAAK,EAAErB,IAAI,CAACyB,IAAL,CAAWC,IAAD,IAAUA,IAAI,CAACrB,KAAL,KAAeA,KAAnC,GAA2CgB,KAA3C,IAAoDhB;AAFxD,OAAP;AAIH;AACJ,GAVmC,EAWpC;AAAEA,IAAAA,KAAK,EAAEC,SAAS,IAAIC,YAAtB;AAAoCc,IAAAA,KAAK,EAAEM;AAA3C,GAXoC,EAYpC,CAAC;AAAEtB,IAAAA;AAAF,GAAD,KAAmC;AAC/B,QAAIA,KAAK,KAAKsB,SAAV,IAAuBzB,WAA3B,EAAwC;AACpC,aAAO;AACHG,QAAAA,KADG;AAEHgB,QAAAA,KAAK,EAAEM;AAFJ,OAAP;AAIH;;AACD,WAAO;AACHtB,MAAAA,KADG;AAEHgB,MAAAA,KAAK,EAAErB,IAAI,CAACyB,IAAL,CAAWC,IAAD,IAAUA,IAAI,CAACrB,KAAL,KAAeA,KAAnC,GAA2CgB,KAA3C,IAAoDhB;AAFxD,KAAP;AAIH,GAvBmC,CAAxC;AA0BA,QAAMuB,OAAO,GAAG,oBAAO,KAAP,CAAhB;AAEA,yBAAU,MAAM;AACZ,QAAIA,OAAO,CAACJ,OAAZ,EAAqB;AACjB,UAAIV,aAAJ,EAAmB;AACfA,QAAAA,aAAa,CAACT,KAAD,CAAb;AACH;AACJ,KAJD,MAIO;AACHuB,MAAAA,OAAO,CAACJ,OAAR,GAAkB,IAAlB;AACH;AACJ,GARD,EAQG,CAACV,aAAD,EAAgBT,KAAhB,CARH;AAUA,yBAAU,MAAM;AACZ,QAAIE,YAAY,KAAKoB,SAArB,EAAgC;AAC5BL,MAAAA,WAAW,CAAC;AAAEjB,QAAAA,KAAK,EAAEC;AAAT,OAAD,CAAX;AACH;AACJ,GAJD,EAIG,CAACA,SAAD,EAAYC,YAAZ,CAJH;AAMA,QAAM,CAACsB,UAAD,EAAaC,aAAb,IAA8B,uBAApC;AASA,QAAM,CAACC,WAAD,EAAcC,cAAd,IAAgC,sBAA6B,IAA7B,CAAtC;AACA,QAAM,CAACC,YAAD,EAAeC,eAAf,IAAkC,uBAAxC;AACA,QAAMC,WAAW,GAAG,yBAAY,MAAM;AAClClB,IAAAA,OAAO,CAAEM,IAAD,IAAU,CAACA,IAAZ,CAAP;AACAS,IAAAA,cAAc,CAAC,IAAD,CAAd;AACAE,IAAAA,eAAe,CAACP,SAAD,CAAf;AACH,GAJmB,EAIjB,EAJiB,CAApB;AAMA,QAAMS,UAAU,GAAG,yBACf,CAACC,MAAD,EAA6BC,IAA7B,KAAuD;AACnD,UAAMjC,KAAK,GAAGgC,MAAM,CAAChC,KAArB;AACA,UAAMgB,KAAK,GAAGgB,MAAM,CAAChB,KAAP,IAAgBhB,KAAhB,IAAyB,EAAvC;AACA,WAAO;AACHiC,MAAAA,IAAI,EAAG,GAAEA,IAAK,EADX;AAEHC,MAAAA,MAAM,EAAE,MAAM;AACV,YAAIF,MAAM,CAACG,MAAP,KAAkBb,SAAtB,EAAiC;AAC7B,iBAAQ,GAAEN,KAAM,EAAhB;AACH,SAFD,MAEO,IAAI,OAAOgB,MAAM,CAACG,MAAd,KAAyB,UAA7B,EAAyC;AAC5C,gBAAMC,UAAU,GAAGR,YAAY,KAAM,GAAEK,IAAK,EAA5C;AACA,iBAAOD,MAAM,CAACG,MAAP,CAAc;AACjBnB,YAAAA,KADiB;AAEjBhB,YAAAA,KAFiB;AAGjBoC,YAAAA;AAHiB,WAAd,CAAP;AAKH,SAPM,MAOA;AACH,iBAAOJ,MAAM,CAACG,MAAd;AACH;AACJ,OAfE;AAgBHE,MAAAA,QAAQ,EAAE,OAAO;AACbC,QAAAA,GAAG,EAAG,GAAEL,IAAK,IAAGD,MAAM,CAAChC,KAAM,EADhB;AAEbuC,QAAAA,OAAO,EAAGC,KAAD,IAAwD;AAC7DzB,UAAAA,eAAe,CAACI,OAAhB,GAA0B,KAA1B;;AACA,cAAIa,MAAM,CAACS,OAAX,EAAoB;AAChBd,YAAAA,cAAc,CAACa,KAAK,CAACE,aAAP,CAAd;AACAjB,YAAAA,aAAa,CAACO,MAAM,CAACS,OAAP,CAAe3B,GAAf,CAAmB,CAAC6B,MAAD,EAASC,KAAT,KAAmBb,UAAU,CAACY,MAAD,EAAU,GAAEV,IAAK,IAAGW,KAAM,EAA1B,CAAhD,CAAD,CAAb;AACAf,YAAAA,eAAe,CAAE,GAAEI,IAAK,EAAT,CAAf;AACH,WAJD,MAIO;AACHhB,YAAAA,WAAW,CAAC;AAAEjB,cAAAA;AAAF,aAAD,CAAX;;AACA,gBAAIF,QAAJ,EAAc;AACV0C,cAAAA,KAAK,CAACK,OAAN;AACAC,cAAAA,MAAM,CAACC,cAAP,CAAsBP,KAAtB,EAA6B,QAA7B,EAAuC;AACnCQ,gBAAAA,QAAQ,EAAE,IADyB;AAEnChD,gBAAAA,KAAK,EAAE;AAAEA,kBAAAA;AAAF;AAF4B,eAAvC;AAIA8C,cAAAA,MAAM,CAACC,cAAP,CAAsBP,KAAtB,EAA6B,eAA7B,EAA8C;AAC1CQ,gBAAAA,QAAQ,EAAE,IADgC;AAE1ChD,gBAAAA,KAAK,EAAE;AAAEA,kBAAAA;AAAF;AAFmC,eAA9C;AAIAF,cAAAA,QAAQ,CAAC0C,KAAD,CAAR;AACH;;AACD5B,YAAAA,OAAO,CAAC,KAAD,CAAP;AACAe,YAAAA,cAAc,CAAC,IAAD,CAAd;AACH;AACJ;AAzBY,OAAP;AAhBP,KAAP;AA4CH,GAhDc,EAiDf,CAAC7B,QAAD,EAAW8B,YAAX,CAjDe,CAAnB;AAmDA,QAAMa,OAAO,GAAG,qBAAQ,MAAM;AAC1B,WAAO9C,IAAI,CAACmB,GAAL,CAASiB,UAAT,CAAP;AACH,GAFe,EAEb,CAACpC,IAAD,EAAOoC,UAAP,CAFa,CAAhB;AAIA,QAAMkB,KAAK,GAAG,sBAAd;AAEA,QAAM;AAAE1C,IAAAA,OAAF;AAAWH,IAAAA;AAAX,MAAwB,+BAAc;AACxCG,IAAAA,OAAO,EAAEC,YAD+B;AAExCJ,IAAAA,QAAQ,EAAEC;AAF8B,GAAd,CAA9B;AAKA,QAAM6C,OAAO,GAAG,oBAAuB,IAAvB,CAAhB;AAEA,gCAAkB,CAACrC,GAAD,EAAMqC,OAAN,CAAlB,EAAkC,MAAM;AACpCtC,IAAAA,OAAO,CAAC,KAAD,CAAP;AACH,GAFD;AAIA,SACI,gBAAC,eAAD,CAAO,QAAP,QACI,gBAAC,4BAAD;AAAe,IAAA,MAAM,EAAEL;AAAvB,KACI;AACI,IAAA,GAAG,EAAEM,GADT;AAEI,IAAA,OAAO,EAAE,CAACV,QAAD,IAAa,CAACC,QAAd,GAAyB0B,WAAzB,GAAuCR,SAFpD;AAGI,qBAAenB,QAHnB;AAII,iBAAWQ,IAJf;AAKI,qBAAeP,QALnB;AAMI,wBAAkBY,KAAK,GAAGM,SAAH,GAAezB,WAN1C;AAOI,IAAA,GAAG,mBAAEsD,UAAF,8IAOeF,KAAK,CAACG,OAAN,GAAgB,CAP/B,uCASG,gBAAIH,KAAK,CAACI,UAAN,CAAiBC,IAArB,wmfATH,aAUUL,KAAK,CAACM,OAAN,CAAcC,IAAd,CAAmBC,OAV7B,mDAaqBR,KAAK,CAACM,OAAN,CAAcC,IAAd,CAAmBE,SAbxC,wEAiBqBT,KAAK,CAACM,OAAN,CAAcI,UAAd,CAAyBF,OAAzB,CAAiCG,IAjBtD,wCAoBcX,KAAK,CAACM,OAAN,CAAcM,MAAd,CAAqB1D,QApBnC,2CAsByB8C,KAAK,CAACM,OAAN,CAAcM,MAAd,CAAqBC,kBAtB9C,oBAuBqBb,KAAK,CAACM,OAAN,CAAcM,MAAd,CAAqB1D,QAvB1C,+DA2ByB4D,uCA3BzB,oBA4BqBC,mCA5BrB,0CA+Bcf,KAAK,CAACM,OAAN,CAAcC,IAAd,CAAmBE,SA/BjC;AAPP,KA0CQhD,KA1CR,GA4CI,6BAAMM,KAAN,CA5CJ,EA6CI;AACI,IAAA,GAAG,EAAEhB,KADT;AAEI,IAAA,IAAI,EAAC,MAFT;AAGI,IAAA,GAAG,OAHP;AAYI,IAAA,IAAI,EAAEN,IAZV;AAaI,IAAA,YAAY,EAAEM,KAblB;AAcI,IAAA,QAAQ,EAAED;AAdd,IA7CJ,EA6DI,gBAAC,4CAAD;AAAuB,IAAA,IAAI,EAAEY;AAA7B,IA7DJ,CADJ,CADJ,EAkEI,gBAAC,cAAD;AACI,IAAA,QAAQ,EAAEE,GAAG,CAACM,OADlB;AAEI,IAAA,IAAI,EAAER,IAFV;AAGI,IAAA,SAAS,EAAC,YAHd;AAII,IAAA,aAAa,MAJjB;AAKI,IAAA,GAAG;AALP,KASI,gBAAC,sBAAD;AAAY,IAAA,GAAG,EAAEuC;AAAjB,KACKe,gBAAMC,QAAN,CAAeC,OAAf,CAAuB7D,QAAvB,EAAiCQ,GAAjC,CAAqC,CAACsD,KAAD,EAAQC,CAAR,KAClC,gBAAC,0BAAD;AAAc,IAAA,QAAQ,MAAtB;AAAuB,IAAA,GAAG,EAAG,mBAAkBA,CAAE;AAAjD,KACKD,KADL,CADH,CADL,EAMK3B,OAAO,CAAC3B,GAAR,CAAa6B,MAAD,IACT,gBAAC,0BAAD,EAAkBA,MAAM,CAACN,QAAP,EAAlB,EAAsCM,MAAM,CAACT,MAAP,EAAtC,CADH,CANL,CATJ,CAlEJ,EAsFI,gBAAC,cAAD;AAAQ,IAAA,QAAQ,EAAER,WAAlB;AAA+B,IAAA,SAAS,EAAC,aAAzC;AAAuD,IAAA,KAAK,EAAE;AAAE4C,MAAAA,QAAQ,EAAE;AAAZ;AAA9D,KACI,gBAAC,sBAAD;AAAY,IAAA,SAAS,EAAE;AAAvB,KACK9C,UAAU,EAAEV,GAAZ,CAAiByD,SAAD,IACb,gBAAC,0BAAD,EAAkBA,SAAS,CAAClC,QAAV,EAAlB,EAAyCkC,SAAS,CAACrC,MAAV,EAAzC,CADH,CADL,CADJ,CAtFJ,CADJ;AAgGH,CA7PM","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n value: string | undefined\n label?: string\n Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n options?: SelectData\n}[]\n\nexport interface SelectProps {\n name?: string\n defaultValue?: string\n /**\n * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n */\n value?: string\n disabled?: boolean\n renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n style?: React.CSSProperties\n className?: string\n /**\n * placeholder\n */\n placeholder?: string\n /**\n * selecting data is required\n */\n required?: boolean\n /**\n {\n value: string\n label?: string\n Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n }[]\n */\n data: SelectData | string[]\n readOnly?: boolean\n /**\n * SelectFieldのOptionがクリックされた際に発火する関数。\n * イベントを取得できます。\n */\n onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n /**\n * 値が変更されたときに発火する関数。\n * 引数から最新のvalueを取得できます。\n */\n onChangeValue?: (value?: string) => void\n loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n name,\n data: dataProp,\n placeholder,\n onChange,\n required,\n value: valueProp,\n defaultValue,\n disabled,\n readOnly: propsReadOnly,\n children,\n loading: propsLoading,\n onChangeValue,\n ...props\n}) => {\n const [open, setOpen] = useState(false)\n const ref = useRef<HTMLDivElement>(null)\n\n const data: SelectData = useMemo(() => {\n if (typeof dataProp[0] === \"string\") {\n return (dataProp as string[]).map((value) => ({ value }))\n } else {\n return dataProp as SelectData\n }\n }, [dataProp])\n\n const notUpdatedValue = useRef(true)\n\n const [{ value, label }, updateValue] = useReducer(\n (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n if (prev.value === value && notUpdatedValue.current) {\n return prev\n } else {\n return {\n value,\n label: data.find((item) => item.value === value)?.label || value\n }\n }\n },\n { value: valueProp || defaultValue, label: undefined },\n ({ value }: { value?: string }) => {\n if (value === undefined && placeholder) {\n return {\n value,\n label: undefined\n }\n }\n return {\n value,\n label: data.find((item) => item.value === value)?.label || value\n }\n }\n )\n\n const mounted = useRef(false)\n\n useEffect(() => {\n if (mounted.current) {\n if (onChangeValue) {\n onChangeValue(value)\n }\n } else {\n mounted.current = true\n }\n }, [onChangeValue, value])\n\n useEffect(() => {\n if (defaultValue === undefined) {\n updateValue({ value: valueProp })\n }\n }, [valueProp, defaultValue])\n\n const [subOptions, setSubOptions] = useState<\n {\n render: () => React.ReactNode\n getProps: () => {\n key: string\n onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n }\n }[]\n >()\n const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n const [selectedPath, setSelectedPath] = useState<string>()\n const handleClick = useCallback(() => {\n setOpen((prev) => !prev)\n setSubAnchorEl(null)\n setSelectedPath(undefined)\n }, [])\n\n const makeOption = useCallback(\n (source: SelectData[number], path: number | string) => {\n const value = source.value\n const label = source.label || value || \"\"\n return {\n path: `${path}`,\n render: () => {\n if (source.Option === undefined) {\n return `${label}`\n } else if (typeof source.Option === \"function\") {\n const isExpanded = selectedPath === `${path}`\n return source.Option({\n label,\n value,\n isExpanded\n })\n } else {\n return source.Option\n }\n },\n getProps: () => ({\n key: `${path}.${source.value}`,\n onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n notUpdatedValue.current = false\n if (source.options) {\n setSubAnchorEl(event.currentTarget)\n setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n setSelectedPath(`${path}`)\n } else {\n updateValue({ value })\n if (onChange) {\n event.persist()\n Object.defineProperty(event, \"target\", {\n writable: true,\n value: { value }\n })\n Object.defineProperty(event, \"currentTarget\", {\n writable: true,\n value: { value }\n })\n onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n }\n setOpen(false)\n setSubAnchorEl(null)\n }\n }\n })\n }\n },\n [onChange, selectedPath]\n )\n const options = useMemo(() => {\n return data.map(makeOption)\n }, [data, makeOption])\n\n const theme = useTheme()\n\n const { loading, readOnly } = useFieldGroup({\n loading: propsLoading,\n readOnly: propsReadOnly\n })\n\n const listRef = useRef<HTMLDivElement>(null)\n\n useOnClickOutside([ref, listRef], () => {\n setOpen(false)\n })\n\n return (\n <React.Fragment>\n <ShimmerEffect active={loading}>\n <div\n ref={ref}\n onClick={!disabled && !readOnly ? handleClick : undefined}\n aria-disabled={disabled}\n data-open={open}\n aria-readonly={readOnly}\n aria-placeholder={label ? undefined : placeholder}\n css={css`\n position: relative;\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: space-between;\n background-color: white;\n min-height: ${theme.spacing * 6}px;\n padding: 9px 12px;\n ${css(theme.typography.body)}\n color: ${theme.palette.text.primary};\n cursor: pointer;\n resize: none;\n border: 1px solid ${theme.palette.text.secondary};\n border-radius: 4px;\n outline: 0px;\n &[data-open=\"true\"] {\n border-color: ${theme.palette.intentions.primary.main};\n }\n &[aria-disabled=\"true\"] {\n color: ${theme.palette.action.disabled};\n cursor: not-allowed;\n background-color: ${theme.palette.action.disabledBackground};\n border-color: ${theme.palette.action.disabled};\n }\n &[aria-readonly=\"true\"] {\n cursor: text;\n background-color: ${readonlyFieldBackgroundColor};\n border-color: ${readonlyFieldBorderColor};\n }\n &[aria-placeholder]::before {\n color: ${theme.palette.text.secondary};\n content: attr(aria-placeholder);\n }\n `}\n {...props}\n >\n <div>{label}</div>\n <input\n key={value}\n type=\"text\"\n css={css`\n position: absolute;\n top: 50%;\n left: 50%;\n z-index: -1;\n width: 1px;\n height: 1px;\n opacity: 0;\n `}\n name={name}\n defaultValue={value}\n required={required}\n />\n <SelectInnerSpinButton open={open} />\n </div>\n </ShimmerEffect>\n <Popper\n anchorEl={ref.current}\n open={open}\n placement=\"bottom-end\"\n disablePortal\n css={css`\n width: 100%;\n `}\n >\n <SelectList ref={listRef}>\n {React.Children.toArray(children).map((child, i) => (\n <SelectOption disabled key={`disabled-option-${i}`}>\n {child}\n </SelectOption>\n ))}\n {options.map((option) => (\n <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n ))}\n </SelectList>\n </Popper>\n <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n <SelectList elevation={4}>\n {subOptions?.map((subOption) => (\n <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n ))}\n </SelectList>\n </Popper>\n </React.Fragment>\n )\n}\n"],"file":"Select.js"}
1
+ {"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":["Select","name","data","dataProp","placeholder","onChange","required","value","valueProp","defaultValue","disabled","readOnly","propsReadOnly","children","loading","propsLoading","onChangeValue","props","open","setOpen","ref","map","notUpdatedValue","label","updateValue","prev","current","find","item","undefined","mounted","subOptions","setSubOptions","subAnchorEl","setSubAnchorEl","selectedPath","setSelectedPath","handleClick","makeOption","source","path","render","Option","isExpanded","getProps","key","onClick","event","options","currentTarget","option","index","persist","Object","defineProperty","writable","theme","listRef","css","spacing","typography","body","palette","text","primary","secondary","intentions","main","action","disabledBackground","readonlyFieldBackgroundColor","readonlyFieldBorderColor","React","Children","toArray","child","i","minWidth","subOption"],"mappings":"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","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n value: string | undefined\n label?: string\n Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n options?: SelectData\n}[]\n\nexport interface SelectProps {\n name?: string\n defaultValue?: string\n /**\n * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n */\n value?: string\n disabled?: boolean\n renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n style?: React.CSSProperties\n className?: string\n /**\n * placeholder\n */\n placeholder?: string\n /**\n * selecting data is required\n */\n required?: boolean\n /**\n {\n value: string\n label?: string\n Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n }[]\n */\n data: SelectData | string[]\n readOnly?: boolean\n /**\n * SelectFieldのOptionがクリックされた際に発火する関数。\n * イベントを取得できます。\n */\n onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n /**\n * 値が変更されたときに発火する関数。\n * 引数から最新のvalueを取得できます。\n */\n onChangeValue?: (value?: string) => void\n loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n name,\n data: dataProp,\n placeholder,\n onChange,\n required,\n value: valueProp,\n defaultValue,\n disabled,\n readOnly: propsReadOnly,\n children,\n loading: propsLoading,\n onChangeValue,\n ...props\n}) => {\n const [open, setOpen] = useState(false)\n const ref = useRef<HTMLDivElement>(null)\n\n const data: SelectData = useMemo(() => {\n if (typeof dataProp[0] === \"string\") {\n return (dataProp as string[]).map((value) => ({ value }))\n } else {\n return dataProp as SelectData\n }\n }, [dataProp])\n\n const notUpdatedValue = useRef(true)\n\n const [{ value, label }, updateValue] = useReducer(\n (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n if (prev.value === value && notUpdatedValue.current) {\n return prev\n } else {\n return {\n value,\n label: data.find((item) => item.value === value)?.label || value\n }\n }\n },\n { value: valueProp || defaultValue, label: undefined },\n ({ value }: { value?: string }) => {\n if (value === undefined && placeholder) {\n return {\n value,\n label: undefined\n }\n }\n return {\n value,\n label: data.find((item) => item.value === value)?.label || value\n }\n }\n )\n\n const mounted = useRef(false)\n\n useEffect(() => {\n if (mounted.current) {\n if (onChangeValue) {\n onChangeValue(value)\n }\n } else {\n mounted.current = true\n }\n }, [onChangeValue, value])\n\n useEffect(() => {\n if (defaultValue === undefined) {\n updateValue({ value: valueProp })\n setOpen(false)\n }\n }, [valueProp, defaultValue])\n\n const [subOptions, setSubOptions] = useState<\n {\n render: () => React.ReactNode\n getProps: () => {\n key: string\n onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n }\n }[]\n >()\n const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n const [selectedPath, setSelectedPath] = useState<string>()\n const handleClick = useCallback(() => {\n setOpen((prev) => !prev)\n setSubAnchorEl(null)\n setSelectedPath(undefined)\n }, [])\n\n const makeOption = useCallback(\n (source: SelectData[number], path: number | string) => {\n const value = source.value\n const label = source.label || value || \"\"\n return {\n path: `${path}`,\n render: () => {\n if (source.Option === undefined) {\n return `${label}`\n } else if (typeof source.Option === \"function\") {\n const isExpanded = selectedPath === `${path}`\n return source.Option({\n label,\n value,\n isExpanded\n })\n } else {\n return source.Option\n }\n },\n getProps: () => ({\n key: `${path}.${source.value}`,\n onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n notUpdatedValue.current = false\n if (source.options) {\n setSubAnchorEl(event.currentTarget)\n setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n setSelectedPath(`${path}`)\n } else {\n updateValue({ value })\n if (onChange) {\n event.persist()\n Object.defineProperty(event, \"target\", {\n writable: true,\n value: { value }\n })\n Object.defineProperty(event, \"currentTarget\", {\n writable: true,\n value: { value }\n })\n onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n }\n setOpen(false)\n setSubAnchorEl(null)\n }\n }\n })\n }\n },\n [onChange, selectedPath]\n )\n const options = useMemo(() => {\n return data.map(makeOption)\n }, [data, makeOption])\n\n const theme = useTheme()\n\n const { loading, readOnly } = useFieldGroup({\n loading: propsLoading,\n readOnly: propsReadOnly\n })\n\n const listRef = useRef<HTMLDivElement>(null)\n\n useOnClickOutside([ref, listRef], () => {\n setOpen(false)\n })\n\n return (\n <React.Fragment>\n <ShimmerEffect active={loading}>\n <div\n ref={ref}\n onClick={!disabled && !readOnly ? handleClick : undefined}\n aria-disabled={disabled}\n data-open={open}\n aria-readonly={readOnly}\n aria-placeholder={label ? undefined : placeholder}\n css={css`\n position: relative;\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: space-between;\n background-color: white;\n min-height: ${theme.spacing * 6}px;\n padding: 9px 12px;\n ${css(theme.typography.body)}\n color: ${theme.palette.text.primary};\n cursor: pointer;\n resize: none;\n border: 1px solid ${theme.palette.text.secondary};\n border-radius: 4px;\n outline: 0px;\n &[data-open=\"true\"] {\n border-color: ${theme.palette.intentions.primary.main};\n }\n &[aria-disabled=\"true\"] {\n color: ${theme.palette.action.disabled};\n cursor: not-allowed;\n background-color: ${theme.palette.action.disabledBackground};\n border-color: ${theme.palette.action.disabled};\n }\n &[aria-readonly=\"true\"] {\n cursor: text;\n background-color: ${readonlyFieldBackgroundColor};\n border-color: ${readonlyFieldBorderColor};\n }\n &[aria-placeholder]::before {\n color: ${theme.palette.text.secondary};\n content: attr(aria-placeholder);\n }\n `}\n {...props}\n >\n <div>{label}</div>\n <input\n key={value}\n type=\"text\"\n css={css`\n position: absolute;\n top: 50%;\n left: 50%;\n z-index: -1;\n width: 1px;\n height: 1px;\n opacity: 0;\n `}\n name={name}\n defaultValue={value}\n required={required}\n />\n <SelectInnerSpinButton open={open} />\n </div>\n </ShimmerEffect>\n <Popper\n anchorEl={ref.current}\n open={open}\n placement=\"bottom-end\"\n disablePortal\n css={css`\n width: 100%;\n `}\n >\n <SelectList ref={listRef}>\n {React.Children.toArray(children).map((child, i) => (\n <SelectOption disabled key={`disabled-option-${i}`}>\n {child}\n </SelectOption>\n ))}\n {options.map((option) => (\n <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n ))}\n </SelectList>\n </Popper>\n <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n <SelectList elevation={4}>\n {subOptions?.map((subOption) => (\n <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n ))}\n </SelectList>\n </Popper>\n </React.Fragment>\n )\n}\n"],"file":"Select.js"}
@@ -27,7 +27,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
27
27
  } : {
28
28
  name: "d2k9xu-Select",
29
29
  styles: "width:100%;label:Select;",
30
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AAiSwB","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */",
30
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AAkSwB","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n            setOpen(false)\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */",
31
31
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
32
32
  };
33
33
 
@@ -37,7 +37,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
37
37
  } : {
38
38
  name: "1ukhufr-Select",
39
39
  styles: "position:absolute;top:50%;left:50%;z-index:-1;width:1px;height:1px;opacity:0;label:Select;",
40
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AA4QgC","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */",
40
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AA6QgC","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n            setOpen(false)\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */",
41
41
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
42
42
  };
43
43
 
@@ -125,6 +125,7 @@ export var Select = _ref3 => {
125
125
  updateValue({
126
126
  value: valueProp
127
127
  });
128
+ setOpen(false);
128
129
  }
129
130
  }, [valueProp, defaultValue]);
130
131
  var [subOptions, setSubOptions] = useState();
@@ -216,7 +217,7 @@ export var Select = _ref3 => {
216
217
  "data-open": open,
217
218
  "aria-readonly": readOnly,
218
219
  "aria-placeholder": label ? undefined : placeholder,
219
- css: /*#__PURE__*/css("position:relative;box-sizing:border-box;display:flex;align-items:center;justify-content:space-between;background-color:white;min-height:", theme.spacing * 6, "px;padding:9px 12px;", /*#__PURE__*/css(theme.typography.body, process.env.NODE_ENV === "production" ? "" : ";label:Select;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AA4O0B","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */"), " color:", theme.palette.text.primary, ";cursor:pointer;resize:none;border:1px solid ", theme.palette.text.secondary, ";border-radius:4px;outline:0px;&[data-open=\"true\"]{border-color:", theme.palette.intentions.primary.main, ";}&[aria-disabled=\"true\"]{color:", theme.palette.action.disabled, ";cursor:not-allowed;background-color:", theme.palette.action.disabledBackground, ";border-color:", theme.palette.action.disabled, ";}&[aria-readonly=\"true\"]{cursor:text;background-color:", readonlyFieldBackgroundColor, ";border-color:", readonlyFieldBorderColor, ";}&[aria-placeholder]::before{color:", theme.palette.text.secondary, ";content:attr(aria-placeholder);}" + (process.env.NODE_ENV === "production" ? "" : ";label:Select;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AAmO4B","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */")
220
+ css: /*#__PURE__*/css("position:relative;box-sizing:border-box;display:flex;align-items:center;justify-content:space-between;background-color:white;min-height:", theme.spacing * 6, "px;padding:9px 12px;", /*#__PURE__*/css(theme.typography.body, process.env.NODE_ENV === "production" ? "" : ";label:Select;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AA6O0B","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n            setOpen(false)\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */"), " color:", theme.palette.text.primary, ";cursor:pointer;resize:none;border:1px solid ", theme.palette.text.secondary, ";border-radius:4px;outline:0px;&[data-open=\"true\"]{border-color:", theme.palette.intentions.primary.main, ";}&[aria-disabled=\"true\"]{color:", theme.palette.action.disabled, ";cursor:not-allowed;background-color:", theme.palette.action.disabledBackground, ";border-color:", theme.palette.action.disabled, ";}&[aria-readonly=\"true\"]{cursor:text;background-color:", readonlyFieldBackgroundColor, ";border-color:", readonlyFieldBorderColor, ";}&[aria-placeholder]::before{color:", theme.palette.text.secondary, ";content:attr(aria-placeholder);}" + (process.env.NODE_ENV === "production" ? "" : ";label:Select;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":[],"mappings":"AAoO4B","file":"../../../src/SelectField/Select.tsx","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n    value: string | undefined\n    label?: string\n    Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n    options?: SelectData\n}[]\n\nexport interface SelectProps {\n    name?: string\n    defaultValue?: string\n    /**\n     * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n     */\n    value?: string\n    disabled?: boolean\n    renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n    style?: React.CSSProperties\n    className?: string\n    /**\n     * placeholder\n     */\n    placeholder?: string\n    /**\n     * selecting data is required\n     */\n    required?: boolean\n    /**\n    {\n        value: string\n        label?: string\n        Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n    }[]\n     */\n    data: SelectData | string[]\n    readOnly?: boolean\n    /**\n     * SelectFieldのOptionがクリックされた際に発火する関数。\n     * イベントを取得できます。\n     */\n    onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n    /**\n     * 値が変更されたときに発火する関数。\n     * 引数から最新のvalueを取得できます。\n     */\n    onChangeValue?: (value?: string) => void\n    loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n    name,\n    data: dataProp,\n    placeholder,\n    onChange,\n    required,\n    value: valueProp,\n    defaultValue,\n    disabled,\n    readOnly: propsReadOnly,\n    children,\n    loading: propsLoading,\n    onChangeValue,\n    ...props\n}) => {\n    const [open, setOpen] = useState(false)\n    const ref = useRef<HTMLDivElement>(null)\n\n    const data: SelectData = useMemo(() => {\n        if (typeof dataProp[0] === \"string\") {\n            return (dataProp as string[]).map((value) => ({ value }))\n        } else {\n            return dataProp as SelectData\n        }\n    }, [dataProp])\n\n    const notUpdatedValue = useRef(true)\n\n    const [{ value, label }, updateValue] = useReducer(\n        (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n            if (prev.value === value && notUpdatedValue.current) {\n                return prev\n            } else {\n                return {\n                    value,\n                    label: data.find((item) => item.value === value)?.label || value\n                }\n            }\n        },\n        { value: valueProp || defaultValue, label: undefined },\n        ({ value }: { value?: string }) => {\n            if (value === undefined && placeholder) {\n                return {\n                    value,\n                    label: undefined\n                }\n            }\n            return {\n                value,\n                label: data.find((item) => item.value === value)?.label || value\n            }\n        }\n    )\n\n    const mounted = useRef(false)\n\n    useEffect(() => {\n        if (mounted.current) {\n            if (onChangeValue) {\n                onChangeValue(value)\n            }\n        } else {\n            mounted.current = true\n        }\n    }, [onChangeValue, value])\n\n    useEffect(() => {\n        if (defaultValue === undefined) {\n            updateValue({ value: valueProp })\n            setOpen(false)\n        }\n    }, [valueProp, defaultValue])\n\n    const [subOptions, setSubOptions] = useState<\n        {\n            render: () => React.ReactNode\n            getProps: () => {\n                key: string\n                onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n            }\n        }[]\n    >()\n    const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n    const [selectedPath, setSelectedPath] = useState<string>()\n    const handleClick = useCallback(() => {\n        setOpen((prev) => !prev)\n        setSubAnchorEl(null)\n        setSelectedPath(undefined)\n    }, [])\n\n    const makeOption = useCallback(\n        (source: SelectData[number], path: number | string) => {\n            const value = source.value\n            const label = source.label || value || \"\"\n            return {\n                path: `${path}`,\n                render: () => {\n                    if (source.Option === undefined) {\n                        return `${label}`\n                    } else if (typeof source.Option === \"function\") {\n                        const isExpanded = selectedPath === `${path}`\n                        return source.Option({\n                            label,\n                            value,\n                            isExpanded\n                        })\n                    } else {\n                        return source.Option\n                    }\n                },\n                getProps: () => ({\n                    key: `${path}.${source.value}`,\n                    onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n                        notUpdatedValue.current = false\n                        if (source.options) {\n                            setSubAnchorEl(event.currentTarget)\n                            setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n                            setSelectedPath(`${path}`)\n                        } else {\n                            updateValue({ value })\n                            if (onChange) {\n                                event.persist()\n                                Object.defineProperty(event, \"target\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                Object.defineProperty(event, \"currentTarget\", {\n                                    writable: true,\n                                    value: { value }\n                                })\n                                onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n                            }\n                            setOpen(false)\n                            setSubAnchorEl(null)\n                        }\n                    }\n                })\n            }\n        },\n        [onChange, selectedPath]\n    )\n    const options = useMemo(() => {\n        return data.map(makeOption)\n    }, [data, makeOption])\n\n    const theme = useTheme()\n\n    const { loading, readOnly } = useFieldGroup({\n        loading: propsLoading,\n        readOnly: propsReadOnly\n    })\n\n    const listRef = useRef<HTMLDivElement>(null)\n\n    useOnClickOutside([ref, listRef], () => {\n        setOpen(false)\n    })\n\n    return (\n        <React.Fragment>\n            <ShimmerEffect active={loading}>\n                <div\n                    ref={ref}\n                    onClick={!disabled && !readOnly ? handleClick : undefined}\n                    aria-disabled={disabled}\n                    data-open={open}\n                    aria-readonly={readOnly}\n                    aria-placeholder={label ? undefined : placeholder}\n                    css={css`\n                        position: relative;\n                        box-sizing: border-box;\n                        display: flex;\n                        align-items: center;\n                        justify-content: space-between;\n                        background-color: white;\n                        min-height: ${theme.spacing * 6}px;\n                        padding: 9px 12px;\n                        ${css(theme.typography.body)}\n                        color: ${theme.palette.text.primary};\n                        cursor: pointer;\n                        resize: none;\n                        border: 1px solid ${theme.palette.text.secondary};\n                        border-radius: 4px;\n                        outline: 0px;\n                        &[data-open=\"true\"] {\n                            border-color: ${theme.palette.intentions.primary.main};\n                        }\n                        &[aria-disabled=\"true\"] {\n                            color: ${theme.palette.action.disabled};\n                            cursor: not-allowed;\n                            background-color: ${theme.palette.action.disabledBackground};\n                            border-color: ${theme.palette.action.disabled};\n                        }\n                        &[aria-readonly=\"true\"] {\n                            cursor: text;\n                            background-color: ${readonlyFieldBackgroundColor};\n                            border-color: ${readonlyFieldBorderColor};\n                        }\n                        &[aria-placeholder]::before {\n                            color: ${theme.palette.text.secondary};\n                            content: attr(aria-placeholder);\n                        }\n                    `}\n                    {...props}\n                >\n                    <div>{label}</div>\n                    <input\n                        key={value}\n                        type=\"text\"\n                        css={css`\n                            position: absolute;\n                            top: 50%;\n                            left: 50%;\n                            z-index: -1;\n                            width: 1px;\n                            height: 1px;\n                            opacity: 0;\n                        `}\n                        name={name}\n                        defaultValue={value}\n                        required={required}\n                    />\n                    <SelectInnerSpinButton open={open} />\n                </div>\n            </ShimmerEffect>\n            <Popper\n                anchorEl={ref.current}\n                open={open}\n                placement=\"bottom-end\"\n                disablePortal\n                css={css`\n                    width: 100%;\n                `}\n            >\n                <SelectList ref={listRef}>\n                    {React.Children.toArray(children).map((child, i) => (\n                        <SelectOption disabled key={`disabled-option-${i}`}>\n                            {child}\n                        </SelectOption>\n                    ))}\n                    {options.map((option) => (\n                        <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n            <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n                <SelectList elevation={4}>\n                    {subOptions?.map((subOption) => (\n                        <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n                    ))}\n                </SelectList>\n            </Popper>\n        </React.Fragment>\n    )\n}\n"]} */")
220
221
  }, props), ___EmotionJSX("div", null, label), ___EmotionJSX("input", {
221
222
  key: value,
222
223
  type: "text",
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":["Popper","SelectInnerSpinButton","SelectList","SelectOption","ShimmerEffect","css","readonlyFieldBackgroundColor","readonlyFieldBorderColor","useFieldGroup","useOnClickOutside","useTheme","React","useCallback","useEffect","useMemo","useReducer","useRef","useState","Select","name","data","dataProp","placeholder","onChange","required","value","valueProp","defaultValue","disabled","readOnly","propsReadOnly","children","loading","propsLoading","onChangeValue","props","open","setOpen","ref","map","notUpdatedValue","label","updateValue","prev","current","find","item","undefined","mounted","subOptions","setSubOptions","subAnchorEl","setSubAnchorEl","selectedPath","setSelectedPath","handleClick","makeOption","source","path","render","Option","isExpanded","getProps","key","onClick","event","options","currentTarget","option","index","persist","Object","defineProperty","writable","theme","listRef","spacing","typography","body","palette","text","primary","secondary","intentions","main","action","disabledBackground","Children","toArray","child","i","minWidth","subOption"],"mappings":"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","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n value: string | undefined\n label?: string\n Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n options?: SelectData\n}[]\n\nexport interface SelectProps {\n name?: string\n defaultValue?: string\n /**\n * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n */\n value?: string\n disabled?: boolean\n renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n style?: React.CSSProperties\n className?: string\n /**\n * placeholder\n */\n placeholder?: string\n /**\n * selecting data is required\n */\n required?: boolean\n /**\n {\n value: string\n label?: string\n Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n }[]\n */\n data: SelectData | string[]\n readOnly?: boolean\n /**\n * SelectFieldのOptionがクリックされた際に発火する関数。\n * イベントを取得できます。\n */\n onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n /**\n * 値が変更されたときに発火する関数。\n * 引数から最新のvalueを取得できます。\n */\n onChangeValue?: (value?: string) => void\n loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n name,\n data: dataProp,\n placeholder,\n onChange,\n required,\n value: valueProp,\n defaultValue,\n disabled,\n readOnly: propsReadOnly,\n children,\n loading: propsLoading,\n onChangeValue,\n ...props\n}) => {\n const [open, setOpen] = useState(false)\n const ref = useRef<HTMLDivElement>(null)\n\n const data: SelectData = useMemo(() => {\n if (typeof dataProp[0] === \"string\") {\n return (dataProp as string[]).map((value) => ({ value }))\n } else {\n return dataProp as SelectData\n }\n }, [dataProp])\n\n const notUpdatedValue = useRef(true)\n\n const [{ value, label }, updateValue] = useReducer(\n (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n if (prev.value === value && notUpdatedValue.current) {\n return prev\n } else {\n return {\n value,\n label: data.find((item) => item.value === value)?.label || value\n }\n }\n },\n { value: valueProp || defaultValue, label: undefined },\n ({ value }: { value?: string }) => {\n if (value === undefined && placeholder) {\n return {\n value,\n label: undefined\n }\n }\n return {\n value,\n label: data.find((item) => item.value === value)?.label || value\n }\n }\n )\n\n const mounted = useRef(false)\n\n useEffect(() => {\n if (mounted.current) {\n if (onChangeValue) {\n onChangeValue(value)\n }\n } else {\n mounted.current = true\n }\n }, [onChangeValue, value])\n\n useEffect(() => {\n if (defaultValue === undefined) {\n updateValue({ value: valueProp })\n }\n }, [valueProp, defaultValue])\n\n const [subOptions, setSubOptions] = useState<\n {\n render: () => React.ReactNode\n getProps: () => {\n key: string\n onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n }\n }[]\n >()\n const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n const [selectedPath, setSelectedPath] = useState<string>()\n const handleClick = useCallback(() => {\n setOpen((prev) => !prev)\n setSubAnchorEl(null)\n setSelectedPath(undefined)\n }, [])\n\n const makeOption = useCallback(\n (source: SelectData[number], path: number | string) => {\n const value = source.value\n const label = source.label || value || \"\"\n return {\n path: `${path}`,\n render: () => {\n if (source.Option === undefined) {\n return `${label}`\n } else if (typeof source.Option === \"function\") {\n const isExpanded = selectedPath === `${path}`\n return source.Option({\n label,\n value,\n isExpanded\n })\n } else {\n return source.Option\n }\n },\n getProps: () => ({\n key: `${path}.${source.value}`,\n onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n notUpdatedValue.current = false\n if (source.options) {\n setSubAnchorEl(event.currentTarget)\n setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n setSelectedPath(`${path}`)\n } else {\n updateValue({ value })\n if (onChange) {\n event.persist()\n Object.defineProperty(event, \"target\", {\n writable: true,\n value: { value }\n })\n Object.defineProperty(event, \"currentTarget\", {\n writable: true,\n value: { value }\n })\n onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n }\n setOpen(false)\n setSubAnchorEl(null)\n }\n }\n })\n }\n },\n [onChange, selectedPath]\n )\n const options = useMemo(() => {\n return data.map(makeOption)\n }, [data, makeOption])\n\n const theme = useTheme()\n\n const { loading, readOnly } = useFieldGroup({\n loading: propsLoading,\n readOnly: propsReadOnly\n })\n\n const listRef = useRef<HTMLDivElement>(null)\n\n useOnClickOutside([ref, listRef], () => {\n setOpen(false)\n })\n\n return (\n <React.Fragment>\n <ShimmerEffect active={loading}>\n <div\n ref={ref}\n onClick={!disabled && !readOnly ? handleClick : undefined}\n aria-disabled={disabled}\n data-open={open}\n aria-readonly={readOnly}\n aria-placeholder={label ? undefined : placeholder}\n css={css`\n position: relative;\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: space-between;\n background-color: white;\n min-height: ${theme.spacing * 6}px;\n padding: 9px 12px;\n ${css(theme.typography.body)}\n color: ${theme.palette.text.primary};\n cursor: pointer;\n resize: none;\n border: 1px solid ${theme.palette.text.secondary};\n border-radius: 4px;\n outline: 0px;\n &[data-open=\"true\"] {\n border-color: ${theme.palette.intentions.primary.main};\n }\n &[aria-disabled=\"true\"] {\n color: ${theme.palette.action.disabled};\n cursor: not-allowed;\n background-color: ${theme.palette.action.disabledBackground};\n border-color: ${theme.palette.action.disabled};\n }\n &[aria-readonly=\"true\"] {\n cursor: text;\n background-color: ${readonlyFieldBackgroundColor};\n border-color: ${readonlyFieldBorderColor};\n }\n &[aria-placeholder]::before {\n color: ${theme.palette.text.secondary};\n content: attr(aria-placeholder);\n }\n `}\n {...props}\n >\n <div>{label}</div>\n <input\n key={value}\n type=\"text\"\n css={css`\n position: absolute;\n top: 50%;\n left: 50%;\n z-index: -1;\n width: 1px;\n height: 1px;\n opacity: 0;\n `}\n name={name}\n defaultValue={value}\n required={required}\n />\n <SelectInnerSpinButton open={open} />\n </div>\n </ShimmerEffect>\n <Popper\n anchorEl={ref.current}\n open={open}\n placement=\"bottom-end\"\n disablePortal\n css={css`\n width: 100%;\n `}\n >\n <SelectList ref={listRef}>\n {React.Children.toArray(children).map((child, i) => (\n <SelectOption disabled key={`disabled-option-${i}`}>\n {child}\n </SelectOption>\n ))}\n {options.map((option) => (\n <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n ))}\n </SelectList>\n </Popper>\n <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n <SelectList elevation={4}>\n {subOptions?.map((subOption) => (\n <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n ))}\n </SelectList>\n </Popper>\n </React.Fragment>\n )\n}\n"],"file":"Select.js"}
1
+ {"version":3,"sources":["../../../src/SelectField/Select.tsx"],"names":["Popper","SelectInnerSpinButton","SelectList","SelectOption","ShimmerEffect","css","readonlyFieldBackgroundColor","readonlyFieldBorderColor","useFieldGroup","useOnClickOutside","useTheme","React","useCallback","useEffect","useMemo","useReducer","useRef","useState","Select","name","data","dataProp","placeholder","onChange","required","value","valueProp","defaultValue","disabled","readOnly","propsReadOnly","children","loading","propsLoading","onChangeValue","props","open","setOpen","ref","map","notUpdatedValue","label","updateValue","prev","current","find","item","undefined","mounted","subOptions","setSubOptions","subAnchorEl","setSubAnchorEl","selectedPath","setSelectedPath","handleClick","makeOption","source","path","render","Option","isExpanded","getProps","key","onClick","event","options","currentTarget","option","index","persist","Object","defineProperty","writable","theme","listRef","spacing","typography","body","palette","text","primary","secondary","intentions","main","action","disabledBackground","Children","toArray","child","i","minWidth","subOption"],"mappings":"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","sourcesContent":["import { Popper } from \"../Popper\"\nimport { SelectInnerSpinButton } from \"./SelectInnerSpinButton\"\nimport { SelectList } from \"./SelectList\"\nimport { SelectOption } from \"./SelectOption\"\nimport { ShimmerEffect } from \"../ShimmerEffect\"\nimport { css } from \"@emotion/react\"\nimport { readonlyFieldBackgroundColor, readonlyFieldBorderColor } from \"../InputBase/InputBase\"\nimport { useFieldGroup } from \"../FieldGroup\"\nimport { useOnClickOutside } from \"../hooks\"\nimport { useTheme } from \"../theme\"\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\"\n\nexport type SelectData = {\n value: string | undefined\n label?: string\n Option?: React.ReactNode | ((props: { value?: string; label: string; isExpanded: boolean }) => JSX.Element)\n options?: SelectData\n}[]\n\nexport interface SelectProps {\n name?: string\n defaultValue?: string\n /**\n * valueの変更は、defaultValueが指定されていないときのみ反映されます。\n */\n value?: string\n disabled?: boolean\n renderValue?: ({ value, isExpanded }: { value: string; isExpanded: boolean }) => JSX.Element\n style?: React.CSSProperties\n className?: string\n /**\n * placeholder\n */\n placeholder?: string\n /**\n * selecting data is required\n */\n required?: boolean\n /**\n {\n value: string\n label?: string\n Option?: React.ReactNode | ((props: { value: string; label: string }) => JSX.Element)\n }[]\n */\n data: SelectData | string[]\n readOnly?: boolean\n /**\n * SelectFieldのOptionがクリックされた際に発火する関数。\n * イベントを取得できます。\n */\n onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void\n /**\n * 値が変更されたときに発火する関数。\n * 引数から最新のvalueを取得できます。\n */\n onChangeValue?: (value?: string) => void\n loading?: boolean\n}\n\nexport const Select: React.FC<SelectProps> = ({\n name,\n data: dataProp,\n placeholder,\n onChange,\n required,\n value: valueProp,\n defaultValue,\n disabled,\n readOnly: propsReadOnly,\n children,\n loading: propsLoading,\n onChangeValue,\n ...props\n}) => {\n const [open, setOpen] = useState(false)\n const ref = useRef<HTMLDivElement>(null)\n\n const data: SelectData = useMemo(() => {\n if (typeof dataProp[0] === \"string\") {\n return (dataProp as string[]).map((value) => ({ value }))\n } else {\n return dataProp as SelectData\n }\n }, [dataProp])\n\n const notUpdatedValue = useRef(true)\n\n const [{ value, label }, updateValue] = useReducer(\n (prev: { value?: string; label?: React.ReactNode }, { value }: { value?: string }) => {\n if (prev.value === value && notUpdatedValue.current) {\n return prev\n } else {\n return {\n value,\n label: data.find((item) => item.value === value)?.label || value\n }\n }\n },\n { value: valueProp || defaultValue, label: undefined },\n ({ value }: { value?: string }) => {\n if (value === undefined && placeholder) {\n return {\n value,\n label: undefined\n }\n }\n return {\n value,\n label: data.find((item) => item.value === value)?.label || value\n }\n }\n )\n\n const mounted = useRef(false)\n\n useEffect(() => {\n if (mounted.current) {\n if (onChangeValue) {\n onChangeValue(value)\n }\n } else {\n mounted.current = true\n }\n }, [onChangeValue, value])\n\n useEffect(() => {\n if (defaultValue === undefined) {\n updateValue({ value: valueProp })\n setOpen(false)\n }\n }, [valueProp, defaultValue])\n\n const [subOptions, setSubOptions] = useState<\n {\n render: () => React.ReactNode\n getProps: () => {\n key: string\n onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => void\n }\n }[]\n >()\n const [subAnchorEl, setSubAnchorEl] = useState<HTMLElement | null>(null)\n const [selectedPath, setSelectedPath] = useState<string>()\n const handleClick = useCallback(() => {\n setOpen((prev) => !prev)\n setSubAnchorEl(null)\n setSelectedPath(undefined)\n }, [])\n\n const makeOption = useCallback(\n (source: SelectData[number], path: number | string) => {\n const value = source.value\n const label = source.label || value || \"\"\n return {\n path: `${path}`,\n render: () => {\n if (source.Option === undefined) {\n return `${label}`\n } else if (typeof source.Option === \"function\") {\n const isExpanded = selectedPath === `${path}`\n return source.Option({\n label,\n value,\n isExpanded\n })\n } else {\n return source.Option\n }\n },\n getProps: () => ({\n key: `${path}.${source.value}`,\n onClick: (event: React.MouseEvent<HTMLLIElement, MouseEvent>) => {\n notUpdatedValue.current = false\n if (source.options) {\n setSubAnchorEl(event.currentTarget)\n setSubOptions(source.options.map((option, index) => makeOption(option, `${path}.${index}`)))\n setSelectedPath(`${path}`)\n } else {\n updateValue({ value })\n if (onChange) {\n event.persist()\n Object.defineProperty(event, \"target\", {\n writable: true,\n value: { value }\n })\n Object.defineProperty(event, \"currentTarget\", {\n writable: true,\n value: { value }\n })\n onChange(event as unknown as React.ChangeEvent<HTMLInputElement>)\n }\n setOpen(false)\n setSubAnchorEl(null)\n }\n }\n })\n }\n },\n [onChange, selectedPath]\n )\n const options = useMemo(() => {\n return data.map(makeOption)\n }, [data, makeOption])\n\n const theme = useTheme()\n\n const { loading, readOnly } = useFieldGroup({\n loading: propsLoading,\n readOnly: propsReadOnly\n })\n\n const listRef = useRef<HTMLDivElement>(null)\n\n useOnClickOutside([ref, listRef], () => {\n setOpen(false)\n })\n\n return (\n <React.Fragment>\n <ShimmerEffect active={loading}>\n <div\n ref={ref}\n onClick={!disabled && !readOnly ? handleClick : undefined}\n aria-disabled={disabled}\n data-open={open}\n aria-readonly={readOnly}\n aria-placeholder={label ? undefined : placeholder}\n css={css`\n position: relative;\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: space-between;\n background-color: white;\n min-height: ${theme.spacing * 6}px;\n padding: 9px 12px;\n ${css(theme.typography.body)}\n color: ${theme.palette.text.primary};\n cursor: pointer;\n resize: none;\n border: 1px solid ${theme.palette.text.secondary};\n border-radius: 4px;\n outline: 0px;\n &[data-open=\"true\"] {\n border-color: ${theme.palette.intentions.primary.main};\n }\n &[aria-disabled=\"true\"] {\n color: ${theme.palette.action.disabled};\n cursor: not-allowed;\n background-color: ${theme.palette.action.disabledBackground};\n border-color: ${theme.palette.action.disabled};\n }\n &[aria-readonly=\"true\"] {\n cursor: text;\n background-color: ${readonlyFieldBackgroundColor};\n border-color: ${readonlyFieldBorderColor};\n }\n &[aria-placeholder]::before {\n color: ${theme.palette.text.secondary};\n content: attr(aria-placeholder);\n }\n `}\n {...props}\n >\n <div>{label}</div>\n <input\n key={value}\n type=\"text\"\n css={css`\n position: absolute;\n top: 50%;\n left: 50%;\n z-index: -1;\n width: 1px;\n height: 1px;\n opacity: 0;\n `}\n name={name}\n defaultValue={value}\n required={required}\n />\n <SelectInnerSpinButton open={open} />\n </div>\n </ShimmerEffect>\n <Popper\n anchorEl={ref.current}\n open={open}\n placement=\"bottom-end\"\n disablePortal\n css={css`\n width: 100%;\n `}\n >\n <SelectList ref={listRef}>\n {React.Children.toArray(children).map((child, i) => (\n <SelectOption disabled key={`disabled-option-${i}`}>\n {child}\n </SelectOption>\n ))}\n {options.map((option) => (\n <SelectOption {...option.getProps()}>{option.render()}</SelectOption>\n ))}\n </SelectList>\n </Popper>\n <Popper anchorEl={subAnchorEl} placement=\"right-start\" style={{ minWidth: 200 }}>\n <SelectList elevation={4}>\n {subOptions?.map((subOption) => (\n <SelectOption {...subOption.getProps()}>{subOption.render()}</SelectOption>\n ))}\n </SelectList>\n </Popper>\n </React.Fragment>\n )\n}\n"],"file":"Select.js"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "matsuri-ui",
3
- "version": "10.2.2",
3
+ "version": "10.2.3",
4
4
  "repository": "https://github.com/matsuri-tech/matsuri-ui.git",
5
5
  "license": "GPL-3.0",
6
6
  "sideEffects": false,