OSDN Git Service

Merge branch 'v06' of git.sourceforge.jp:/gitroot/pettanr/pettanr into v06
[pettanr/pettanr.git] / app / assets / javascripts / pettanr / proxy.js.coffee
index 6ed77b5..2ef5195 100644 (file)
@@ -2,26 +2,55 @@ class Pettanr.Proxy
   \r
   constructor: (options) ->\r
     @operators = options.operators\r
+    @gate = options.gate\r
     _.extend(this, Backbone.Events)\r
   \r
   local_router: (parsed_callback) ->\r
     local_router = new Pettanr.LocalRouter({operators: @operators})\r
     @listenTo(local_router, 'go', parsed_callback)\r
-    @listenTo(local_router, 'deny', @deny)\r
-    @listenTo(local_router, 'cancel', @cancel)\r
     local_router\r
   \r
   http_get: (url, form) ->\r
     @local_router(@get).navigate(url, form)\r
   \r
   get: (params, form) ->\r
-    controller = Pettanr.AppController.new2(params, form, @operators)\r
+    return if !@test(params, form)\r
+    return if !@filter(params, form)\r
+    controller = Pettanr.AppController.new2(params, form, @operators, @gate)\r
     @listenTo(controller, 'ready', @ready)\r
     @listenTo(controller, 'title', @title)\r
     @listenTo(controller, 'done', @done)\r
+    @listenTo(controller, 'other', @other)\r
+    @listenTo(controller, 'deny', @remote_folder_deny)\r
+    @listenTo(controller, 'lock', @lock)\r
+    @listenTo(controller, 'unlock', @unlock)\r
     action_name = params['action']\r
     controller[action_name]()\r
   \r
+  test: (params, form) ->\r
+    return true if !@gate\r
+    switch @gate.test()\r
+      when 0\r
+        # free\r
+        true\r
+      when 1\r
+        # agree move\r
+        @gate.unlock()\r
+        true\r
+      else\r
+        # blocking\r
+        # back button event\r
+        Backbone.history.navigate('/' + @gate.url(), {trigger: false})\r
+        @trigger('cancel', params, form)\r
+        false\r
+  \r
+  filter: (params, form) ->\r
+    if safe_url = Pettanr.ActionFilter.test(params, @operators)\r
+      @trigger('deny', params, form, safe_url)\r
+      false\r
+    else\r
+      true\r
+  \r
   ready: (view) ->\r
     @trigger('ready', view)\r
   \r
@@ -31,11 +60,20 @@ class Pettanr.Proxy
   done: (params) ->\r
     @trigger('done', params)\r
   \r
+  other: (url) ->\r
+    @local_router(@get).navigate(url)\r
+  \r
+  lock: (params, form) ->\r
+    @trigger('lock', params, form)\r
+  \r
+  unlock: (params, form) ->\r
+    @trigger('unlock', params, form)\r
+  \r
   deny: (params, form, safe_url) ->\r
     @trigger('deny', params, form, safe_url)\r
   \r
-  cancel: () ->\r
-    @trigger('cancel')\r
+  remote_folder_deny: (params, form, safe_url) ->\r
+    @trigger('deny', params, form, safe_url)\r
   \r
   http_post: (url, form) ->\r
     @local_router(@post).navigate(url, form)\r
@@ -47,6 +85,8 @@ class Pettanr.Proxy
     @listenTo(controller, 'redirect', @redirect)\r
     @listenTo(controller, 'sign_in', @sign_in)\r
     @listenTo(controller, 'sign_out', @sign_out)\r
+    @listenTo(controller, 'lock', @lock)\r
+    @listenTo(controller, 'unlock', @unlock)\r
     action_name = params['action']\r
     controller[action_name]()\r
   \r
@@ -65,3 +105,16 @@ class Pettanr.Proxy
   sign_out: () ->\r
     @trigger('sign_out')\r
   \r
+class Pettanr.PickerProxy extends Pettanr.Proxy\r
+  \r
+  get: (params, form) ->\r
+    if @is_deny(params)\r
+      alert("editor can't open on pick window")\r
+    else\r
+      super(params, form)\r
+  \r
+  is_deny: (params) ->\r
+    c = Pettanr.AppController.controller_by_name(params['controller'])\r
+    return false if !c['is_deny_action_on_picker']\r
+    c.is_deny_action_on_picker(params)\r
+  \r