OSDN Git Service

fix:pp link
[pettanr/pettanr.git] / app / assets / javascripts / views / panels / body.js.coffee
index 32681bd..9ae783e 100644 (file)
@@ -1,23 +1,22 @@
 # panel: panel item\r
-# operators: operators\r
 # spot: no opacity element\r
-class Pettanr.Views.Panel.Body extends Backbone.View\r
+class Pettanr.Views.Panel.Body extends Pettanr.View\r
   tagName: 'div'\r
-  className: 'pettanr-comic-panel'\r
   \r
   initialize: (options) ->\r
     @panel = options.panel\r
-    @operators = options.operators\r
     @spot = options.spot\r
-    @collect_views()\r
+    @class_name = 'pettanr-comic-panel'\r
+    @views = []\r
+    if @is_visible()\r
+      _.each @panel.zorderd_elements(), (element) =>\r
+        @add_element(element)\r
   \r
   render: () ->\r
+    this.$el.addClass(@class_name)\r
     @restyle()\r
     #this.$el.html('')\r
-    if @is_visible()\r
-      #_.each @views, (view) =>\r
-       #this.$el.append(view.render().el)\r
-    else\r
+    if not @is_visible()\r
       tag = new Tag.Div({\r
         content: I18n.t('panels.hidden'), \r
         class_name: 'hidden'\r
@@ -25,17 +24,12 @@ class Pettanr.Views.Panel.Body extends Backbone.View
       this.$el.html(tag.render().el)\r
     this\r
   \r
-  collect_views: () ->\r
-    @views = []\r
-    _.each @panel.scenario_elements(), (element) =>\r
-      @add_element(element)\r
-  \r
   restyle: () ->\r
     attr = {style: Pettanr.to_style(@style())}\r
     this.$el.attr(attr)\r
   \r
   is_visible: () ->\r
-    @panel.is_visible(@operators)\r
+    @panel.is_visible()\r
   \r
   render_element: (index) ->\r
   \r
@@ -43,11 +37,20 @@ class Pettanr.Views.Panel.Body extends Backbone.View
     index = element.get('z') - 1\r
     c = @element_class(element)\r
     view = new c({element: element, root: @panel, spot: @spot})\r
-    @views[index] = view\r
+    @add_event(view)\r
+    @views.splice(index, 0, view)\r
     if @is_visible()\r
       this.$el.append(view.render().el)\r
     view\r
   \r
+  add_event: (view) ->\r
+    @listenTo(view, 'http_get', @http_get)\r
+  \r
+  remove_element: (element) ->\r
+    _.each @views, (view) =>\r
+      if view.element.cid == element.cid\r
+        view.remove()\r
+  \r
   element_class: (element) ->\r
     Pettanr.Views[element.singular()].Element\r
   \r
@@ -64,6 +67,9 @@ class Pettanr.Views.Panel.Body extends Backbone.View
       'background-color': 'white'\r
     }\r
   \r
+  http_get: (url) ->\r
+    @trigger('http_get', url)\r
+  \r
 class Pettanr.Views.Panel.Body.Edit extends Pettanr.Views.Panel.Body\r
   \r
   initialize: (options) ->\r
@@ -71,6 +77,10 @@ class Pettanr.Views.Panel.Body.Edit extends Pettanr.Views.Panel.Body
     @listenTo(@panel, 'input:width', @restyle)\r
     @listenTo(@panel, 'input:height', @restyle)\r
     @listenTo(@panel, 'input:border', @restyle)\r
+    @listenTo(@panel, 'active', @active)\r
+    @listenTo(@panel, 'inactive', @inactive)\r
+    @listenTo(this, 'active', @active)\r
+    @listenTo(this, 'inactive', @inactive)\r
   \r
   render: () ->\r
     super()\r
@@ -80,39 +90,34 @@ class Pettanr.Views.Panel.Body.Edit extends Pettanr.Views.Panel.Body
         h = parseInt(this.$el.height())\r
         @panel.set({width: w, height: h}, {silent: true})\r
         @panel.trigger('resize')\r
-      , autoHide: true\r
+      , autoHide: false\r
     }\r
+    @inactive()\r
+    _this = this\r
+    this.$el.mouseover -> \r
+      _this.trigger('active')\r
+    this.$el.mouseout -> \r
+      _this.trigger('inactive')\r
     this\r
   \r
   is_visible: () ->\r
     true  # show everytime as editor\r
   \r
-  collect_views: () ->\r
-    @views = []  # elements collect by dock\r
+  active: () ->\r
+    n = @class_name\r
+    $('.ui-resizable-handle', this.el).map ->\r
+      if $(@).parent().hasClass(n)\r
+        $(@).css('display', 'block')\r
+  \r
+  inactive: () ->\r
+    n = @class_name\r
+    $('.ui-resizable-handle', this.el).map ->\r
+      if $(@).parent().hasClass(n)\r
+        $(@).css('display', 'none')\r
   \r
   element_class: (element) ->\r
     Pettanr.Views[element.singular()].Element.Edit\r
   \r
-class Pettanr.Views.Panel.Footer extends Backbone.View\r
-  tagName: 'table'\r
-  className: 'no-border'\r
-  \r
-  initialize: (options) ->\r
-    @panel = options.panel\r
-    @operators = options.operators\r
-  \r
-  render: () ->\r
-    this.$el.html('')\r
-    this.$el.append(\r
-      (new Pettanr.Views.Panel.Icon({item: @panel, half: true})).render().el\r
-    )\r
-    this.$el.append(\r
-      (new Pettanr.Views.Author.Icon({item: @panel.author(), half: true})).render().el\r
-    )\r
-    this.$el.append(Pettanr.AppHelper.distance_of_time_in_words_to_now(@panel.get('updated_at')))\r
-    if @panel.is_own(@operators)\r
-      this.$el.append(\r
-        (new Pettanr.Views.Show.LinkedEditButton({item: @panel})).render().el\r
-      )\r
-    this\r
+  # stop listen link msg\r
+  add_event: (view) ->\r
   \r