client/js/renderer/edge.js
author ymh <ymh.work@gmail.com>
Wed, 03 Jun 2015 13:16:46 +0200
changeset 459 98cae534083d
parent 458 423bdf56d103
child 461 48235ed6b07d
permissions -rw-r--r--
add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
     1
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
     2
define(['jquery', 'underscore', 'requtils', 'renderer/baserepresentation'], function ($, _, requtils, BaseRepresentation) {
293
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
     3
    'use strict';
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
     4
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
     5
    var Utils = requtils.getUtils();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
     6
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
     7
    /* Edge Class Begin */
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
     8
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
     9
    //var Edge = Renderer.Edge = Utils.inherit(Renderer._BaseRepresentation);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    10
    var Edge = Utils.inherit(BaseRepresentation);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    11
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    12
    _(Edge.prototype).extend({
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    13
        _init: function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    14
            this.renderer.edge_layer.activate();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    15
            this.type = "Edge";
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    16
            this.from_representation = this.renderer.getRepresentationByModel(this.model.get("from"));
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    17
            this.to_representation = this.renderer.getRepresentationByModel(this.model.get("to"));
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    18
            this.bundle = this.renderer.addToBundles(this);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    19
            this.line = new paper.Path();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    20
            this.line.add([0,0],[0,0],[0,0]);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    21
            this.line.__representation = this;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    22
            this.line.strokeWidth = this.options.edge_stroke_width;
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    23
            this.arrow_scale = 1;
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    24
            this.arrow = new paper.Path();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    25
            this.arrow.add(
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    26
                    [ 0, 0 ],
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    27
                    [ this.options.edge_arrow_length, this.options.edge_arrow_width / 2 ],
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    28
                    [ 0, this.options.edge_arrow_width ]
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    29
            );
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    30
            this.arrow.pivot = new paper.Point([ this.options.edge_arrow_length / 2, this.options.edge_arrow_width / 2 ]);
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    31
            this.arrow.__representation = this;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    32
            this.text = $('<div class="Rk-Label Rk-Edge-Label">').appendTo(this.renderer.labels_$);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    33
            this.arrow_angle = 0;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    34
            if (this.options.editor_mode) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    35
                var Renderer = requtils.getRenderer();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    36
                this.normal_buttons = [
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    37
                                       new Renderer.EdgeEditButton(this.renderer, null),
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    38
                                       new Renderer.EdgeRemoveButton(this.renderer, null)
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    39
                                       ];
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    40
                this.pending_delete_buttons = [
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    41
                                               new Renderer.EdgeRevertButton(this.renderer, null)
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    42
                                               ];
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    43
                this.all_buttons = this.normal_buttons.concat(this.pending_delete_buttons);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    44
                for (var i = 0; i < this.all_buttons.length; i++) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    45
                    this.all_buttons[i].source_representation = this;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    46
                }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    47
                this.active_buttons = [];
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    48
            } else {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    49
                this.active_buttons = this.all_buttons = [];
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    50
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    51
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    52
            if (this.renderer.minimap) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    53
                this.renderer.minimap.edge_layer.activate();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    54
                this.minimap_line = new paper.Path();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    55
                this.minimap_line.add([0,0],[0,0]);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    56
                this.minimap_line.__representation = this.renderer.minimap.miniframe.__representation;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    57
                this.minimap_line.strokeWidth = 1;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    58
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    59
        },
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    60
        _getStrokeWidth: function() {
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    61
            var thickness = (this.model.has('style') && this.model.get('style').thickness) || 1;
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    62
            return this.options.edge_stroke_width + (thickness-1) * (this.options.edge_stroke_max_width - this.options.edge_stroke_width) / (this.options.edge_stroke_witdh_scale-1);
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    63
        },
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    64
        _getSelectedStrokeWidth: function() {
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    65
            var thickness = (this.model.has('style') && this.model.get('style').thickness) || 1;
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    66
            return this.options.selected_edge_stroke_width + (thickness-1) * (this.options.selected_edge_stroke_max_width - this.options.selected_edge_stroke_width) / (this.options.edge_stroke_witdh_scale-1);
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    67
        },
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    68
        _getArrowScale: function() {
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    69
            var thickness = (this.model.has('style') && this.model.get('style').thickness) || 1;
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    70
            return 1 + (thickness-1) * ((this.options.edge_arrow_max_width / this.options.edge_arrow_width) - 1) / (this.options.edge_stroke_witdh_scale-1);
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    71
        },
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    72
        redraw: function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    73
            var from = this.model.get("from"),
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    74
            to = this.model.get("to");
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    75
            if (!from || !to) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    76
                return;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    77
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    78
            this.from_representation = this.renderer.getRepresentationByModel(from);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    79
            this.to_representation = this.renderer.getRepresentationByModel(to);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    80
            if (typeof this.from_representation === "undefined" || typeof this.to_representation === "undefined") {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    81
                return;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    82
            }
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    83
            var _strokeWidth = this._getStrokeWidth(),
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    84
                _arrow_scale = this._getArrowScale(),
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    85
                _p0a = this.from_representation.paper_coords,
458
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
    86
                _p1a = this.to_representation.paper_coords,
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
    87
                _v = _p1a.subtract(_p0a),
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
    88
                _r = _v.length,
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
    89
                _u = _v.divide(_r),
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
    90
                _ortho = new paper.Point([- _u.y, _u.x]),
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
    91
                _group_pos = this.bundle.getPosition(this),
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
    92
                _delta = _ortho.multiply( this.options.edge_gap_in_bundles * _group_pos ),
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
    93
                _p0b = _p0a.add(_delta), /* Adding a 4 px difference */
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
    94
                _p1b = _p1a.add(_delta), /* to differentiate bundled links */
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
    95
                _a = _v.angle,
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    96
                _textdelta = _ortho.multiply(this.options.edge_label_distance + 0.5 * _arrow_scale * this.options.edge_arrow_width),
458
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
    97
                _handle = _v.divide(3),
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
    98
                _color = (this.model.has("style") && this.model.get("style").color) || (this.model.get("created_by") || Utils._USER_PLACEHOLDER(this.renkan)).get("color"),
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
    99
                _dash = (this.model.has("style") && this.model.get("style").dash) ? this.options.default_dash_array : null,
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
   100
                opacity = 1;
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   101
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   102
            if (this.model.get("delete_scheduled") || this.from_representation.model.get("delete_scheduled") || this.to_representation.model.get("delete_scheduled")) {
293
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
   103
                opacity = 0.5;
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   104
                this.line.dashArray = [2, 2];
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   105
            } else {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   106
                opacity = 1;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   107
                this.line.dashArray = null;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   108
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   109
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   110
            var old_act_btn = this.active_buttons;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   111
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   112
            var array_opacity =
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   113
                (this.model.has("style") && this.model.get("style").arrow) || !this.model.has("style") || (typeof this.model.get("style").arrow === 'undefined') ? opacity : 0;
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   114
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   115
            this.active_buttons = this.model.get("delete_scheduled") ? this.pending_delete_buttons : this.normal_buttons;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   116
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   117
            if (this.selected && this.renderer.isEditable() && old_act_btn !== this.active_buttons) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   118
                old_act_btn.forEach(function(b) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   119
                    b.hide();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   120
                });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   121
                this.active_buttons.forEach(function(b) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   122
                    b.show();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   123
                });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   124
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   125
458
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
   126
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
   127
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   128
            this.paper_coords = _p0b.add(_p1b).divide(2);
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   129
            this.line.strokeWidth = _strokeWidth;
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   130
            this.line.strokeColor = _color;
458
423bdf56d103 migrated to style, added dash style to client + small refactoring for shapes + triangle
ymh <ymh.work@gmail.com>
parents: 434
diff changeset
   131
            this.line.dashArray = _dash;
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   132
            this.line.opacity = opacity;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   133
            this.line.segments[0].point = _p0a;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   134
            this.line.segments[1].point = this.paper_coords;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   135
            this.line.segments[1].handleIn = _handle.multiply(-1);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   136
            this.line.segments[1].handleOut = _handle;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   137
            this.line.segments[2].point = _p1a;
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   138
            this.arrow.scale(_arrow_scale / this.arrow_scale);
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   139
            this.arrow_scale = _arrow_scale;
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   140
            this.arrow.fillColor = _color;
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   141
            this.arrow.opacity = array_opacity;
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   142
            this.arrow.rotate(_a - this.arrow_angle, this.arrow.bounds.center);
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   143
            this.arrow.position = this.paper_coords;
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   144
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   145
            this.arrow_angle = _a;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   146
            if (_a > 90) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   147
                _a -= 180;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   148
                _textdelta = _textdelta.multiply(-1);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   149
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   150
            if (_a < -90) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   151
                _a += 180;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   152
                _textdelta = _textdelta.multiply(-1);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   153
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   154
            var _text = this.model.get("title") || this.renkan.translate(this.options.label_untitled_edges) || "";
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   155
            _text = Utils.shortenText(_text, this.options.node_label_max_length);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   156
            this.text.text(_text);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   157
            var _textpos = this.paper_coords.add(_textdelta);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   158
            this.text.css({
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   159
                left: _textpos.x,
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   160
                top: _textpos.y,
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   161
                transform: "rotate(" + _a + "deg)",
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   162
                "-moz-transform": "rotate(" + _a + "deg)",
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   163
                "-webkit-transform": "rotate(" + _a + "deg)",
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   164
                opacity: opacity
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   165
            });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   166
            this.text_angle = _a;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   167
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   168
            var _pc = this.paper_coords;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   169
            this.all_buttons.forEach(function(b) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   170
                b.moveTo(_pc);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   171
            });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   172
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   173
            if (this.renderer.minimap) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   174
                this.minimap_line.strokeColor = _color;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   175
                this.minimap_line.segments[0].point = this.renderer.toMinimapCoords(new paper.Point(this.from_representation.model.get("position")));
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   176
                this.minimap_line.segments[1].point = this.renderer.toMinimapCoords(new paper.Point(this.to_representation.model.get("position")));
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   177
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   178
        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   179
        openEditor: function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   180
            this.renderer.removeRepresentationsOfType("editor");
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   181
            var _editor = this.renderer.addRepresentation("EdgeEditor",null);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   182
            _editor.source_representation = this;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   183
            _editor.draw();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   184
        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   185
        select: function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   186
            this.selected = true;
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   187
            this.line.strokeWidth = this._getSelectedStrokeWidth();
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   188
            if (this.renderer.isEditable()) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   189
                this.active_buttons.forEach(function(b) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   190
                    b.show();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   191
                });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   192
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   193
            if (!this.options.editor_mode) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   194
                this.openEditor();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   195
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   196
            this._super("select");
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   197
        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   198
        unselect: function(_newTarget) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   199
            if (!_newTarget || _newTarget.source_representation !== this) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   200
                this.selected = false;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   201
                if (this.options.editor_mode) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   202
                    this.all_buttons.forEach(function(b) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   203
                        b.hide();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   204
                    });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   205
                }
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   206
                this.line.strokeWidth = this._getStrokeWidth();
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   207
                this._super("unselect");
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   208
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   209
        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   210
        mousedown: function(_event, _isTouch) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   211
            if (_isTouch) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   212
                this.renderer.unselectAll();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   213
                this.select();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   214
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   215
        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   216
        mouseup: function(_event, _isTouch) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   217
            if (!this.renkan.read_only && this.renderer.is_dragging) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   218
                this.from_representation.saveCoords();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   219
                this.to_representation.saveCoords();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   220
                this.from_representation.is_dragging = false;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   221
                this.to_representation.is_dragging = false;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   222
            } else {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   223
                if (!_isTouch) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   224
                    this.openEditor();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   225
                }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   226
                this.model.trigger("clicked");
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   227
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   228
            this.renderer.click_target = null;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   229
            this.renderer.is_dragging = false;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   230
        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   231
        paperShift: function(_delta) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   232
            if (this.options.editor_mode) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   233
                if (!this.options.read_only) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   234
                    this.from_representation.paperShift(_delta);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   235
                    this.to_representation.paperShift(_delta);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   236
                }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   237
            } else {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   238
                this.renderer.paperShift(_delta);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   239
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   240
        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   241
        destroy: function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   242
            this._super("destroy");
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   243
            this.line.remove();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   244
            this.arrow.remove();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   245
            this.text.remove();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   246
            if (this.renderer.minimap) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   247
                this.minimap_line.remove();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   248
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   249
            this.all_buttons.forEach(function(b) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   250
                b.destroy();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   251
            });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   252
            var _this = this;
433
e457ec945e50 replace underscore par lodash
ymh <ymh.work@gmail.com>
parents: 293
diff changeset
   253
            this.bundle.edges = _.reject(this.bundle.edges, function(_edge) {
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   254
                return _this === _edge;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   255
            });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   256
        }
433
e457ec945e50 replace underscore par lodash
ymh <ymh.work@gmail.com>
parents: 293
diff changeset
   257
    }).value();
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   258
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   259
    return Edge;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   260
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   261
});