OSDN Git Service

t#32066:validate_forms
[pettanr/pettanr.git] / app / views / panels / _form.html.erb
index f99dd66..67217dc 100644 (file)
@@ -1,37 +1,44 @@
-<div id="tabs">
+<% @configurations = configurations %>
+<div id="tabs" class="panel-editor" panel_id="<%= @panel.tag_panel_id -%>" current="1">
   <ul>
-    <li><a href="#tabs-1">panel</a></li>
-    <li><a href="#tabs-2">elements</a></li>
-    <li><a href="#tabs-3">t order</a></li>
-    <li><a href="#tabs-4">z order</a></li>
-    <li><a href="#tabs-5">new</a></li>
+    <li id="tabs-1-tab"><a href="#tabs-1">panel</a></li>
+    <li id="tabs-2-tab"><a href="#tabs-2">elements</a></li>
+    <li id="tabs-3-tab"><a href="#tabs-3">t order</a></li>
+    <li id="tabs-4-tab"><a href="#tabs-4">z order</a></li>
+    <li id="tabs-5-tab"><a href="#tabs-5">new</a></li>
   </ul>
   <div id="tabs-1">
-    <%= form_for(@panel) do |f| %>
+    <%= form_for(@panel, :html => {:id => @panel.tag_id('form'), 'data-form-name' => 'panel'}) do |f| %>
       <%= render 'system/error_explanation', :obj => @panel %>
 
       <div class="field">
-        <%= f.label :caption %><br />
-        <%= f.text_field :caption, :id => @panel.field_tag_id(:caption), :panel_id => @panel.tag_panel_id, :column => :caption, :tree => @panel.field_tree(:caption) -%>
+        <%= f.label :caption %>
+        <%= f.text_field :caption, @panel.field_tag_attributes(:caption, 'data-model' => 'panel') -%>
+      </div>
+      <div class="row_break">
       </div>
       <div class="field">
-        <%= f.label :width %><br />
-        <%= f.number_field :width, :id => @panel.field_tag_id(:width), :panel_id => @panel.tag_panel_id, :column => :width, :tree => @panel.field_tree(:width) %>
+        <%= f.label :width %>
+        <%= f.number_field :width, @panel.field_tag_attributes(:width, :size => 5, 'data-model' => 'panel') %>
       </div>
       <div class="field">
-        <%= f.label :height %><br />
-        <%= f.number_field :height, :id => @panel.field_tag_id(:height), :panel_id => @panel.tag_panel_id, :column => :height, :tree => @panel.field_tree(:height) %>
+        <%= f.label :height %>
+        <%= f.number_field :height, @panel.field_tag_attributes(:height, :size => 5, 'data-model' => 'panel') %>
+      </div>
+      <div class="row_break">
       </div>
       <div class="field">
-        <%= f.label :border %><br />
-        <%= f.number_field :border, :id => @panel.field_tag_id(:border), :panel_id => @panel.tag_panel_id, :column => :border, :tree => @panel.field_tree(:border) %>
+        <%= f.label :border %>
+        <%= f.number_field :border, @panel.field_tag_attributes(:border, :size => 5, 'data-model' => 'panel') %>
       </div>
       <div class="field">
-        <%= f.label :publish %><br />
-        <%= f.collection_select :publish, t_select_items(MagicNumber['panel_visible_items']), :last, :first, {:html => {:selected => @panel.publish}}, {:id => @panel.field_tag_id(:publish), :panel_id => @panel.tag_panel_id, :column => :publish, :tree => @panel.field_tree(:publish)} %>
+        <%= f.label :publish %>
+        <%= f.collection_select :publish, t_select_items(MagicNumber['panel_visible_items']), *@panel.select_tag_attributes(@panel.publish, :publish, 'data-model' => 'panel') %>
+      </div>
+      <div class="row_break">
       </div>
       <% unless @panel.new_record?  %>
-        <%= f.hidden_field :id, :id => @panel.field_tag_id(:id), :panel_id => @panel.tag_panel_id, :column => :id, :tree => @panel.field_tree(:id) %>
+        <%= f.hidden_field :id, @panel.field_tag_attributes(:id, 'data-model' => 'panel') %>
       <% end %>
       <div class="actions">
         <%= f.submit 'panels.submit', :class => "submit" %>
     <div id="elements-tabs">
       <ul>
         <% @panel.panel_elements.each do |elm| %>
