- New "debug/develop" map overlays, closed #785 - Upgraded [_jsPlumb_](http://jsplumb.github.io/jsplumb/home.html) js lib `v1.7.6` → `v2.9.3`
97 lines
4.0 KiB
JavaScript
97 lines
4.0 KiB
JavaScript
/**
|
|
* map overlay util functions
|
|
*/
|
|
|
|
define([
|
|
'jquery',
|
|
'app/init',
|
|
'app/util',
|
|
'app/map/util'
|
|
], ($, Init, Util) => {
|
|
'use strict';
|
|
|
|
let config = {
|
|
logTimerCount: 3, // map log timer in seconds
|
|
|
|
mapWrapperClass: 'pf-map-wrapper', // wrapper div (scrollable)
|
|
|
|
// map overlays sections
|
|
mapOverlayClass: 'pf-map-overlay', // class for all map overlays
|
|
mapOverlayTimerClass: 'pf-map-overlay-timer', // class for map overlay timer e.g. map timer
|
|
mapOverlayZoomClass: 'pf-map-overlay-zoom', // class for map overlay zoom
|
|
mapOverlayInfoClass: 'pf-map-overlay-info', // class for map overlay info e.g. map info
|
|
overlayLocalClass: 'pf-map-overlay-local', // class for map overlay "local" table
|
|
|
|
// system
|
|
systemHeadClass: 'pf-system-head', // class for system head
|
|
|
|
// connection overlay ids (they are not unique like CSS ids!)
|
|
connectionOverlayArrowId: 'pf-map-connection-arrow-overlay', // connection Arrows overlay ID (jsPlumb)
|
|
connectionOverlayWhId: 'pf-map-connection-wh-overlay', // connection WH overlay ID (jsPlumb)
|
|
connectionOverlayEolId: 'pf-map-connection-eol-overlay', // connection EOL overlay ID (jsPlumb)
|
|
|
|
debugOverlayId: 'pf-map-debug-overlay', // connection/endpoint overlay ID (jsPlumb)
|
|
|
|
endpointOverlayId: 'pf-map-endpoint-overlay', // endpoint overlay ID (jsPlumb)
|
|
|
|
// connection overlay classes classes
|
|
componentOverlayClass: 'pf-map-component-overlay', // class for "normal size" overlay
|
|
|
|
connectionArrowOverlaySuccessClass: 'pf-map-connection-arrow-overlay-success', // class for "success" arrow overlays
|
|
connectionArrowOverlayDangerClass: 'pf-map-connection-arrow-overlay-danger', // class for "danger" arrow overlays
|
|
|
|
// zoom overlay
|
|
zoomOverlayUpClass: 'pf-zoom-overlay-up',
|
|
zoomOverlayDownClass: 'pf-zoom-overlay-down',
|
|
zoomOverlayValueClass: 'pf-zoom-overlay-value'
|
|
};
|
|
|
|
/**
|
|
* get map overlay element by type e.g. timer/counter, info - overlay
|
|
* @param element
|
|
* @param overlayType
|
|
* @returns {null}
|
|
*/
|
|
let getMapOverlay = (element, overlayType) => {
|
|
let mapWrapperElement = $(element).parents('.' + config.mapWrapperClass);
|
|
|
|
let mapOverlay = null;
|
|
switch(overlayType){
|
|
case 'timer':
|
|
mapOverlay = mapWrapperElement.find('.' + config.mapOverlayTimerClass);
|
|
break;
|
|
case 'info':
|
|
mapOverlay = mapWrapperElement.find('.' + config.mapOverlayInfoClass);
|
|
break;
|
|
case 'zoom':
|
|
mapOverlay = mapWrapperElement.find('.' + config.mapOverlayZoomClass);
|
|
break;
|
|
case 'local':
|
|
mapOverlay = mapWrapperElement.find('.' + config.overlayLocalClass);
|
|
break;
|
|
}
|
|
|
|
return mapOverlay;
|
|
};
|
|
|
|
/**
|
|
* get the map counter chart from overlay
|
|
* @param element
|
|
* @returns {jQuery}
|
|
*/
|
|
let getMapCounter = element => $(element).find('.' + Init.classes.pieChart.pieChartMapCounterClass);
|
|
|
|
/**
|
|
* get interval value from map timer overlay
|
|
* @param element
|
|
* @returns {*}
|
|
*/
|
|
let getMapOverlayInterval = element => getMapCounter(getMapOverlay(element, 'timer')).data('interval');
|
|
|
|
return {
|
|
config: config,
|
|
getMapOverlay: getMapOverlay,
|
|
getMapCounter: getMapCounter,
|
|
getMapOverlayInterval: getMapOverlayInterval
|
|
};
|
|
}); |