aboutsummaryrefslogtreecommitdiff
path: root/js/mediators/element-mediator.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/mediators/element-mediator.js')
-rwxr-xr-xjs/mediators/element-mediator.js123
1 files changed, 44 insertions, 79 deletions
</
diff --git a/js/mediators/element-mediator.js b/js/mediators/element-mediator.js
index 88baf3d9..93a8dbce 100755
--- a/js/mediators/element-mediator.js
+++ b/js/mediators/element-mediator.js
@@ -35,16 +35,13 @@ exports.ElementMediator = Montage.create(Component, {
35 if(Array.isArray(elements)) { 35 if(Array.isArray(elements)) {
36 elements.forEach(function(element) { 36 elements.forEach(function(element) {
37 ElementController.addElement(element, rules); 37 ElementController.addElement(element, rules);
38 if(element.elementModel && element.elementModel.props3D) {
39 element.elementModel.props3D.init(element, false); 38 element.elementModel.props3D.init(element, false);
40 }
41 }); 39 });
42 } else { 40 } else {
43 ElementController.addElement(elements, rules); 41 ElementController.addElement(elements, rules);
44 if(elements.elementModel && elements.elementModel.props3D) {
45 elements.elementModel.props3D.init(elements, false); 42 elements.elementModel.props3D.init(elements, false);
43
46 } 44 }
47 }
48 45
49 if(this.addDelegate && typeof (this.addDelegate['onAddElements']) === "function") { 46 if(this.addDelegate && typeof (this.addDelegate['onAddElements']) === "function") {
50 this.addDelegate['onAddElements'].call(this.addDelegate, elements); 47 this.addDelegate['onAddElements'].call(this.addDelegate, elements);
@@ -108,11 +105,6 @@ exports.ElementMediator = Montage.create(Component, {
108 105
109 getProperty: { 106 getProperty: {
110 value: function(el, prop, valueMutator) { 107 value: function(el, prop, valueMutator) {
111 if(!el.elementModel) {
112 console.log("Element has no Model -> One should have been created");
113 this._NJUtils.makeElementModel(el, "Div", "block");
114 }
115
116 if(valueMutator && typeof valueMutator === "function") { 108 if(valueMutator && typeof valueMutator === "function") {
117 return valueMutator(el.elementModel.controller["getProperty"](el, prop)); 109 return valueMutator(el.elementModel.controller["getProperty"](el, prop));
118 } else { 110 } else {
@@ -123,22 +115,12 @@ exports.ElementMediator = Montage.create(Component, {
123 115
124 getShapeProperty: { 116 getShapeProperty: {
125 value: function(el, prop) { 117 value: function(el, prop) {
126 if(!el.elementModel) {
127 console.log("Element has no Model -> One should have been created");
128 this._NJUtils.makeElementModel(el, "Canvas", "block", true);
129 }
130
131 return el.elementModel.controller["getShapeProperty"](el, prop); 118 return el.elementModel.controller["getShapeProperty"](el, prop);
132 } 119 }
133 }, 120 },
134 121
135 setShapeProperty: { 122 setShapeProperty: {
136 value: function(el, prop, value) { 123 value: function(el, prop, value) {
137 if(!el.elementModel) {
138 console.log("Element has no Model -> One should have been created");
139 this._NJUtils.makeElementModel(el, "Canvas", "block", true);
140 }
141
142 return el.elementModel.controller["setShapeProperty"](el, prop, value); 124 return el.elementModel.controller["setShapeProperty"](el, prop, value);
143 } 125 }
144 }, 126 },
@@ -303,9 +285,6 @@ exports.ElementMediator = Montage.create(Component, {
303 // Routines to get/set color 285 // Routines to get/set color
304 getColor: { 286 getColor: {
305 value: function(el, isFill, borderSide) { 287 value: function(el, isFill, borderSide) {
306 if(!el.elementModel) {
307 this._NJUtils.makeModelFromElement(el);
308 }
309 return el.elementModel.controller["getColor"](el, isFill, borderSide); 288 return el.elementModel.controller["getColor"](el, isFill, borderSide);
310 } 289 }
311 }, 290 },
@@ -379,78 +358,76 @@ exports.ElementMediator = Montage.create(Component, {
379 }, 358 },
380 359
381 getStroke: { 360 getStroke: {
382 value: function(el) { 361 value: function(el, strokeProperties) {
383 if(!el.elementModel) { 362 return el.elementModel.controller["getStroke"](el, strokeProperties);
384 this._NJUtils.makeElementModel(el, "Div", "block");
385 }
386 return el.elementModel.controller["getStroke"](el);
387 } 363 }
388 }, 364 },
389 365
390
391 /** 366 /**
392 Set a property change command for an element or array of elements 367 Set stroke/border properties on an element or array of elements
393 @param els: Array of elements. Can contain 1 or more elements 368 @param els: Array of elements. Can contain 1 or more elements
394 @param value: Value to be set. This is the stroke info 369 @param value: Value to be set. This is the stroke info
395 @param eventType: Change/Changing. Will be passed to the dispatched event 370 @param eventType: Change/Changing. Will be passed to the dispatched event
396 @param source: String for the source object making the call 371 @param source: String for the source object making the call
397 @param currentValue *OPTIONAL*: current value array. If not found the current value is calculated 372 @param currentValue *OPTIONAL*: current value array. If not found the current value is calculated
398 @param stageRedraw: *OPTIONAL*: True. If set to false the stage will not redraw the selection/outline
399 */ 373 */
400 setStroke: { 374 setStroke: {
401 value: function(els, value, eventType, source, currentValue) { 375 value: function(els, value, eventType, source, currentValue) {
402 376
403 if(eventType === "Changing") { 377 if(eventType !== "Changing") {
404 this._setStroke(els, value, isFill, eventType, source);
405 } else {
406 // Calculate currentValue if not found for each element 378 // Calculate currentValue if not found for each element
407 if(!currentValue) { 379 if(!currentValue) {
408 var that = this; 380 var that = this,
381 val = value;
409 currentValue = els.map(function(item) { 382 currentValue = els.map(function(item) {
410 return that.getStroke(item); 383 return that.getStroke(item, val);
411 }); 384 });
412 } 385 }
386 document.application.undoManager.add("Set stroke", this.setStroke, this, els, currentValue, eventType, source, value);
387 }
413 388
414 var command = Montage.create(Command, { 389 for(var i=0, item; item = els[i]; i++) {
415 _els: { value: els }, 390 item.elementModel.controller["setStroke"](item, (value[i] || value), eventType, source);
416 _value: { value: value },
417 _previous: { value: currentValue },
418 _eventType: { value: eventType},
419 _source: { value: "undo-redo"},
420 description: { value: "Set Color"},
421 receiver: { value: this},
422
423 execute: {
424 value: function(senderObject) {
425 if(senderObject) this._source = senderObject;
426 this.receiver._setStroke(this._els, this._value, this._eventType, this._source);
427 this._source = "undo-redo";
428 return "";
429 }
430 },
431
432 unexecute: {
433 value: function() {
434 this.receiver._setStroke(this._els, this._previous, this._eventType, this._source);
435 return "";
436 }
437 }
438 });
439
440 NJevent("sendToUndo", command);
441 command.execute(source);
442 } 391 }
443 392
393 NJevent("element" + eventType, {type : "setStroke", source: source, data: {"els": els, "prop": "stroke", "value": value}, redraw: null});
444 } 394 }
445 }, 395 },
446 396
447 _setStroke: { 397 getFill: {
448 value: function(els, value, eventType, source) { 398 value: function(el, fillProperties) {
399 return el.elementModel.controller["getFill"](el, fillProperties);
400 }
401 },
402
403 /**
404 Set fill/background properties for an element or array of elements
405 @param els: Array of elements. Can contain 1 or more elements
406 @param value: Value to be set. This is the fill info
407 @param eventType: Change/Changing. Will be passed to the dispatched event
408 @param source: String for the source object making the call
409 @param currentValue *OPTIONAL*: current value array. If not found the current value is calculated
410 */
411 setFill: {
412 value: function(els, value, eventType, source, currentValue) {
413
414 if(eventType !== "Changing") {
415 // Calculate currentValue if not found for each element
416 if(!currentValue) {
417 var that = this,
418 val = value;
419 currentValue = els.map(function(item) {
420 return that.getFill(item, val);
421 });
422 }
423 document.application.undoManager.add("Set fill", this.setFill, this, els, currentValue, eventType, source, value);
424 }
425
449 for(var i=0, item; item = els[i]; i++) { 426 for(var i=0, item; item = els[i]; i++) {
450 item.elementModel.controller["setStroke"](item, value); 427 item.elementModel.controller["setFill"](item, (value[i] || value));
451 } 428 }
452 429
453 NJevent("element" + eventType, {type : "setStroke", source: source, data: {"els": els, "prop": "stroke", "value": value}, redraw: null}); 430 NJevent("element" + eventType, {type : "setFill", source: source, data: {"els": els, "prop": "fill", "value": value}, redraw: null});
454 } 431 }
455 }, 432 },
456 433
@@ -458,18 +435,12 @@ exports.ElementMediator = Montage.create(Component, {
458 // Routines to get/set 3D properties 435 // Routines to get/set 3D properties
459 get3DProperty: { 436 get3DProperty: {
460 value: function(el, prop) { 437 value: function(el, prop) {
461 if(!el.elementModel) {
462 this._NJUtils.makeModelFromElement(el);
463 }
464 return el.elementModel.controller["get3DProperty"](el, prop); 438 return el.elementModel.controller["get3DProperty"](el, prop);
465 } 439 }
466 }, 440 },
467 441