@gechiui/block-editor
Version:
99 lines (89 loc) • 2.46 kB
JavaScript
/**
* External dependencies
*/
import { colord, extend } from 'colord';
import namesPlugin from 'colord/plugins/names';
import a11yPlugin from 'colord/plugins/a11y';
/**
* GeChiUI dependencies
*/
import { speak } from '@gechiui/a11y';
import { __ } from '@gechiui/i18n';
import { Notice } from '@gechiui/components';
import { useEffect } from '@gechiui/element';
extend( [ namesPlugin, a11yPlugin ] );
function ContrastCheckerMessage( {
colordBackgroundColor,
colordTextColor,
backgroundColor,
textColor,
} ) {
const msg =
colordBackgroundColor.brightness() < colordTextColor.brightness()
? __(
'此颜色组合可能不便阅读,请改用较深的背景颜色搭配较浅的文本颜色。'
)
: __(
'此颜色组合可能不便阅读,请改用较浅的背景颜色搭配较深的文本颜色。'
);
// Note: The `Notice` component can speak messages via its `spokenMessage`
// prop, but the contrast checker requires granular control over when the
// announcements are made. Notably, the message will be re-announced if a
// new color combination is selected and the contrast is still insufficient.
useEffect( () => {
speak( __( '此颜色组合可能不便阅读。' ) );
}, [ backgroundColor, textColor ] );
return (
<div className="block-editor-contrast-checker">
<Notice
spokenMessage={ null }
status="warning"
isDismissible={ false }
>
{ msg }
</Notice>
</div>
);
}
function ContrastChecker( {
backgroundColor,
fallbackBackgroundColor,
fallbackTextColor,
fontSize, // font size value in pixels
isLargeText,
textColor,
} ) {
if (
! ( backgroundColor || fallbackBackgroundColor ) ||
! ( textColor || fallbackTextColor )
) {
return null;
}
const colordBackgroundColor = colord(
backgroundColor || fallbackBackgroundColor
);
const colordTextColor = colord( textColor || fallbackTextColor );
const hasTransparency =
colordBackgroundColor.alpha() !== 1 || colordTextColor.alpha() !== 1;
if (
hasTransparency ||
colordTextColor.isReadable( colordBackgroundColor, {
level: 'AA',
size:
isLargeText || ( isLargeText !== false && fontSize >= 24 )
? 'large'
: 'small',
} )
) {
return null;
}
return (
<ContrastCheckerMessage
backgroundColor={ backgroundColor }
textColor={ textColor }
colordBackgroundColor={ colordBackgroundColor }
colordTextColor={ colordTextColor }
/>
);
}
export default ContrastChecker;