mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
feat(ui): prepare staging area
This commit is contained in:
parent
cff28dfaa9
commit
cad4212fe8
@ -1,27 +1,37 @@
|
|||||||
import { CanvasEntity } from 'features/controlLayers/konva/CanvasEntity';
|
|
||||||
import { CanvasImage } from 'features/controlLayers/konva/CanvasImage';
|
import { CanvasImage } from 'features/controlLayers/konva/CanvasImage';
|
||||||
import type { CanvasManager } from 'features/controlLayers/konva/CanvasManager';
|
import type { CanvasManager } from 'features/controlLayers/konva/CanvasManager';
|
||||||
import type { StagingAreaImage } from 'features/controlLayers/store/types';
|
import { getPrefixedId } from 'features/controlLayers/konva/util';
|
||||||
|
import type { GetLoggingContext, StagingAreaImage } from 'features/controlLayers/store/types';
|
||||||
import Konva from 'konva';
|
import Konva from 'konva';
|
||||||
|
import type { Logger } from 'roarr';
|
||||||
|
|
||||||
export class CanvasStagingArea extends CanvasEntity {
|
export class CanvasStagingArea {
|
||||||
static NAME_PREFIX = 'staging-area';
|
static TYPE = 'staging_area';
|
||||||
static GROUP_NAME = `${CanvasStagingArea.NAME_PREFIX}_group`;
|
static GROUP_NAME = `${CanvasStagingArea.TYPE}_group`;
|
||||||
|
|
||||||
|
id: string;
|
||||||
|
manager: CanvasManager;
|
||||||
|
log: Logger;
|
||||||
|
getLoggingContext: GetLoggingContext;
|
||||||
|
|
||||||
type = 'staging_area';
|
|
||||||
konva: { group: Konva.Group };
|
konva: { group: Konva.Group };
|
||||||
|
|
||||||
image: CanvasImage | null;
|
image: CanvasImage | null;
|
||||||
selectedImage: StagingAreaImage | null;
|
selectedImage: StagingAreaImage | null;
|
||||||
|
|
||||||
constructor(manager: CanvasManager) {
|
constructor(manager: CanvasManager) {
|
||||||
super('staging-area', manager);
|
this.id = getPrefixedId(CanvasStagingArea.TYPE);
|
||||||
|
this.manager = manager;
|
||||||
|
this.getLoggingContext = this.manager.buildEntityGetLoggingContext(this);
|
||||||
|
this.log = this.manager.buildLogger(this.getLoggingContext);
|
||||||
|
this.log.debug('Creating staging area');
|
||||||
|
|
||||||
this.konva = { group: new Konva.Group({ name: CanvasStagingArea.GROUP_NAME, listening: false }) };
|
this.konva = { group: new Konva.Group({ name: CanvasStagingArea.GROUP_NAME, listening: false }) };
|
||||||
this.image = null;
|
this.image = null;
|
||||||
this.selectedImage = null;
|
this.selectedImage = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
async render() {
|
render = async () => {
|
||||||
const session = this.manager.stateApi.getSession();
|
const session = this.manager.stateApi.getSession();
|
||||||
const bboxRect = this.manager.stateApi.getBbox().rect;
|
const bboxRect = this.manager.stateApi.getBbox().rect;
|
||||||
const shouldShowStagedImage = this.manager.stateApi.getShouldShowStagedImage();
|
const shouldShowStagedImage = this.manager.stateApi.getShouldShowStagedImage();
|
||||||
@ -65,13 +75,13 @@ export class CanvasStagingArea extends CanvasEntity {
|
|||||||
} else {
|
} else {
|
||||||
this.image?.konva.group.visible(false);
|
this.image?.konva.group.visible(false);
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
repr() {
|
repr = () => {
|
||||||
return {
|
return {
|
||||||
id: this.id,
|
id: this.id,
|
||||||
type: this.type,
|
type: CanvasStagingArea.TYPE,
|
||||||
selectedImage: this.selectedImage,
|
selectedImage: this.selectedImage,
|
||||||
};
|
};
|
||||||
}
|
};
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user