-          <li><a href="#elements-tabs-<%= elm.t -%>">
-            <% case elm.class.to_s %>
-            <% when 'PanelPicture' %>
-              <%= tag(:img, elm.tmb_opt_img_tag) %>
-            <% when 'SpeechBalloon' %>
-              <%= h(truncate(elm.speech.content, :length => 6)) %>
-            <% when 'GroundPicture' %>
-              <%= tag(:img, elm.tmb_opt_img_tag) -%>
-            <% when 'GroundColor' %>
-              <div style="color: #<%= format("%06x", elm.code ^ 0xffffff) -%>; background-color: #<%= format("%06x", elm.code) -%>;">
-                <%= format("%06x", elm.code) %>
-              </div>
-            <% end %>
-          </a></li>
+          <%= render 'element_tab', :elm => elm %>
         <% end %>
       </ul>
-        <% @panel.panel_elements.each do |elm| %>
+      <% @panel.panel_elements.each do |elm| %>
+        <div <%= raw elm.tag_attr(:tab_panel) -%>>
           <div id="elements-tabs-<%= elm.t -%>">
-            <% case elm.class.to_s %>
-            <% when 'PanelPicture' %>
-              <%= render 'panel_pictures/form', :panel_picture => elm %>
-            <% when 'SpeechBalloon' %>
-              <% 
-                speech_balloon = elm
-                speech_balloon_template = speech_balloon.speech_balloon_template
-                balloon = speech_balloon.balloon 
-                speech = speech_balloon.speech 
-                speech_balloon.extend speech_balloon_template.engine_speech_balloon_module
-                balloon.extend speech_balloon_template.engine_balloon_module
-                speech.extend speech_balloon_template.engine_speech_module
-                
-                speech_balloon_extend = speech_balloon.extend_speech_balloon
-                balloon_extend = balloon.extend_balloon
-                speech_extend = speech.extend_speech
-              %>
-              <%= render elm.speech_balloon_template.engine_name + '/speech_balloons/form', :speech_balloon => speech_balloon, :balloon => balloon, :speech => speech, :speech_balloon_extend => speech_balloon_extend, :balloon_extend => balloon_extend, :speech_extend => speech_extend %>
-            <% when 'GroundPicture' %>
-              <%= render 'ground_pictures/form', :ground_picture => elm %>
-            <% when 'GroundColor' %>
-              <%= render 'ground_colors/form', :ground_color => elm %>
-            <% end %>
+            <%= render 'element_form', :elm => elm, :no_attr => 0 %>
+            <%= hidden_field_tag '_destroy', '', elm.field_tag_attributes(:_destroy, 0) %>
           </div>
-        <% end %>
+        </div>
+      <% end %>
     </div>
   </div>
   <div id="tabs-3">
     <div class="tsort-box">
-      <ul id="<%= @panel.tag_id -%>tsort" class="tsort" panel_id="<%= @panel.tag_panel_id -%>">
+      <ul class="tsort tsort-tabs-nav" <%= raw @panel.tag_attr(:tsort) -%>>
         <% @panel.panel_elements.each do |elm| %>
-          <li panel_id="<%= elm.tag_panel_id -%>" element_id="<%= elm.tag_element_id -%>" element_type="<%= elm.tag_element_type -%>">
-            <% case elm.class.to_s %>
-            <% when 'PanelPicture' %>
-              <span>
-                <%= tag(:img, elm.tmb_opt_img_tag) %>
-              </span>
-            <% when 'SpeechBalloon' %>
-              <span>
-                <%= elm.id -%>
-                <%= h(truncate(elm.speech.content, :length => 12)) -%>
-              </span>
-            <% when 'GroundPicture' %>
-              <span>
-                <%= tag(:img, elm.tmb_opt_img_tag) -%>
-              </span>
-            <% when 'GroundColor' %>
-              <span style="color: #<%= format("%06x", elm.code ^ 0xffffff) -%>; background-color: #<%= format("%06x", elm.code) -%>;">
-                <%= format("%06x", elm.code ^ 0xffffff) %>
-              </span>
-            <% end %>
-            <span>
-              <%= h(truncate(elm.caption, :length => 12)) %>
-            </span>
+          <li <%= raw elm.tag_attr(:tsort) -%>>
+            <div class="elements-tab">
+              <%= render elm.path_name + '/element_face', :elm => elm %>
+            </div>
           </li>
         <% end %>
       </ul>
     </div>
