Skip to content

Commit

Permalink
fix: 修正漏れ
Browse files Browse the repository at this point in the history
  • Loading branch information
uknmr committed Aug 14, 2024
1 parent 6739432 commit f4d5444
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 98 deletions.
22 changes: 14 additions & 8 deletions packages/smarthr-ui/src/components/Dialog/DialogBody.tsx
Original file line number Diff line number Diff line change
@@ -1,13 +1,14 @@
import React, { type PropsWithChildren } from 'react'
import React, { type ComponentProps, type PropsWithChildren } from 'react'
import { VariantProps, tv } from 'tailwind-variants'

import type { Gap } from '../../types'

export type Props = PropsWithChildren<
Pick<VariantProps<typeof dialogBody>, 'contentBgColor'> & {
contentPadding?: Gap | { block?: Gap; inline?: Gap }
}
>
export type Props = ComponentProps<'div'> &
PropsWithChildren<
Pick<VariantProps<typeof dialogBody>, 'contentBgColor'> & {
contentPadding?: Gap | { block?: Gap; inline?: Gap }
}
>

const dialogBody = tv({
base: ['smarthr-ui-Dialog-body', 'shr-overflow-auto shr-flex-auto'],
Expand Down Expand Up @@ -78,10 +79,15 @@ const dialogBody = tv({
},
})

export const DialogBody: React.FC<Props> = ({ contentBgColor, contentPadding = 1.5, ...rest }) => {
export const DialogBody: React.FC<Props> = ({
contentBgColor,
contentPadding = 1.5,
className,
...rest
}) => {
const paddingBlock = contentPadding instanceof Object ? contentPadding.block : contentPadding
const paddingInline = contentPadding instanceof Object ? contentPadding.inline : contentPadding

const style = dialogBody({ contentBgColor, paddingBlock, paddingInline })
const style = dialogBody({ contentBgColor, paddingBlock, paddingInline, className })
return <div {...rest} className={style} />
}
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ export type BaseProps = PropsWithChildren<
actionTheme?: 'primary' | 'secondary' | 'danger'
/**
* アクションボタンをクリックした時に発火するコールバック関数
* @param closeDialog - ダイアログを閉じる関数
* @param closeDialog ダイアログを閉じる関数
*/
onSubmit: (closeDialog: () => void, e: FormEvent<HTMLFormElement>) => void
/** アクションボタンを無効にするかどうか */
Expand Down
104 changes: 15 additions & 89 deletions packages/smarthr-ui/src/components/Dialog/ModelessDialog.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -19,13 +19,13 @@ import { useId } from '../../hooks/useId'
import { useTheme } from '../../hooks/useTailwindTheme'
import { Base, BaseElementProps } from '../Base'
import { Button } from '../Button'
import { FaGripHorizontalIcon, FaTimesIcon } from '../Icon'
import { FaGripIcon, FaXmarkIcon } from '../Icon'

import { DialogBody, type Props as DialogBodyProps } from './DialogBody'
import { DialogOverlap } from './DialogOverlap'
import { type ContentBodyProps } from './dialogInnerStyle'
import { useDialogPortal } from './useDialogPortal'

import type { DecoratorsType, Gap } from '../../types'
import type { DecoratorsType } from '../../types'

type Props = PropsWithChildren<{
/**
Expand Down Expand Up @@ -82,7 +82,7 @@ type Props = PropsWithChildren<{
dialogHandlerAriaValuetext?: (txt: string, data: DOMRect | undefined) => string
}
}> &
ContentBodyProps
DialogBodyProps

const DIALOG_HANDLER_ARIA_LABEL = 'ダイアログの位置'
const CLOSE_BUTTON_ICON_ALT = '閉じる'
Expand All @@ -108,84 +108,12 @@ const modelessDialog = tv({
footerEl: 'smarthr-ui-ModelessDialog-footer shr-border-t-shorthand',
},
})
// FIXME: 他のダイアログと共通化したかったが別でやる
const dialogBody = tv({
base: [
'smarthr-ui-ModelessDialog-content',
'shr-flex-1 shr-overflow-auto shr-overscroll-contain',
],
variants: {
contentPaddingBlock: {
0: 'shr-py-0',
0.25: 'shr-py-0.25',
0.5: 'shr-py-0.5',
0.75: 'shr-py-0.75',
1: 'shr-py-1',
1.25: 'shr-py-1.25',
1.5: 'shr-py-1.5',
2: 'shr-py-2',
2.5: 'shr-py-2.5',
3: 'shr-py-3',
3.5: 'shr-py-3.5',
4: 'shr-py-4',
8: 'shr-py-8',
X3S: 'shr-py-0.25',
XXS: 'shr-py-0.5',
XS: 'shr-py-1',
S: 'shr-py-1.5',
M: 'shr-py-2',
L: 'shr-py-2.5',
XL: 'shr-py-3',
XXL: 'shr-py-3.5',
X3L: 'shr-py-4',
} as { [key in Gap]: string },
contentPaddingInline: {
0: 'shr-px-0',
0.25: 'shr-px-0.25',
0.5: 'shr-px-0.5',
0.75: 'shr-px-0.75',
1: 'shr-px-1',
1.25: 'shr-px-1.25',
1.5: 'shr-px-1.5',
2: 'shr-px-2',
2.5: 'shr-px-2.5',
3: 'shr-px-3',
3.5: 'shr-px-3.5',
4: 'shr-px-4',
8: 'shr-px-8',
X3S: 'shr-px-0.25',
XXS: 'shr-px-0.5',
XS: 'shr-px-1',
S: 'shr-px-1.5',
M: 'shr-px-2',
L: 'shr-px-2.5',
XL: 'shr-px-3',
XXL: 'shr-px-3.5',
X3L: 'shr-px-4',
} as { [key in Gap]: string },
contentBgColor: {
BACKGROUND: 'shr-bg-background',
COLUMN: 'shr-bg-column',
BASE_GREY: 'shr-bg-base-grey',
OVER_BACKGROUND: 'shr-bg-over-background',
HEAD: 'shr-bg-head',
BORDER: 'shr-bg-[theme(colors.grey.20)]',
ACTION_BACKGROUND: 'shr-bg-action-background',
WHITE: 'shr-bg-white',
GREY_5: 'shr-bg-[theme(colors.grey.5)]',
GREY_6: 'shr-bg-[theme(colors.grey.6)]',
GREY_7: 'shr-bg-[theme(colors.grey.7)]',
GREY_9: 'shr-bg-[theme(colors.grey.9)]',
GREY_20: 'shr-bg-[theme(colors.grey.20)]',
},
},
})

export const ModelessDialog: FC<Props & BaseElementProps> = ({
header,
children,
contentBgColor,
contentPadding = 1.5,
contentPadding,
footer,
isOpen,
onClickClose,
Expand Down Expand Up @@ -213,28 +141,20 @@ export const ModelessDialog: FC<Props & BaseElementProps> = ({
titleStyle,
dialogHandlerStyle,
closeButtonLayoutStyle,
contentStyle,
footerStyle,
} = useMemo(() => {
const { layout, box, headerEl, title, dialogHandler, closeButtonLayout, footerEl } =
modelessDialog()
const paddingBlock = contentPadding instanceof Object ? contentPadding.block : contentPadding
const paddingInline = contentPadding instanceof Object ? contentPadding.inline : contentPadding
return {
layoutStyle: layout({ className }),
boxStyle: box(),
headerStyle: headerEl(),
titleStyle: title(),
dialogHandlerStyle: dialogHandler(),
closeButtonLayoutStyle: closeButtonLayout(),
contentStyle: dialogBody({
contentBgColor,
contentPaddingBlock: paddingBlock,
contentPaddingInline: paddingInline,
}),
footerStyle: footerEl(),
}
}, [className, contentBgColor, contentPadding])
}, [className])
const boxStyleProps = useMemo(() => {
const leftMargin = typeof left === 'number' ? `${left}px` : left
const rightMargin = typeof right === 'number' ? `${right}px` : right
Expand Down Expand Up @@ -430,7 +350,7 @@ export const ModelessDialog: FC<Props & BaseElementProps> = ({
aria-valuetext={dialogHandlerAriaValuetext}
onKeyDown={handleArrowKey}
>
<FaGripHorizontalIcon />
<FaGripIcon />
</div>
<div id={labelId} className={titleStyle}>
{header}
Expand All @@ -443,11 +363,17 @@ export const ModelessDialog: FC<Props & BaseElementProps> = ({
onClick={onClickClose}
className="smarthr-ui-ModelessDialog-closeButton"
>
<FaTimesIcon alt={closeButtonIconAlt} />
<FaXmarkIcon alt={closeButtonIconAlt} />
</Button>
</div>
</div>
<div className={contentStyle}>{children}</div>
<DialogBody
contentBgColor={contentBgColor}
contentPadding={contentPadding}
className="smarthr-ui-ModelessDialog-content shr-overscroll-contain"
>
{children}
</DialogBody>
{footer && <div className={footerStyle}>{footer}</div>}
</Base>
</div>
Expand Down

0 comments on commit f4d5444

Please sign in to comment.