kopia lustrzana https://github.com/Tldraw/Tldraw
134 wiersze
4.2 KiB
TypeScript
134 wiersze
4.2 KiB
TypeScript
import * as React from 'react'
|
|
import { FormattedMessage, useIntl } from 'react-intl'
|
|
import { DMCheckboxItem, DMDivider, DMSubMenu } from '~components/Primitives/DropdownMenu'
|
|
import { useTldrawApp } from '~hooks'
|
|
import { TDSnapshot } from '~types'
|
|
|
|
const settingsSelector = (s: TDSnapshot) => s.settings
|
|
|
|
export function PreferencesMenu() {
|
|
const app = useTldrawApp()
|
|
const intl = useIntl()
|
|
|
|
const settings = app.useStore(settingsSelector)
|
|
|
|
const toggleDebugMode = React.useCallback(() => {
|
|
app.setSetting('isDebugMode', (v) => !v)
|
|
}, [app])
|
|
|
|
const toggleDarkMode = React.useCallback(() => {
|
|
app.setSetting('isDarkMode', (v) => !v)
|
|
}, [app])
|
|
|
|
const toggleFocusMode = React.useCallback(() => {
|
|
app.setSetting('isFocusMode', (v) => !v)
|
|
}, [app])
|
|
|
|
const toggleRotateHandle = React.useCallback(() => {
|
|
app.setSetting('showRotateHandles', (v) => !v)
|
|
}, [app])
|
|
|
|
const toggleGrid = React.useCallback(() => {
|
|
app.setSetting('showGrid', (v) => !v)
|
|
}, [app])
|
|
|
|
const toggleBoundShapesHandle = React.useCallback(() => {
|
|
app.setSetting('showBindingHandles', (v) => !v)
|
|
}, [app])
|
|
|
|
const toggleisSnapping = React.useCallback(() => {
|
|
app.setSetting('isSnapping', (v) => !v)
|
|
}, [app])
|
|
|
|
const toggleKeepStyleMenuOpen = React.useCallback(() => {
|
|
app.setSetting('keepStyleMenuOpen', (v) => !v)
|
|
}, [app])
|
|
|
|
const toggleCloneControls = React.useCallback(() => {
|
|
app.setSetting('showCloneHandles', (v) => !v)
|
|
}, [app])
|
|
|
|
const toggleCadSelectMode = React.useCallback(() => {
|
|
app.setSetting('isCadSelectMode', (v) => !v)
|
|
}, [app])
|
|
|
|
return (
|
|
<DMSubMenu label={intl.formatMessage({ id: 'menu.preferences' })} id="TD-MenuItem-Preferences">
|
|
<DMCheckboxItem
|
|
checked={settings.isDarkMode}
|
|
onCheckedChange={toggleDarkMode}
|
|
kbd="#⇧D"
|
|
id="TD-MenuItem-Preferences-Dark_Mode"
|
|
>
|
|
<FormattedMessage id="preferences.dark.mode" />
|
|
</DMCheckboxItem>
|
|
<DMCheckboxItem
|
|
checked={settings.isFocusMode}
|
|
onCheckedChange={toggleFocusMode}
|
|
kbd="#."
|
|
id="TD-MenuItem-Preferences-Focus_Mode"
|
|
>
|
|
<FormattedMessage id="preferences.focus.mode" />
|
|
</DMCheckboxItem>
|
|
<DMCheckboxItem
|
|
checked={settings.isDebugMode}
|
|
onCheckedChange={toggleDebugMode}
|
|
id="TD-MenuItem-Preferences-Debug_Mode"
|
|
>
|
|
<FormattedMessage id="preferences.debug.mode" />
|
|
</DMCheckboxItem>
|
|
<DMDivider />
|
|
<DMCheckboxItem
|
|
checked={settings.showGrid}
|
|
onCheckedChange={toggleGrid}
|
|
kbd="#⇧G"
|
|
id="TD-MenuItem-Preferences-Grid"
|
|
>
|
|
<FormattedMessage id="preferences.show.grid" />
|
|
</DMCheckboxItem>
|
|
<DMCheckboxItem
|
|
checked={settings.isCadSelectMode}
|
|
onCheckedChange={toggleCadSelectMode}
|
|
id="TD-MenuItem-Preferences-Cad_Selection"
|
|
>
|
|
<FormattedMessage id="preferences.use.cad.selection" />
|
|
</DMCheckboxItem>
|
|
<DMCheckboxItem
|
|
checked={settings.keepStyleMenuOpen}
|
|
onCheckedChange={toggleKeepStyleMenuOpen}
|
|
id="TD-MenuItem-Preferences-Style_menu"
|
|
>
|
|
<FormattedMessage id="preferences.keep.stylemenu.open" />
|
|
</DMCheckboxItem>
|
|
<DMCheckboxItem
|
|
checked={settings.isSnapping}
|
|
onCheckedChange={toggleisSnapping}
|
|
id="TD-MenuItem-Preferences-Always_Show_Snaps"
|
|
>
|
|
<FormattedMessage id="preferences.always.show.snaps" />
|
|
</DMCheckboxItem>
|
|
<DMCheckboxItem
|
|
checked={settings.showRotateHandles}
|
|
onCheckedChange={toggleRotateHandle}
|
|
id="TD-MenuItem-Preferences-Rotate_Handles"
|
|
>
|
|
<FormattedMessage id="preferences.rotate.handles" />
|
|
</DMCheckboxItem>
|
|
<DMCheckboxItem
|
|
checked={settings.showBindingHandles}
|
|
onCheckedChange={toggleBoundShapesHandle}
|
|
id="TD-MenuItem-Preferences-Binding_Handles"
|
|
>
|
|
<FormattedMessage id="preferences.binding.handles" />
|
|
</DMCheckboxItem>
|
|
<DMCheckboxItem
|
|
checked={settings.showCloneHandles}
|
|
onCheckedChange={toggleCloneControls}
|
|
id="TD-MenuItem-Preferences-Clone_Handles"
|
|
>
|
|
<FormattedMessage id="preferences.clone.handles" />
|
|
</DMCheckboxItem>
|
|
</DMSubMenu>
|
|
)
|
|
}
|