import IconButton from "./IconButton.svelte"; import type { IconButtonProps } from "./IconButton"; import DropdownMenu from "./DropdownMenu.svelte"; import type { DropdownMenuProps } from "./DropdownMenu"; import DropdownItem from "./DropdownItem.svelte"; import type { DropdownItemProps } from "./DropdownItem"; import WithDropdownMenu from "./WithDropdownMenu.svelte"; import type { WithDropdownMenuProps } from "./WithDropdownMenu"; import ButtonGroup from "./ButtonGroup.svelte"; import type { ButtonGroupProps } from "./ButtonGroup"; import { bridgeCommand } from "anki/bridgecommand"; import { dynamicComponent } from "sveltelib/dynamicComponent"; import * as tr from "anki/i18n"; import paperclipIcon from "./paperclip.svg"; import micIcon from "./mic.svg"; import bracketsIcon from "./code-brackets.svg"; import functionIcon from "./function-variant.svg"; import xmlIcon from "./xml.svg"; function onAttachment(): void { bridgeCommand("attach"); } function onRecord(): void { bridgeCommand("record"); } function onCloze(): void { bridgeCommand("cloze"); } function onHtmlEdit(): void { bridgeCommand("htmlEdit"); } const iconButton = dynamicComponent(IconButton); const withDropdownMenu = dynamicComponent(WithDropdownMenu); const dropdownMenu = dynamicComponent(DropdownMenu); const dropdownItem = dynamicComponent(DropdownItem); const attachmentButton = iconButton( { icon: paperclipIcon, onClick: onAttachment, }, { tooltip: tr.editingAttachPicturesaudiovideoF3, } ); const recordButton = iconButton( { icon: micIcon, onClick: onRecord }, { tooltip: tr.editingRecordAudioF5, } ); const clozeButton = iconButton( { id: "cloze", icon: bracketsIcon, onClick: onCloze, }, { tooltip: tr.editingClozeDeletionCtrlandshiftandc, } ); const mathjaxButton = iconButton>( { icon: functionIcon, }, {} ); const mathjaxMenuId = "mathjaxMenu"; const mathjaxMenu = dropdownMenu( { id: mathjaxMenuId, menuItems: [ dropdownItem( { onClick: () => bridgeCommand("mathjaxInline"), tooltip: "test", endLabel: "test", }, { label: tr.editingMathjaxInline } ), dropdownItem( { onClick: () => bridgeCommand("mathjaxBlock"), tooltip: "test", endLabel: "test", }, { label: tr.editingMathjaxBlock } ), dropdownItem( { onClick: () => bridgeCommand("mathjaxChemistry"), tooltip: "test", endLabel: "test", }, { label: tr.editingMathjaxChemistry } ), ], }, {} ); const mathjaxButtonWithMenu = withDropdownMenu( { button: mathjaxButton, menuId: mathjaxMenuId, }, {} ); const htmlButton = iconButton( { icon: xmlIcon, onClick: onHtmlEdit, }, { tooltip: tr.editingHtmlEditor, } ); const buttonGroup = dynamicComponent(ButtonGroup); export const templateGroup = buttonGroup( { id: "template", buttons: [ attachmentButton, recordButton, clozeButton, mathjaxButtonWithMenu, htmlButton, ], }, {} ); export const templateMenus = [mathjaxMenu];