* feat: add editor icon * refactor: remove 'any' type and format * refactor: move NotesOptions and add ChangeEditorOption * refactor: fix type for using regular RefObject<T> * feat: add hide-if-last-child util class * feat: add Change Editor option * feat: make radio btn gray if not checked * fix: accordion menu header and item sizing/spacing * feat: add Escape key to KeyboardKey enum * refactor: Remove Editor Menu * feat: add editor select functionality * refactor: move plain editor name to constant * feat: add premium editors with modal if no subscription refactor: simplify menu group creation * feat: show alert when switching to non-interchangeable editor * fix: change editor menu going out of bounds * feat: increase group header & editor item size * fix: change editor menu close on blur * refactor: Use KeyboardKey enum & remove else statement * feat: add keyboard navigation to change editor menu * fix: editor menu separators * feat: improve change editor menu sizing & spacing * feat: show alert only if editor is not interchangeable * feat: don't show alert when switching to/from plain editor * chore: bump snjs version * feat: temporarily remove change editor alert * feat: dynamically get footer height * refactor: move magic number to const * refactor: move constants to constants file * feat: use const instead of magic number
166 lines
5.8 KiB
TypeScript
166 lines
5.8 KiB
TypeScript
import EditorIcon from '../../icons/ic-editor.svg';
|
|
import PremiumFeatureIcon from '../../icons/ic-premium-feature.svg';
|
|
import PencilOffIcon from '../../icons/ic-pencil-off.svg';
|
|
import PlainTextIcon from '../../icons/ic-text-paragraph.svg';
|
|
import RichTextIcon from '../../icons/ic-text-rich.svg';
|
|
import TrashIcon from '../../icons/ic-trash.svg';
|
|
import TrashFilledIcon from '../../icons/ic-trash-filled.svg';
|
|
import PinIcon from '../../icons/ic-pin.svg';
|
|
import PinFilledIcon from '../../icons/ic-pin-filled.svg';
|
|
import UnpinIcon from '../../icons/ic-pin-off.svg';
|
|
import ArchiveIcon from '../../icons/ic-archive.svg';
|
|
import UnarchiveIcon from '../../icons/ic-unarchive.svg';
|
|
import HashtagIcon from '../../icons/ic-hashtag.svg';
|
|
import ChevronRightIcon from '../../icons/ic-chevron-right.svg';
|
|
import RestoreIcon from '../../icons/ic-restore.svg';
|
|
import CloseIcon from '../../icons/ic-close.svg';
|
|
import PasswordIcon from '../../icons/ic-textbox-password.svg';
|
|
import TrashSweepIcon from '../../icons/ic-trash-sweep.svg';
|
|
import MoreIcon from '../../icons/ic-more.svg';
|
|
import TuneIcon from '../../icons/ic-tune.svg';
|
|
import MenuArrowDownIcon from '../../icons/ic-menu-arrow-down.svg';
|
|
import MenuCloseIcon from '../../icons/ic-menu-close.svg';
|
|
import AuthenticatorIcon from '../../icons/ic-authenticator.svg';
|
|
import SpreadsheetsIcon from '../../icons/ic-spreadsheets.svg';
|
|
import TasksIcon from '../../icons/ic-tasks.svg';
|
|
import MarkdownIcon from '../../icons/ic-markdown.svg';
|
|
import NotesIcon from '../../icons/ic-notes.svg';
|
|
import CodeIcon from '../../icons/ic-code.svg';
|
|
|
|
import AccessibilityIcon from '../../icons/ic-accessibility.svg';
|
|
import AddIcon from '../../icons/ic-add.svg';
|
|
import HelpIcon from '../../icons/ic-help.svg';
|
|
import KeyboardIcon from '../../icons/ic-keyboard.svg';
|
|
import ListBulleted from '../../icons/ic-list-bulleted.svg';
|
|
import ListedIcon from '../../icons/ic-listed.svg';
|
|
import SecurityIcon from '../../icons/ic-security.svg';
|
|
import SettingsIcon from '../../icons/ic-settings.svg';
|
|
import StarIcon from '../../icons/ic-star.svg';
|
|
import ThemesIcon from '../../icons/ic-themes.svg';
|
|
import UserIcon from '../../icons/ic-user.svg';
|
|
import CopyIcon from '../../icons/ic-copy.svg';
|
|
import DownloadIcon from '../../icons/ic-download.svg';
|
|
import InfoIcon from '../../icons/ic-info.svg';
|
|
import CheckIcon from '../../icons/ic-check.svg';
|
|
import CheckBoldIcon from '../../icons/ic-check-bold.svg';
|
|
import AccountCircleIcon from '../../icons/ic-account-circle.svg';
|
|
import CloudOffIcon from '../../icons/ic-cloud-off.svg';
|
|
import SignInIcon from '../../icons/ic-signin.svg';
|
|
import SignOutIcon from '../../icons/ic-signout.svg';
|
|
import CheckCircleIcon from '../../icons/ic-check-circle.svg';
|
|
import SyncIcon from '../../icons/ic-sync.svg';
|
|
import ArrowLeftIcon from '../../icons/ic-arrow-left.svg';
|
|
import ChevronDownIcon from '../../icons/ic-chevron-down.svg';
|
|
import EmailIcon from '../../icons/ic-email.svg';
|
|
import ServerIcon from '../../icons/ic-server.svg';
|
|
import EyeIcon from '../../icons/ic-eye.svg';
|
|
import EyeOffIcon from '../../icons/ic-eye-off.svg';
|
|
import LockIcon from '../../icons/ic-lock.svg';
|
|
import LockFilledIcon from '../../icons/ic-lock-filled.svg';
|
|
import ArrowsSortUpIcon from '../../icons/ic-arrows-sort-up.svg';
|
|
import ArrowsSortDownIcon from '../../icons/ic-arrows-sort-down.svg';
|
|
import WindowIcon from '../../icons/ic-window.svg';
|
|
import LinkOffIcon from '../../icons/ic-link-off.svg';
|
|
|
|
import MenuArrowDownAlt from '../../icons/ic-menu-arrow-down-alt.svg';
|
|
import MenuArrowRight from '../../icons/ic-menu-arrow-right.svg';
|
|
|
|
import { toDirective } from './utils';
|
|
import { FunctionalComponent } from 'preact';
|
|
|
|
const ICONS = {
|
|
'editor': EditorIcon,
|
|
'menu-arrow-down-alt': MenuArrowDownAlt,
|
|
'menu-arrow-right': MenuArrowRight,
|
|
notes: NotesIcon,
|
|
'arrows-sort-up': ArrowsSortUpIcon,
|
|
'arrows-sort-down': ArrowsSortDownIcon,
|
|
lock: LockIcon,
|
|
'lock-filled': LockFilledIcon,
|
|
eye: EyeIcon,
|
|
'eye-off': EyeOffIcon,
|
|
server: ServerIcon,
|
|
email: EmailIcon,
|
|
'chevron-down': ChevronDownIcon,
|
|
'arrow-left': ArrowLeftIcon,
|
|
sync: SyncIcon,
|
|
'check-circle': CheckCircleIcon,
|
|
signIn: SignInIcon,
|
|
signOut: SignOutIcon,
|
|
'cloud-off': CloudOffIcon,
|
|
'pencil-off': PencilOffIcon,
|
|
'plain-text': PlainTextIcon,
|
|
'rich-text': RichTextIcon,
|
|
code: CodeIcon,
|
|
markdown: MarkdownIcon,
|
|
authenticator: AuthenticatorIcon,
|
|
spreadsheets: SpreadsheetsIcon,
|
|
tasks: TasksIcon,
|
|
trash: TrashIcon,
|
|
'trash-filled': TrashFilledIcon,
|
|
pin: PinIcon,
|
|
'pin-filled': PinFilledIcon,
|
|
unpin: UnpinIcon,
|
|
archive: ArchiveIcon,
|
|
unarchive: UnarchiveIcon,
|
|
hashtag: HashtagIcon,
|
|
'chevron-right': ChevronRightIcon,
|
|
restore: RestoreIcon,
|
|
close: CloseIcon,
|
|
password: PasswordIcon,
|
|
'trash-sweep': TrashSweepIcon,
|
|
more: MoreIcon,
|
|
tune: TuneIcon,
|
|
accessibility: AccessibilityIcon,
|
|
add: AddIcon,
|
|
help: HelpIcon,
|
|
keyboard: KeyboardIcon,
|
|
spellcheck: NotesIcon,
|
|
'list-bulleted': ListBulleted,
|
|
'link-off': LinkOffIcon,
|
|
listed: ListedIcon,
|
|
security: SecurityIcon,
|
|
settings: SettingsIcon,
|
|
star: StarIcon,
|
|
themes: ThemesIcon,
|
|
user: UserIcon,
|
|
copy: CopyIcon,
|
|
download: DownloadIcon,
|
|
info: InfoIcon,
|
|
check: CheckIcon,
|
|
'check-bold': CheckBoldIcon,
|
|
'account-circle': AccountCircleIcon,
|
|
'menu-arrow-down': MenuArrowDownIcon,
|
|
'menu-close': MenuCloseIcon,
|
|
window: WindowIcon,
|
|
'premium-feature': PremiumFeatureIcon,
|
|
};
|
|
|
|
export type IconType = keyof typeof ICONS;
|
|
|
|
type Props = {
|
|
type: IconType;
|
|
className?: string;
|
|
ariaLabel?: string;
|
|
};
|
|
|
|
export const Icon: FunctionalComponent<Props> = ({
|
|
type,
|
|
className = '',
|
|
ariaLabel,
|
|
}) => {
|
|
const IconComponent = ICONS[type];
|
|
return (
|
|
<IconComponent
|
|
className={`sn-icon ${className}`}
|
|
role="img"
|
|
{...(ariaLabel ? { 'aria-label': ariaLabel } : {})}
|
|
/>
|
|
);
|
|
};
|
|
|
|
export const IconDirective = toDirective<Props>(Icon, {
|
|
type: '@',
|
|
className: '@',
|
|
});
|