Skip to content

Commit

Permalink
fix(many): adjust border colors to meet a11y contrast standards
Browse files Browse the repository at this point in the history
Closes: INSTUI-4319
  • Loading branch information
ToMESSKa authored and balzss committed Nov 18, 2024
1 parent 569072e commit 2f47e06
Show file tree
Hide file tree
Showing 37 changed files with 300 additions and 51 deletions.
2 changes: 2 additions & 0 deletions packages/shared-types/src/Colors.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ type Primitives = {
grey12: string
grey14: string
grey24: string
grey30: string
grey45: string
grey57: string
grey70: string
Expand Down Expand Up @@ -195,6 +196,7 @@ type Contrasts = {
grey1214: Primitives['grey12'] | Primitives['grey14']
grey1424: Primitives['grey14'] | Primitives['grey24']
grey2424: Primitives['grey24']
grey3045: Primitives['grey30'] | Primitives['grey45']
grey4570: Primitives['grey45'] | Primitives['grey70']
grey5782: Primitives['grey57'] | Primitives['grey82']
grey100100: Primitives['grey100']
Expand Down
16 changes: 16 additions & 0 deletions packages/shared-types/src/ComponentThemeVariables.ts
Original file line number Diff line number Diff line change
Expand Up @@ -345,6 +345,8 @@ export type ToggleFacadeTheme = {
labelFontSizeMedium: Typography['fontSizeMedium']
labelFontSizeLarge: Typography['fontSizeLarge']
errorBorderColor: Colors['contrasts']['red4570']
uncheckedIconBorderColor: Colors['contrasts']['grey3045']
checkedIconBorderColor: Colors['contrasts']['green5782']
}

export type CodeEditorTheme = {
Expand Down Expand Up @@ -536,6 +538,8 @@ export type DrilldownTheme = {
headerTitleFontWeight: Typography['fontWeightBold']
headerActionColor: Colors['contrasts']['blue4570']
labelInfoPadding: Spacing['small']
labelInfoColor: Colors['contrasts']['grey5782']
borderColor: Colors['contrasts']['grey3045']
}

export type FileDropTheme = {
Expand Down Expand Up @@ -714,6 +718,7 @@ export type MenuItemTheme = {
activeBackground: Colors['contrasts']['blue4570']
activeLabelColor: Colors['contrasts']['white1010']
activeIconColor: Colors['contrasts']['white1010']
labelInfoColor: Colors['contrasts']['grey5782']
}

export type MenuGroupTheme = {
Expand Down Expand Up @@ -964,6 +969,10 @@ export type PillTheme = {
borderRadius: string | 0
}

export type PopoverTheme = {
borderColor: Colors['contrasts']['grey3045']
}

export type PositionTheme = {
zIndex: Stacking['topmost']
}
Expand Down Expand Up @@ -1423,6 +1432,10 @@ export type ToggleDetailsTheme = {
filledPadding: Spacing['small']
}

export type ToggleGroupTheme = {
borderColor: Colors['contrasts']['grey3045']
}

export type TooltipTheme = {
fontFamily: Typography['fontFamily']
fontWeight: Typography['fontWeightNormal']
Expand Down Expand Up @@ -1749,6 +1762,7 @@ export interface ThemeVariables {
Pages: PagesTheme
PaginationPageInput: PaginationPageInputTheme
'Pagination.PageInput': PaginationPageInputTheme
Popover: PopoverTheme
Position: PositionTheme
Pill: PillTheme
ProgressBar: ProgressBarTheme
Expand Down Expand Up @@ -1785,6 +1799,8 @@ export interface ThemeVariables {
TextArea: TextAreaTheme
TextInput: TextInputTheme
ToggleDetails: ToggleDetailsTheme
ToggleGroup: ToggleGroupTheme
'ToggleDetails.ToggleGroup': ToggleGroupTheme
Tooltip: TooltipTheme
TopNavBarBrand: TopNavBarBrandTheme
'TopNavBar.Brand': TopNavBarBrandTheme
Expand Down
2 changes: 1 addition & 1 deletion packages/ui-avatar/src/Avatar/theme.ts
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ const generateComponentTheme = (theme: Theme): AvatarTheme => {
background: colors?.contrasts?.white1010,
borderWidthSmall: borders?.widthSmall,
borderWidthMedium: borders?.widthMedium,
borderColor: colors?.contrasts?.grey1214,
borderColor: colors?.contrasts?.grey3045,
boxShadowColor: alpha('#2d3b45', 12),
boxShadowBlur: '1rem',
fontFamily: typography?.fontFamily,
Expand Down
14 changes: 7 additions & 7 deletions packages/ui-buttons/src/BaseButton/theme.ts
Original file line number Diff line number Diff line change
Expand Up @@ -39,18 +39,18 @@ const generateComponentTheme = (theme: Theme): BaseButtonTheme => {
const themeSpecificStyle: ThemeSpecificStyle<BaseButtonTheme> = {
canvas: {
primaryColor: theme['ic-brand-button--primary-text']!,
primaryBorderColor: theme['ic-brand-button--primary-bgd']!,
primaryBorderColor: darken(theme['ic-brand-button--primary-bgd']!),
primaryBackground: theme['ic-brand-button--primary-bgd']!,
primaryHoverBackground: darken(theme['ic-brand-button--primary-bgd']!),
primaryActiveBackground: darken(theme['ic-brand-button--primary-bgd']!),
primaryActiveBoxShadow: `${activeShadow} ${theme[
'ic-brand-button--primary-bgd'
]!}`,
primaryGhostColor: theme['ic-brand-button--primary-bgd']!,
primaryGhostBorderColor: theme['ic-brand-button--primary-bgd']!,
primaryGhostColor: darken(theme['ic-brand-button--primary-bgd']!),
primaryGhostBorderColor: darken(theme['ic-brand-button--primary-bgd']!),
primaryGhostBackground: 'transparent',
primaryGhostHoverBackground: alpha(
theme['ic-brand-button--primary-bgd']!,
darken(theme['ic-brand-button--primary-bgd']!),
10
),
primaryGhostActiveBackground: 'transparent',
Expand Down Expand Up @@ -104,10 +104,10 @@ const generateComponentTheme = (theme: Theme): BaseButtonTheme => {
primaryHoverBackground: colors?.contrasts?.blue5782,
primaryActiveBackground: colors?.contrasts?.blue5782,
primaryActiveBoxShadow: `${activeShadow} ${colors?.contrasts?.white1010}`,
primaryGhostColor: colors?.contrasts?.blue4570,
primaryGhostColor: colors?.contrasts?.blue5782,
primaryGhostBorderColor: colors?.contrasts?.blue4570,
primaryGhostBackground: 'transparent',
primaryGhostHoverBackground: alpha(colors?.contrasts?.blue4570, 10),
primaryGhostHoverBackground: colors?.contrasts?.blue1212,
primaryGhostActiveBackground: 'transparent',
primaryGhostActiveBoxShadow: `${activeShadow} ${alpha(
colors?.contrasts?.blue1212,
Expand All @@ -123,7 +123,7 @@ const generateComponentTheme = (theme: Theme): BaseButtonTheme => {
secondaryGhostColor: colors?.contrasts?.grey125125,
secondaryGhostBorderColor: colors?.contrasts?.grey125125,
secondaryGhostBackground: 'transparent',
secondaryGhostHoverBackground: alpha(colors?.contrasts?.grey125125, 10),
secondaryGhostHoverBackground: colors?.contrasts?.grey1111,
secondaryGhostActiveBackground: 'transparent',
secondaryGhostActiveBoxShadow: `${activeShadow} ${alpha(
colors?.contrasts?.grey125125,
Expand Down
2 changes: 1 addition & 1 deletion packages/ui-checkbox/src/Checkbox/CheckboxFacade/theme.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ const generateComponentTheme = (theme: Theme): CheckboxFacadeTheme => {
const componentVariables: CheckboxFacadeTheme = {
color: colors?.contrasts?.white1010,
borderWidth: borders?.widthSmall,
borderColor: colors?.contrasts?.grey1214,
borderColor: colors?.contrasts?.grey3045,
errorBorderColor: colors?.ui?.textError,
borderRadius: borders?.radiusMedium,
background: colors?.contrasts?.white1010,
Expand Down
13 changes: 8 additions & 5 deletions packages/ui-checkbox/src/Checkbox/ToggleFacade/styles.ts
Original file line number Diff line number Diff line change
Expand Up @@ -157,13 +157,16 @@ const generateStyle = (
'&::before': {
content: '""',
position: 'absolute',
top: componentTheme.borderWidth,
left: componentTheme.borderWidth,
height: `calc(100% - (${componentTheme.borderWidth} * 2))`,
width: `calc(100% - (${componentTheme.borderWidth} * 2))`,
height: `calc(100% - (${componentTheme.borderWidth} * 6))`,
width: `calc(100% - (${componentTheme.borderWidth} * 6))`,
background: componentTheme.toggleBackground,
boxShadow: componentTheme.toggleShadow,
borderRadius: '100%'
borderRadius: '100%',
border: `${componentTheme.borderWidth} solid ${
checked
? componentTheme.checkedIconBorderColor
: componentTheme.uncheckedIconBorderColor
}`
}
},

Expand Down
8 changes: 5 additions & 3 deletions packages/ui-checkbox/src/Checkbox/ToggleFacade/theme.ts
Original file line number Diff line number Diff line change
Expand Up @@ -56,15 +56,15 @@ const generateComponentTheme = (theme: Theme): ToggleFacadeTheme => {
color: colors?.contrasts?.white1010,
errorBorderColor: colors?.ui?.textError,
background: colors?.contrasts?.grey1111,
borderColor: colors?.contrasts?.grey1214,
borderColor: colors?.contrasts?.grey3045,
borderWidth: borders?.widthSmall,
borderRadius: '4rem',
marginEnd: spacing?.small,
marginStart: spacing?.small,
marginVertical: spacing?.xSmall,
checkedBackground: colors?.contrasts?.green4570,
uncheckedIconColor: colors?.contrasts?.grey125125,
checkedIconColor: colors?.contrasts?.green4570,
checkedIconColor: colors?.contrasts?.green5782,
focusOutlineColor: colors?.contrasts?.blue4570,
focusBorderWidth: borders?.widthMedium,
focusBorderStyle: borders?.style,
Expand All @@ -77,7 +77,9 @@ const generateComponentTheme = (theme: Theme): ToggleFacadeTheme => {
labelLineHeight: typography?.lineHeightCondensed,
labelFontSizeSmall: typography?.fontSizeSmall,
labelFontSizeMedium: typography?.fontSizeMedium,
labelFontSizeLarge: typography?.fontSizeLarge
labelFontSizeLarge: typography?.fontSizeLarge,
uncheckedIconBorderColor: colors?.contrasts?.grey5782,
checkedIconBorderColor: colors?.contrasts?.green5782
}

return {
Expand Down
1 change: 1 addition & 0 deletions packages/ui-drilldown/src/Drilldown/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -1377,6 +1377,7 @@ class Drilldown extends Component<DrilldownProps, DrilldownState> {
getDisabledOptionProps
}) => (
<View
borderWidth="small"
as="div"
elementRef={this.handleDrilldownRef}
tabIndex={0}
Expand Down
4 changes: 3 additions & 1 deletion packages/ui-drilldown/src/Drilldown/styles.ts
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,7 @@ const generateStyle = (
drilldown: {
label: 'drilldown',
overflow: 'visible', // needed for focus ring!
borderColor: componentTheme.borderColor,

...(hasHighlightedOption && {
'&:focus::before': {
Expand Down Expand Up @@ -80,7 +81,8 @@ const generateStyle = (
flexShrink: 0,
height: '100%',
alignItems: 'center',
paddingInlineStart: componentTheme.labelInfoPadding
paddingInlineStart: componentTheme.labelInfoPadding,
color: componentTheme.labelInfoColor
},
optionContent: {
label: 'drilldown__optionContent',
Expand Down
4 changes: 3 additions & 1 deletion packages/ui-drilldown/src/Drilldown/theme.ts
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,9 @@ const generateComponentTheme = (theme: Theme): DrilldownTheme => {
const componentVariables: DrilldownTheme = {
headerTitleFontWeight: typography.fontWeightBold,
headerActionColor: colors?.contrasts?.blue4570,
labelInfoPadding: spacing?.small
labelInfoPadding: spacing?.small,
labelInfoColor: colors?.contrasts?.grey5782,
borderColor: colors?.contrasts?.grey3045
}

return {
Expand Down
3 changes: 2 additions & 1 deletion packages/ui-menu/src/Menu/MenuItem/styles.ts
Original file line number Diff line number Diff line change
Expand Up @@ -143,7 +143,8 @@ const generateStyle = (
height: '100%',
float: 'right',
clear: 'right',
paddingRight: '1.75rem'
paddingRight: '1.75rem',
color: componentTheme.labelInfoColor
},
label: {
label: 'menuItem__label',
Expand Down
4 changes: 3 additions & 1 deletion packages/ui-menu/src/Menu/MenuItem/theme.ts
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,9 @@ const generateComponentTheme = (theme: Theme): MenuItemTheme => {

activeBackground: colors?.contrasts?.blue4570,
activeLabelColor: colors?.contrasts?.white1010,
activeIconColor: colors?.contrasts?.white1010
activeIconColor: colors?.contrasts?.white1010,

labelInfoColor: colors?.contrasts?.grey5782
}

return {
Expand Down
2 changes: 1 addition & 1 deletion packages/ui-number-input/src/NumberInput/theme.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ const generateComponentTheme = (theme: Theme): NumberInputTheme => {

borderWidth: borders?.widthSmall,
borderStyle: borders?.style,
borderColor: colors?.contrasts?.grey1214,
borderColor: colors?.contrasts?.grey3045,
borderRadius: borders?.radiusMedium,

color: colors?.contrasts?.grey125125,
Expand Down
2 changes: 1 addition & 1 deletion packages/ui-options/src/Options/Item/theme.ts
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ const generateComponentTheme = (theme: Theme): OptionsItemTheme => {
descriptionFontWeight: typography.fontWeightNormal,
descriptionLineHeight: typography.lineHeight,
descriptionPaddingStart: '0.25em',
descriptionColor: colors?.contrasts?.grey4570
descriptionColor: colors?.contrasts?.grey5782
}

return {
Expand Down
20 changes: 17 additions & 3 deletions packages/ui-popover/src/Popover/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -55,10 +55,14 @@ import type { ViewProps, ContextViewProps } from '@instructure/ui-view'
import type { PositionProps } from '@instructure/ui-position'
import type { DialogProps } from '@instructure/ui-dialog'

import { withStyle } from '@instructure/emotion'

import generateStyle from './styles'
import generateComponentTheme from './theme'

import type { PopoverProps, PopoverState } from './props'
import { allowedProps, propTypes } from './props'
import type { Renderable } from '@instructure/shared-types'

/**
---
category: components
Expand All @@ -67,6 +71,7 @@ tags: overlay, portal, dialog
**/
@withDeterministicId()
@textDirectionContextConsumer()
@withStyle(generateStyle, generateComponentTheme)
@testable()
class Popover extends Component<PopoverProps, PopoverState> {
static readonly componentId = 'Popover'
Expand Down Expand Up @@ -558,6 +563,7 @@ class Popover extends Component<PopoverProps, PopoverState> {
}

const { placement } = this.state
const { styles } = this.props

if (this.props.withArrow) {
viewProps = {
Expand All @@ -570,7 +576,11 @@ class Popover extends Component<PopoverProps, PopoverState> {
: placement
} as Partial<ContextViewProps> & { ref: any }

return <ContextView {...viewProps}>{content}</ContextView>
return (
<ContextView {...viewProps} borderColor={styles?.borderColor}>
{content}
</ContextView>
)
} else {
viewProps = {
...viewProps,
Expand All @@ -579,7 +589,11 @@ class Popover extends Component<PopoverProps, PopoverState> {
...(color === 'primary-inverse' && { borderColor: 'transparent' })
} as Partial<ViewProps> & { ref: any }

return <View {...viewProps}>{content}</View>
return (
<View {...viewProps} borderColor={styles?.borderColor}>
{content}
</View>
)
}
} else {
return null
Expand Down
12 changes: 8 additions & 4 deletions packages/ui-popover/src/Popover/props.ts
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ import { element } from '@instructure/ui-prop-types'
import { ThemeablePropTypes } from '@instructure/emotion'
import { PositionPropTypes } from '@instructure/ui-position'

import type { Shadow, Stacking } from '@instructure/emotion'
import type { Shadow, Stacking, WithStyleProps } from '@instructure/emotion'

import type {
PlacementPropValues,
Expand All @@ -41,7 +41,8 @@ import type {
PropValidators,
LiveRegion,
UIElement,
Renderable
Renderable,
PopoverTheme
} from '@instructure/shared-types'
import type { WithDeterministicIdProps } from '@instructure/ui-react-utils'

Expand Down Expand Up @@ -278,7 +279,8 @@ type PopoverOwnProps = {

type PopoverProps = PopoverOwnProps &
TextDirectionContextConsumerProps &
WithDeterministicIdProps
WithDeterministicIdProps &
WithStyleProps<PopoverTheme, PopoverStyle>

type PopoverState = {
placement: PopoverOwnProps['placement']
Expand All @@ -291,6 +293,8 @@ type PropKeys = keyof PopoverOwnProps

type AllowedPropKeys = Readonly<Array<PropKeys>>

type PopoverStyle = { borderColor: string }

const propTypes: PropValidators<PropKeys> = {
isShowingContent: PropTypes.bool,
defaultIsShowingContent: PropTypes.bool,
Expand Down Expand Up @@ -388,5 +392,5 @@ const allowedProps: AllowedPropKeys = [
'elementRef'
]

export type { PopoverOwnProps, PopoverProps, PopoverState }
export type { PopoverOwnProps, PopoverProps, PopoverState, PopoverStyle }
export { propTypes, allowedProps }
Loading

0 comments on commit 2f47e06

Please sign in to comment.