2017-03-14 17:20:59 +00:00
|
|
|
/**
|
|
|
|
* Update plugin. Use updateUrl and updateInterval (optional, default is 60000ms)
|
2017-05-19 13:55:24 +00:00
|
|
|
* in the meta data of the diagram to configure the plugin. (Alternatively, the
|
|
|
|
* update-url and update-interval URL parameters may be used instead.)
|
|
|
|
*
|
|
|
|
* It will send the XML of the current page to the given URL as a POST request
|
|
|
|
* (with a parameter called xml) and allows for the following type of XML response
|
|
|
|
* (with CORS headers):
|
2017-03-14 17:20:59 +00:00
|
|
|
*
|
|
|
|
* <updates>
|
|
|
|
* <update ...>
|
2017-05-08 21:49:59 +00:00
|
|
|
* <model>...</model>
|
|
|
|
* <view ...>
|
2017-05-16 14:10:23 +00:00
|
|
|
* <fit ...>
|
2017-03-14 17:20:59 +00:00
|
|
|
* </updates>
|
|
|
|
*
|
2017-05-16 14:10:23 +00:00
|
|
|
* The outermost updates node may contain an optional url and interval property
|
|
|
|
* to change the current updateUrl and updateInterval.
|
|
|
|
*
|
2017-03-14 17:20:59 +00:00
|
|
|
* Where update must contain an id attribute to reference the cell in the diagram.
|
|
|
|
*
|
|
|
|
* - An optional value attribute that contains XML markup is used as the value for
|
|
|
|
* the cell, with label and tooltip for the label and tooltip, respectively.
|
|
|
|
* Additionally, placeholders="1" can be used to enable placeholders in the label
|
|
|
|
* or tooltip of the cell.
|
|
|
|
*
|
2017-05-08 21:49:59 +00:00
|
|
|
* Example: <object label="Hello, %var1%!" var1="World" tooltip=
|
|
|
|
* "Click <a href=\"https://www.draw.io\">here</a>" placeholders="1">
|
|
|
|
*
|
2017-03-14 17:20:59 +00:00
|
|
|
* - An optional replace-value attribute that contains 1 can be specified to
|
|
|
|
* replace the value of the cell. Default is to add the attributes of the XML
|
|
|
|
* value specified above to the existing value of the cell. (Attributes with
|
|
|
|
* an empty string value are removed.)
|
|
|
|
*
|
2017-03-15 07:57:48 +00:00
|
|
|
* - An optional style attribute that contains the cell style is used to replace
|
2017-03-14 17:20:59 +00:00
|
|
|
* the existing cell style.
|
|
|
|
*
|
2017-05-08 21:49:59 +00:00
|
|
|
* Example: fillColor=red;gradientColor=white;"
|
|
|
|
*
|
2017-03-14 17:20:59 +00:00
|
|
|
* - An optional icon attribute that contains JSON is used to add an icon to the
|
2017-05-08 21:49:59 +00:00
|
|
|
* given cell. The object value that the icon attribute is parsed and may contain
|
2017-03-14 17:20:59 +00:00
|
|
|
* a tooltip (string), align ("left"|"center"|"right", default is "right"), valign
|
|
|
|
* (top|middle|bottom, default is bottom) and append (true|false, default is false)
|
|
|
|
* for adding or replacing existing icons. The image attribute is an object value
|
|
|
|
* with src, width and height for defining the icon to be displayed (default is
|
|
|
|
* mxGraph.warningImage). An empty string for the attribute removes all icons.
|
|
|
|
*
|
2017-05-08 21:49:59 +00:00
|
|
|
* Example: JSON.stringify({tooltip: 'Locked', append: true, image:
|
|
|
|
* {src: IMAGE_PATH + '/locked.png', width: 26, height:26}}
|
|
|
|
*
|
|
|
|
* - An optional geometry attribute that contains a JSON mxGeometry object can be used
|
|
|
|
* to replace the current geometry of the refenced cell. In addition to the existing
|
|
|
|
* field names in mxGeometry, dx and dy can be used to define a vector for moving the
|
|
|
|
* shape, and dh and dw can be used to resize the cell.
|
|
|
|
*
|
|
|
|
* Example: JSON.stringify({dx: (Math.random() * 100) - 50, dh: (Math.random() * 100) - 50}))
|
|
|
|
*
|
|
|
|
* - Additionally a model node may be specified to set the current graph model.
|
|
|
|
*
|
|
|
|
* Example: <model><mxGraphModel><root><mxCell id="0"/></mxCell>...</root></mxGraphModel></model>
|
|
|
|
*
|
|
|
|
* - A view node may be specified with a scale, dx and dy attribute to change the current
|
|
|
|
* scale and translate.
|
|
|
|
*
|
|
|
|
* Example: <view scale="0.5" dx="100" dy="100"/>
|
2017-05-16 14:10:23 +00:00
|
|
|
*
|
|
|
|
* - A fit node may be specified with a max-scale property to fit the diagram to the
|
|
|
|
* available viewport with the specified max-scale.
|
2017-03-14 17:20:59 +00:00
|
|
|
*/
|
|
|
|
Draw.loadPlugin(function(editorUi)
|
|
|
|
{
|
|
|
|
if (editorUi.editor.chromeless)
|
|
|
|
{
|
|
|
|
var graph = editorUi.editor.graph;
|
2017-05-19 13:55:24 +00:00
|
|
|
var updateInterval = parseInt(urlParams['update-interval'] || 60000);
|
|
|
|
var updateUrlParam = urlParams['update-url'];
|
2017-05-16 14:10:23 +00:00
|
|
|
var updateUrl = null;
|
2017-03-14 17:20:59 +00:00
|
|
|
|
2017-05-19 13:55:24 +00:00
|
|
|
if (updateUrlParam != null)
|
|
|
|
{
|
|
|
|
updateUrl = decodeURIComponent(updateUrlParam);
|
|
|
|
|
|
|
|
// Creates empty file if update URL is in URL parameter
|
|
|
|
if (editorUi.getCurrentFile() == null)
|
|
|
|
{
|
|
|
|
editorUi.createFile(editorUi.defaultFilename, null, null, null, null, null, null, true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-14 17:20:59 +00:00
|
|
|
function createOverlay(desc)
|
|
|
|
{
|
|
|
|
var overlay = new mxCellOverlay(desc.image || graph.warningImage,
|
|
|
|
desc.tooltip, desc.align, desc.valign, desc.offset);
|
|
|
|
|
|
|
|
// Installs a handler for clicks on the overlay
|
|
|
|
overlay.addListener(mxEvent.CLICK, function(sender, evt)
|
|
|
|
{
|
|
|
|
editorUi.alert(desc.tooltip);
|
|
|
|
});
|
|
|
|
|
|
|
|
return overlay;
|
|
|
|
};
|
|
|
|
|
2017-05-08 21:49:59 +00:00
|
|
|
function parseResponse(xml)
|
2017-03-14 17:20:59 +00:00
|
|
|
{
|
|
|
|
if (xml != null && xml.length > 0)
|
|
|
|
{
|
|
|
|
var doc = mxUtils.parseXml(xml);
|
2017-05-16 14:10:23 +00:00
|
|
|
var node = (doc != null) ? doc.documentElement : null;
|
2017-03-14 17:20:59 +00:00
|
|
|
|
2017-05-16 14:10:23 +00:00
|
|
|
if (node != null && node.nodeName == 'updates')
|
2017-03-14 17:20:59 +00:00
|
|
|
{
|
2017-05-16 14:10:23 +00:00
|
|
|
if (node.hasAttribute('url'))
|
|
|
|
{
|
|
|
|
updateUrl = node.getAttribute('url');
|
|
|
|
}
|
|
|
|
|
|
|
|
if (node.hasAttribute('interval'))
|
|
|
|
{
|
|
|
|
updateInterval = node.getAttribute('interval');
|
|
|
|
}
|
|
|
|
|
2017-03-14 17:20:59 +00:00
|
|
|
var model = graph.getModel();
|
2017-05-08 21:49:59 +00:00
|
|
|
model.beginUpdate();
|
|
|
|
var fit = null;
|
2017-05-16 14:10:23 +00:00
|
|
|
|
2017-05-08 21:49:59 +00:00
|
|
|
try
|
2017-03-14 17:20:59 +00:00
|
|
|
{
|
2017-05-16 14:10:23 +00:00
|
|
|
node = node.firstChild;
|
|
|
|
|
2017-05-08 21:49:59 +00:00
|
|
|
while (node != null)
|
2017-03-14 17:20:59 +00:00
|
|
|
{
|
2017-05-08 21:49:59 +00:00
|
|
|
if (node.nodeName == 'update')
|
2017-03-14 17:20:59 +00:00
|
|
|
{
|
|
|
|
// Resolves the cell ID
|
2017-05-08 21:49:59 +00:00
|
|
|
var cell = model.getCell(node.getAttribute('id'));
|
|
|
|
|
2017-03-14 17:20:59 +00:00
|
|
|
if (cell != null)
|
|
|
|
{
|
|
|
|
// Changes the value
|
|
|
|
try
|
|
|
|
{
|
2017-05-08 21:49:59 +00:00
|
|
|
var value = node.getAttribute('value');
|
2017-03-14 17:20:59 +00:00
|
|
|
|
|
|
|
if (value != null)
|
|
|
|
{
|
2017-05-08 21:49:59 +00:00
|
|
|
var valueNode = mxUtils.parseXml(value).documentElement;
|
|
|
|
|
|
|
|
if (valueNode != null)
|
2017-03-14 17:20:59 +00:00
|
|
|
{
|
2017-05-08 21:49:59 +00:00
|
|
|
if (valueNode.getAttribute('replace-value') == '1')
|
2017-03-14 17:20:59 +00:00
|
|
|
{
|
2017-05-08 21:49:59 +00:00
|
|
|
model.setValue(cell, valueNode);
|
2017-03-14 17:20:59 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-05-08 21:49:59 +00:00
|
|
|
var attrs = valueNode.attributes;
|
2017-03-14 17:20:59 +00:00
|
|
|
|
|
|
|
for (var j = 0; j < attrs.length; j++)
|
|
|
|
{
|
|
|
|
graph.setAttributeForCell(cell, attrs[j].nodeName,
|
|
|
|
(attrs[j].nodeValue.length > 0) ? attrs[j].nodeValue : null);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (e)
|
|
|
|
{
|
|
|
|
console.log('Error in value for ' + cell.id + ': ' + e);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Changes the style
|
|
|
|
try
|
|
|
|
{
|
2017-05-08 21:49:59 +00:00
|
|
|
var style = node.getAttribute('style');
|
2017-03-14 17:20:59 +00:00
|
|
|
|
|
|
|
if (style != null)
|
|
|
|
{
|
|
|
|
graph.model.setStyle(cell, style);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (e)
|
|
|
|
{
|
|
|
|
console.log('Error in style for ' + cell.id + ': ' + e);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Adds or removes an overlay icon
|
|
|
|
try
|
|
|
|
{
|
2017-05-08 21:49:59 +00:00
|
|
|
var icon = node.getAttribute('icon');
|
2017-03-14 17:20:59 +00:00
|
|
|
|
|
|
|
if (icon != null)
|
|
|
|
{
|
|
|
|
var desc = (icon.length > 0) ? JSON.parse(icon) : null;
|
|
|
|
|
|
|
|
if (desc == null || !desc.append)
|
|
|
|
{
|
|
|
|
graph.removeCellOverlays(cell);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (desc != null)
|
|
|
|
{
|
|
|
|
graph.addCellOverlay(cell, createOverlay(desc));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (e)
|
|
|
|
{
|
|
|
|
console.log('Error in icon for ' + cell.id + ': ' + e);
|
|
|
|
}
|
2017-05-08 21:49:59 +00:00
|
|
|
|
|
|
|
// Replaces the geometry
|
|
|
|
try
|
|
|
|
{
|
|
|
|
var geo = node.getAttribute('geometry');
|
|
|
|
|
|
|
|
if (geo != null)
|
|
|
|
{
|
|
|
|
geo = JSON.parse(geo);
|
|
|
|
var curr = graph.getCellGeometry(cell);
|
|
|
|
|
|
|
|
if (curr != null)
|
|
|
|
{
|
|
|
|
curr = curr.clone();
|
|
|
|
|
|
|
|
// Partially overwrites geometry
|
|
|
|
for (key in geo)
|
|
|
|
{
|
|
|
|
var val = parseFloat(geo[key]);
|
|
|
|
|
|
|
|
if (key == 'dx')
|
|
|
|
{
|
|
|
|
curr.x += val;
|
|
|
|
}
|
|
|
|
else if (key == 'dy')
|
|
|
|
{
|
|
|
|
curr.y += val;
|
|
|
|
}
|
|
|
|
else if (key == 'dw')
|
|
|
|
{
|
|
|
|
curr.width += val;
|
|
|
|
}
|
|
|
|
else if (key == 'dh')
|
|
|
|
{
|
|
|
|
curr.height += val;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
curr[key] = parseFloat(geo[key]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
graph.model.setGeometry(cell, curr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (e)
|
|
|
|
{
|
|
|
|
console.log('Error in icon for ' + cell.id + ': ' + e);
|
|
|
|
}
|
|
|
|
} // if cell != null
|
|
|
|
} // if node.nodeName == 'update
|
|
|
|
else if (node.nodeName == 'model')
|
|
|
|
{
|
2017-05-16 14:10:23 +00:00
|
|
|
// Finds first child element
|
|
|
|
var dataNode = node.firstChild;
|
|
|
|
|
|
|
|
while (dataNode != null && dataNode.nodeType != mxConstants.NODETYPE_ELEMENT)
|
|
|
|
{
|
|
|
|
dataNode = dataNode.nextSibling;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (dataNode != null)
|
|
|
|
{
|
|
|
|
var dec = new mxCodec(node.firstChild);
|
|
|
|
dec.decode(dataNode, model);
|
|
|
|
}
|
2017-05-08 21:49:59 +00:00
|
|
|
}
|
|
|
|
else if (node.nodeName == 'view')
|
|
|
|
{
|
|
|
|
if (node.hasAttribute('scale'))
|
|
|
|
{
|
|
|
|
graph.view.scale = parseFloat(node.getAttribute('scale'));
|
2017-03-14 17:20:59 +00:00
|
|
|
}
|
2017-05-08 21:49:59 +00:00
|
|
|
|
|
|
|
if (node.hasAttribute('dx') || node.hasAttribute('dy'))
|
|
|
|
{
|
|
|
|
graph.view.translate = new mxPoint(parseFloat(node.getAttribute('dx') || 0),
|
|
|
|
parseFloat(node.getAttribute('dy') || 0));
|
|
|
|
}
|
|
|
|
}
|
2017-05-16 14:10:23 +00:00
|
|
|
else if (node.nodeName == 'fit')
|
|
|
|
{
|
|
|
|
if (node.hasAttribute('max-scale'))
|
|
|
|
{
|
|
|
|
fit = parseFloat(node.getAttribute('max-scale'));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
fit = 1;
|
|
|
|
}
|
|
|
|
}
|
2017-05-08 21:49:59 +00:00
|
|
|
|
|
|
|
node = node.nextSibling;
|
|
|
|
} // end of while
|
|
|
|
}
|
|
|
|
finally
|
|
|
|
{
|
|
|
|
model.endUpdate();
|
2017-03-14 17:20:59 +00:00
|
|
|
}
|
2017-05-16 14:10:23 +00:00
|
|
|
|
|
|
|
if (fit != null && editorUi.chromelessResize)
|
|
|
|
{
|
|
|
|
editorUi.chromelessResize(true, fit);
|
|
|
|
}
|
2017-03-14 17:20:59 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
var currentThread = null;
|
|
|
|
|
|
|
|
function scheduleUpdates()
|
|
|
|
{
|
2017-05-16 14:10:23 +00:00
|
|
|
var page = editorUi.currentPage;
|
2017-03-14 17:20:59 +00:00
|
|
|
var root = editorUi.editor.graph.getModel().getRoot();
|
|
|
|
var result = false;
|
|
|
|
|
2017-05-19 13:55:24 +00:00
|
|
|
if (urlParams['update-url'] || (root.value != null && typeof(root.value) == 'object'))
|
2017-03-14 17:20:59 +00:00
|
|
|
{
|
2017-05-19 13:55:24 +00:00
|
|
|
if (root.value != null && typeof(root.value) == 'object')
|
|
|
|
{
|
|
|
|
updateInterval = parseInt(root.value.getAttribute('updateInterval') || updateInterval);
|
|
|
|
updateUrl = root.value.getAttribute('updateUrl') || updateUrl;
|
|
|
|
}
|
2017-03-14 17:20:59 +00:00
|
|
|
|
2017-05-16 14:10:23 +00:00
|
|
|
if (updateUrl != null)
|
2017-03-14 17:20:59 +00:00
|
|
|
{
|
|
|
|
var currentXml = mxUtils.getXml(editorUi.editor.getGraphXml());
|
|
|
|
|
|
|
|
function doUpdate()
|
|
|
|
{
|
2017-05-16 14:10:23 +00:00
|
|
|
if (updateUrl === 'demo')
|
2017-03-14 17:20:59 +00:00
|
|
|
{
|
2017-05-08 21:49:59 +00:00
|
|
|
parseResponse(mxUtils.getXml(createDemoResponse().documentElement));
|
2017-03-14 17:20:59 +00:00
|
|
|
schedule();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-05-16 14:10:23 +00:00
|
|
|
mxUtils.post(updateUrl, 'xml=' + encodeURIComponent(currentXml), function(req)
|
2017-03-14 17:20:59 +00:00
|
|
|
{
|
2017-05-16 14:10:23 +00:00
|
|
|
if (page === editorUi.currentPage)
|
2017-03-14 17:20:59 +00:00
|
|
|
{
|
|
|
|
if (req.getStatus() >= 200 && req.getStatus() <= 300)
|
|
|
|
{
|
2017-05-08 21:49:59 +00:00
|
|
|
parseResponse(mxUtils.getXml(req.getDocumentElement()));
|
2017-03-14 17:20:59 +00:00
|
|
|
schedule();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
editorUi.handleError({message: mxResources.get('error') + ' ' +
|
|
|
|
req.getStatus()});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}, function(err)
|
|
|
|
{
|
|
|
|
editorUi.handleError(err);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
function schedule()
|
|
|
|
{
|
2017-05-16 14:10:23 +00:00
|
|
|
currentThread = window.setTimeout(doUpdate, updateInterval);
|
2017-03-14 17:20:59 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
doUpdate();
|
|
|
|
result = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
};
|
|
|
|
|
|
|
|
function startUpdates()
|
|
|
|
{
|
|
|
|
var result = scheduleUpdates();
|
|
|
|
|
|
|
|
if (result)
|
|
|
|
{
|
|
|
|
editorUi.editor.addListener('pageSelected', function()
|
|
|
|
{
|
|
|
|
window.clearTimeout(currentThread);
|
|
|
|
scheduleUpdates();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
};
|
|
|
|
|
|
|
|
function createDemoResponse()
|
|
|
|
{
|
|
|
|
var doc = mxUtils.createXmlDocument();
|
|
|
|
var status = doc.createElement('updates');
|
2017-05-08 21:49:59 +00:00
|
|
|
|
2017-03-14 17:20:59 +00:00
|
|
|
for (var id in graph.model.cells)
|
|
|
|
{
|
|
|
|
var cell = graph.model.cells[id];
|
|
|
|
|
2017-05-08 21:49:59 +00:00
|
|
|
if (graph.model.isEdge(cell))
|
|
|
|
{
|
|
|
|
// Ignores short edges
|
|
|
|
var state = graph.view.getState(cell);
|
|
|
|
|
|
|
|
if (Math.random() > 0.5 && state.length > 50)
|
|
|
|
{
|
|
|
|
var update = doc.createElement('update');
|
|
|
|
update.setAttribute('id', cell.id);
|
|
|
|
update.setAttribute('value', '<object label="%load% minutes" load="' +
|
|
|
|
Math.round(Math.random() * 100) + '" placeholders="1">');
|
|
|
|
update.setAttribute('style', cell.style + ';strokeColor=red;strokeWidth=' +
|
|
|
|
Math.round(Math.random() * 5) + ';');
|
|
|
|
status.appendChild(update);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
var update = doc.createElement('update');
|
|
|
|
update.setAttribute('id', cell.id);
|
|
|
|
update.setAttribute('value', '<object label="" load="' +
|
|
|
|
Math.round(Math.random() * 100) + '" placeholders="1">');
|
|
|
|
update.setAttribute('style', cell.style + ';strokeColor=black;strokeWidth=;');
|
|
|
|
status.appendChild(update);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (graph.model.isVertex(cell))
|
2017-03-14 17:20:59 +00:00
|
|
|
{
|
|
|
|
// For the purpose of the demo we flag stuff to update with update="1".
|
|
|
|
// This is not needed for the general case.
|
|
|
|
if (cell.value != null && typeof(cell.value) == 'object' &&
|
|
|
|
cell.value.getAttribute('update') == '1')
|
|
|
|
{
|
2017-05-08 21:49:59 +00:00
|
|
|
// Restores original style in demo roundtrip
|
|
|
|
if (cell.prevStyle == null)
|
|
|
|
{
|
|
|
|
cell.prevStyle = cell.style;
|
|
|
|
}
|
|
|
|
|
2017-03-14 17:20:59 +00:00
|
|
|
if (Math.random() > 0.5)
|
|
|
|
{
|
|
|
|
var update = doc.createElement('update');
|
|
|
|
update.setAttribute('id', cell.id);
|
|
|
|
update.setAttribute('value', '<object tooltip="%load%% Done" load="' +
|
|
|
|
Math.round(Math.random() * 100) + '" placeholders="1">');
|
2017-05-08 21:49:59 +00:00
|
|
|
update.setAttribute('style', cell.prevStyle + ';fillColor=red;gradientColor=white;');
|
|
|
|
update.setAttribute('icon', JSON.stringify({tooltip: 'Alert', align: 'right',
|
|
|
|
valign: 'top', image: {src: 'mxgraph/images/warning.gif', width: 26, height: 26}}));
|
|
|
|
// update.setAttribute('geometry', JSON.stringify({dx: (Math.random() * 100) - 50,
|
|
|
|
// y: cell.geometry.y + (Math.random() * 100) - 50, dh: (Math.random() * 100) - 50}));
|
2017-03-14 17:20:59 +00:00
|
|
|
status.appendChild(update);
|
|
|
|
|
|
|
|
// Adds another icon
|
|
|
|
if (Math.random() > 0.5)
|
|
|
|
{
|
|
|
|
var update = doc.createElement('update');
|
|
|
|
update.setAttribute('id', cell.id);
|
2017-05-08 21:49:59 +00:00
|
|
|
update.setAttribute('icon', JSON.stringify({tooltip: 'Busy', append: true,
|
|
|
|
image: {src: IMAGE_PATH + '/spin.gif', width: 26, height:26}}));
|
2017-03-14 17:20:59 +00:00
|
|
|
status.appendChild(update);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
var update = doc.createElement('update');
|
|
|
|
update.setAttribute('id', cell.id);
|
2017-05-08 21:49:59 +00:00
|
|
|
update.setAttribute('style', cell.prevStyle + ';fillColor=#d4e1f5;gradientColor=white;');
|
|
|
|
update.setAttribute('value',
|
|
|
|
'<object tooltip="Click <a href=\"https://www.draw.io\">here</a>">');
|
2017-03-14 17:20:59 +00:00
|
|
|
update.setAttribute('icon', '');
|
|
|
|
status.appendChild(update);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-05-08 21:49:59 +00:00
|
|
|
// var modelNode = mxUtils.parseXml('<model><mxGraphModel> <root> <mxCell id="0"/> <mxCell id="1" parent="0"/> <mxCell id="12" value="Program" style="rounded=0;shadow=0;strokeWidth=1;fontSize=12;fillColor=#F0F0F0;" vertex="1" parent="1"> <mxGeometry x="274" y="227" width="100" height="40" as="geometry"/> </mxCell> <mxCell id="13" value="PDF
Outline" style="ellipse;rounded=0;shadow=0;strokeWidth=1;fillColor=none;fontSize=12;" vertex="1" parent="1"> <mxGeometry x="80" y="247" width="90" height="40" as="geometry"/> </mxCell> <mxCell id="14" style="rounded=0;html=0;shadow=0;startArrow=none;endArrow=none;endFill=0;endSize=10;strokeColor=#000000;strokeWidth=1;fontSize=12;startFill=0;" edge="1" source="13" target="12" parent="1"> <mxGeometry relative="1" as="geometry"/> </mxCell> <mxCell id="15" value="HTML
Outline" style="ellipse;rounded=0;shadow=0;strokeWidth=1;fillColor=none;fontSize=12;" vertex="1" parent="1"> <mxGeometry x="118" y="140" width="90" height="40" as="geometry"/> </mxCell> <mxCell id="16" style="rounded=0;html=0;shadow=0;startArrow=none;endArrow=none;endFill=0;endSize=10;strokeColor=#000000;strokeWidth=1;fontSize=12;startFill=0;" edge="1" source="15" target="12" parent="1"> <mxGeometry relative="1" as="geometry"> <mxPoint x="267" y="158.2814070351758" as="targetPoint"/> </mxGeometry> </mxCell> <mxCell id="17" style="rounded=0;html=0;shadow=0;startArrow=none;endArrow=none;endFill=0;endSize=10;strokeColor=#000000;strokeWidth=1;fontSize=12;startFill=0;" edge="1" source="18" target="12" parent="1"> <mxGeometry relative="1" as="geometry"> <mxPoint x="413.7317073170732" y="171" as="targetPoint"/> </mxGeometry> </mxCell> <mxCell id="18" value="Name" style="ellipse;rounded=0;shadow=0;strokeWidth=1;fillColor=none;fontSize=12;" vertex="1" parent="1"> <mxGeometry x="274" y="100" width="90" height="40" as="geometry"/> </mxCell> <mxCell id="19" style="rounded=0;html=0;shadow=0;startArrow=none;endArrow=none;endFill=0;endSize=10;strokeColor=#000000;strokeWidth=1;fontSize=12;startFill=0;" edge="1" source="20" target="12" parent="1"> <mxGeometry relative="1" as="geometry"> <mxPoint x="464.5244755244755" y="227" as="targetPoint"/> </mxGeometry> </mxCell> <mxCell id="20" value="Description" style="ellipse;rounded=0;shadow=0;strokeWidth=1;fillColor=none;fontSize=12;" vertex="1" parent="1"> <mxGeometry x="437" y="124" width="90" height="40" as="geometry"/> </mxCell> <mxCell id="21" style="rounded=0;html=0;shadow=0;startArrow=none;endArrow=none;endFill=0;endSize=10;strokeColor=#000000;strokeWidth=1;fontSize=12;startFill=0;" edge="1" source="22" target="12" parent="1"> <mxGeometry relative="1" as="geometry"> <mxPoint x="436.80419580419584" y="319" as="targetPoint"/> </mxGeometry> </mxCell> <mxCell id="22" value="Admission
Deadline" style="ellipse;rounded=0;shadow=0;strokeWidth=1;fillColor=none;fontSize=12;" vertex="1" parent="1"> <mxGeometry x="495" y="216" width="90" height="40" as="geometry"/> </mxCell> <mxCell id="23" value="courses" style="rhombus;whiteSpace=wrap;html=1;rounded=0;shadow=0;strokeWidth=1;fillColor=none;fontSize=12;" vertex="1" parent="1"> <mxGeometry x="284" y="349" width="80" height="50" as="geometry"/> </mxCell> <mxCell id="24" style="rounded=0;html=0;shadow=0;startArrow=none;endArrow=none;endFill=0;endSize=10;strokeColor=#000000;strokeWidth=1;fontSize=12;startFill=0;" edge="1" source="23" target="12" parent="1"> <mxGeometry relative="1" as="geometry"> <mxPoint x="495.26224188188667" y="238.15603653581252" as="sourcePoint"/> <mxPoint x="374" y="244.4537037037037" as="targetPoint"/> </mxGeometry> </mxCell> <mxCell id="25" value="Course" style="rounded=0;shadow=0;strokeWidth=1;fontSize=12;fillColor=#F0F0F0;" vertex="1" parent="1"> <mxGeometry x="274" y="458" width="100" height="40" as="geometry"/> </mxCell> <mxCell id="26" style="rounded=0;html=0;shadow=0;startArrow=none;en
|
|
|
|
// status.appendChild(modelNode.documentElement);
|
|
|
|
//
|
|
|
|
// var fitNode = mxUtils.parseXml('<view scale="0.5" dx="0"/>');
|
|
|
|
// status.appendChild(fitNode.documentElement);
|
|
|
|
|
2017-03-14 17:20:59 +00:00
|
|
|
doc.appendChild(status);
|
|
|
|
|
|
|
|
return doc;
|
|
|
|
};
|
|
|
|
|
|
|
|
// Wait for file to be loaded if no animation data is present
|
|
|
|
if (!startUpdates())
|
|
|
|
{
|
|
|
|
editorUi.editor.addListener('fileLoaded', startUpdates);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|