client/js/renderer/edge.js
author ymh <ymh.work@gmail.com>
Thu, 04 Jun 2015 13:44:55 +0200
changeset 462 255b66d1ce78
parent 461 48235ed6b07d
child 532 030f2e4c0664
permissions -rw-r--r--
remove magical constant, put ghost opacity in the defaults.
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";
450
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
    16
            this.hidden = false;
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
    17
            this.ghost = false;
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    18
            this.from_representation = this.renderer.getRepresentationByModel(this.model.get("from"));
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    19
            this.to_representation = this.renderer.getRepresentationByModel(this.model.get("to"));
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    20
            this.bundle = this.renderer.addToBundles(this);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    21
            this.line = new paper.Path();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    22
            this.line.add([0,0],[0,0],[0,0]);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    23
            this.line.__representation = this;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    24
            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
    25
            this.arrow_scale = 1;
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    26
            this.arrow = new paper.Path();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    27
            this.arrow.add(
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    28
                    [ 0, 0 ],
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    29
                    [ this.options.edge_arrow_length, this.options.edge_arrow_width / 2 ],
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    30
                    [ 0, this.options.edge_arrow_width ]
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    31
            );
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    32
            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
    33
            this.arrow.__representation = this;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    34
            this.text = $('<div class="Rk-Label Rk-Edge-Label">').appendTo(this.renderer.labels_$);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    35
            this.arrow_angle = 0;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    36
            if (this.options.editor_mode) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    37
                var Renderer = requtils.getRenderer();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    38
                this.normal_buttons = [
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    39
                                       new Renderer.EdgeEditButton(this.renderer, null),
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    40
                                       new Renderer.EdgeRemoveButton(this.renderer, null)
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    41
                                       ];
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    42
                this.pending_delete_buttons = [
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    43
                                               new Renderer.EdgeRevertButton(this.renderer, null)
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    44
                                               ];
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    45
                this.all_buttons = this.normal_buttons.concat(this.pending_delete_buttons);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    46
                for (var i = 0; i < this.all_buttons.length; i++) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    47
                    this.all_buttons[i].source_representation = this;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    48
                }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    49
                this.active_buttons = [];
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    50
            } else {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    51
                this.active_buttons = this.all_buttons = [];
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    52
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    53
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    54
            if (this.renderer.minimap) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    55
                this.renderer.minimap.edge_layer.activate();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    56
                this.minimap_line = new paper.Path();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    57
                this.minimap_line.add([0,0],[0,0]);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    58
                this.minimap_line.__representation = this.renderer.minimap.miniframe.__representation;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    59
                this.minimap_line.strokeWidth = 1;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    60
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    61
        },
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    62
        _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
    63
            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
    64
            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
    65
        },
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    66
        _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
    67
            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
    68
            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
    69
        },
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    70
        _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
    71
            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
    72
            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
    73
        },
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    74
        redraw: function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    75
            var from = this.model.get("from"),
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    76
            to = this.model.get("to");
