feat(ui): prepare staging area

This commit is contained in:
psychedelicious 2024-08-01 19:53:04 +10:00
parent cff28dfaa9
commit cad4212fe8

View File

@ -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,
}; };
} };
} }