-    <div id="<%= @panel.tag_id -%>scenario" class="scenario" panel_id="<%= @panel.tag_panel_id -%>">
+    <div class="scenario" <%= raw @panel.tag_attr(:scenario) -%>>
       <% @panel.panel_elements.each do |elm| %>
-        <div panel_id="<%= elm.tag_panel_id -%>" element_id="<%= elm.tag_element_id -%>" element_type="<%= elm.tag_element_type -%>">
-          <% case elm.class.to_s %>
-          <% when 'PanelPicture' %>
-            <%= render 'panel_pictures/scenario', :panel_picture => elm %>
-          <% when 'SpeechBalloon' %>
-            <%= render elm.speech_balloon_template.engine_name + '/speech_balloons/scenario', :speech_balloon => elm %>
-          <% when 'GroundPicture' %>
-            <%= render 'ground_pictures/scenario', :ground_picture => elm %>
-          <% when 'GroundColor' %>
-            <%= render 'ground_colors/scenario', :ground_color => elm %>
-          <% end %>
+        <div <%= raw elm.tag_attr() -%>>
+          <%= render elm.scenario_template, :elm => elm, :no_attr => 0 %>
         </div>
       <% end %>
     </div>
     </div>
   </div>
   <div id="tabs-4">
-    <h2><%= 'z reorder' -%></h2>
-    <table id="z-sortable">
-      <tbody >
-      <% @panel.zorderd_elements.each do |elm| %>
-        <tr panel_id="<%= elm.tag_panel_id -%>" element_id="<%= elm.tag_element_id -%>" element_type="<%= elm.tag_element_type -%>">
-          <% case elm.class.to_s %>
-          <% when 'PanelPicture' %>
-            <td>
-              <%= tag(:img, elm.tmb_opt_img_tag) %>
-            </td>
-          <% when 'SpeechBalloon' %>
-            <td>
-              <%= elm.id -%>
-              <%= elm.caption -%>
-            </td>
-          <% when 'GroundPicture' %>
-            <td>
-              <%= tag(:img, elm.tmb_opt_img_tag) -%>
-            </td>
-          <% when 'GroundColor' %>
-            <td style="color: #<%= format("%06x", elm.code ^ 0xffffff) -%>; background-color: #<%= format("%06x", elm.code) -%>;">
-              <%= format("%06x", elm.code ^ 0xffffff) %>
-            </td>
-          <% end %>
-          <td>
-            <%= h(truncate(elm.caption, :length => 12)) %>
-          </td>
-        </tr>
-      <% end %>
-      </tbody>
-    </table>
+    <div class="zsort-box">
+      <ul class="zsort zsort-tabs-nav" <%= raw @panel.tag_attr(:zsort) -%>>
+        <% @panel.zorderd_elements.each do |elm| %>
+          <li <%= raw elm.tag_attr(:zsort) -%>>
+            <div class="elements-tab">
+              <%= render elm.class.to_s.tableize + '/element_face', :elm => elm %>
+            </div>
+          </li>
+        <% end %>
+      </ul>
+    </div>
   </div>
   <div id="tabs-5">
