wisemapping-frontend/packages/mindplot/src/components/Events.js

72 lines
2.0 KiB
JavaScript
Raw Normal View History

2021-12-04 01:11:17 +01: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-07-16 16:41:58 +02:00
2021-12-04 01:11:17 +01:00
class Events {
constructor() {
this.$events = {};
}
static _removeOn(string) {
2021-10-05 02:05:34 +02:00
return string.replace(/^on([A-Z])/, (full, first) => first.toLowerCase());
2021-12-04 01:11:17 +01:00
}
2021-07-16 16:41:58 +02:00
2021-12-14 18:06:09 +01:00
addEvent(typeName, fn, internal) {
const type = Events._removeOn(typeName);
2021-07-16 16:41:58 +02:00
2021-12-14 18:06:09 +01:00
// Add function had not been added yet
const funByType = this.$events[type] ? this.$events[type] : [];
if (!funByType.includes(fn)) {
funByType.push(fn);
this.$events[type] = funByType;
}
// Mark reference ...
// eslint-disable-next-line no-param-reassign
fn.internal = Boolean(internal);
2021-10-05 02:05:34 +02:00
return this;
2021-12-04 01:11:17 +01:00
}
2021-07-16 16:41:58 +02:00
fireEvent(typeName, eventArgs, delay) {
2021-12-14 18:06:09 +01:00
const type = Events._removeOn(typeName);
2021-10-05 02:05:34 +02:00
const events = this.$events[type];
if (!events) return this;
2021-12-05 17:14:15 +01:00
const args = Array.isArray(eventArgs) ? eventArgs : [eventArgs];
2021-12-05 17:14:15 +01:00
events.forEach(((fn) => {
if (delay) {
fn.delay(delay, this, args);
2021-12-14 18:06:09 +01:00
} else {
2021-12-05 17:14:15 +01:00
fn.apply(this, args);
}
2021-12-14 18:06:09 +01:00
}));
2021-10-05 02:05:34 +02:00
return this;
2021-12-04 01:11:17 +01:00
}
2021-07-16 16:41:58 +02:00
2021-12-14 18:06:09 +01:00
removeEvent(typeName, fn) {
const type = Events._removeOn(typeName);
2021-10-05 02:05:34 +02:00
const events = this.$events[type];
if (events && !fn.internal) {
const index = events.indexOf(fn);
2021-12-04 01:11:17 +01:00
if (index !== -1) events.splice(index, 1);
2021-10-05 02:05:34 +02:00
}
return this;
2021-12-04 01:11:17 +01:00
}
}
2021-07-16 16:41:58 +02:00
export default Events;