12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 |
- svgEditor.addExtension('ClosePath', function() {'use strict';
- var selElems,
- updateButton = function(path) {
- var seglist = path.pathSegList,
- closed = seglist.getItem(seglist.numberOfItems - 1).pathSegType == 1,
- showbutton = closed ? '#tool_openpath' : '#tool_closepath',
- hidebutton = closed ? '#tool_closepath' : '#tool_openpath';
- $(hidebutton).hide();
- $(showbutton).show();
- },
- showPanel = function(on) {
- $('#closepath_panel').toggle(on);
- if (on) {
- var path = selElems[0];
- if (path) {updateButton(path);}
- }
- },
- toggleClosed = function() {
- var path = selElems[0];
- if (path) {
- var seglist = path.pathSegList,
- last = seglist.numberOfItems - 1;
-
- if (seglist.getItem(last).pathSegType == 1) {
- seglist.removeItem(last);
- } else {
- seglist.appendItem(path.createSVGPathSegClosePath());
- }
- updateButton(path);
- }
- };
- return {
- name: 'ClosePath',
- svgicons: svgEditor.curConfig.extPath + 'closepath_icons.svg',
- buttons: [{
- id: 'tool_openpath',
- type: 'context',
- panel: 'closepath_panel',
- title: 'Open path',
- events: {
- click: function() {
- toggleClosed();
- }
- }
- },
- {
- id: 'tool_closepath',
- type: 'context',
- panel: 'closepath_panel',
- title: 'Close path',
- events: {
- click: function() {
- toggleClosed();
- }
- }
- }],
- callback: function() {
- $('#closepath_panel').hide();
- },
- selectedChanged: function(opts) {
- selElems = opts.elems;
- var i = selElems.length;
- while (i--) {
- var elem = selElems[i];
- if (elem && elem.tagName == 'path') {
- if (opts.selectedElement && !opts.multiselected) {
- showPanel(true);
- } else {
- showPanel(false);
- }
- } else {
- showPanel(false);
- }
- }
- }
- };
- });
|