-    <script>
-    <!--
-      <% SpeechBalloonTemplate.list().each do |sbt| %>
-        var <%= h(sbt.engine_name) %>_settings = <%= raw sbt.parsed_settings.to_json -%>;
+    <div id="new-element-tabs">
+      <ul>
+      <% i = 0 %>
+        <% Panel.each_element_classes do |k| %>
+          <li>
+            <a href="#new-element-tabs-<%= i -%>">
+              <div class="new-element-tab">
+                <%= t_m k.to_s %>
+              </div>
+            </a>
+          </li>
+        <% i += 1 %>
+        <% end %>
+      </ul>
+      <% i = 0 %>
+      <% Panel.each_element_classes do |k| %>
+        <div>
+          <div id="new-element-tabs-<%= i -%>">
+            <% case k.to_s %>
+            <% when 'PanelPicture' %>
+            <% when 'SpeechBalloon' %>
+              <div id="new-speech_balloon-tabs">
+                <ul>
+                  <% SpeechBalloonTemplate.enable_list().each_with_index do |sbt, index| %>
+                    <li>
+                      <a href="#new-speech_balloon-tabs-<%= index -%>">
+                        <div class="new-speech_balloon-tab">
+                          <%= tag(:img, sbt.system_picture.tmb_opt_img_tag) %>
+                          <div>
+                            <%= h(sbt.caption) %>
+                          </div>
+                        </div>
+                      </a>
+                    </li>
+                  <% end %>
+                </ul>
+                <% SpeechBalloonTemplate.enable_list().each_with_index do |sbt, index| %>
+                  <div id="new-speech_balloon-tabs-<%= index -%>">
+                    <% elm = SpeechBalloon.new :panel_id => @panel.id, :speech_balloon_template_id => sbt.id %>
+                    <% 
+                      elm.new_panel = @panel
+                      elm.boost
+                      elm.supply_default
+                      elm.balloon.supply_default 
+                      elm.speech.supply_default 
+                    %>
+                    <%= render elm.form_template, :elm => elm, :no_attr => 1 %>
+                  </div>
+                <% end %>
+            <% when 'GroundPicture' %>
+            <% when 'GroundColor' %>
+              <% elm = GroundColor.new :panel_id => @panel.id %>
+              <% elm.new_panel = @panel ; elm.boost ; elm.supply_default %>
+              <%= render elm.form_template, :elm => elm, :no_attr => 1 %>
+            <% end %>
+          </div>
+        </div>
+        <% i += 1 %>
       <% end %>
-    // -->
-    </script>
-    <% SpeechBalloonTemplate.list().each do |sbt| %>
-      <%= stylesheet_link_tag sbt.engine_name + "/application" %>
-      <%= javascript_include_tag sbt.engine_name + "/application" %>
-    <% end %>
+    </div>
   </div>
 </div>
 <%= form_for(@panel, :html => {:jqform => 'pettanr-panel-form'}) do |f| %>
     <%= submit_tag t('panels.create_from_json'), :id => 'pettanr-panel-submit' -%>
   </div>
 <% end %>
-
-<style>
-<!--
-.tsort {
-    list-style-type: none;
-    margin: 0;
-    padding: 0;
-}
-.tsort li {
-    margin: 0 3px 3px 3px;
-    padding: 0.3em;
-    padding-left: 1em;
-    font-size: 15px;
-    font-weight: bold;
-    cursor: move;
-}
-#z-sortable tr {
-    margin: 0 3px 3px 3px;
-    padding: 0.3em;
-    padding-left: 1em;
-    font-size: 15px;
-    font-weight: bold;
-    cursor: move;
-}
-.ui-slider .ui-slider-handle {
-       width: 1em;
-  height: 1em;
-}
-.ui-slider-horizontal {
-       height: 0.6em;
-}
--->
-</style>
-<script>
-<!--
-var pettanr_current_panel_id = <%= @panel.tag_panel_id -%>;
-
-function confirm_confirm_confirm() {
-  confirm(  );
-};
-function set_tree_value(keys, last_attr, value) {
-  var key = keys.shift();
-  if (keys.length <= 0) {
-    last_attr[key] = value;
-  } else {
-    last_attr[key] = last_attr[key] || {};
-    set_tree_value(keys, last_attr[key], value);
-  }
-};
-// -->
-</script>
+<div id="writing_formats">
+  <% WritingFormat.enable_list().each do |wf| %>
+    <div id="writing_format-<%= wf.id -%>" writing_format_id="<%= wf.id -%>" writing_format_engine_name="<%= wf.engine_name -%>">
+    </div>
+  <% end %>
+</div>
+<div id="speech_balloon_templates">
+  <% SpeechBalloonTemplate.enable_list().each do |sbt| %>
+    <div id="speech_balloon_template-<%= sbt.id -%>" speech_balloon_template_id="<%= sbt.id -%>" engine_name="<%= sbt.engine_name -%>" settings="<%= sbt.parsed_settings.to_json -%>">
+    </div>
+  <% end %>
+</div>
+  <%# text_field_tag "json", '', :id => 'pettanr-configurations' %>