commit for survey questions
This commit is contained in:
		
							parent
							
								
									e45b7e09a0
								
							
						
					
					
						commit
						e4a16eab3a
					
				|  | @ -1,4 +1,4 @@ | ||||||
| $(function() { | function textareaResizable() { | ||||||
| 	var $btnW = null, | 	var $btnW = null, | ||||||
| 		$textareaLangBtnGroup = $('.textarea-lang > .btn-group'), | 		$textareaLangBtnGroup = $('.textarea-lang > .btn-group'), | ||||||
| 		$textareaLang = $('.textarea-lang'), | 		$textareaLang = $('.textarea-lang'), | ||||||
|  | @ -8,12 +8,12 @@ $(function() { | ||||||
| 		$btnW = 4 | 		$btnW = 4 | ||||||
| 		$(this).find('.btn').each(function() { | 		$(this).find('.btn').each(function() { | ||||||
| 			$btnW += $(this).outerWidth(true); | 			$btnW += $(this).outerWidth(true); | ||||||
| 			$(this).on('click', function() { | 			$(this).on(clickEvent, function() { | ||||||
| 				var $id = $($(this).attr('href')); | 				var $id = $($(this).attr('href')); | ||||||
| 				if($id.find('.ui-wrapper').height() < 96) { | 				if($id.find('.ui-wrapper').height() < 96) { | ||||||
| 					$id.find('.ui-wrapper').height(96) | 					$id.find('.ui-wrapper').height(96) | ||||||
| 				} | 				}; | ||||||
| 			}) | 			}); | ||||||
| 		}); | 		}); | ||||||
| 	}); | 	}); | ||||||
| 	$textarea.each(function() { | 	$textarea.each(function() { | ||||||
|  | @ -26,4 +26,7 @@ $(function() { | ||||||
| 		minWidth: $btnW+114, | 		minWidth: $btnW+114, | ||||||
| 		handles: "se", | 		handles: "se", | ||||||
| 	}); | 	}); | ||||||
|  | }; | ||||||
|  | $(function() { | ||||||
|  | 	textareaResizable(); | ||||||
| }); | }); | ||||||
|  | @ -280,6 +280,17 @@ | ||||||
| 	line-height: 26px; | 	line-height: 26px; | ||||||
| 	margin: 0; | 	margin: 0; | ||||||
| } | } | ||||||
|  | .main-forms .attributes-header h4 b { | ||||||
|  | 	padding: 0 1px; | ||||||
|  | 	border-style: dotted; | ||||||
|  | 	border-width: 0 2px; | ||||||
|  | 	border-color: #AAA; | ||||||
|  | 	margin-right: 5px; | ||||||
|  | 	cursor: move; | ||||||
|  | } | ||||||
|  | .main-forms .attributes-header h4 i { | ||||||
|  | 	cursor: pointer; | ||||||
|  | } | ||||||
| .main-forms .field-type { | .main-forms .field-type { | ||||||
| 	background-color: #f5f5f5; | 	background-color: #f5f5f5; | ||||||
| 	border-radius: 5px; | 	border-radius: 5px; | ||||||
|  |  | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							|  | @ -0,0 +1,143 @@ | ||||||
|  | // Check Questions Length
 | ||||||
|  | function checkQuestionsLength() { | ||||||
|  | 	var questionsLength = $('.questions > .attributes').length; | ||||||
|  | 	if(questionsLength == 1) { | ||||||
|  | 		$('.questions .delete').addClass('hide'); | ||||||
|  | 	} else { | ||||||
|  | 		$('.questions .delete').removeClass('hide'); | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // Role Attribute Template Data
 | ||||||
|  | function setData(l, length, optionsI, className) { | ||||||
|  | 	if(!optionsI) { | ||||||
|  | 		optionsI = 0; | ||||||
|  | 	} | ||||||
|  | 	var id = "survey_survey_questions_attributes_", | ||||||
|  | 		name = "survey[survey_questions_attributes][", | ||||||
|  | 		optionID = l+"_survey_question_options_attributes_"+optionsI+"_name_translations_", | ||||||
|  | 		optionName = l+"][survey_question_options_attributes]["+optionsI+"][name_translations]", | ||||||
|  | 		radiogroupsID = l+"_survey_question_radiogroups_attributes_"+optionsI+"_name_translations_", | ||||||
|  | 		radiogroupsName = l+"][survey_question_radiogroups_attributes]["+optionsI+"][name_translations]"; | ||||||
|  | 	data = { | ||||||
|  | 		_l: l, | ||||||
|  | 		_length: length, | ||||||
|  | 		_className: className, | ||||||
|  | 		_destroy: [id+l+"_destroy", name+l+"][_destroy]"], | ||||||
|  | 		_sequence : [id+l+"_sequence",name+l+"][sequence]"], | ||||||
|  | 		_title_translations: [id+l+"_title_translations", name+l+"][title_translations]", "questions_title_"+l], | ||||||
|  | 		_description_translations: [id+l+"_description_translations", name+l+"][description_translations]", "questions_depiction_"+l], | ||||||
|  | 		_type: [id+l+"_type", name+l+"][type]"], | ||||||
|  | 		_is_required: [id+l+"_is_required", name+l+"][is_required]"], | ||||||
|  | 		_option: [id+optionID, name+optionName, "attributes_"+l+"_options_"+optionsI+"_"], | ||||||
|  | 		_radiogroups: [id+radiogroupsID, name+radiogroupsName, "attributes_"+l+"_radiogroups_"+optionsI+"_"], | ||||||
|  | 		_custom_option: [id+l+"_custom_option", name+l+"][custom_option]"] | ||||||
|  | 	}; | ||||||
|  | 	return data; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | function inputAppendLength(element, length) { | ||||||
|  | 	if(length == 2) { | ||||||
|  | 		element.closest('.add-target').find('.remove-input').addClass('hide').prev().addClass('last'); | ||||||
|  | 	} | ||||||
|  | 	element.closest('.input-append').remove(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | $(function() { | ||||||
|  | 	var l = $('.questions > .attributes').length  || 0; | ||||||
|  | 	if($('#survey_redirect_mode').prop('checked')) { | ||||||
|  | 		$('.questions').fadeOut(300); | ||||||
|  | 		$('.redirect-url').fadeIn(300); | ||||||
|  | 	} else { | ||||||
|  | 		$('.questions').fadeIn(300); | ||||||
|  | 		$('.redirect-url').fadeOut(300); | ||||||
|  | 	}; | ||||||
|  | 	$('#survey_redirect_mode').change(function(event) { | ||||||
|  | 		if($(this).prop('checked')) { | ||||||
|  | 			$('.questions').fadeOut(300); | ||||||
|  | 			$('.redirect-url').fadeIn(300); | ||||||
|  | 		} else { | ||||||
|  | 			$('.questions').fadeIn(300); | ||||||
|  | 			$('.redirect-url').fadeOut(300); | ||||||
|  | 		} | ||||||
|  | 	}); | ||||||
|  | 	$('.field-type').each(function() { | ||||||
|  | 		$(this).children('.control-group').each(function() { | ||||||
|  | 			$(this).data().index = $(this).find('.input-append').length | ||||||
|  | 		}); | ||||||
|  | 	}); | ||||||
|  | 	$('.add-target').each(function() { | ||||||
|  | 		if($(this).children('.input-append').length == 1) { | ||||||
|  | 			$(this).find('.remove-input').addClass('hide').prev().addClass('last'); | ||||||
|  | 		}; | ||||||
|  | 	}); | ||||||
|  | 	$('.add-question').on(clickEvent, function(event) { | ||||||
|  | 		$('#template-survery').tmpl(setData(l, $('.questions > .attributes').length + 1)).appendTo($('.questions')); | ||||||
|  | 		checkQuestionsLength(); | ||||||
|  | 		textareaResizable(); // from textarea-lang-btn.js
 | ||||||
|  | 		l += 1; | ||||||
|  | 	}); | ||||||
|  | 
 | ||||||
|  | 	$('.questions').on('change', '.type-selector', function(event) { | ||||||
|  | 		$(this).children("option:selected").each(function () { | ||||||
|  | 			var $fieldType = $(this).closest('.control-group').siblings('.field-type'), | ||||||
|  | 				_val = $(this).val(), | ||||||
|  | 				_index = $(this).closest('.attributes').data().index; | ||||||
|  | 			if(_val < 2) { | ||||||
|  | 				$fieldType.fadeOut(300); | ||||||
|  | 			} else { | ||||||
|  | 				$fieldType.fadeIn(300); | ||||||
|  | 				if(_val < 5) { | ||||||
|  | 					$fieldType.find('.rgl, hr').addClass('hide').siblings('.allow').removeClass('hide'); | ||||||
|  | 				} else { | ||||||
|  | 					$fieldType.find('.rgl, hr').removeClass('hide').siblings('.allow').addClass('hide'); | ||||||
|  | 				} | ||||||
|  | 			}; | ||||||
|  | 		}); | ||||||
|  | 	}); | ||||||
|  | 
 | ||||||
|  | 	$('.questions').on('keyup', '.q-title', function(event) { | ||||||
|  | 		var $questionsTitle = $(this).closest('.attributes-body').siblings('.attributes-header').find('.questions-title'), | ||||||
|  | 			$tabPane = $(this).closest('.tab-content'); | ||||||
|  | 		$questionsTitle.text($tabPane.find('.active input[type="text"]').val()) | ||||||
|  | 		event.preventDefault(); | ||||||
|  | 		/* Act on the event */ | ||||||
|  | 	}); | ||||||
|  | 
 | ||||||
|  | 	$('.questions').on(clickEvent, '.add-btn a, .remove-input, .delete, .attributes-header h4 i, .btn-group .btn', function(event) { | ||||||
|  | 		if($(this).hasClass('remove-input')){ | ||||||
|  | 			inputAppendLength($(this), $(this).closest('.add-target').children('.input-append').length); | ||||||
|  | 		} else if($(this).hasClass('delete')) { | ||||||
|  | 			$(this).closest('.attributes').fadeOut(300, function() { | ||||||
|  | 				$(this).remove(); | ||||||
|  | 				checkQuestionsLength(); | ||||||
|  | 				$('.questions > .attributes').each(function(index, el) { | ||||||
|  | 					$(this).find('h4').find('span').text(index + 1); | ||||||
|  | 				}); | ||||||
|  | 			}); | ||||||
|  | 		} else if($(this).hasClass('icon-caret-up') || $(this).hasClass('icon-caret-down')) { | ||||||
|  | 			if($(this).hasClass('icon-caret-up')) { | ||||||
|  | 				$(this).closest('.attributes-header').siblings('.attributes-body').slideUp(300) | ||||||
|  | 				$(this).addClass('icon-caret-down').removeClass('icon-caret-up'); | ||||||
|  | 			} else { | ||||||
|  | 				$(this).closest('.attributes-header').siblings('.attributes-body').slideDown(300) | ||||||
|  | 				$(this).addClass('icon-caret-up').removeClass('icon-caret-down'); | ||||||
|  | 			} | ||||||
|  | 		} else if($(this).parent().hasClass('btn-group')){ | ||||||
|  | 			var $questionsTitle = $(this).closest('.attributes-body').siblings('.attributes-header').find('.questions-title'), | ||||||
|  | 				$tabPane = $(this).closest('.btn-group').siblings('.tab-content'); | ||||||
|  | 			$questionsTitle.text($tabPane.find('div').not('.active').children('input[type="text"]').val()) | ||||||
|  | 		} else { | ||||||
|  | 			var _i = $('.questions .attributes').length, | ||||||
|  | 				_className = $(this).closest('.control-group').attr('class').match(/options|rgl/g)[0], | ||||||
|  | 				_index = $(this).closest('.attributes').data().index, | ||||||
|  | 				_length = $(this).closest('.add-btn').siblings('.input-append').length; | ||||||
|  | 				console.log(_i) | ||||||
|  | 			$('#template-survery-option').tmpl(setData(_index, "", _i, _className)).insertBefore($(this).closest('.add-btn')); | ||||||
|  | 			$(this).closest('.add-target').find('.input-append').find('.remove-input').removeClass('hide').prev().removeClass('last'); | ||||||
|  | 		} | ||||||
|  | 		event.preventDefault(); | ||||||
|  | 	}); | ||||||
|  | 	checkQuestionsLength(); | ||||||
|  | }); | ||||||
|  | @ -1,102 +1,121 @@ | ||||||
| <% content_for :page_specific_css do %> | <% content_for :page_specific_css do %> | ||||||
|   <%= stylesheet_link_tag "lib/main-forms" %> |   <%= stylesheet_link_tag "lib/main-forms" %> | ||||||
|   <%= stylesheet_link_tag "lib/fileupload" %> |   <%= stylesheet_link_tag "lib/wrap-nav" %> | ||||||
|   <%= stylesheet_link_tag "lib/main-list" %> |   <%= stylesheet_link_tag "lib/main-list" %> | ||||||
| <% end %> | <% end %> | ||||||
| <% content_for :page_specific_javascript do %> | <% content_for :page_specific_javascript do %> | ||||||
|   <%= javascript_include_tag "lib/bootstrap-fileupload" %> |   <%= javascript_include_tag "jquery-ui-custom.js" %> | ||||||
|   <%= javascript_include_tag "lib/bootstrap-datetimepicker" %> |   <%= javascript_include_tag "lib/bootstrap-datetimepicker" %> | ||||||
|   <%= javascript_include_tag "lib/datetimepicker/datetimepicker.js" %> |   <%= javascript_include_tag "lib/datetimepicker/datetimepicker.js" %> | ||||||
|   <%= javascript_include_tag "lib/modal-preview" %> |   <%= javascript_include_tag "lib/member/textarea-lang-btn.js" %> | ||||||
|   <%= javascript_include_tag "lib/file-type" %> |   <%= javascript_include_tag "lib/jquery.tmpl.min.js" %> | ||||||
|  |   <%= javascript_include_tag "survey.js" %> | ||||||
| <% end %> | <% end %> | ||||||
| <%= f.error_messages %> | <%= f.error_messages %> | ||||||
| <fieldset> | <fieldset> | ||||||
|   <div class="input-area"> |   <div class="input-area"> | ||||||
|     <div class="nav-name"><strong><%= t(:module) %></strong></div> |     <div class="attributes"> | ||||||
|      <ul class="nav nav-pills module-nav"> |         <div class="attributes-header clearfix"> | ||||||
|       <li class="active"> |           <h4>Basic</h4> | ||||||
|         <a href="#basic" data-toggle="tab"><%= t(:basic) %></a> |         </div> | ||||||
|       </li> |         <div class="attributes-body"> | ||||||
|       <li> |     </div> | ||||||
|         <a href="#redirect" data-toggle="tab"><%= t('survey.redirect') %></a> |  | ||||||
|       </li> |  | ||||||
|     </ul> |  | ||||||
| 
 | 
 | ||||||
|   <div class="tab-content module-area"> |     <!-- Tiltle --> | ||||||
| 
 |  | ||||||
|   <!-- Basic Module --> |  | ||||||
|     <div class="tab-pane fade in active" id="basic"> |  | ||||||
|       <div class="input-area"> |  | ||||||
|       <div class="control-group"> |       <div class="control-group"> | ||||||
|             <label class="control-label muted"><%= t(:start) %></label> |         <label class="control-label muted" for="">Title</label> | ||||||
|  |         <div class="controls"> | ||||||
|  |           <div class="input-append"> | ||||||
|  |             <div class="tab-content"> | ||||||
|  |                 <% @site_valid_locales.each_with_index do |locale, i| %> | ||||||
|  |                    <div class="tab-pane fade in <%= ( i == 0 ) ? "active" : '' %>" id="title_<%= locale %>"> | ||||||
|  |                     <%= f.fields_for :title_translations do |f| %> | ||||||
|  |                       <%= f.text_field locale, :class=>'span4', :value => (@survey.title_translations[locale] rescue nil), :placeholder => I18nVariable.from_locale(locale) %> | ||||||
|  |                     <% end %> | ||||||
|  |                    </div> | ||||||
|  |                 <% end %> | ||||||
|  |             </div> | ||||||
|  |             <div class="btn-group" data-toggle="buttons-radio"> | ||||||
|  |                <% @site_valid_locales.each_with_index do |locale, i| %> | ||||||
|  |                   <a class="btn <%= ( i == 0 ) ? "active" : '' %>" href="#title_<%= locale %>" data-toggle="tab"><%= I18nVariable.from_locale(locale) %></a> | ||||||
|  |                 <% end %> | ||||||
|  |             </div> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |         <!-- Description --> | ||||||
|  |         <div class="control-group"> | ||||||
|  |           <label class="control-label muted">Description</label> | ||||||
|  |           <div class="controls"> | ||||||
|  |             <div class="tab-content textarea-lang"> | ||||||
|  |               <div class="btn-group" data-toggle="buttons-radio"> | ||||||
|  |                 <% @site_valid_locales.each_with_index do |locale, i| %> | ||||||
|  |                   <a class="btn <%= ( i == 0 ) ? "active" : '' %>" href="#textarea_<%= locale %>_0" data-toggle="tab"><%= I18nVariable.from_locale(locale) %></a> | ||||||
|  |                 <% end %> | ||||||
|  |               </div> | ||||||
|  |               <% @site_valid_locales.each_with_index do |locale, i| %> | ||||||
|  |                  <div class="tab-pane fade in <%= ( i == 0 ) ? "active" : '' %>" id="textarea_<%= locale %>_0"> | ||||||
|  |                   <%= f.fields_for :description_translations do |f| %> | ||||||
|  |                     <%= f.text_area locale, :class=>'resizable', :value => (@survey.description_translations[locale] rescue nil), :placeholder => I18nVariable.from_locale(locale), :rows=>"3" %> | ||||||
|  |                   <% end %> | ||||||
|  |                  </div> | ||||||
|  |               <% end %> | ||||||
|  |             </div> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |         <!-- start date --> | ||||||
|  |         <div class="control-group"> | ||||||
|  |           <label class="control-label muted" for="account">Start Date</label> | ||||||
|           <div class="controls"> |           <div class="controls"> | ||||||
|            <%= f.datetime_picker :postdate, :no_label => true %> |            <%= f.datetime_picker :postdate, :no_label => true %> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
| 
 |         <!-- end date --> | ||||||
|          <div class="control-group"> |          <div class="control-group"> | ||||||
|             <label class="control-label muted"><%= t(:end) %></label> |           <label class="control-label muted" for="account">End Date</label> | ||||||
|           <div class="controls"> |           <div class="controls"> | ||||||
|            <%= f.datetime_picker :deadline, :no_label => true %> |            <%= f.datetime_picker :deadline, :no_label => true %> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|       </div> |          <!-- redirect mode --> | ||||||
|     </div> |  | ||||||
|     <div class="tab-pane fade" id="redirect"> |  | ||||||
|       <div class="input-area"> |  | ||||||
|           <div class="control-group"> |           <div class="control-group"> | ||||||
|           <label class="control-label muted"><%= t('survey.redirect_mode') %></label> |             <label class="control-label muted" for="redirectMode">Redirect Mode</label> | ||||||
|             <div class="controls"> |             <div class="controls"> | ||||||
|  |               <label class="checkbox"> | ||||||
|  |                <!--  <input name="survey[redirect_mode]" type="hidden" value="0" /> | ||||||
|  |                 <input id="survey_redirect_mode" name="survey[redirect_mode]" type="checkbox" value="1" /> --> | ||||||
|                 <%= f.check_box :redirect_mode %> |                 <%= f.check_box :redirect_mode %> | ||||||
|  |                 The surveys is an external link | ||||||
|  |               </label> | ||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|          <div class="control-group"> |           <!-- redirect url --> | ||||||
|           <label class="control-label muted"><%= t('survey.redirect_url') %></label> | 
 | ||||||
|  |           <div class="control-group redirect-url hide"> | ||||||
|  |             <label class="control-label muted" for="survey_redirect_url">Redirect URL</label> | ||||||
|             <div class="controls"> |             <div class="controls"> | ||||||
|               <%= f.text_field :redirect_url %> |                <%= f.text_field :redirect_url, :class=>"input-xlarge", :placeholder=>"Redirect URL" %> | ||||||
|            </div> |  | ||||||
|          </div> |  | ||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
| 
 | 
 | ||||||
|         </div> |         </div> | ||||||
|   <div class="nav-name"><strong>Language</strong></div> |         <!-- questions --> | ||||||
|   <ul class="nav nav-pills language-nav"> |         <div class="questions"> | ||||||
|       <% @site_valid_locales.each_with_index do |locale, i| %> |  | ||||||
|           <li <%= ( i == 0 ) ? "class=active" : '' %>><a data-toggle="tab" href=".<%= locale %>"><%= I18nVariable.from_locale(locale) %></a></li> |  | ||||||
|       <% end %> |  | ||||||
|   </ul> |  | ||||||
|              |              | ||||||
|   <!-- Language --> |  | ||||||
|   <div class="tab-content language-area"> |  | ||||||
|     <% @site_valid_locales.each_with_index do |locale, i| %> |  | ||||||
|       <div class="<%= locale %> fade tab-pane <%= ( i == 0 ) ? "in active" : '' %>"> |  | ||||||
|           <div class="control-group input-title"> |  | ||||||
|               <%= f.label :title , t('survey.question'), :class=>"control-label muted" %> |  | ||||||
|               <div class="controls"> |  | ||||||
|                   <%= f.fields_for :title_translations do |f| %> |  | ||||||
|                       <%= f.text_field locale, :class=>'post-title', :value => (@survey.title_translations[locale] rescue nil) %> |  | ||||||
|                   <% end %> |  | ||||||
|         </div> |         </div> | ||||||
|  | 
 | ||||||
|       </div> |       </div> | ||||||
|           <div class="control-group input-content"> | 
 | ||||||
|               <%= f.label :description ,t('survey.description'), :class => "control-label muted" %> |       <div class="form-actions"> | ||||||
|               <%= f.fields_for :description_translations do |f| %> |         <button type="button" class="btn btn-success add-question">Add Question</button> | ||||||
|                   <div class="controls"> |         <%= f.submit t('save'), :class=>'btn btn-primary' %> | ||||||
|                       <div class="textarea"> |         <%= link_to t('cancel'), get_go_back, :class=>"btn" %>  | ||||||
|                           <%= f.text_area locale, :style=>"width:100%", :class => 'ckeditor input-block-level', :value => (@survey.description_translations[locale] rescue nil) %> |  | ||||||
|                       </div> |  | ||||||
|                   </div> |  | ||||||
|               <% end %> |  | ||||||
|           </div> |  | ||||||
|       </div> |  | ||||||
|     <% end %> |  | ||||||
|   </div> |  | ||||||
|       </div> |       </div> | ||||||
| </fieldset> | </fieldset> | ||||||
| 
 | 
 | ||||||
|  | <%= render :partial => "questions" %> | ||||||
|  | 
 | ||||||
| <div id= "poststuff"> | <div id= "poststuff"> | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -116,7 +135,6 @@ | ||||||
|           </div> |           </div> | ||||||
|           <div id='add_survey_question' class="info_input survey_questions_block"> |           <div id='add_survey_question' class="info_input survey_questions_block"> | ||||||
|             <%= hidden_field_tag 'survey_question_field_count', @survey.survey_questions.count %> |             <%= hidden_field_tag 'survey_question_field_count', @survey.survey_questions.count %> | ||||||
|             <a class="add"><span class="btn btn-primary btn-small"><i class="icon-plus icon-white"></i> <%= t(:add) %> <%= t('survey.question') %></span></a> |  | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|  | @ -124,57 +142,5 @@ | ||||||
| 
 | 
 | ||||||
|     </div> |     </div> | ||||||
| 
 | 
 | ||||||
|     <div class="form-actions"> |  | ||||||
|       <%= hidden_field_tag 'page', params[:page] if !params[:page].blank? %> |  | ||||||
|       <%= f.submit t('submit'), :class=>'btn btn-primary' %> |  | ||||||
|       <%= link_to t('cancel'), get_go_back, :class=>"btn" %>  |  | ||||||
|   </div> |   </div> | ||||||
| 
 | 
 | ||||||
|   </div> |  | ||||||
| 
 |  | ||||||
| </div> |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| <% content_for :page_specific_javascript do %> |  | ||||||
|   <%= javascript_include_tag "survey_form" %> |  | ||||||
|   <script> |  | ||||||
|     var refresh_sequence_input = function() { |  | ||||||
|       var sequence = 0; |  | ||||||
|       $('.sequence input').each(function(){ |  | ||||||
|         sequence += 1; |  | ||||||
|         $(this).val(sequence); |  | ||||||
|       }); |  | ||||||
|     } |  | ||||||
|     $(document).ready(function() { |  | ||||||
|       $('.sequence .move-up').bind('click', function(){ |  | ||||||
|         $survey_question_item = $(this).parents('.survey_question_item') |  | ||||||
|         $prev = $survey_question_item.prev(); |  | ||||||
|         $survey_question_item.insertBefore($prev); |  | ||||||
|         refresh_sequence_input(); |  | ||||||
|         return false; |  | ||||||
|       }); |  | ||||||
| 
 |  | ||||||
|       $('.sequence .move-down').bind('click', function(){ |  | ||||||
|         $survey_question_item = $(this).parents('.survey_question_item') |  | ||||||
|         $next = $survey_question_item.next(); |  | ||||||
|         $survey_question_item.insertAfter($next); |  | ||||||
|         refresh_sequence_input(); |  | ||||||
|         return false; |  | ||||||
|       }); |  | ||||||
|        |  | ||||||
|       refresh_sequence_input(); |  | ||||||
| 
 |  | ||||||
|       $('#add_survey_question a.add').live('click', function(){ |  | ||||||
|         var new_id = $(this).prev().attr('value'); |  | ||||||
|         var old_id = new RegExp("new_survey_questions", "g"); |  | ||||||
|         $(this).prev().attr('value', parseInt(new_id) + 1); |  | ||||||
|         $_new = $(("<%= escape_javascript(add_attribute 'form_survey_question', f, :survey_questions) %>").replace(old_id, new_id)); |  | ||||||
|         $('#survey_questions').append($_new); |  | ||||||
|         $_new.find('a.delete_question').on('click', function(){ |  | ||||||
|           $(this).parents('.survey_question_item').remove(); |  | ||||||
|         }); |  | ||||||
|       }); |  | ||||||
| 
 |  | ||||||
|     }); |  | ||||||
|   </script> |  | ||||||
| <% end %> |  | ||||||
							
								
								
									
										192
									
								
								vendor/built_in_modules/survey/app/views/panel/survey/back_end/surveys/_questions.html.erb
								
								
								
									vendored
								
								
									Normal file
								
							
							
						
						
									
										192
									
								
								vendor/built_in_modules/survey/app/views/panel/survey/back_end/surveys/_questions.html.erb
								
								
								
									vendored
								
								
									Normal file
								
							|  | @ -0,0 +1,192 @@ | ||||||
|  | <script id="template-survery" type="text/x-tmpl"> | ||||||
|  |   <div class="attributes" data-index="${_l}"> | ||||||
|  |     <div class="attributes-header clearfix"> | ||||||
|  |       <a class="btn btn-mini pull-right btn-danger delete" href="#"><i class="icon-trash"></i> Delete</a> | ||||||
|  |       <input class="should_destroy" id="${_destroy[0]}" name="${_destroy[1]}" type="hidden"> | ||||||
|  |        <input id="${_sequence[0]}" name="${_sequence[1]}" type="hidden" value="${_length - 1}"> | ||||||
|  |       <h4><b></b> Q<span>${_length}</span> <i class="icon-caret-up"></i> <span class="questions-title"></span></h4> | ||||||
|  |     </div> | ||||||
|  |     <div class="attributes-body"> | ||||||
|  |       <div class="control-group"> | ||||||
|  |         <label class="control-label muted" for="">Question Title</label> | ||||||
|  |         <div class="controls"> | ||||||
|  |           <div class="input-append"> | ||||||
|  |             <div class="tab-content"> | ||||||
|  |               <div class="tab-pane fade active in" id="${_title_translations[2]+'_en'}"> | ||||||
|  |                 <input class="span4 q-title" id="${_title_translations[0]+'_en'}" name="${_title_translations[1]+'[en]'}" type="text" value="" /> | ||||||
|  |               </div> | ||||||
|  |               <div class="tab-pane fade" id="${_title_translations[2]+'_zh_tw'}"> | ||||||
|  |                 <input class="span4 q-title" id="${_title_translations[0]+'_zh_tw'}" name="${_title_translations[1]+'[zh_tw]'}" type="text" value="" /> | ||||||
|  |               </div> | ||||||
|  |             </div> | ||||||
|  |             <div class="btn-group" data-toggle="buttons-radio"> | ||||||
|  |               <a class="btn active" href="${'#'+_title_translations[2]+'_en'}" data-toggle="tab">English</a> | ||||||
|  |               <a class="btn" href="${'#'+_title_translations[2]+'_zh_tw'}" data-toggle="tab">Chinese</a> | ||||||
|  |             </div> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |       <div class="control-group"> | ||||||
|  |         <label class="control-label muted">Description </label> | ||||||
|  |         <div class="controls"> | ||||||
|  |           <div class="tab-content textarea-lang"> | ||||||
|  |             <div class="btn-group" data-toggle="buttons-radio"> | ||||||
|  |               <a class="btn active" href="${'#'+_description_translations[2]+'_en'}" data-toggle="tab">English</a> | ||||||
|  |               <a class="btn" href="${'#'+_description_translations[2]+'_zh_tw'}" data-toggle="tab">Chinese</a> | ||||||
|  |             </div> | ||||||
|  |             <div class="tab-pane fade active in" id="${_description_translations[2]+'_en'}"> | ||||||
|  |               <textarea class="resizable" id="${_description_translations[0]+'_en'}" name="${_description_translations[1]+'[en]'}" rows="3"></textarea> | ||||||
|  |             </div> | ||||||
|  |             <div class="tab-pane fade" id="${_description_translations[2]+'_zh_tw'}"> | ||||||
|  |               <textarea class="resizable" id="${_description_translations[0]+'_zh_tw'}" name="${_description_translations[1]+'[zh_tw]'}" rows="3"></textarea> | ||||||
|  |             </div> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |       <div class="control-group"> | ||||||
|  |         <label class="control-label muted" for="">Type </label> | ||||||
|  |         <div class="controls"> | ||||||
|  |           <select class="type-selector" id="${_type[0]}" name="${_type[1]}"> | ||||||
|  |             <option value="0">Oneline</option> | ||||||
|  |             <option value="1">Multi-line</option> | ||||||
|  |             <option value="2">Radio</option> | ||||||
|  |             <option value="3">Check</option> | ||||||
|  |             <option value="4">Select</option> | ||||||
|  |             <option value="5">Radio Group</option> | ||||||
|  |           </select> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  | 
 | ||||||
|  |       <div class="field-type" style="display: none"> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |         <div class="control-group rgl"> | ||||||
|  |           <label for="" class="control-label muted">Radio Group Label</label> | ||||||
|  |           <div class="controls add-input"> | ||||||
|  |             <div class="add-target"> | ||||||
|  |               <div class="input-append"> | ||||||
|  |                 <div class="tab-content"> | ||||||
|  |                   <div class="tab-pane fade active in" id="${_radiogroups[2]+'en'}"> | ||||||
|  |                     <input type="text" class="span4" id="${_radiogroups[0]+'en'}" name="${_radiogroups[1]+'[en]'}" /> | ||||||
|  |                   </div> | ||||||
|  |                   <div class="tab-pane fade" id="${_radiogroups[2]+'zh_tw'}"> | ||||||
|  |                     <input type="text" class="span4" id="${_radiogroups[0]+'zh_tw'}" name="${_radiogroups[1]+'[zh_tw]'}" /> | ||||||
|  |                   </div> | ||||||
|  |                 </div> | ||||||
|  |                 <div class="btn-group" data-toggle="buttons-radio"> | ||||||
|  |                   <a class="btn active" href="${'#'+_radiogroups[2]+'en'}" data-toggle="tab">English</a> | ||||||
|  |                   <a class="btn last" href="${'#'+_radiogroups[2]+'zh_tw'}" data-toggle="tab">Chinese</a> | ||||||
|  |                   <a href="#" class="btn remove-input hide"> | ||||||
|  |                     <i class="icon-trash"></i> | ||||||
|  |                   </a> | ||||||
|  |                 </div> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <p class="add-btn"> | ||||||
|  |                 <a href="#" class="btn btn-mini btn-primary"><i class="icons-plus"></i> Add</a> | ||||||
|  |               </p> | ||||||
|  |             </div> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  | 
 | ||||||
|  |         <hr /> | ||||||
|  | 
 | ||||||
|  |         <div class="control-group options"> | ||||||
|  |           <label for="" class="control-label muted">Options List</label> | ||||||
|  |           <div class="controls add-input"> | ||||||
|  |             <div class="add-target"> | ||||||
|  |               <div class="input-append"> | ||||||
|  |                 <div class="tab-content"> | ||||||
|  |                   <div class="tab-pane fade active in" id="${_option[2]+'en'}"> | ||||||
|  |                     <input type="text" class="span4" id="${_option[0]+'en'}" name="${_option[1]+'[en]'}" /> | ||||||
|  |                   </div> | ||||||
|  |                   <div class="tab-pane fade" id="${_option[2]+'zh_tw'}"> | ||||||
|  |                     <input type="text" class="span4" id="${_option[0]+'zh_tw'}" name="${_option[1]+'[zh_tw]'}" /> | ||||||
|  |                   </div> | ||||||
|  |                 </div> | ||||||
|  |                 <div class="btn-group" data-toggle="buttons-radio"> | ||||||
|  |                   <a class="btn active" href="${'#'+_option[2]+'en'}" data-toggle="tab">English</a> | ||||||
|  |                   <a class="btn last" href="${'#'+_option[2]+'zh_tw'}" data-toggle="tab">Chinese</a> | ||||||
|  |                   <a href="#" class="btn remove-input hide"> | ||||||
|  |                     <i class="icon-trash"></i> | ||||||
|  |                   </a> | ||||||
|  |                 </div> | ||||||
|  |               </div> | ||||||
|  | 
 | ||||||
|  |               <p class="add-btn"> | ||||||
|  |                 <a href="#" class="btn btn-mini btn-primary"><i class="icons-plus"></i> Add</a> | ||||||
|  |               </p> | ||||||
|  |             </div> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  | 
 | ||||||
|  |         <div class="control-group allow"> | ||||||
|  |           <div class="controls"> | ||||||
|  |             <label class="checkbox"> | ||||||
|  |               <input name="${_custom_option[1]}" type="hidden" value="0" /> | ||||||
|  |               <input id="${_custom_option[0]}" name="${_custom_option[1]}" type="checkbox" value="1"> | ||||||
|  |               Allow Custom Option | ||||||
|  |             </label> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |       </div> | ||||||
|  | 
 | ||||||
|  |       <div class="control-group"> | ||||||
|  |         <label class="control-label muted" for="redirectMode"></label> | ||||||
|  |         <div class="controls"> | ||||||
|  |           <label class="checkbox"> | ||||||
|  |             <input name="${_is_required[1]}" type="hidden" value="0" /> | ||||||
|  |             <input id="${_is_required[0]}" name="${_is_required[1]}" type="checkbox" value="1"> | ||||||
|  |             Is Required | ||||||
|  |           </label> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  | 
 | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | <script id="template-survery-option" type="text/x-tmpl"> | ||||||
|  | {{if _className == 'rgl'}} | ||||||
|  |   <div class="input-append"> | ||||||
|  |     <div class="tab-content"> | ||||||
|  |       <div class="tab-pane fade active in" id="${_radiogroups[2]+'en'}"> | ||||||
|  |         <input type="text" class="span4" id="${_radiogroups[0]+'en'}" name="${_radiogroups[1]+'[en]'}" /> | ||||||
|  |       </div> | ||||||
|  |       <div class="tab-pane fade" id="${_radiogroups[2]+'zh_tw'}"> | ||||||
|  |         <input type="text" class="span4" id="${_radiogroups[0]+'zh_tw'}" name="${_radiogroups[1]+'[zh_tw]'}" /> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |     <div class="btn-group" data-toggle="buttons-radio"> | ||||||
|  |       <a class="btn active" href="${'#'+_radiogroups[2]+'en'}" data-toggle="tab">English</a> | ||||||
|  |       <a class="btn" href="${'#'+_radiogroups[2]+'zh_tw'}" data-toggle="tab">Chinese</a> | ||||||
|  |       <a href="#" class="btn remove-input"> | ||||||
|  |         <i class="icon-trash"></i> | ||||||
|  |       </a> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | {{else}} | ||||||
|  |   <div class="input-append"> | ||||||
|  |     <div class="tab-content"> | ||||||
|  |       <div class="tab-pane fade active in" id="${_option[2]+'en'}"> | ||||||
|  |         <input type="text" class="span4" id="${_option[0]+'en'}" name="${_option[1]+'[en]'}" /> | ||||||
|  |       </div> | ||||||
|  |       <div class="tab-pane fade" id="${_option[2]+'zh_tw'}"> | ||||||
|  |         <input type="text" class="span4" id="${_option[0]+'zh_tw'}" name="${_option[1]+'[zh_tw]'}" /> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |     <div class="btn-group" data-toggle="buttons-radio"> | ||||||
|  |       <a class="btn active" href="${'#'+_option[2]+'en'}" data-toggle="tab">English</a> | ||||||
|  |       <a class="btn" href="${'#'+_option[2]+'zh_tw'}" data-toggle="tab">Chinese</a> | ||||||
|  |       <a href="#" class="btn remove-input"> | ||||||
|  |         <i class="icon-trash"></i> | ||||||
|  |       </a> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | {{/if}} | ||||||
|  | 
 | ||||||
|  | </script> | ||||||
		Loading…
	
		Reference in New Issue