2021-07-16 16:41:58 +02:00
|
|
|
/*
|
|
|
|
* Copyright [2015] [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.
|
|
|
|
*/
|
2021-12-02 01:41:56 +01:00
|
|
|
import Events from './Events';
|
2021-07-16 16:41:58 +02:00
|
|
|
|
|
|
|
const DesignerModel = new Class(/** @lends DesignerModel */{
|
2021-10-05 02:05:34 +02:00
|
|
|
Implements: [Events],
|
|
|
|
/**
|
2021-07-16 16:41:58 +02:00
|
|
|
* @implements {mindplot.Events}
|
|
|
|
* @constructs
|
2021-10-05 02:05:34 +02:00
|
|
|
* @param {{readOnly: Boolean, zoom: Number, saveOnLoad: Boolean, size: {width: Number,
|
|
|
|
* height: Number}, viewPort: {width: Number, height: Number}, container: String,
|
2021-07-16 16:41:58 +02:00
|
|
|
* persistenceManager: String, mapId: String, locale: String}} options
|
2021-10-05 02:05:34 +02:00
|
|
|
* options loaded from json config
|
2021-07-16 16:41:58 +02:00
|
|
|
* @see {@link ConfigParameters.md}
|
|
|
|
* @see {@link editor.html}
|
|
|
|
*/
|
2021-10-05 02:05:34 +02:00
|
|
|
initialize(options) {
|
|
|
|
this._zoom = options.zoom;
|
|
|
|
this._topics = [];
|
|
|
|
this._relationships = [];
|
|
|
|
},
|
|
|
|
|
|
|
|
/** @return {Number} zoom between 0.3 (largest text) and 1.9 */
|
|
|
|
getZoom() {
|
|
|
|
return this._zoom;
|
|
|
|
},
|
|
|
|
|
|
|
|
/** @param {Number} zoom number between 0.3 and 1.9 to set the zoom to */
|
|
|
|
setZoom(zoom) {
|
|
|
|
this._zoom = zoom;
|
|
|
|
},
|
|
|
|
|
|
|
|
/** @return {@link mindplot.Topic[]} all topics */
|
|
|
|
getTopics() {
|
|
|
|
return this._topics;
|
|
|
|
},
|
|
|
|
|
|
|
|
/** @return {mindplot.Relationship[]} all relationships */
|
|
|
|
getRelationships() {
|
|
|
|
return this._relationships;
|
|
|
|
},
|
|
|
|
|
|
|
|
/** @return {mindplot.CentralTopic} the central topic */
|
|
|
|
getCentralTopic() {
|
|
|
|
const topics = this.getTopics();
|
|
|
|
return topics[0];
|
|
|
|
},
|
|
|
|
|
|
|
|
/** @return {mindplot.Topic[]} selected topics */
|
|
|
|
filterSelectedTopics() {
|
|
|
|
const result = [];
|
|
|
|
for (let i = 0; i < this._topics.length; i++) {
|
|
|
|
if (this._topics[i].isOnFocus()) {
|
|
|
|
result.push(this._topics[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
2021-07-16 16:41:58 +02:00
|
|
|
* @return {mindplot.Relationship[]} selected relationships
|
|
|
|
*/
|
2021-10-05 02:05:34 +02:00
|
|
|
filterSelectedRelationships() {
|
|
|
|
const result = [];
|
|
|
|
for (let i = 0; i < this._relationships.length; i++) {
|
|
|
|
if (this._relationships[i].isOnFocus()) {
|
|
|
|
result.push(this._relationships[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
2021-07-16 16:41:58 +02:00
|
|
|
* @return {Array.<mindplot.Relationship, mindplot.Topic>} all topics and relationships
|
|
|
|
*/
|
2021-10-05 02:05:34 +02:00
|
|
|
getEntities() {
|
|
|
|
const result = [].append(this._topics);
|
|
|
|
result.append(this._relationships);
|
|
|
|
return result;
|
|
|
|
},
|
2021-07-16 16:41:58 +02:00
|
|
|
|
2021-10-05 02:05:34 +02:00
|
|
|
/**
|
2021-07-16 16:41:58 +02:00
|
|
|
* removes occurrences of the given topic from the topic array
|
|
|
|
* @param {mindplot.Topic} topic the topic to remove
|
|
|
|
*/
|
2021-10-05 02:05:34 +02:00
|
|
|
removeTopic(topic) {
|
|
|
|
$assert(topic, 'topic can not be null');
|
|
|
|
this._topics.erase(topic);
|
|
|
|
},
|
2021-07-16 16:41:58 +02:00
|
|
|
|
2021-10-05 02:05:34 +02:00
|
|
|
/**
|
2021-07-16 16:41:58 +02:00
|
|
|
* removes occurrences of the given relationship from the relationship array
|
|
|
|
* @param {mindplot.Relationship} rel the relationship to remove
|
|
|
|
*/
|
2021-10-05 02:05:34 +02:00
|
|
|
removeRelationship(rel) {
|
|
|
|
$assert(rel, 'rel can not be null');
|
|
|
|
this._relationships.erase(rel);
|
|
|
|
},
|
2021-07-16 16:41:58 +02:00
|
|
|
|
2021-10-05 02:05:34 +02:00
|
|
|
/**
|
2021-07-16 16:41:58 +02:00
|
|
|
* adds the given topic to the topic array
|
|
|
|
* @param {mindplot.Topic} topic the topic to add
|
|
|
|
* @throws will throw an error if topic is null or undefined
|
|
|
|
* @throws will throw an error if the topic's id is not a number
|
|
|
|
*/
|
2021-10-05 02:05:34 +02:00
|
|
|
addTopic(topic) {
|
|
|
|
$assert(topic, 'topic can not be null');
|
|
|
|
$assert(typeof topic.getId() === 'number', `id is not a number:${topic.getId()}`);
|
|
|
|
this._topics.push(topic);
|
|
|
|
},
|
2021-07-16 16:41:58 +02:00
|
|
|
|
2021-10-05 02:05:34 +02:00
|
|
|
/**
|
2021-07-16 16:41:58 +02:00
|
|
|
* adds the given relationship to the relationship array
|
|
|
|
* @param {mindplot.Relationship} rel the relationship to add
|
|
|
|
* @throws will throw an error if rel is null or undefined
|
|
|
|
*/
|
2021-10-05 02:05:34 +02:00
|
|
|
addRelationship(rel) {
|
|
|
|
$assert(rel, 'rel can not be null');
|
|
|
|
this._relationships.push(rel);
|
|
|
|
},
|
2021-07-16 16:41:58 +02:00
|
|
|
|
2021-10-05 02:05:34 +02:00
|
|
|
/**
|
2021-07-16 16:41:58 +02:00
|
|
|
* @param {Function=} validate a function to validate nodes
|
|
|
|
* @param {String=} errorMsg an error message to display if the validation fails
|
|
|
|
* @return {String} returns an array of the selected (and, if applicable, valid) topics' ids
|
|
|
|
*/
|
2021-10-05 02:05:34 +02:00
|
|
|
filterTopicsIds(validate, errorMsg) {
|
|
|
|
const result = [];
|
|
|
|
const topics = this.filterSelectedTopics();
|
|
|
|
|
|
|
|
let isValid = true;
|
|
|
|
for (let i = 0; i < topics.length; i++) {
|
|
|
|
const selectedNode = topics[i];
|
|
|
|
if ($defined(validate)) {
|
|
|
|
isValid = validate(selectedNode);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add node only if it's valid.
|
|
|
|
if (isValid) {
|
|
|
|
result.push(selectedNode.getId());
|
|
|
|
} else {
|
|
|
|
$notify(errorMsg);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return {mindplot.Topic} the first selected topic if one or more are found by the
|
2021-07-16 16:41:58 +02:00
|
|
|
* filterSelectedTopics function, null otherwise
|
|
|
|
*/
|
2021-10-05 02:05:34 +02:00
|
|
|
selectedTopic() {
|
|
|
|
const topics = this.filterSelectedTopics();
|
|
|
|
return (topics.length > 0) ? topics[0] : null;
|
|
|
|
},
|
2021-07-16 16:41:58 +02:00
|
|
|
|
2021-10-05 02:05:34 +02:00
|
|
|
/**
|
2021-07-16 16:41:58 +02:00
|
|
|
* @param {String} id the id of the topic to be retrieved
|
|
|
|
* @return {mindplot.Topic} the topic with the respective id
|
|
|
|
*/
|
2021-10-05 02:05:34 +02:00
|
|
|
findTopicById(id) {
|
|
|
|
let result = null;
|
|
|
|
for (let i = 0; i < this._topics.length; i++) {
|
|
|
|
const topic = this._topics[i];
|
|
|
|
if (topic.getId() == id) {
|
|
|
|
result = topic;
|
|
|
|
break;
|
|
|
|
}
|
2021-07-16 16:41:58 +02:00
|
|
|
}
|
2021-10-05 02:05:34 +02:00
|
|
|
return result;
|
|
|
|
},
|
2021-07-16 16:41:58 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
export default DesignerModel;
|