450
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
    77
            if (!from || !to || (this.hidden && !this.ghost)) {
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    78
                return;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    79
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    80
            this.from_representation = this.renderer.getRepresentationByModel(from);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    81
            this.to_representation = this.renderer.getRepresentationByModel(to);
450
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
    82
            if (typeof this.from_representation === "undefined" || typeof this.to_representation === "undefined" ||
453
04b7d46e9d67 new node's button to show the hidden neighbors
rougeronj
parents: 450
diff changeset
    83
                    (this.from_representation.hidden && !this.from_representation.ghost) ||
461
48235ed6b07d Merge with a3bf10beb710d1cfdda455ab98705f9e7a631739
ymh <ymh.work@gmail.com>
parents: 459 453
diff changeset
    84
                    (this.to_representation.hidden && !this.to_representation.ghost)) {
453
04b7d46e9d67 new node's button to show the hidden neighbors
rougeronj
parents: 450
diff changeset
    85
                this.hide();
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    86
                return;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    87
            }
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
    88
            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
    89
                _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
    90
                _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
    91
                _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
    92
                _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
    93
                _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
    94
                _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
    95
                _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
    96
                _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
    97
                _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
    98
                _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
    99
                _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
   100
                _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
   101
                _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
   102
                _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
   103
                _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
   104
                _dash = (this.model.has("style") && this.model.get("style").dash) ? this.options.default_dash_array : null,
462
255b66d1ce78 remove magical constant, put ghost opacity in the defaults.
ymh <ymh.work@gmail.com>
parents: 461
diff changeset
   105
                _opacity;
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   106
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   107
            if (this.model.get("delete_scheduled") || this.from_representation.model.get("delete_scheduled") || this.to_representation.model.get("delete_scheduled")) {
462
255b66d1ce78 remove magical constant, put ghost opacity in the defaults.
ymh <ymh.work@gmail.com>
parents: 461
diff changeset
   108
                _opacity = 0.5;
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   109
                this.line.dashArray = [2, 2];
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   110
            } else {
462
255b66d1ce78 remove magical constant, put ghost opacity in the defaults.
ymh <ymh.work@gmail.com>
parents: 461
diff changeset
   111
                _opacity = this.ghost ? this.options.ghost_opacity : 1;
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   112
                this.line.dashArray = null;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   113
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   114
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   115
            var old_act_btn = this.active_buttons;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   116
462
255b66d1ce78 remove magical constant, put ghost opacity in the defaults.
ymh <ymh.work@gmail.com>
parents: 461
diff changeset
   117
            this.arrow.visible =
255b66d1ce78 remove magical constant, put ghost opacity in the defaults.
ymh <ymh.work@gmail.com>
parents: 461
diff changeset
   118
                (this.model.has("style") && this.model.get("style").arrow) ||
255b66d1ce78 remove magical constant, put ghost opacity in the defaults.
ymh <ymh.work@gmail.com>
parents: 461
diff changeset
   119
                !this.model.has("style") ||
255b66d1ce78 remove magical constant, put ghost opacity in the defaults.
ymh <ymh.work@gmail.com>
parents: 461
diff changeset
   120
                typeof this.model.get("style").arrow === 'undefined';
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   121
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   122
            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
   123
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   124
            if (this.selected && this.renderer.isEditable() && old_act_btn !== this.active_buttons) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   125
                old_act_btn.forEach(function(b) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   126
                    b.hide();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   127
                });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   128
                this.active_buttons.forEach(function(b) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   129
                    b.show();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   130
                });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   131
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   132
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   133
            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
   134
            this.line.strokeWidth = _strokeWidth;
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   135
            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
   136
            this.line.dashArray = _dash;
462
255b66d1ce78 remove magical constant, put ghost opacity in the defaults.
ymh <ymh.work@gmail.com>
parents: 461
diff changeset
   137
            this.line.opacity = _opacity;
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   138
            this.line.segments[0].point = _p0a;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   139
            this.line.segments[1].point = this.paper_coords;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   140
            this.line.segments[1].handleIn = _handle.multiply(-1);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   141
            this.line.segments[1].handleOut = _handle;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   142
            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
   143
            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
   144
            this.arrow_scale = _arrow_scale;
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   145
            this.arrow.fillColor = _color;
462
255b66d1ce78 remove magical constant, put ghost opacity in the defaults.
ymh <ymh.work@gmail.com>
parents: 461
diff changeset
   146
            this.arrow.opacity = _opacity;
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   147
            this.arrow.rotate(_a - this.arrow_angle, this.arrow.bounds.center);
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   148
            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
   149
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   150
            this.arrow_angle = _a;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   151
            if (_a > 90) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   152
                _a -= 180;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   153
                _textdelta = _textdelta.multiply(-1);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   154
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   155
            if (_a < -90) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   156
                _a += 180;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   157
                _textdelta = _textdelta.multiply(-1);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   158
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   159
            var _text = this.model.get("title") || this.renkan.translate(this.options.label_untitled_edges) || "";
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   160
            _text = Utils.shortenText(_text, this.options.node_label_max_length);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   161
            this.text.text(_text);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   162
            var _textpos = this.paper_coords.add(_textdelta);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   163
            this.text.css({
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   164
                left: _textpos.x,
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   165
                top: _textpos.y,
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   166
                transform: "rotate(" + _a + "deg)",
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   167
                "-moz-transform": "rotate(" + _a + "deg)",
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   168
                "-webkit-transform": "rotate(" + _a + "deg)",
462
255b66d1ce78 remove magical constant, put ghost opacity in the defaults.
ymh <ymh.work@gmail.com>
parents: 461
diff changeset
   169
                opacity: _opacity
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   170
            });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   171
            this.text_angle = _a;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   172
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   173
            var _pc = this.paper_coords;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   174
            this.all_buttons.forEach(function(b) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   175
                b.moveTo(_pc);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   176
            });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   177
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   178
            if (this.renderer.minimap) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   179
                this.minimap_line.strokeColor = _color;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   180
                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
   181
                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
   182
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   183
        },
