Interactive Angular 19 demo for @sda/notification-elements-ui with 6 sections: Bell & Feed, Notification Center, Inbox, Comments & Threads, Mention Input, and Full-Featured layout. Includes mock data, dark mode toggle, and real-time event log. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
31 lines
730 B
JavaScript
31 lines
730 B
JavaScript
import {getCategory, isAmbiguous, isFullWidth, isWide} from './lookup.js';
|
|
|
|
function validate(codePoint) {
|
|
if (!Number.isSafeInteger(codePoint)) {
|
|
throw new TypeError(`Expected a code point, got \`${typeof codePoint}\`.`);
|
|
}
|
|
}
|
|
|
|
export function eastAsianWidthType(codePoint) {
|
|
validate(codePoint);
|
|
|
|
return getCategory(codePoint);
|
|
}
|
|
|
|
export function eastAsianWidth(codePoint, {ambiguousAsWide = false} = {}) {
|
|
validate(codePoint);
|
|
|
|
if (
|
|
isFullWidth(codePoint)
|
|
|| isWide(codePoint)
|
|
|| (ambiguousAsWide && isAmbiguous(codePoint))
|
|
) {
|
|
return 2;
|
|
}
|
|
|
|
return 1;
|
|
}
|
|
|
|
// Private exports for https://github.com/sindresorhus/is-fullwidth-code-point
|
|
export {isFullWidth as _isFullWidth, isWide as _isWide} from './lookup.js';
|