client/js/renderer/nodeeditor.js
author rougeronj
Wed, 11 Feb 2015 12:33:19 +0100
changeset 384 6a7930a0d4d1
parent 331 0628ed75e8d3
child 385 29dcaa4c1748
permissions -rw-r--r--
Close #60 - Add a trash icon to delete the image URL
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/baseeditor'], function ($, _, requtils, BaseEditor) {
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
    /* NodeEditor Begin */
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
     8
    //var NodeEditor = Renderer.NodeEditor = Utils.inherit(Renderer._BaseEditor);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
     9
    var NodeEditor = Utils.inherit(BaseEditor);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    10
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    11
    _(NodeEditor.prototype).extend({
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    12
        template: _.template(
293
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    13
                '<h2><span class="Rk-CloseX">&times;</span><%-renkan.translate("Edit Node")%></span></h2>' +
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    14
                '<p><label><%-renkan.translate("Title:")%></label><input class="Rk-Edit-Title" type="text" value="<%-node.title%>"/></p>' +
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    15
                '<% if (options.show_node_editor_uri) { %><p><label><%-renkan.translate("URI:")%></label><input class="Rk-Edit-URI" type="text" value="<%-node.uri%>"/><a class="Rk-Edit-Goto" href="<%-node.uri%>" target="_blank"></a></p><% } %>' +
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    16
                '<% if (options.show_node_editor_description) { %><p><label><%-renkan.translate("Description:")%></label><textarea class="Rk-Edit-Description"><%-node.description%></textarea></p><% } %>' +
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    17
                '<% if (options.show_node_editor_size) { %><p><span class="Rk-Editor-Label"><%-renkan.translate("Size:")%></span><a href="#" class="Rk-Edit-Size-Down">-</a><span class="Rk-Edit-Size-Value"><%-node.size%></span><a href="#" class="Rk-Edit-Size-Up">+</a></p><% } %>' +
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    18
                '<% if (options.show_node_editor_color) { %><div class="Rk-Editor-p"><span class="Rk-Editor-Label"><%-renkan.translate("Node color:")%></span><div class="Rk-Edit-ColorPicker-Wrapper"><span class="Rk-Edit-Color" style="background:<%-node.color%>;"><span class="Rk-Edit-ColorTip"></span></span>' +
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    19
                '<%= renkan.colorPicker %><span class="Rk-Edit-ColorPicker-Text"><%- renkan.translate("Choose color") %></span></div></div><% } %>' +
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    20
                '<% if (options.show_node_editor_image) { %><div class="Rk-Edit-ImgWrap"><div class="Rk-Edit-ImgPreview"><img src="<%-node.image || node.image_placeholder%>" />' +
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    21
                '<% if (node.clip_path) { %><svg xmlns="http://www.w3.org/2000/svg" version="1.1" viewbox="0 0 1 1" preserveAspectRatio="none"><path style="stroke-width: .02; stroke:red; fill-opacity:.3; fill:red;" d="<%- node.clip_path %>"/></svg><% }%>' +
384
6a7930a0d4d1 Close #60 - Add a trash icon to delete the image URL
rougeronj
parents: 331
diff changeset
    22
                '</div></div><p><label><%-renkan.translate("Image URL:")%></label><div><a class="Rk-Edit-Image-Del" href="#"></a><input class="Rk-Edit-Image" type="text" value="<%-node.image%>"/></div></p>' +
293
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    23
                '<p><label><%-renkan.translate("Choose Image File:")%></label><input class="Rk-Edit-Image-File" type="file" accept="image/*"/></p><% } %>' +
330
4f92e61f87ba change shape in node editor
cavaliet
parents: 293
diff changeset
    24
                '<% if (options.show_node_editor_creator && node.has_creator) { %><p><span class="Rk-Editor-Label"><%-renkan.translate("Created by:")%></span> <span class="Rk-UserColor" style="background:<%-node.created_by_color%>;"></span><%- shortenText(node.created_by_title, 25) %></p><% } %>' +
331
0628ed75e8d3 select shape in node editor
cavaliet
parents: 330
diff changeset
    25
                '<% if (options.change_shapes) { %><p><label><%-renkan.translate("Shapes available")%>:</label> <select class="Rk-Edit-Shape">' +
330
4f92e61f87ba change shape in node editor
cavaliet
parents: 293
diff changeset
    26
                '<option class="Rk-Edit-Vocabulary-Property" value="circle"<% if (node.shape === "circle") { %> selected<% } %>><%- renkan.translate("Circle") %></option>' +
4f92e61f87ba change shape in node editor
cavaliet
parents: 293
diff changeset
    27
                '<option class="Rk-Edit-Vocabulary-Property" value="rectangle"<% if (node.shape === "rectangle") { %> selected<% } %>><%- renkan.translate("Square") %></option>' +
4f92e61f87ba change shape in node editor
cavaliet
parents: 293
diff changeset
    28
                '<option class="Rk-Edit-Vocabulary-Property" value="diamond"<% if (node.shape === "diamond") { %> selected<% } %>><%- renkan.translate("Diamond") %></option>' +
4f92e61f87ba change shape in node editor
cavaliet
parents: 293
diff changeset
    29
                '<option class="Rk-Edit-Vocabulary-Property" value="polygon"<% if (node.shape === "polygon") { %> selected<% } %>><%- renkan.translate("Hexagone") %></option>' +
4f92e61f87ba change shape in node editor
cavaliet
parents: 293
diff changeset
    30
                '<option class="Rk-Edit-Vocabulary-Property" value="ellipse"<% if (node.shape === "ellipse") { %> selected<% } %>><%- renkan.translate("Ellipse") %></option>' +
4f92e61f87ba change shape in node editor
cavaliet
parents: 293
diff changeset
    31
                '<option class="Rk-Edit-Vocabulary-Property" value="star"<% if (node.shape === "star") { %> selected<% } %>><%- renkan.translate("Star") %></option>' +
4f92e61f87ba change shape in node editor
cavaliet
parents: 293
diff changeset
    32
                '</select></p><% } %>'
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    33
        ),
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    34
        readOnlyTemplate: _.template(
293
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    35
                '<h2><span class="Rk-CloseX">&times;</span><% if (options.show_node_tooltip_color) { %><span class="Rk-UserColor" style="background:<%-node.color%>;"></span><% } %>' +
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    36
                '<span class="Rk-Display-Title"><% if (node.uri) { %><a href="<%-node.uri%>" target="_blank"><% } %><%-node.title%><% if (node.uri) { %></a><% } %></span></h2>' +
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    37
                '<% if (node.uri && options.show_node_tooltip_uri) { %><p class="Rk-Display-URI"><a href="<%-node.uri%>" target="_blank"><%-node.short_uri%></a></p><% } %>' +
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    38
                '<% if (options.show_node_tooltip_description) { %><p class="Rk-Display-Description"><%-node.description%></p><% } %>' +
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    39
                '<% if (node.image && options.show_node_tooltip_image) { %><img class="Rk-Display-ImgPreview" src="<%-node.image%>" /><% } %>' +
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
    40
                '<% if (node.has_creator && options.show_node_tooltip_creator) { %><p><span class="Rk-Editor-Label"><%-renkan.translate("Created by:")%></span><span class="Rk-UserColor" style="background:<%-node.created_by_color%>;"></span><%- shortenText(node.created_by_title, 25) %></p><% } %>'
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    41
        ),
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    42
        draw: function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    43
            var _model = this.source_representation.model,
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    44
            _created_by = _model.get("created_by") || Utils._USER_PLACEHOLDER(this.renkan),
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    45
            _template = (this.renderer.isEditable() ? this.template : this.readOnlyTemplate ),
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    46
            _image_placeholder = this.options.static_url + "img/image-placeholder.png",
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    47
            _size = (_model.get("size") || 0);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    48
            this.editor_$
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    49
            .html(_template({
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    50
                node: {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    51
                    has_creator: !!_model.get("created_by"),
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    52
                    title: _model.get("title"),
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    53
                    uri: _model.get("uri"),
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    54
                    short_uri:  Utils.shortenText((_model.get("uri") || "").replace(/^(https?:\/\/)?(www\.)?/,'').replace(/\/$/,''),40),
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    55
                    description: _model.get("description"),
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    56
                    image: _model.get("image") || "",
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    57
                    image_placeholder: _image_placeholder,
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    58
                    color: _model.get("color") || _created_by.get("color"),
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    59
                    clip_path: _model.get("clip_path") || false,
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    60
                    created_by_color: _created_by.get("color"),
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    61
                    created_by_title: _created_by.get("title"),
330
4f92e61f87ba change shape in node editor
cavaliet
parents: 293
diff changeset
    62
                    size: (_size > 0 ? "+" : "") + _size,
4f92e61f87ba change shape in node editor
cavaliet
parents: 293
diff changeset
    63
                    shape: _model.get("shape") || "circle"
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    64
                },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    65
                renkan: this.renkan,
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    66
                options: this.options,
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    67
                shortenText: Utils.shortenText
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    68
            }));
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    69
            this.redraw();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    70
            var _this = this,
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    71
            closeEditor = function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    72
                _this.renderer.removeRepresentation(_this);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    73
                paper.view.draw();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    74
            };
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    75
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    76
            this.editor_$.find(".Rk-CloseX").click(closeEditor);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    77
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    78
            this.editor_$.find(".Rk-Edit-Goto").click(function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    79
                if (!_model.get("uri")) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    80
                    return false;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    81
                }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    82
            });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    83
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    84
            if (this.renderer.isEditable()) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    85
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    86
                var onFieldChange = _(function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    87
                    _(function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    88
                        if (_this.renderer.isEditable()) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    89
                            var _data = {
330
4f92e61f87ba change shape in node editor
cavaliet
parents: 293
diff changeset
    90
                                title: _this.editor_$.find(".Rk-Edit-Title").val()
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    91
                            };
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    92
                            if (_this.options.show_node_editor_uri) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    93
                                _data.uri = _this.editor_$.find(".Rk-Edit-URI").val();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    94
                                _this.editor_$.find(".Rk-Edit-Goto").attr("href",_data.uri || "#");
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    95
                            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    96
                            if (_this.options.show_node_editor_image) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    97
                                _data.image = _this.editor_$.find(".Rk-Edit-Image").val();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    98
                                _this.editor_$.find(".Rk-Edit-ImgPreview").attr("src", _data.image || _image_placeholder);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
    99
                            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   100
                            if (_this.options.show_node_editor_description) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   101
                                _data.description = _this.editor_$.find(".Rk-Edit-Description").val();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   102
                            }
330
4f92e61f87ba change shape in node editor
cavaliet
parents: 293
diff changeset
   103
                            if (_this.options.change_shapes) {
331
0628ed75e8d3 select shape in node editor
cavaliet
parents: 330
diff changeset
   104
                                if(_model.get("shape")!==_this.editor_$.find(".Rk-Edit-Shape").val()){
0628ed75e8d3 select shape in node editor
cavaliet
parents: 330
diff changeset
   105
                                    _data.shape = _this.editor_$.find(".Rk-Edit-Shape").val();
0628ed75e8d3 select shape in node editor
cavaliet
parents: 330
diff changeset
   106
                                    _data.shape_changed = true;
0628ed75e8d3 select shape in node editor
cavaliet
parents: 330
diff changeset
   107
                                }
330
4f92e61f87ba change shape in node editor
cavaliet
parents: 293
diff changeset
   108
                            }
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   109
                            _model.set(_data);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   110
                            _this.redraw();
331
0628ed75e8d3 select shape in node editor
cavaliet
parents: 330
diff changeset
   111
                            // For an unknown reason, we have to set data twice when we change shape, otherwise the image disappears.
0628ed75e8d3 select shape in node editor
cavaliet
parents: 330
diff changeset
   112
                            if(_data.shape_changed===true){
0628ed75e8d3 select shape in node editor
cavaliet
parents: 330
diff changeset
   113
                                _model.set(_data);
0628ed75e8d3 select shape in node editor
cavaliet
parents: 330
diff changeset
   114
                            }
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   115
                        } else {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   116
                            closeEditor();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   117
                        }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   118
                    }).defer();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   119
                }).throttle(500);
