feat(editor): add gfx pointer extension (#12006)

<!-- This is an auto-generated comment: release notes by coderabbit.ai -->
## Summary by CodeRabbit

- **New Features**
  - Introduced a new pointer graphics module with tools and quick tool integration for edgeless surfaces.
  - Added a quick tool button for pointer interactions in edgeless mode.
  - Exposed new extension points for pointer graphics and effects.

- **Improvements**
  - Integrated pointer graphics as a dependency into related packages.
  - Enhanced toolbar context to support additional surface alignment modes.
  - Added conditional clipboard configuration registrations for edgeless contexts across multiple block types.

- **Removals**
  - Removed legacy tool and effect definitions and related quick tool exports from edgeless components.
  - Streamlined extension arrays and removed unused exports for a cleaner codebase.
  - Deleted obsolete utility functions and component registrations.

- **Chores**
  - Updated workspace and TypeScript project references to include the new pointer graphics module.
<!-- end of auto-generated comment: release notes by coderabbit.ai -->
This commit is contained in:
Saul-Mirone
2025-04-27 04:46:44 +00:00
parent 59d4942d9b
commit 81b439c4e1
49 changed files with 290 additions and 183 deletions

View File

@@ -8,6 +8,7 @@ import { literal } from 'lit/static-html.js';
import { NoteSlashMenuConfigExtension } from './configs/slash-menu';
import { createBuiltinToolbarConfigExtension } from './configs/toolbar';
import { EdgelessClipboardNoteConfig } from './edgeless-clipboard-config';
import { effects } from './effects';
import { NoteKeymapExtension } from './note-keymap';
@@ -29,17 +30,14 @@ export class NoteViewExtension extends ViewExtensionProvider {
NoteKeymapExtension,
]);
const scope = context.scope;
const isEdgeless =
scope === 'edgeless' ||
scope === 'preview-edgeless' ||
scope === 'mobile-edgeless';
const isEdgeless = this.isEdgeless(context.scope);
if (isEdgeless) {
context.register(
BlockViewExtension(flavour, literal`affine-edgeless-note`)
);
context.register(createBuiltinToolbarConfigExtension(flavour));
context.register(EdgelessClipboardNoteConfig);
} else {
context.register(BlockViewExtension(flavour, literal`affine-note`));
}