450
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   184
        hide: function(){
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   185
            this.hidden = true;
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   186
            this.ghost = false;
462
255b66d1ce78 remove magical constant, put ghost opacity in the defaults.
ymh <ymh.work@gmail.com>
parents: 461
diff changeset
   187
450
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   188
            this.text.hide();
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   189
            this.line.visible = false;
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   190
            this.arrow.visible = false;
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   191
            this.minimap_line.visible = false;
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   192
        },
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   193
        show: function(ghost){
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   194
            this.ghost = ghost;
461
48235ed6b07d Merge with a3bf10beb710d1cfdda455ab98705f9e7a631739
ymh <ymh.work@gmail.com>
parents: 459 453
diff changeset
   195
            if (this.ghost) {
450
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   196
                this.text.css('opacity', 0.3);
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   197
                this.line.opacity = 0.3;
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   198
                this.arrow.opacity = 0.3;
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   199
                this.minimap_line.opacity = 0.3;
461
48235ed6b07d Merge with a3bf10beb710d1cfdda455ab98705f9e7a631739
ymh <ymh.work@gmail.com>
parents: 459 453
diff changeset
   200
            } else {
450
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   201
                this.hidden = false;
462
255b66d1ce78 remove magical constant, put ghost opacity in the defaults.
ymh <ymh.work@gmail.com>
parents: 461
diff changeset
   202
450
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   203
                this.text.css('opacity', 1);
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   204
                this.line.opacity = 1;
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   205
                this.arrow.opacity = 1;
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   206
                this.minimap_line.opacity = 1;
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   207
            }
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   208
            this.text.show();
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   209
            this.line.visible = true;
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   210
            this.arrow.visible = true;
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   211
            this.minimap_line.visible = true;
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   212
            this.redraw();
88e8673aaeeb add the hidden/ghost behaviour:
rougeronj
parents: 434
diff changeset
   213
        },
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   214
        openEditor: function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   215
            this.renderer.removeRepresentationsOfType("editor");
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   216
            var _editor = this.renderer.addRepresentation("EdgeEditor",null);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   217
            _editor.source_representation = this;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   218
            _editor.draw();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   219
        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   220
        select: function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   221
            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
   222
            this.line.strokeWidth = this._getSelectedStrokeWidth();
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   223
            if (this.renderer.isEditable()) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   224
                this.active_buttons.forEach(function(b) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   225
                    b.show();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   226
                });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   227
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   228
            if (!this.options.editor_mode) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   229
                this.openEditor();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   230
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   231
            this._super("select");
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   232
        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   233
        unselect: function(_newTarget) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   234
            if (!_newTarget || _newTarget.source_representation !== this) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   235
                this.selected = false;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   236
                if (this.options.editor_mode) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   237
                    this.all_buttons.forEach(function(b) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   238
                        b.hide();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   239
                    });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   240
                }
459
98cae534083d add node and edge stroke width + adjust text + arrow placement + conrol arrow visibility
ymh <ymh.work@gmail.com>
parents: 458
diff changeset
   241
                this.line.strokeWidth = this._getStrokeWidth();
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   242
                this._super("unselect");
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   243
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   244
        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   245
        mousedown: function(_event, _isTouch) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   246
            if (_isTouch) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   247
                this.renderer.unselectAll();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   248
                this.select();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   249
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   250
        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   251
        mouseup: function(_event, _isTouch) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   252
            if (!this.renkan.read_only && this.renderer.is_dragging) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   253
                this.from_representation.saveCoords();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   254
                this.to_representation.saveCoords();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   255
                this.from_representation.is_dragging = false;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   256
                this.to_representation.is_dragging = false;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   257
            } else {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   258
                if (!_isTouch) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   259
                    this.openEditor();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   260
                }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   261
                this.model.trigger("clicked");
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   262
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   263
            this.renderer.click_target = null;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   264
            this.renderer.is_dragging = false;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   265
        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   266
        paperShift: function(_delta) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   267
            if (this.options.editor_mode) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   268
                if (!this.options.read_only) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   269
                    this.from_representation.paperShift(_delta);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   270
                    this.to_representation.paperShift(_delta);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   271
                }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   272
            } else {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   273
                this.renderer.paperShift(_delta);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   274
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   275
        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   276
        destroy: function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   277
            this._super("destroy");
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   278
            this.line.remove();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   279
            this.arrow.remove();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   280
            this.text.remove();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   281
            if (this.renderer.minimap) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   282
                this.minimap_line.remove();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   283
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   284
            this.all_buttons.forEach(function(b) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   285
                b.destroy();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   286
            });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   287
            var _this = this;
433
e457ec945e50 replace underscore par lodash
ymh <ymh.work@gmail.com>
parents: 293
diff changeset
   288
            this.bundle.edges = _.reject(this.bundle.edges, function(_edge) {
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   289
                return _this === _edge;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   290
            });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   291
        }
433
e457ec945e50 replace underscore par lodash
ymh <ymh.work@gmail.com>
parents: 293
diff changeset
   292
    }).value();
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   293
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   294
    return Edge;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   295
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   296
});