331
0628ed75e8d3 select shape in node editor
cavaliet
parents: 330
diff changeset
   120
                
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   121
                this.editor_$.on("keyup", function(_e) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   122
                    if (_e.keyCode === 27) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   123
                        closeEditor();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   124
                    }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   125
                });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   126
330
4f92e61f87ba change shape in node editor
cavaliet
parents: 293
diff changeset
   127
                this.editor_$.find("input, textarea, select").on("change keyup paste", onFieldChange);
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   128
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   129
                this.editor_$.find(".Rk-Edit-Image-File").change(function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   130
                    if (this.files.length) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   131
                        var f = this.files[0],
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   132
                        fr = new FileReader();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   133
                        if (f.type.substr(0,5) !== "image") {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   134
                            alert(_this.renkan.translate("This file is not an image"));
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   135
                            return;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   136
                        }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   137
                        if (f.size > (_this.options.uploaded_image_max_kb * 1024)) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   138
                            alert(_this.renkan.translate("Image size must be under ") + _this.options.uploaded_image_max_kb + _this.renkan.translate("KB"));
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   139
                            return;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   140
                        }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   141
                        fr.onload = function(e) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   142
                            _this.editor_$.find(".Rk-Edit-Image").val(e.target.result);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   143
                            onFieldChange();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   144
                        };
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   145
                        fr.readAsDataURL(f);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   146
                    }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   147
                });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   148
                this.editor_$.find(".Rk-Edit-Title")[0].focus();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   149
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   150
                var _picker = _this.editor_$.find(".Rk-Edit-ColorPicker");
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   151
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   152
                this.editor_$.find(".Rk-Edit-ColorPicker-Wrapper").hover(
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   153
                        function(_e) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   154
                            _e.preventDefault();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   155
                            _picker.show();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   156
                        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   157
                        function(_e) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   158
                            _e.preventDefault();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   159
                            _picker.hide();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   160
                        }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   161
                );
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   162
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   163
                _picker.find("li").hover(
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   164
                        function(_e) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   165
                            _e.preventDefault();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   166
                            _this.editor_$.find(".Rk-Edit-Color").css("background", $(this).attr("data-color"));
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   167
                        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   168
                        function(_e) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   169
                            _e.preventDefault();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   170
                            _this.editor_$.find(".Rk-Edit-Color").css("background", _model.get("color") || (_model.get("created_by") || Utils._USER_PLACEHOLDER(_this.renkan)).get("color"));
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   171
                        }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   172
                ).click(function(_e) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   173
                    _e.preventDefault();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   174
                    if (_this.renderer.isEditable()) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   175
                        _model.set("color", $(this).attr("data-color"));
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   176
                        _picker.hide();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   177
                        paper.view.draw();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   178
                    } else {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   179
                        closeEditor();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   180
                    }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   181
                });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   182
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   183
                var shiftSize = function(n) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   184
                    if (_this.renderer.isEditable()) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   185
                        var _newsize = n+(_model.get("size") || 0);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   186
                        _this.editor_$.find(".Rk-Edit-Size-Value").text((_newsize > 0 ? "+" : "") + _newsize);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   187
                        _model.set("size", _newsize);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   188
                        paper.view.draw();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   189
                    } else {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   190
                        closeEditor();
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
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   194
                this.editor_$.find(".Rk-Edit-Size-Down").click(function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   195
                    shiftSize(-1);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   196
                    return false;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   197
                });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   198
                this.editor_$.find(".Rk-Edit-Size-Up").click(function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   199
                    shiftSize(1);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   200
                    return false;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   201
                });
