OSDN Git Service

Merge branch 'v06' of git.sourceforge.jp:/gitroot/pettanr/pettanr into v06
[pettanr/pettanr.git] / app / assets / javascripts / editor / panel_editor.js.coffee
index 0808bad..59e2ba2 100644 (file)
@@ -5,23 +5,75 @@ class Editor.PanelEditor extends Backbone.View
   initialize: (options) ->\r
     @panel = options.root_item\r
     @operators = options.operators\r
-    @body = new Pettanr.Views.Panel.Body({\r
+    @item = @panel\r
+    @dialog = new Editor.PanelEditor.Dialog({\r
+      parent: this, operators: @operators\r
+    })\r
+    @body = new Pettanr.Views.Panel.Body.Edit({\r
       panel: @root_item(),\r
       operators: @operators,\r
       spot: null\r
     })\r
     @dock = new Editor.PanelEditor.Dock({parent: this})\r
-    @credits = new Pettanr.Views.Panel.Show.Credits({panel: @root_item()})\r
+    @credits = new Pettanr.Views.Panel.ShowModule.Credits({pictures: {}})\r
+    \r
+    @body.on('panel:resize', @panel_resize)\r
+    @listenTo(@dock, 'http_post', @http_post)\r
+    @listenTo(@dock, 'add:element', @add_element)\r
+    @listenTo(@dock, 'add:credit', @add_credit)\r
+  \r
+  add_element: (element) ->\r
+    @body.add_element(element)\r
+  \r
+  add_credit: (element) ->\r
+    @credits.add_picture(element.picture())\r
+  \r
+  remove_element: (element) ->\r
+    @body.remove_element(element)\r
   \r
   render: () ->\r
     this.$el.html('')\r
+    this.$el.append(@dialog.render().el)\r
+    @dialog.$el.dialog({\r
+      autoOpen: false,\r
+      width: 750, \r
+      height: 560\r
+    })\r
     this.$el.append(@body.render().el)\r
     this.$el.append(@dock.render().el)\r
     this.$el.append(@credits.render().el)\r
     rb = new Tag.RowBreak()\r
     this.$el.append(rb.render().el)\r
+    @dock.init_tabs()\r
+    @dock.$el.tabs()\r
     this\r
   \r
+  panel_resize: () ->\r
+    my = @body.$el\r
+    w = parseInt(my.width())\r
+    h = parseInt(my.height())\r
+    #$(trace + 'width').val(w)\r
+    #$(trace + 'height').val(h)\r
+  \r
+  quit: () ->\r
+    @dialog.$el.dialog('destroy')\r
+  \r
+  http_post: (url, dock) ->\r
+    @trigger('http_post', url, this)  # send editor\r
+  \r
+  save: () ->\r
+    @listenTo(@panel, 'save:success', @post_success)\r
+    @listenTo(@panel, 'save:fail', @post_fail)\r
+    @panel.save(@dock.save_data())\r
+    false\r
+  \r
+  post_success: (model, response) ->\r
+    Pettanr.History.lock_url = null  # release editor\r
+    @trigger('success', model, response)\r
+  \r
+  post_fail: (model, response) ->\r
+    @trigger('fail', response)\r
+  \r
   root_item: () ->\r
     @panel\r
   \r
@@ -31,3 +83,71 @@ class Editor.PanelEditor extends Backbone.View
   dom_class: () ->\r
     'editor'\r
 \r
+class Editor.PanelEditor.Dialog extends Backbone.View\r
+  tagName: 'div'\r
+  className: 'panel-editor-dialog'\r
+  \r
+  initialize: (options) ->\r
+    @parent = options.parent\r
+    @operators = options.operators\r
+    @target_model = options.target_model\r
+    @history = new Pettanr.Views.History({parent: this})\r
+    @listenTo(@history, 'http_get', @http_get)\r
+    @listenTo(@history, 'get', @get)\r
+  \r
+  start: (@target_model, params, form) ->\r
+    @get(params, form)\r
+  \r
+  stop: () ->\r
+    @dialog().$el.dialog('close')\r
+  \r
+  render: () ->\r
+    this.$el.html('')\r
+    this\r
+  \r
+  refresh: (view) ->\r
+    this.$el.html('')\r
+    this.$el.append(@history.render().el)\r
+    rb = new Tag.RowBreak()\r
+    this.$el.append(rb.render().el)\r
+    this.$el.append(view.el)\r
+  \r
+  getter_proxy: () ->\r
+    proxy = new Pettanr.PickerProxy({operators: @operators})\r
+    @listenTo(proxy, 'ready', @ready)\r
+    @listenTo(proxy, 'title', @title)\r
+    @listenTo(proxy, 'title', @push_history)\r
+    @listenTo(proxy, 'done', @done)\r
+    @listenTo(proxy, 'deny', @deny)\r
+    proxy\r
+  \r
+  http_get: (url, form) ->\r
+    @getter_proxy().http_get(url, form)\r
+  \r
+  get: (params, form) ->\r
+    @getter_proxy().get(params, form)\r
+  \r
+  ready: (view) ->\r
+    @listenTo(view, 'http_get', @http_get)\r
+    # @listenTo(view, 'http_post', @http_post)\r
+    @listenTo(view, 'pick', @pick)\r
+    if view['is_pickable'] and view.is_pickable()\r
+      view.add_pick(@target_model)\r
+    @refresh(view)\r
+    this.$el.dialog('open')\r
+  \r
+  done: (params) ->\r
+  \r
+  deny: (params, form, safe_url) ->\r
+    @getter_proxy().http_get(safe_url, params, form)\r
+  \r
+  push_history: (params, str = null) ->\r
+    @history.push(params, str)\r
+  \r
+  title: (params, str = null) ->\r
+    t = str || I18n.t(params['controller'] + '.' + params['action'] + '.title')\r
+    this.$el.dialog({title: t})\r
+  \r
+  pick: (item) ->\r
+    @trigger('pick', item)\r
+  \r