mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
feat(ui): node manager getter/setter
This commit is contained in:
parent
b703884763
commit
5f4a3928d2
@ -1,12 +1,11 @@
|
|||||||
import { enqueueRequested } from 'app/store/actions';
|
import { enqueueRequested } from 'app/store/actions';
|
||||||
import type { AppStartListening } from 'app/store/middleware/listenerMiddleware';
|
import type { AppStartListening } from 'app/store/middleware/listenerMiddleware';
|
||||||
import { $nodeManager } from 'features/controlLayers/konva/renderers/renderer';
|
import { getNodeManager } from 'features/controlLayers/konva/nodeManager';
|
||||||
import { isImageViewerOpenChanged } from 'features/gallery/store/gallerySlice';
|
import { isImageViewerOpenChanged } from 'features/gallery/store/gallerySlice';
|
||||||
import { prepareLinearUIBatch } from 'features/nodes/util/graph/buildLinearBatchConfig';
|
import { prepareLinearUIBatch } from 'features/nodes/util/graph/buildLinearBatchConfig';
|
||||||
import { buildGenerationTabGraph } from 'features/nodes/util/graph/generation/buildGenerationTabGraph';
|
import { buildGenerationTabGraph } from 'features/nodes/util/graph/generation/buildGenerationTabGraph';
|
||||||
import { buildGenerationTabSDXLGraph } from 'features/nodes/util/graph/generation/buildGenerationTabSDXLGraph';
|
import { buildGenerationTabSDXLGraph } from 'features/nodes/util/graph/generation/buildGenerationTabSDXLGraph';
|
||||||
import { queueApi } from 'services/api/endpoints/queue';
|
import { queueApi } from 'services/api/endpoints/queue';
|
||||||
import { assert } from 'tsafe';
|
|
||||||
|
|
||||||
export const addEnqueueRequestedLinear = (startAppListening: AppStartListening) => {
|
export const addEnqueueRequestedLinear = (startAppListening: AppStartListening) => {
|
||||||
startAppListening({
|
startAppListening({
|
||||||
@ -20,8 +19,7 @@ export const addEnqueueRequestedLinear = (startAppListening: AppStartListening)
|
|||||||
|
|
||||||
let graph;
|
let graph;
|
||||||
|
|
||||||
const manager = $nodeManager.get();
|
const manager = getNodeManager();
|
||||||
assert(manager, 'Konva node manager not initialized');
|
|
||||||
|
|
||||||
console.log('generation mode', manager.util.getGenerationMode());
|
console.log('generation mode', manager.util.getGenerationMode());
|
||||||
|
|
||||||
|
@ -21,6 +21,7 @@ import type {
|
|||||||
import { isValidLayer } from 'features/nodes/util/graph/generation/addLayers';
|
import { isValidLayer } from 'features/nodes/util/graph/generation/addLayers';
|
||||||
import type Konva from 'konva';
|
import type Konva from 'konva';
|
||||||
import type { Vector2d } from 'konva/lib/types';
|
import type { Vector2d } from 'konva/lib/types';
|
||||||
|
import { atom } from 'nanostores';
|
||||||
import { getImageDTO as defaultGetImageDTO, uploadImage as defaultUploadImage } from 'services/api/endpoints/images';
|
import { getImageDTO as defaultGetImageDTO, uploadImage as defaultUploadImage } from 'services/api/endpoints/images';
|
||||||
import type { ImageCategory, ImageDTO } from 'services/api/types';
|
import type { ImageCategory, ImageDTO } from 'services/api/types';
|
||||||
import { assert } from 'tsafe';
|
import { assert } from 'tsafe';
|
||||||
@ -466,3 +467,13 @@ export class KonvaEntityAdapter {
|
|||||||
return this.objectRecords.delete(id);
|
return this.objectRecords.delete(id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const $nodeManager = atom<KonvaNodeManager | null>(null);
|
||||||
|
export const setNodeManager = (manager: KonvaNodeManager) => {
|
||||||
|
$nodeManager.set(manager);
|
||||||
|
};
|
||||||
|
export const getNodeManager = () => {
|
||||||
|
const nodeManager = $nodeManager.get();
|
||||||
|
assert(nodeManager, 'Konva node manager not initialized');
|
||||||
|
return nodeManager;
|
||||||
|
};
|
||||||
|
@ -4,7 +4,7 @@ import { logger } from 'app/logging/logger';
|
|||||||
import { $isDebugging } from 'app/store/nanostores/isDebugging';
|
import { $isDebugging } from 'app/store/nanostores/isDebugging';
|
||||||
import type { RootState } from 'app/store/store';
|
import type { RootState } from 'app/store/store';
|
||||||
import { setStageEventHandlers } from 'features/controlLayers/konva/events';
|
import { setStageEventHandlers } from 'features/controlLayers/konva/events';
|
||||||
import { KonvaNodeManager } from 'features/controlLayers/konva/nodeManager';
|
import { KonvaNodeManager, setNodeManager } from 'features/controlLayers/konva/nodeManager';
|
||||||
import { getArrangeEntities } from 'features/controlLayers/konva/renderers/arrange';
|
import { getArrangeEntities } from 'features/controlLayers/konva/renderers/arrange';
|
||||||
import { createBackgroundLayer, getRenderBackground } from 'features/controlLayers/konva/renderers/background';
|
import { createBackgroundLayer, getRenderBackground } from 'features/controlLayers/konva/renderers/background';
|
||||||
import { updateBboxes } from 'features/controlLayers/konva/renderers/bbox';
|
import { updateBboxes } from 'features/controlLayers/konva/renderers/bbox';
|
||||||
@ -66,12 +66,9 @@ import type {
|
|||||||
import type Konva from 'konva';
|
import type Konva from 'konva';
|
||||||
import type { IRect, Vector2d } from 'konva/lib/types';
|
import type { IRect, Vector2d } from 'konva/lib/types';
|
||||||
import { debounce } from 'lodash-es';
|
import { debounce } from 'lodash-es';
|
||||||
import { atom } from 'nanostores';
|
|
||||||
import type { RgbaColor } from 'react-colorful';
|
import type { RgbaColor } from 'react-colorful';
|
||||||
import type { ImageDTO } from 'services/api/types';
|
import type { ImageDTO } from 'services/api/types';
|
||||||
|
|
||||||
export const $nodeManager = atom<KonvaNodeManager | null>(null);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initializes the canvas renderer. It subscribes to the redux store and listens for changes directly, bypassing the
|
* Initializes the canvas renderer. It subscribes to the redux store and listens for changes directly, bypassing the
|
||||||
* react rendering cycle entirely, improving canvas performance.
|
* react rendering cycle entirely, improving canvas performance.
|
||||||
@ -301,7 +298,7 @@ export const initializeRenderer = (
|
|||||||
};
|
};
|
||||||
|
|
||||||
const manager = new KonvaNodeManager(stage, container);
|
const manager = new KonvaNodeManager(stage, container);
|
||||||
$nodeManager.set(manager);
|
setNodeManager(manager);
|
||||||
|
|
||||||
manager.background = { layer: createBackgroundLayer() };
|
manager.background = { layer: createBackgroundLayer() };
|
||||||
manager.stage.add(manager.background.layer);
|
manager.stage.add(manager.background.layer);
|
||||||
|
Loading…
Reference in New Issue
Block a user