384
6a7930a0d4d1 Close #60 - Add a trash icon to delete the image URL
rougeronj
parents: 331
diff changeset
   202
                
6a7930a0d4d1 Close #60 - Add a trash icon to delete the image URL
rougeronj
parents: 331
diff changeset
   203
                this.editor_$.find(".Rk-Edit-Image-Del").click(function() {
6a7930a0d4d1 Close #60 - Add a trash icon to delete the image URL
rougeronj
parents: 331
diff changeset
   204
                	_this.editor_$.find(".Rk-Edit-Image").val('');
6a7930a0d4d1 Close #60 - Add a trash icon to delete the image URL
rougeronj
parents: 331
diff changeset
   205
                	onFieldChange();
6a7930a0d4d1 Close #60 - Add a trash icon to delete the image URL
rougeronj
parents: 331
diff changeset
   206
                    return false;
6a7930a0d4d1 Close #60 - Add a trash icon to delete the image URL
rougeronj
parents: 331
diff changeset
   207
                });
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   208
            } else {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   209
                if (typeof this.source_representation.highlighted === "object") {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   210
                    var titlehtml = this.source_representation.highlighted.replace(_(_model.get("title")).escape(),'<span class="Rk-Highlighted">$1</span>');
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   211
                    this.editor_$.find(".Rk-Display-Title" + (_model.get("uri") ? " a" : "")).html(titlehtml);
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   212
                    if (this.options.show_node_tooltip_description) {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   213
                        this.editor_$.find(".Rk-Display-Description").html(this.source_representation.highlighted.replace(_(_model.get("description")).escape(),'<span class="Rk-Highlighted">$1</span>'));
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
            }
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   217
            this.editor_$.find("img").load(function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   218
                _this.redraw();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   219
            });
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   220
        },
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   221
        redraw: function() {
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   222
            var _coords = this.source_representation.paper_coords;
293
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
   223
            Utils.drawEditBox(this.options, _coords, this.editor_block, this.source_representation.circle_radius * 0.75, this.editor_$);
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   224
            this.editor_$.show();
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   225
            paper.view.draw();
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
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   229
    /* NodeEditor End */
293
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
   230
284
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   231
    return NodeEditor;
fa8035885814 build renderer with require js
cavaliet
parents:
diff changeset
   232
293
fba23fde14ba Correct jshint errors and force it on build
ymh <ymh.work@gmail.com>
parents: 284
diff changeset
   233
});