mirror of
https://bitbucket.org/wisemapping/wisemapping-frontend.git
synced 2024-06-03 01:04:31 +02:00
229 lines
5.3 KiB
TypeScript
229 lines
5.3 KiB
TypeScript
/*
|
|
* Copyright [2021] [wisemapping]
|
|
*
|
|
* Licensed under WiseMapping Public License, Version 1.0 (the "License").
|
|
* It is basically the Apache License, Version 2.0 (the "License") plus the
|
|
* "powered by wisemapping" text requirement on every single page;
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the license at
|
|
*
|
|
* http://www.wisemapping.org/license
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
import { $assert, $defined } from '@wisemapping/core-js';
|
|
import PositionType from '../PositionType';
|
|
import SizeType from '../SizeType';
|
|
import ChildrenSorterStrategy from './ChildrenSorterStrategy';
|
|
|
|
class Node {
|
|
private _id: number;
|
|
|
|
// eslint-disable-next-line no-use-before-define
|
|
_parent!: Node | null;
|
|
|
|
private _sorter: ChildrenSorterStrategy;
|
|
|
|
private _properties;
|
|
|
|
// eslint-disable-next-line no-use-before-define
|
|
_children!: Node[];
|
|
|
|
constructor(id: number, size: SizeType, position: PositionType, sorter: ChildrenSorterStrategy) {
|
|
$assert(typeof id === 'number' && Number.isFinite(id), 'id can not be null');
|
|
this._id = id;
|
|
this._sorter = sorter;
|
|
this._properties = {};
|
|
|
|
this.setSize(size);
|
|
this.setPosition(position);
|
|
this.setShrunken(false);
|
|
}
|
|
|
|
/** */
|
|
getId(): number {
|
|
return this._id;
|
|
}
|
|
|
|
/** */
|
|
setFree(value) {
|
|
this._setProperty('free', value);
|
|
}
|
|
|
|
/** */
|
|
isFree() {
|
|
return this._getProperty('free');
|
|
}
|
|
|
|
/** */
|
|
hasFreeChanged() {
|
|
return this._isPropertyChanged('free');
|
|
}
|
|
|
|
/** */
|
|
hasFreeDisplacementChanged() {
|
|
return this._isPropertyChanged('freeDisplacement');
|
|
}
|
|
|
|
/** */
|
|
setShrunken(value: boolean) {
|
|
this._setProperty('shrink', value);
|
|
}
|
|
|
|
/** */
|
|
areChildrenShrunken() {
|
|
return this._getProperty('shrink');
|
|
}
|
|
|
|
/** */
|
|
setOrder(order: number) {
|
|
$assert(
|
|
typeof order === 'number' && Number.isFinite(order),
|
|
`Order can not be null. Value:${order}`,
|
|
);
|
|
this._setProperty('order', order);
|
|
}
|
|
|
|
/** */
|
|
resetPositionState() {
|
|
const prop = this._properties.position;
|
|
if (prop) {
|
|
prop.hasChanged = false;
|
|
}
|
|
}
|
|
|
|
/** */
|
|
resetOrderState() {
|
|
const prop = this._properties.order;
|
|
if (prop) {
|
|
prop.hasChanged = false;
|
|
}
|
|
}
|
|
|
|
/** */
|
|
resetFreeState() {
|
|
const prop = this._properties.freeDisplacement;
|
|
if (prop) {
|
|
prop.hasChanged = false;
|
|
}
|
|
}
|
|
|
|
/** */
|
|
getOrder() {
|
|
return this._getProperty('order');
|
|
}
|
|
|
|
/** */
|
|
hasOrderChanged() {
|
|
return this._isPropertyChanged('order');
|
|
}
|
|
|
|
/** */
|
|
hasPositionChanged() {
|
|
return this._isPropertyChanged('position');
|
|
}
|
|
|
|
/** */
|
|
hasSizeChanged(): boolean {
|
|
return this._isPropertyChanged('size');
|
|
}
|
|
|
|
/** */
|
|
getPosition(): PositionType {
|
|
return this._getProperty('position');
|
|
}
|
|
|
|
/** */
|
|
setSize(size: SizeType) {
|
|
$assert($defined(size), 'Size can not be null');
|
|
this._setProperty('size', { ...size });
|
|
}
|
|
|
|
/** */
|
|
getSize(): SizeType {
|
|
return this._getProperty('size');
|
|
}
|
|
|
|
setFreeDisplacement(displacement: PositionType) {
|
|
const oldDisplacement = this.getFreeDisplacement();
|
|
const newDisplacement = {
|
|
x: oldDisplacement.x + displacement.x,
|
|
y: oldDisplacement.y + displacement.y,
|
|
};
|
|
|
|
this._setProperty('freeDisplacement', { ...newDisplacement });
|
|
}
|
|
|
|
/** */
|
|
resetFreeDisplacement() {
|
|
this._setProperty('freeDisplacement', { x: 0, y: 0 });
|
|
}
|
|
|
|
/** */
|
|
getFreeDisplacement() {
|
|
const freeDisplacement = this._getProperty('freeDisplacement');
|
|
return freeDisplacement || { x: 0, y: 0 };
|
|
}
|
|
|
|
setPosition(position: PositionType) {
|
|
// This is a performance improvement to avoid movements that really could be avoided.
|
|
const currentPos = this.getPosition();
|
|
if (
|
|
currentPos == null ||
|
|
Math.abs(currentPos.x - position.x) > 2 ||
|
|
Math.abs(currentPos.y - position.y) > 2
|
|
) {
|
|
this._setProperty('position', position);
|
|
}
|
|
}
|
|
|
|
_setProperty(key: string, value) {
|
|
let prop = this._properties[key];
|
|
if (!prop) {
|
|
prop = {
|
|
hasChanged: false,
|
|
value: null,
|
|
oldValue: null,
|
|
};
|
|
}
|
|
|
|
// Only update if the property has changed ...
|
|
if (JSON.stringify(prop.value) !== JSON.stringify(value)) {
|
|
prop.oldValue = prop.value;
|
|
prop.value = value;
|
|
prop.hasChanged = true;
|
|
}
|
|
this._properties[key] = prop;
|
|
}
|
|
|
|
_getProperty(key: string) {
|
|
const prop = this._properties[key];
|
|
return $defined(prop) ? prop.value : null;
|
|
}
|
|
|
|
_isPropertyChanged(key) {
|
|
const prop = this._properties[key];
|
|
return prop ? prop.hasChanged : false;
|
|
}
|
|
|
|
/** */
|
|
getSorter() {
|
|
return this._sorter;
|
|
}
|
|
|
|
/** @return {String} returns id, order, position, size and shrink information */
|
|
toString(): string {
|
|
return `[id:${this.getId()}, order:${this.getOrder()}, position: {${this.getPosition().x},${
|
|
this.getPosition().y
|
|
}}, size: {${this.getSize().width},${
|
|
this.getSize().height
|
|
}}, shrink:${this.areChildrenShrunken()}]`;
|
|
}
|
|
}
|
|
|
|
export default Node;
|