OSDN Git Service

Merge branch 'v06' of git.sourceforge.jp:/gitroot/pettanr/pettanr into v06
[pettanr/pettanr.git] / app / assets / javascripts / manifest / controller / action / base.js.coffee
index 21263e8..5179037 100644 (file)
@@ -2,13 +2,35 @@ class Manifest.ControllerModule.ActionModule.Base extends ManifestBase.TypeNameA
   \r
   set_default: () ->\r
     super()\r
-    @args.item_name ||= @parent.item_name  # not parent.name. follow singularized name\r
+    @args.item_name ||= Manifest.manifest().singularize(@parent.name)\r
     @args.param_id ||= 'prefix'\r
     \r
   init: () ->\r
     super()\r
+    @action_name = @name\r
+    @alias = @args.alias\r
     @item_name = @args.item_name\r
     @param_id = @args.param_id\r
+    # source manifest of alias manifest\r
+    @original = @args.original\r
+  \r
+  a_arg_names: () ->\r
+    []\r
+  \r
+  b_arg_names: () ->\r
+    ['item_name', 'param_id']\r
+  \r
+  controller: () ->\r
+    @parent\r
+  \r
+  alias_action: () ->\r
+    s = @alias.split('.')\r
+    c = Manifest.manifest().controllers[s[0]]\r
+    c.actions[s[1]]\r
+  \r
+  path_name: () ->\r
+    @parent.name\r
+    #Manifest.manifest().pluralize(@item_name)\r
   \r
   encode_query: (params) ->\r
     q = []\r
@@ -20,8 +42,9 @@ class Manifest.ControllerModule.ActionModule.Base extends ManifestBase.TypeNameA
       ''\r
   \r
   encode_url: (action_name, params) ->\r
-    c = @parent.name\r
-    a = if action_name == 'index' or action_name == 'show'\r
+    controller_name = @path_name()\r
+    c = controller_name\r
+    a = if action_name == 'index' or action_name == 'show' # or action_name == 'destroy' # router does not detect delete method action\r
       ''\r
     else\r
       '/' + action_name\r