OSDN Git Service

fix: fetch fail
[pettanr/pettanr.git] / app / assets / javascripts / editor / panel_editor.js.coffee
index e19fa4c..0148b91 100644 (file)
@@ -1,45 +1,55 @@
-class Editor.PanelEditor extends Backbone.View\r
+class Editor.PanelEditor extends Pettanr.View\r
   tagName: 'div'\r
   className: 'panel-editor'\r
   \r
   initialize: (options) ->\r
     @panel = options.root_item\r
-    @operators = options.operators\r
     @item = @panel\r
-    @dialog = new Editor.PanelEditor.Dialog({\r
-      parent: this, operators: @operators\r
-    })\r
+    @dialogs = {}\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.ShowModule.Credits({pictures: {}})\r
+    @credits = new Pettanr.View.Credits(this, {icon: true})\r
     \r
     @body.on('panel:resize', @panel_resize)\r
     @listenTo(@dock, 'http_post', @http_post)\r
+    @listenTo(@dock, 'save:success', @post_success)\r
+    @listenTo(@dock, 'save:fail', @post_fail)\r
+    @listenTo(@dock, 'add:element', @add_element)\r
     @listenTo(@dock, 'add:credit', @add_credit)\r
+    @listenTo(@dock, 'destroy', @destroy)\r
+    @listenTo(@dock, 'dialog:open', @open_dialog)\r
+    @listenTo(@dock, 'dialog:close', @close_dialog)\r
+  \r
+  add_element: (element) ->\r
+    @body.add_element(element)\r
   \r
   add_credit: (element) ->\r
-    @credits.add_picture(element.picture())\r
+    r = {}\r
+    r[element.get('picture_id')] = null\r
+    @credits.push(r)\r
+  \r
+  open_dialog: (dialog) ->\r
+    @dialogs[dialog.cid] = dialog\r
+  \r
+  close_dialog: (dialog) ->\r
+    delete @dialogs[dialog.cid]\r
+    dialog.remove()\r
+  \r
+  destroy: (element, index) ->\r
+    @remove_element(element)\r
   \r
   remove_element: (element) ->\r
-    \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
+    @append_rb()\r
     @dock.init_tabs()\r
     @dock.$el.tabs()\r
     this\r
@@ -52,19 +62,18 @@ class Editor.PanelEditor extends Backbone.View
     #$(trace + 'height').val(h)\r
   \r
   quit: () ->\r
-    @dialog.$el.dialog('destroy')\r
+    @dock.quit()\r
+    _.each @dialogs, (dialog) =>\r
+      @close_dialog(dialog)\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
+    @dock.save()\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
@@ -79,69 +88,3 @@ 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
-  render: () ->\r
-    this.$el.html('')\r
-    @history.render()\r
-    this\r
-  \r
-  refresh: (view) ->\r
-    this.$el.html('')\r
-    this.$el.append(@history.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.Proxy({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, 'lock', @lock)\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
-  \r
-  done: (params) ->\r
-    this.$el.dialog('open')\r
-  \r
-  lock: (params) ->\r
-    console.log('_lock')\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
-    console.log(item)\r
-  \r