mirror of
https://github.com/google/blockly.git
synced 2026-01-07 00:50:27 +01:00
* fix: added id to rendered ws comments; made getCommentById public; added blocklyDraggable class to ws comments * fix: added workspace comments and comment drag strategy isDeadOrDying checks * chore: removed .idea files * chore: formatted with prettier
103 lines
2.7 KiB
TypeScript
103 lines
2.7 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright 2024 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
import {RenderedWorkspaceComment} from '../comments.js';
|
|
import {CommentMove} from '../events/events_comment_move.js';
|
|
import {EventType} from '../events/type.js';
|
|
import * as eventUtils from '../events/utils.js';
|
|
import {IDragStrategy} from '../interfaces/i_draggable.js';
|
|
import * as layers from '../layers.js';
|
|
import {Coordinate} from '../utils.js';
|
|
import {WorkspaceSvg} from '../workspace_svg.js';
|
|
|
|
export class CommentDragStrategy implements IDragStrategy {
|
|
private startLoc: Coordinate | null = null;
|
|
|
|
private workspace: WorkspaceSvg;
|
|
|
|
/** Was there already an event group in progress when the drag started? */
|
|
private inGroup: boolean = false;
|
|
|
|
constructor(private comment: RenderedWorkspaceComment) {
|
|
this.workspace = comment.workspace;
|
|
}
|
|
|
|
isMovable(): boolean {
|
|
return (
|
|
this.comment.isOwnMovable() &&
|
|
!this.comment.isDeadOrDying() &&
|
|
!this.workspace.options.readOnly
|
|
);
|
|
}
|
|
|
|
startDrag(): void {
|
|
this.inGroup = !!eventUtils.getGroup();
|
|
if (!this.inGroup) {
|
|
eventUtils.setGroup(true);
|
|
}
|
|
this.fireDragStartEvent();
|
|
this.startLoc = this.comment.getRelativeToSurfaceXY();
|
|
this.workspace.setResizesEnabled(false);
|
|
this.workspace.getLayerManager()?.moveToDragLayer(this.comment);
|
|
this.comment.setDragging(true);
|
|
}
|
|
|
|
drag(newLoc: Coordinate): void {
|
|
this.comment.moveDuringDrag(newLoc);
|
|
}
|
|
|
|
endDrag(): void {
|
|
this.fireDragEndEvent();
|
|
this.fireMoveEvent();
|
|
|
|
this.workspace
|
|
.getLayerManager()
|
|
?.moveOffDragLayer(this.comment, layers.BLOCK);
|
|
this.comment.setDragging(false);
|
|
|
|
this.comment.snapToGrid();
|
|
|
|
this.workspace.setResizesEnabled(true);
|
|
if (!this.inGroup) {
|
|
eventUtils.setGroup(false);
|
|
}
|
|
}
|
|
|
|
/** Fire a UI event at the start of a comment drag. */
|
|
private fireDragStartEvent() {
|
|
const event = new (eventUtils.get(EventType.COMMENT_DRAG))(
|
|
this.comment,
|
|
true,
|
|
);
|
|
eventUtils.fire(event);
|
|
}
|
|
|
|
/** Fire a UI event at the end of a comment drag. */
|
|
private fireDragEndEvent() {
|
|
const event = new (eventUtils.get(EventType.COMMENT_DRAG))(
|
|
this.comment,
|
|
false,
|
|
);
|
|
eventUtils.fire(event);
|
|
}
|
|
|
|
/** Fire a move event at the end of a comment drag. */
|
|
private fireMoveEvent() {
|
|
if (this.comment.isDeadOrDying()) return;
|
|
const event = new (eventUtils.get(EventType.COMMENT_MOVE))(
|
|
this.comment,
|
|
) as CommentMove;
|
|
event.setReason(['drag']);
|
|
event.oldCoordinate_ = this.startLoc!;
|
|
event.recordNew();
|
|
eventUtils.fire(event);
|
|
}
|
|
|
|
revertDrag(): void {
|
|
if (this.startLoc) this.comment.moveDuringDrag(this.startLoc);
|
|
}
|
|
}
|