2021-12-03 07:13:01 +01:00
|
|
|
/* eslint-disable class-methods-use-this */
|
2021-10-05 01:56:40 +02:00
|
|
|
/*
|
2021-12-03 05:38:53 +01:00
|
|
|
* Copyright [2021] [wisemapping]
|
2021-10-05 01:56:40 +02:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
2021-12-03 07:13:01 +01:00
|
|
|
|
|
|
|
import ElementClass from './ElementClass';
|
2021-12-02 01:41:56 +01:00
|
|
|
import Toolkit from './Toolkit';
|
2021-10-05 01:56:40 +02:00
|
|
|
|
2021-12-03 07:13:01 +01:00
|
|
|
class Line extends ElementClass {
|
|
|
|
constructor(attributes) {
|
2021-10-05 01:56:40 +02:00
|
|
|
const peer = Toolkit.createLine();
|
|
|
|
const defaultAttributes = { strokeColor: '#495879', strokeWidth: 1, strokeOpacity: 1 };
|
|
|
|
for (const key in attributes) {
|
2021-10-06 04:08:42 +02:00
|
|
|
if (Object.prototype.hasOwnProperty.call(attributes, key)) {
|
|
|
|
defaultAttributes[key] = attributes[key];
|
|
|
|
}
|
2021-10-05 01:56:40 +02:00
|
|
|
}
|
2021-12-03 07:13:01 +01:00
|
|
|
super(peer, defaultAttributes);
|
|
|
|
}
|
2021-10-05 01:56:40 +02:00
|
|
|
|
|
|
|
getType() {
|
|
|
|
return 'Line';
|
2021-12-03 07:13:01 +01:00
|
|
|
}
|
2021-10-05 01:56:40 +02:00
|
|
|
|
|
|
|
setFrom(x, y) {
|
2021-10-05 02:17:02 +02:00
|
|
|
this.peer.setFrom(x, y);
|
2021-12-03 07:13:01 +01:00
|
|
|
}
|
2021-10-05 01:56:40 +02:00
|
|
|
|
|
|
|
setTo(x, y) {
|
2021-10-05 02:17:02 +02:00
|
|
|
this.peer.setTo(x, y);
|
2021-12-03 07:13:01 +01:00
|
|
|
}
|
2021-10-05 01:56:40 +02:00
|
|
|
|
|
|
|
getFrom() {
|
2021-10-05 02:17:02 +02:00
|
|
|
return this.peer.getFrom();
|
2021-12-03 07:13:01 +01:00
|
|
|
}
|
2021-10-05 01:56:40 +02:00
|
|
|
|
|
|
|
getTo() {
|
2021-10-05 02:17:02 +02:00
|
|
|
return this.peer.getTo();
|
2021-12-03 07:13:01 +01:00
|
|
|
}
|
2021-10-05 01:56:40 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the start and the end line arrow style.
|
|
|
|
* Can have values "none | block | classic | diamond | oval | open | chevron | doublechevron"
|
|
|
|
* */
|
|
|
|
setArrowStyle(startStyle, endStyle) {
|
2021-10-05 02:17:02 +02:00
|
|
|
this.peer.setArrowStyle(startStyle, endStyle);
|
2021-12-03 07:13:01 +01:00
|
|
|
}
|
2021-10-05 01:56:40 +02:00
|
|
|
|
2021-10-05 02:21:53 +02:00
|
|
|
setPosition() {
|
|
|
|
throw new Error('Unsupported operation');
|
2021-12-03 07:13:01 +01:00
|
|
|
}
|
2021-10-05 01:56:40 +02:00
|
|
|
|
2021-10-05 02:21:53 +02:00
|
|
|
setSize() {
|
|
|
|
throw new Error('Unsupported operation');
|
2021-12-03 07:13:01 +01:00
|
|
|
}
|
2021-10-05 01:56:40 +02:00
|
|
|
|
2021-10-05 02:21:53 +02:00
|
|
|
setFill() {
|
|
|
|
throw new Error('Unsupported operation');
|
2021-12-03 07:13:01 +01:00
|
|
|
}
|
|
|
|
}
|
2021-10-05 01:56:40 +02:00
|
|
|
|
|
|
|
export default Line;
|