Skip to content

Commit

Permalink
[lexical-devtools] Feature: Reflect picker state on inspector button …
Browse files Browse the repository at this point in the history
…ui (#6077)
  • Loading branch information
2wheeh authored May 14, 2024
1 parent ec18fcf commit d347ee3
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 8 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import {IconButton, Image} from '@chakra-ui/react';
import {getRPCService} from '@webext-pegasus/rpc';
import * as React from 'react';

import {useExtensionStore} from '../../../store';
import {IInjectedPegasusService} from '../../injected/InjectedPegasusService';

interface Props {
Expand All @@ -18,6 +19,9 @@ interface Props {
}

export function EditorInspectorButton({tabID, setErrorMessage}: Props) {
const {isSelecting} = useExtensionStore();
const isActive = isSelecting[tabID] ?? false;

const handleClick = () => {
const injectedPegasusService = getRPCService<IInjectedPegasusService>(
'InjectedPegasusService',
Expand All @@ -41,6 +45,8 @@ export function EditorInspectorButton({tabID, setErrorMessage}: Props) {
size="xs"
onClick={handleClick}
icon={<Image w={5} src="/inspect.svg" />}
isActive={isActive}
_active={{bg: 'blue.100'}}
/>
);
}
Original file line number Diff line number Diff line change
Expand Up @@ -86,18 +86,21 @@ export class InjectedPegasusService
}

toggleEditorPicker(): void {
if (this.pickerActive != null) {
this.pickerActive?.stop();
this.pickerActive = null;

return;
if (this.pickerActive !== null) {
this.deactivatePicker();
} else {
this.activatePicker();
}
}

private activatePicker(): void {
this.extensionStore.getState().setIsSelecting(this.tabID, true);

this.pickerActive = new ElementPicker({style: ELEMENT_PICKER_STYLE});
this.pickerActive.start({
elementFilter: (el) => {
let parent: HTMLElement | null = el;
while (parent != null && parent.tagName !== 'BODY') {
while (parent !== null && parent.tagName !== 'BODY') {
if ('__lexicalEditor' in parent) {
return parent;
}
Expand All @@ -108,8 +111,7 @@ export class InjectedPegasusService
},

onClick: (el) => {
this.pickerActive?.stop();
this.pickerActive = null;
this.deactivatePicker();
if (isLexicalNode(el)) {
this.extensionStore
.getState()
Expand All @@ -120,4 +122,10 @@ export class InjectedPegasusService
},
});
}

private deactivatePicker(): void {
this.pickerActive?.stop();
this.pickerActive = null;
this.extensionStore.getState().setIsSelecting(this.tabID, false);
}
}
12 changes: 12 additions & 0 deletions packages/lexical-devtools/src/store.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,16 +22,21 @@ export interface ExtensionState {
selectedEditorKey: {
[tabID: number]: string | null;
};
isSelecting: {
[tabID: number]: boolean;
};
markTabAsRestricted: (tabID: number) => void;
setStatesForTab: (
id: number,
states: {[editorKey: string]: SerializedRawEditorState},
) => void;
setSelectedEditorKey: (tabID: number, editorKey: string | null) => void;
setIsSelecting: (tadID: number, isSelecting: boolean) => void;
}

export const useExtensionStore = create<ExtensionState>()(
subscribeWithSelector((set) => ({
isSelecting: {},
lexicalState: {},
markTabAsRestricted: (tabID: number) =>
set((state) => ({
Expand All @@ -41,6 +46,13 @@ export const useExtensionStore = create<ExtensionState>()(
},
})),
selectedEditorKey: {},
setIsSelecting: (tabID: number, isSelecting: boolean) =>
set((state) => ({
isSelecting: {
...state.isSelecting,
[tabID]: isSelecting,
},
})),
setSelectedEditorKey: (tabID: number, editorKey: string | null) =>
set((state) => ({
selectedEditorKey: {
Expand Down

0 comments on commit d347ee3

Please sign in to comment.