Merge branch 'master' into various_bugs
Conflicts: config/locales/en.yml config/locales/zh_tw.yml vendor/built_in_modules/announcement/app/views/panel/announcement/back_end/bulletins/_bulletin.html.erb vendor/built_in_modules/personal_patent/app - %BDƻs/views/panel/personal_patent/back_end/writing_patents/_form.html.erb vendor/built_in_modules/personal_patent/app - %BDƻs/views/panel/personal_patent/plugin/writing_patents/_form.html.erb
|  | @ -0,0 +1,22 @@ | |||
| guard 'livereload' do | ||||
|   watch(%r{app/.+\.(erb|haml)}) | ||||
|   watch(%r{app/helpers/.+\.rb}) | ||||
|   watch(%r{public/.+\.(css|js|html)}) | ||||
|   watch(%r{config/locales/.+\.yml}) | ||||
| end | ||||
| 
 | ||||
| guard 'rspec', :version => 2 do | ||||
|   watch(%r{^spec/.+_spec\.rb}) | ||||
|   watch(%r{^lib/(.+)\.rb})     { |m| "spec/lib/#{m[1]}_spec.rb" } | ||||
|   watch('spec/spec_helper.rb') { "spec" } | ||||
| 
 | ||||
|   # Rails example | ||||
|   watch('spec/spec_helper.rb')                       { "spec" } | ||||
|   watch('config/routes.rb')                          { "spec/routing" } | ||||
|   watch('app/controllers/application_controller.rb') { "spec/controllers" } | ||||
|   watch(%r{^spec/.+_spec\.rb}) | ||||
|   watch(%r{^app/(.+)\.rb})                           { |m| "spec/#{m[1]}_spec.rb" } | ||||
|   watch(%r{^lib/(.+)\.rb})                           { |m| "spec/lib/#{m[1]}_spec.rb" } | ||||
|   watch(%r{^app/controllers/(.+)_(controller)\.rb})  { |m| ["spec/routing/#{m[1]}_routing_spec.rb", "spec/#{m[2]}s/#{m[1]}_#{m[2]}_spec.rb", "spec/requests/#{m[1]}_spec.rb"] } | ||||
|   watch(%r{^app/views/(.+)/})                        { |m| "spec/requests/#{m[1]}_spec.rb" } | ||||
| end | ||||
|  | @ -332,9 +332,9 @@ var orbitDesktop = function(dom){ | |||
| 							if(j==0)$group.attr("id",tile.group_id); | ||||
| 							 | ||||
| 							if(tile.data_category == "app") | ||||
| 								$li = $('<li id="'+tile._id+'" class="element '+tile.shape+' hp vp" data-category="'+tile.data_category+'" data-content="'+tile.data_content+'"><span class="tile '+tilecolor+' '+op+'"></span><a href="'+tile.data_content+'" class="appicon"  onclick="return false;"><img src="'+o.iconPath+tile.data_content+'.png" alt="" ></a><h1 class="appname thmtxt">'+tile.title+'</h1></li>'); | ||||
| 								$li = $('<li data-id="'+tile.id+'" class="element '+tile.shape+' hp vp" data-category="'+tile.data_category+'" data-content="'+tile.data_content+'" ><span class="tile '+tilecolor+' '+op+'"></span><a href="'+tile.data_content+'" class="appicon"  onclick="return false;"><img src="'+o.iconPath+tile.data_content+'.png" alt="" ></a><h1 class="appname thmtxt">'+tile.title+'</h1></li>'); | ||||
| 							else | ||||
| 								$li = $('<li id="'+tile._id+'" class="element '+tile.shape+' hp vp" data-category="'+tile.data_category+'" data-content="'+tile.data_content+'"><span class="tile '+tilecolor+' '+op+'"></span><h1 class="appname thmtxt">'+tile.title+'</h1><div class="appholder">Loading...</div></li>'); | ||||
| 								$li = $('<li data-id="'+tile.id+'" class="element '+tile.shape+' hp vp" data-category="'+tile.data_category+'" data-content="'+tile.data_content+'" js-link="'+tile.js[0].url+'" css-link="'+tile.css.url+'"><span class="tile '+tilecolor+' '+op+'"></span><h1 class="appname thmtxt">'+tile.title+'</h1><div class="appholder">Loading...</div></li>'); | ||||
| 								 | ||||
| 							$group.find('.col'+colindex).append($li); | ||||
| 						} | ||||
|  | @ -1557,10 +1557,10 @@ var orbitDesktop = function(dom){ | |||
| 			var widget = $(this); | ||||
| 			if(widget.attr("data-category")=="widget"){ | ||||
| 				var widgename = widget.attr("data-content"); | ||||
| 				$.getScript("/desktop_widgets/"+widgename+"/"+widgename+".js",function(){ | ||||
| 					widget.find("div.appholder").load("/desktop_widgets/"+widgename+"/index.html.erb"); | ||||
| 				$.getScript(widget.attr("js-link"),function(){ | ||||
| 					widget.find("div.appholder").load(widget.attr("data-content")); | ||||
| 				}); | ||||
| 			//	$(this).find("div.appholder").append( $('<link rel="stylesheet" id="dyn_css" type="text/css" />').attr('href', "/desktop_widgets/"+widgename+"/css/"+widgename+".css"));
 | ||||
| 			$(this).find("div.appholder").append( '<link rel="stylesheet" id="dyn_css" href="'+widget.attr("css-link")+'" type="text/css" />') | ||||
| 			} | ||||
| 				 | ||||
| 		}) | ||||
|  | @ -1697,3 +1697,4 @@ orbitDesktop.prototype.currentUsername = "Harry"; | |||
| var uselessfunction = function(){ | ||||
| 	$.post("/desktop/temp_func",{sectionid:"4f83e7bbbd98eb041600001d"}); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -287,36 +287,42 @@ | |||
| 	padding: 0 20px 0 150px !important; | ||||
| 	margin: 20px 0 0; | ||||
| } | ||||
| .user-role .user-info { | ||||
| .role-block .user-info { | ||||
| 	top: 23px; | ||||
| 	margin-left: -135px; | ||||
| 	width: 100px; | ||||
| 	border-right: none; | ||||
| 	box-shadow: none; | ||||
| } | ||||
| .user-role .map-block h4 .gender { | ||||
| .role-block .map-block h4 .gender { | ||||
| 	top: -1px; | ||||
| 	bottom: auto; | ||||
| 	left: -1px; | ||||
| 	right: auto; | ||||
| 	border-radius: 4px 0 0 0; | ||||
| } | ||||
| .user-role .teacher h4 .gender { | ||||
| .role-block .teacher h4 .gender { | ||||
| 	border-color: #186AB6 transparent transparent #186AB6; | ||||
| } | ||||
| .user-role .student h4 .gender { | ||||
| .role-block .student h4 .gender { | ||||
| 	border-color: #F38C08 transparent transparent #F38C08; | ||||
| } | ||||
| .user-role .staff h4 .gender { | ||||
| .role-block .staff h4 .gender { | ||||
| 	border-color: #139E2F transparent transparent #139E2F; | ||||
| } | ||||
| .user-role .tab-content, .user-role .nav-pills { | ||||
| .role-block .tab-content, .role-block .nav-pills { | ||||
| 	float: left; | ||||
| } | ||||
| .user-role .nav-pills { | ||||
| 	margin-left: 10px; | ||||
| .role-block .nav-pills { | ||||
| 	margin-bottom: 0;g | ||||
| } | ||||
| .plural .input-append input, .plural .input-append select, .plural .input-append .uneditable-input { | ||||
| .role-block .nav-pills > li > a { | ||||
| 	margin-top: 0; | ||||
| } | ||||
| /*.role-block .control-group .inline { | ||||
| 	float:  | ||||
| }*/ | ||||
| .plural .input-append input, .plural .input-append select, .plural .input-append .uneditable-input, .unRadius input { | ||||
| 	-webkit-border-radius: 3px; | ||||
| 	-moz-border-radius: 3px; | ||||
| 	border-radius: 3px; | ||||
|  | @ -339,3 +345,7 @@ | |||
| 	-moz-border-radius: 0 3px 3px 0; | ||||
| 	border-radius: 0 3px 3px 0; | ||||
| } | ||||
| .language-swich .tab-pane { | ||||
| 	margin-bottom: 5px; | ||||
| 	margin-right: 10px; | ||||
| } | ||||
|  | @ -81,37 +81,60 @@ | |||
| 	background-color: #5EB92B; | ||||
|     font-size: 9px; | ||||
|     padding: 0px 10px; | ||||
|     border-radius: 8px; | ||||
|     line-height: 16px; | ||||
|     height: 15px; | ||||
|     border-radius: 11px; | ||||
|     line-height: 20px; | ||||
|     height: 19px; | ||||
|     color: #FFF; | ||||
|     width: 38px; | ||||
|     width: 40px; | ||||
|     border: none; | ||||
|     box-shadow: 0px 1px 0px rgba(255, 255, 255, 0.5), 0 0 5px rgba(13, 75, 23, 0.5) inset; | ||||
|     margin-top: 2px; | ||||
|     margin-top: 1px; | ||||
| } | ||||
| 
 | ||||
| /* for mamber role */ | ||||
| 
 | ||||
| .user-role .form-horizontal { | ||||
| .role-block .form-horizontal { | ||||
| 	padding: 20px 10px 10px; | ||||
| 	background-color: #FFF; | ||||
| 	margin-bottom: 0; | ||||
| 	border-radius: 0 0 4px 4px; | ||||
| } | ||||
| .user-role .form-horizontal .control-label { | ||||
| .role-block [class*="type"]  { | ||||
| 	background-color: #F1F1F1; | ||||
| 	padding: 20px 0 10px; | ||||
| 	border-radius: 5px; | ||||
| 	margin: -25px 0 40px; | ||||
| 	/*box-shadow: 0px 1px 3px rgba(100,100,100,.4)*/ | ||||
| } | ||||
| .role-block .form-horizontal .control-label { | ||||
| 	width: 100px; | ||||
| } | ||||
| .user-role .form-horizontal .controls { | ||||
| .role-block .form-horizontal .controls { | ||||
| 	margin-left: 120px; | ||||
| } | ||||
| .user-role .form-horizontal .controls>.input-append { | ||||
| .role-block .form-horizontal .controls>.input-append { | ||||
| 	margin-bottom: 10px; | ||||
| } | ||||
| .user-role .map-block { | ||||
| .role-block .form-horizontal legend .onoff { | ||||
| 	margin-top: 4px; | ||||
| } | ||||
| .role-block .form-horizontal legend .btn-danger { | ||||
| 	margin-right: 20px; | ||||
| } | ||||
| .role-block .form-horizontal legend>.clear { | ||||
| 	margin-right: 150px; | ||||
| 	min-width: 350px; | ||||
| } | ||||
| .role-block .map-block { | ||||
| 	min-width: 440px; | ||||
| } | ||||
| .user-role .map-block legend { | ||||
| .role-block .map-block .form-actions { | ||||
| 	margin: 0; | ||||
| 	padding: 10px 20px; | ||||
| } | ||||
| .role-block .map-block legend { | ||||
| 	font-size: 18px; | ||||
| 	line-height: 25px; | ||||
| } | ||||
| .role-block .map-block legend .nav { | ||||
| 	font-size: 12px; | ||||
| } | ||||
|  |  | |||
|  | @ -1,9 +1,10 @@ | |||
| class Admin::InfosController < ApplicationController | ||||
|    | ||||
|   layout "admin" | ||||
|   layout "new_admin" | ||||
|   before_filter :authenticate_user! | ||||
|   before_filter :is_admin? | ||||
|   before_filter :set_attribute, :only => [:index, :show, :new, :edit] | ||||
|   helper Admin::AttributeValuesViewHelper | ||||
|    | ||||
|   def index | ||||
|     @attributes = Info.all.entries | ||||
|  | @ -32,8 +33,8 @@ class Admin::InfosController < ApplicationController | |||
|    | ||||
|   def update | ||||
|     @attribute = Info.find(params[:id]) | ||||
|     # binding.pry | ||||
|     @attribute.update_attributes(params[:info]) | ||||
|     @attribute.attribute_fields.each{|t| t.destroy if t["to_delete"] == true} | ||||
|     respond_to do |format| | ||||
|       format.html { redirect_to :action => :index } | ||||
|       format.js  { render 'admin/attributes/toggle_enable' } | ||||
|  | @ -47,10 +48,10 @@ class Admin::InfosController < ApplicationController | |||
|   end | ||||
|    | ||||
|   def add_attribute_field | ||||
|     @attribute = Info.find(params[:id]) rescue nil | ||||
|     if !@attribute | ||||
|       @attribute = Info.new | ||||
|     end | ||||
|     attribute = Info.find(params[:info_id]) rescue nil | ||||
|     @attribute_field_counter = attribute.attribute_fields.count | ||||
|     @attribute_field = attribute.attribute_fields.build | ||||
|     @attribute_field.save | ||||
|   end | ||||
|    | ||||
|   protected | ||||
|  |  | |||
|  | @ -33,14 +33,10 @@ class Admin::UsersNewInterfaceController < ApplicationController | |||
|     @student_data = [] | ||||
|     @staff_data = [] | ||||
| 
 | ||||
| 
 | ||||
|     attribute_values = @user.attribute_values.reject{|att_val| | ||||
|       # binding.pry if(att_val.id.to_s == '507fa1295789b52a540000e0') | ||||
|       !att_val.attribute_field.locale and  (att_val.attribute_field.neutral_for != I18n.locale.to_s) | ||||
|     } | ||||
| 
 | ||||
|     attribute_values = @user.attribute_values | ||||
|     attribute_values.each{|att_val| | ||||
|       @profile_data.push({:name => att_val.attribute_field.title,:value =>att_val.get_value_by_locale(I18n.locale)}) if att_val.attribute_field.attribute.key=="profile" rescue false | ||||
|       binding.pry if att_val.id.to_s == '5052dab52b5c49ae9d000006' | ||||
|       @profile_data.push({:name => att_val.attribute_field.title,:value =>att_val.get_value_by_locale(I18n.locale.to_s)}) if att_val.attribute_field.attribute.key=="profile" rescue false | ||||
|     } | ||||
|      | ||||
| 
 | ||||
|  | @ -75,7 +71,6 @@ class Admin::UsersNewInterfaceController < ApplicationController | |||
|   end | ||||
|    | ||||
|   def create | ||||
|     binding.pry | ||||
|     puts params.to_yaml | ||||
|     # attribute_values_key = params[:user].has_key?('new_attribute_values') ? 'new_attribute_values' : 'attribute_values' | ||||
|     # attribute_values = params[:user].delete(attribute_values_key) | ||||
|  | @ -84,6 +79,7 @@ class Admin::UsersNewInterfaceController < ApplicationController | |||
|       #   @user.attribute_values.build(value) | ||||
|       # } | ||||
|     # @user.rebuild_sub_roles_from_attribute_values!(attribute_values) | ||||
|     binding.pry | ||||
|     if @user.save | ||||
|       flash[:notice] = t('create.success.user') | ||||
|       redirect_to :action => :index | ||||
|  |  | |||
|  | @ -103,11 +103,41 @@ class DesktopController< ApplicationController | |||
|   def getgroups | ||||
|     @section = Section.find(params["sectionid"]) | ||||
|     @groups = @section.groups | ||||
|     a = Array.new | ||||
|      | ||||
|     gr = Array.new | ||||
|     @groups.each do |group| | ||||
|       a << group.tiles | ||||
|       a = Array.new | ||||
|       t = group.tiles | ||||
|       t.each do |tile| | ||||
|         data_content = "" | ||||
|         jsfile = [] | ||||
|         cssfile = "" | ||||
|         shape = "w1 h1" | ||||
|         if tile.data_category == "widget" | ||||
|           widge = DesktopWidget.find(tile.desktop_widget_id.to_s) | ||||
|           # data_content = widge.widget_layout.file | ||||
|           data_content = "desktop/widget_layout?id="+tile.desktop_widget_id.to_s | ||||
|           jsfile = widge.javascripts.collect{|js| js.file} | ||||
|           cssfile = widge.css_default.file | ||||
|           shape = widge.shape | ||||
|           title = widge.name | ||||
|         else | ||||
|           data_content = tile.data_content | ||||
|           title = tile.title | ||||
|         end | ||||
|     render :json =>a.to_json | ||||
|         a << {"id"=>tile.id,"data_category"=>tile.data_category,"data_content"=>data_content,"js"=>jsfile,"css"=>cssfile,"shape"=>shape,"position"=>tile.position,"title"=>title} | ||||
|       end | ||||
|       gr << a | ||||
|     end | ||||
|     render :json =>gr.to_json | ||||
|   end | ||||
| 
 | ||||
|   def widget_layout | ||||
|     widget = DesktopWidget.find(params[:id]) | ||||
|     link = '<link href="'+widget.css_default.file.to_s+'" media="screen" rel="stylesheet" type="text/css" />' | ||||
|     content = widget.widget_layout.body | ||||
|     dhtml = link + content | ||||
|     render :text => dhtml.html_safe | ||||
|   end | ||||
|    | ||||
|   def getsectionlist | ||||
|  |  | |||
|  | @ -8,6 +8,7 @@ class DesktopPublicationsController< ApplicationController | |||
|   	end | ||||
|    | ||||
|   	def journal_p_add | ||||
|       debugger | ||||
|     	render "desktop/journal_pages/add", :layout => false | ||||
|   	end | ||||
| 
 | ||||
|  |  | |||
|  | @ -0,0 +1,62 @@ | |||
| class DesktopWidgetsController < OrbitBackendController | ||||
| 	require "net/http" | ||||
| 	require "uri" | ||||
|   	require 'zip/zip' | ||||
| 
 | ||||
| 	def index | ||||
| 	end | ||||
| 
 | ||||
| 	def upload | ||||
| 	if !params[:desktop_widget].nil? | ||||
| 	    temp_file = Tempfile.new("temp_file") | ||||
| 	    original_file = params[:desktop_widget][:package_file] | ||||
| 	      #if original_file.content_type == 'application/zip' | ||||
| 	        temp_file.write(original_file.read.force_encoding('UTF-8')) | ||||
| 	        temp_file.rewind | ||||
| 	        filename = File.basename(original_file.original_filename,".zip") | ||||
| 	        unzip_widget(temp_file, filename) | ||||
| 	      #else | ||||
| 	      #  flash[:error] = "Upload file should be in zip format" | ||||
| 	      #end | ||||
| 	      temp_file.close | ||||
| 	 end | ||||
| 	end | ||||
| 
 | ||||
| 	def unzip_widget(file, zip_name) | ||||
| 	    Zip::ZipFile.open(file) { |zip_file| | ||||
| 	      dw = DesktopWidget.new.from_json(zip_file.read("#{zip_name}/settings.json")) | ||||
| 	      Dir.mktmpdir('f_path') { |dir| | ||||
| 	        javascripts_entries = [] | ||||
| 	        images_entries = [] | ||||
| 
 | ||||
| 	        zip_file.entries.each do |entry| | ||||
| 	          case (path = entry.to_s) | ||||
| 	            when /\A(#{zip_name})\/(default\.css)\z/ | ||||
| 	                #for default css | ||||
| 	              dw.build_css_default(:file => get_temp_file(zip_file, dir, entry)) | ||||
| 	            when /\A(#{zip_name})\/(widget\.html)\z/    #for layout html | ||||
| 	              dw.build_widget_layout(:file => get_temp_file(zip_file, dir, entry)) | ||||
| 	            when /\A(#{zip_name})\/(javascripts)\/.*(\.js)\z/   #for js | ||||
| 	              javascripts_entries << entry | ||||
| 	            when /\A(#{zip_name})\/(images)\/.*((\.jpg)|(\.png)|(\.gif))\z/   #for img | ||||
| 	              images_entries << entry | ||||
| 	          end | ||||
| 	        end | ||||
| 
 | ||||
| 	        ['javascripts', 'images'].each do |type| | ||||
| 	          eval("#{type}_entries").each do |entry| | ||||
| 	            eval("dw.#{type}").build(:file => get_temp_file(zip_file, dir, entry)) | ||||
| 	          end | ||||
| 	        end | ||||
| 	      } | ||||
| 	      dw.save | ||||
| 	    } | ||||
|   end | ||||
|   def get_temp_file(zip_file, dir, entry) | ||||
|     filename = File.basename(entry.to_s) | ||||
|     temp_file = File.new(dir + '/' + filename, 'w+')  | ||||
|     temp_file.write (zip_file.read entry ).force_encoding('UTF-8') | ||||
|     temp_file | ||||
|   end | ||||
| 	 | ||||
| end | ||||
|  | @ -1,4 +1,4 @@ | |||
| class OtheraccountsController< ApplicationController | ||||
| class Desktop::OtheraccountsController< ApplicationController | ||||
|   require 'open-uri' | ||||
|   require 'rexml/document' | ||||
|   require 'net/http'  | ||||
|  |  | |||
|  | @ -0,0 +1,16 @@ | |||
| module Admin::AttributeValuesViewHelper | ||||
|   OPT = [ | ||||
|     ["YYYY / MM / DD hh : mm","format1"], | ||||
|     ["YYYY / MM / DD","format2"], | ||||
|     ["YYYY / MM","format3"], | ||||
|     ["YYYY","format4"] | ||||
|   ] | ||||
|   def show_type_panel(attribute_field,type) | ||||
|     markup = attribute_field.markup | ||||
|     LIST[:markups][markup]["panel"] == type ? type  : [type,'hide'].join(" ")  | ||||
|   end | ||||
| 
 | ||||
|   def name_to_id(str) | ||||
|     str.gsub(/\]/,'').gsub(/\[/,"_") | ||||
|   end | ||||
| end | ||||
|  | @ -9,14 +9,18 @@ module AttributeFieldsHelper | |||
|   include ActionView::Helpers::RenderingHelper | ||||
| 
 | ||||
|   def block_helper(user,index,disable = false) | ||||
|     unless self.disabled | ||||
|       @index = index | ||||
|     @markup_options = markup_options.merge(:disabled=>disable) | ||||
|       @markup_options = markup_options.merge(:disabled=>disable,:func=>"input_unit") | ||||
|       @user = user | ||||
|       @attribute_value = @user.get_value_from_field_id(id) | ||||
|       @new_attribute = @attribute_value.nil?   | ||||
|     @attribute_value = @attribute_value || @user.attribute_values.build(attribute_field_id: id) | ||||
|     @prefiled_value = @attribute_value.get_values | ||||
|       @attribute_value = @attribute_value || @user.attribute_values.build( attribute_field_id: id ) | ||||
|       @prefiled_value = @attribute_value.value | ||||
|       @panel_setting = self.get_data | ||||
|       return instance_eval("render_#{markup}") #rescue "" | ||||
| 
 | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   def lang_tab(str,lang) | ||||
|  | @ -24,6 +28,7 @@ module AttributeFieldsHelper | |||
|   end | ||||
| 
 | ||||
|   def render_address | ||||
|     #NP | ||||
|     control_group_wrapper do |key,value| | ||||
|       result = '<div class="input-append">'.html_safe | ||||
| 
 | ||||
|  | @ -44,17 +49,26 @@ module AttributeFieldsHelper | |||
|   end | ||||
| 
 | ||||
|   def render_checkbox | ||||
|      | ||||
|      @prefiled_value ||=[] | ||||
|     markup_value = eval(self.markup_value) rescue {} | ||||
|     # begin  | ||||
|     #   markup_value = eval(self.markup_value)  | ||||
|     # rescue | ||||
|     #   markup_value  = self.markup_value | ||||
|     # ensure | ||||
|     #   markup_value ||= {} | ||||
|     # end | ||||
| 
 | ||||
|     control_group_wrapper do  | ||||
|       markup_value.collect do |key,value| | ||||
|         label_tag(key,check_box_tag(get_field_name_base+"[value][#{key}]", value[I18n.locale.to_s],  (@prefiled_value.include?(key) ? true : false), {})+value[I18n.locale.to_s],@markup_options.merge(:class=>"control-label")) | ||||
|       a = self[:option_list].collect do |key,value| | ||||
|         label_tag(key,check_box_tag(get_field_name_base+"[#{key}]", true ,  (@prefiled_value.include?(key) ? true : false), {})+value[I18n.locale.to_s],@markup_options.merge(:class=>"control-label")) | ||||
|       end.join rescue "" | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   def render_date  | ||||
|     control_group_wrapper{date_select(get_field_name_base+"[value]",nil,@markup_options.merge(:default=>@prefiled_value),:class=>"input-small")}  | ||||
|     #NP | ||||
|     control_group_wrapper{date_select(get_field_name_base,nil,@markup_options.merge(:default=>@prefiled_value),:class=>"input-small")}  | ||||
|   end | ||||
| 
 | ||||
|   def render_date_durnation #Need re-write low priority | ||||
|  | @ -63,17 +77,27 @@ module AttributeFieldsHelper | |||
| 
 | ||||
|   def render_radio_button  | ||||
|      @prefiled_value ||=[] | ||||
|     markup_value = eval(self.markup_value) rescue {} | ||||
|     # begin  | ||||
|     #   markup_value = eval(self.markup_value)  | ||||
|     # rescue | ||||
|     #   markup_value  = self.markup_value | ||||
|     # ensure | ||||
|     #   markup_value ||= {} | ||||
|     # end | ||||
|     control_group_wrapper do | ||||
|       markup_value.collect do |key,value| | ||||
|         label_tag(key,radio_button_tag(get_field_name_base+"[value][#{key}]", value[I18n.locale.to_s],  (@prefiled_value.include?(key) ? true : false), {})+value[I18n.locale.to_s],@markup_options.merge(:class=>"control-label")) | ||||
|       end.join rescue "" | ||||
|       self[:option_list].collect do |key,value| | ||||
|         label_tag(key,radio_button_tag(get_field_name_base, key ,  (@prefiled_value.include?(key) ? true : false), {})+value[I18n.locale.to_s],@markup_options.merge(:class=>"control-label")) | ||||
|       end.join  | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   def render_select  | ||||
|     markup_value = (self.markup_value.is_a?(Hash) ? self.markup_value : eval(self.markup_value) )rescue {} | ||||
|     control_group_wrapper{select_tag( get_field_name_base+"[value]",options_for_select(markup_value.collect{|p| [p[1][I18n.locale.to_s],p[0]]},@prefiled_value),@markup_options)} rescue "" | ||||
| 
 | ||||
|     prompt = @panel_setting[:prompt][I18n.locale] rescue nil | ||||
|     @markup_options.merge!(:prompt => prompt) unless prompt.nil? | ||||
|     # markup_value = (self.markup_value.is_a?(Hash) ? self.markup_value : eval(self.markup_value) )rescue {} | ||||
|     # check self[:option_list].collect{|p| [p[1][I18n.locale.to_s],p[0]]} | ||||
|     control_group_wrapper{select_tag( get_field_name_base,options_for_select(self.option_list.collect{|p| [p[1][I18n.locale.to_s],p[0]]},@prefiled_value),@markup_options)} rescue "" | ||||
|   end | ||||
| 
 | ||||
|   def render_text_area  | ||||
|  | @ -81,28 +105,35 @@ module AttributeFieldsHelper | |||
|       if(add_more and value.is_a?(Hash)) | ||||
|         values = value | ||||
|         values.each_with_index.collect  do |value,index| | ||||
|           text_area_tag(get_field_name_base + (key.nil? ? '' : "[#{key}][#{index}]"),  value.last,@markup_options) | ||||
|           place_holder= @panel_setting["placeholder"][key] | ||||
|           text_area_tag(get_field_name_base + (key.nil? ? '' : "[#{key}][#{index}]"),  value.last,@markup_options.merge(:placeholder=>place_holder)) | ||||
|         end.join.html_safe | ||||
|       else | ||||
|       value = can_muti_lang_input ?  @prefiled_value[key] : @prefiled_value | ||||
|       key = can_muti_lang_input ? "[#{key}]" : "[value]" | ||||
|       text_area_tag(get_field_name_base + key,  value,@markup_options) | ||||
|       key = can_muti_lang_input ? "[#{key}]" : "" | ||||
|       place_holder= @panel_setting["placeholder"][I18n.locale.to_s] rescue '' | ||||
|       text_area_tag(get_field_name_base + key,  value,@markup_options.merge(:placeholder=>place_holder)) | ||||
|       end | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   def render_text_field | ||||
|      control_group_wrapper do |key,value| | ||||
|       if(add_more and value.is_a?(Hash)) | ||||
|       if(add_more) | ||||
|         values = value | ||||
|         values.each_with_index.collect  do |value,index| | ||||
| 
 | ||||
|           text_field_tag(get_field_name_base + (key.nil? ? '' : "[#{key}][#{index}]"),  value.last,@markup_options) | ||||
|         result = "" | ||||
|         unless values.nil? | ||||
|           result = values.each_with_index.collect  do |value,index| | ||||
|             place_holder= @panel_setting["placeholder"][key] | ||||
|             text_field_tag(get_field_name_base + (key.nil? ? '' : "[#{key}][#{index}]"),  value.last,@markup_options.merge(:placeholder=>place_holder)) | ||||
|           end.join.html_safe | ||||
|          end | ||||
|          result | ||||
|       else | ||||
|       value = can_muti_lang_input ?  @prefiled_value[key] : @prefiled_value | ||||
|       key = can_muti_lang_input ? "[#{key}]" : "[value]" | ||||
|       text_field_tag(get_field_name_base + key,  value,@markup_options) | ||||
|       value = (can_muti_lang_input ?  @prefiled_value[key] : @prefiled_value) rescue nil | ||||
|       key_field = can_muti_lang_input ? "[#{key}]" : "" | ||||
|       place_holder= @panel_setting["placeholder"][key] rescue '' | ||||
|       text_field_tag(get_field_name_base + key_field,  value,@markup_options.merge(:placeholder=>place_holder)) | ||||
|     end | ||||
|   end | ||||
| end | ||||
|  | @ -121,12 +152,14 @@ protected | |||
|     if can_muti_lang_input | ||||
|       result << "<div class='tabbable'>" | ||||
|       result << "<div class='tab-content'>" | ||||
|        | ||||
|       VALID_LOCALES.collect do |key| | ||||
|         value  = @prefiled_value[key.to_s] rescue nil | ||||
|         div_class = ["tab-pane" ,"fade"].join(" ") | ||||
|         div_class << (key == I18n.locale.to_s ?  " active in" : '') | ||||
|         result << content_tag(:div,yield(key,value),:class=>div_class,:id=>"tab"+id.to_s+"_#{key}") | ||||
|       end | ||||
| 
 | ||||
|       result << "</div>" | ||||
|       result << "<ul class='nav nav-pills'>" | ||||
|       VALID_LOCALES.each do |key| | ||||
|  | @ -161,15 +194,13 @@ protected | |||
| 
 | ||||
|   def end_block | ||||
|     if @new_attribute | ||||
|       hidden_field_tag(get_field_name_base+"[attribute_field_id]",id,:for=>"field_#{@index}") | ||||
|       hidden_field_tag(get_basic_field_name_base+"[attribute_field_id]",id,:for=>"field_#{@index}") | ||||
|     else | ||||
|       hidden_field_tag(get_field_name_base+"[id]",@attribute_value.id,:for=>"field_#{@index}") | ||||
|       hidden_field_tag(get_basic_field_name_base+"[id]",@attribute_value.id,:for=>"field_#{@index}") | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   def get_field_name_base | ||||
|     # "user[#{self.attribute._type.downcase.pluralize}][#{self.attribute._id.to_s}][attribute_values][#{attribute_value.id}]" | ||||
|     # binding.pry if @attribute_value[:key] == 'status' | ||||
|   def get_basic_field_name_base | ||||
|     if @new_attribute | ||||
|       "user[new_attribute_values][#{@index}]" | ||||
|     else | ||||
|  | @ -177,12 +208,16 @@ protected | |||
|     end | ||||
|   end | ||||
| 
 | ||||
|   def get_field_name_base | ||||
|     get_basic_field_name_base + "[value]" | ||||
|   end | ||||
| 
 | ||||
|   def label | ||||
|     label_tag(key,title,:class=>"control-label") | ||||
|     label_tag(key,title,:class=>"control-label",:func => "field_label") | ||||
|   end | ||||
| 
 | ||||
|   def can_muti_lang_input | ||||
|     locale and LIST[:markups][markup]["muti_lang_input_supprt"] | ||||
|     LIST[:markups][markup]["muti_lang_input_supprt"] #and locale | ||||
|   end | ||||
| 
 | ||||
|   def can_add_more | ||||
|  |  | |||
|  | @ -1,5 +1,8 @@ | |||
| class CssDefault < Stylesheet | ||||
|    | ||||
|   belongs_to :design | ||||
|   # belongs_to :design | ||||
|   # belongs_to :desktop_widget | ||||
| 
 | ||||
|   belongs_to :css, polymorphic: true | ||||
|    | ||||
| end | ||||
|  |  | |||
|  | @ -8,11 +8,11 @@ class Design | |||
|   field :title, :type => String | ||||
|   field :version, :type => String | ||||
| 
 | ||||
|   has_one :css_default, :autosave => true, :dependent => :destroy | ||||
|   has_one :css_default, as: :css, :autosave => true, :dependent => :destroy | ||||
|   has_one :layout, :autosave => true, :dependent => :destroy | ||||
|   has_one :css_reset, :autosave => true, :dependent => :destroy | ||||
|   has_many :images, :autosave => true, :dependent => :destroy | ||||
|   has_many :javascripts, :autosave => true, :dependent => :destroy | ||||
|   has_many :images,as: :imgs, :autosave => true, :dependent => :destroy | ||||
|   has_many :javascripts, as: :js, :autosave => true, :dependent => :destroy | ||||
|   has_many :pages | ||||
|   has_many :themes, :autosave => true, :dependent => :destroy | ||||
| 
 | ||||
|  |  | |||
|  | @ -10,7 +10,10 @@ class Image | |||
|    | ||||
|   mount_uploader :file, ImageUploader | ||||
| 
 | ||||
|   belongs_to :design | ||||
|   # belongs_to :design | ||||
|   # belongs_to :desktop_widget | ||||
| 
 | ||||
|   belongs_to :imgs, polymorphic: true | ||||
| 
 | ||||
|   before_save :set_name | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,3 +1,6 @@ | |||
| class Javascript < DesignFile | ||||
|   belongs_to :design | ||||
|   # belongs_to :design | ||||
|   # belongs_to :desktop_widget | ||||
| 
 | ||||
|   belongs_to :js, polymorphic: true | ||||
| end | ||||
|  |  | |||
|  | @ -1,23 +1,27 @@ | |||
| class Stylesheet < DesignFile | ||||
|   belongs_to :design | ||||
|   # belongs_to :design | ||||
|   mount_uploader :file_orig, AssetUploader | ||||
|    | ||||
|   def parse_urls | ||||
|     orig_content = content = self.file.read.force_encoding("UTF-8") | ||||
|     # self.remove_file! | ||||
|     # self.remove_file_orig! | ||||
|     names = [] | ||||
|     images = self.design.images | ||||
|     names = {} | ||||
|     images = self.css.images | ||||
|     content.scan(/(?<=url)(.*?)(?=\))/){ | ||||
|       css_name = $1.gsub(' ','').gsub('(','') | ||||
|       unless names.has_key?(css_name) | ||||
|         name = File.basename(css_name).gsub(/[\\\"]/, '') | ||||
|         image = images.detect{ |i| i.file_identifier.eql?(name) } rescue nil | ||||
|       image.update_attribute(:in_css, true) if image | ||||
|       file_name = image.file_url rescue nil | ||||
|       names << [css_name, file_name] | ||||
|         if image | ||||
|           image.update_attribute(:in_css, true) | ||||
|           file_name = image.file_url | ||||
|           names.merge!({css_name => file_name}) | ||||
|         end | ||||
|       end | ||||
|     } | ||||
|     names.each do |name| | ||||
|       content.gsub!(name[0], name[1]) if name[1] | ||||
|     names.each_pair do |key, value| | ||||
|       content.gsub!(key, value) | ||||
|     end | ||||
|     Dir.mktmpdir('f_path') { |dir| | ||||
|       orig_file_name = self.file_identifier | ||||
|  |  | |||
|  | @ -2,14 +2,15 @@ class Desktop | |||
|   include Mongoid::Document | ||||
|   include Mongoid::Timestamps | ||||
|    | ||||
|   field :theme, default: "4f8d3f493b67fcd05f086359" | ||||
|   field :theme, default: "4f8d3f533b67fcd05f08635a" | ||||
|   field :customtheme | ||||
|   field :wallpaper | ||||
|    | ||||
|   belongs_to :user | ||||
|   has_and_belongs_to_many :desktop_widgets, :autosave => true | ||||
|    | ||||
|   has_many  :sections, :autosave => true, :dependent => :destroy | ||||
|   has_many :desktop_widgets, :autosave => true, :dependent => :destroy | ||||
|   # has_many :desktop_widgets, :autosave => true, :dependent => :destroy | ||||
| 
 | ||||
|   before_create :initialize_section | ||||
|    | ||||
|  | @ -0,0 +1,33 @@ | |||
| class DesktopWidget | ||||
| 	include Mongoid::Document | ||||
|   	include Mongoid::Timestamps | ||||
|   	include ParserLayoutWidget | ||||
| 
 | ||||
|   	field :name | ||||
|   	field :author | ||||
|   	field :shape | ||||
|   	field :version, :type => String | ||||
| 
 | ||||
|   has_one :css_default, as: :css, :autosave => true, :dependent => :destroy | ||||
| 	has_one :widget_layout, :autosave => true, :dependent => :destroy | ||||
| 	has_many :images, as: :imgs, :autosave => true, :dependent => :destroy | ||||
| 	has_many :javascripts, as: :js, :autosave => true, :dependent => :destroy | ||||
|   has_and_belongs_to_many :desktops, :autosave => true | ||||
|   belongs_to :tiles, :autosave => true | ||||
| 	 | ||||
| 	accepts_nested_attributes_for :images, :allow_destroy => true | ||||
|   accepts_nested_attributes_for :javascripts, :allow_destroy => true | ||||
| 	 | ||||
| 	after_save :parse_css_for_images | ||||
| 
 | ||||
|   	# belongs_to :desktop | ||||
| 
 | ||||
| 
 | ||||
|   	protected | ||||
|    | ||||
|  	def parse_css_for_images | ||||
| 	    self.css_default.parse_urls | ||||
| 	    parse_widget_for_images(self) | ||||
|   	end | ||||
| 
 | ||||
| end | ||||
|  | @ -0,0 +1,18 @@ | |||
| class Group | ||||
|   include Mongoid::Document | ||||
|   include Mongoid::Timestamps | ||||
|    | ||||
|   belongs_to :section | ||||
|   has_many :tiles, :autosave => true, :dependent => :destroy | ||||
|   before_create :initialize_tile | ||||
|    | ||||
|   def initialize_tile | ||||
|     self.tiles.build(data_category: "app", data_content: "quotes", position: 5, shape: "w1 h1", title: "Quotes") | ||||
|     self.tiles.build(data_category: "app", data_content: "dailyenglish", position: 6, shape: "w1 h1", title: "Daily English Word") | ||||
|     widgets = self.section.desktop.desktop_widgets.collect{|widget| widget.id} | ||||
|     for i in 0..3 | ||||
|       self.tiles.build(data_category: "widget", position: i+1,desktop_widget_id: widgets[i]) | ||||
|     end | ||||
|   end | ||||
| end | ||||
|   | ||||
|  | @ -9,6 +9,6 @@ class Tile | |||
|   field :title | ||||
|    | ||||
|   belongs_to :group | ||||
|    | ||||
|   has_one :desktop_widget | ||||
|      | ||||
| end | ||||
|  | @ -0,0 +1,18 @@ | |||
| class WidgetLayout < DesignFile | ||||
|   | ||||
|   attr_reader :content | ||||
| 
 | ||||
|   field :body | ||||
| 
 | ||||
|   belongs_to :desktop_widget | ||||
|    | ||||
| 
 | ||||
|   def content | ||||
|     self.file.read.force_encoding("UTF-8") rescue '' | ||||
|   end | ||||
| 
 | ||||
|   def self.exist_one? | ||||
|     WidgetLayout.count > 0 | ||||
|   end | ||||
|    | ||||
| end | ||||
|  | @ -1,13 +0,0 @@ | |||
| class DesktopWidget | ||||
| 	include Mongoid::Document | ||||
|   	include Mongoid::Timestamps | ||||
| 
 | ||||
|   	field :name | ||||
|   	field :author | ||||
|   	field :shape | ||||
|   	field :desktop_id | ||||
|   	field :status | ||||
|   	field :section | ||||
| 
 | ||||
|   	belongs_to :desktop | ||||
| end | ||||
|  | @ -1,19 +0,0 @@ | |||
| class Group | ||||
|   include Mongoid::Document | ||||
|   include Mongoid::Timestamps | ||||
|    | ||||
|   belongs_to :section | ||||
|   has_many :tiles, :autosave => true, :dependent => :destroy | ||||
|   before_create :initialize_tile | ||||
|    | ||||
|   def initialize_tile | ||||
|     self.tiles.build(data_category: "widget", data_content: "timetable", position: 1, shape: "w2 h2", title: "Tiime Table") | ||||
|     self.tiles.build(data_category: "app", data_content: "quotes", position: 2, shape: "w1 h1", title: "Quotes") | ||||
|     self.tiles.build(data_category: "widget", data_content: "weather", position: 3, shape: "w2 h2", title: "Weather") | ||||
|     self.tiles.build(data_category: "widget", data_content: "clock", position: 4, shape: "w2 h1", title: "Clock") | ||||
|     self.tiles.build(data_category: "app", data_content: "dailyenglish", position: 5, shape: "w1 h1", title: "Daily English Word") | ||||
|     self.tiles.build(data_category: "widget", data_content: "school_events", position: 6, shape: "w2 h1", title: "School Events") | ||||
|   end | ||||
|    | ||||
| end | ||||
|   | ||||
|  | @ -11,6 +11,7 @@ class Attribute | |||
|   has_many :attribute_fields, :autosave => true, :dependent => :destroy | ||||
|   accepts_nested_attributes_for :attribute_fields, :allow_destroy => true | ||||
|    | ||||
|    | ||||
|   def is_built_in? | ||||
|     self.built_in | ||||
|   end | ||||
|  |  | |||
|  | @ -5,26 +5,43 @@ class AttributeField | |||
|   include ::AttributeFieldsHelper | ||||
| 
 | ||||
|   field :key | ||||
|   field :markup  | ||||
|   field :markup_value ,:type => Hash | ||||
|   field :markup ,:default=>"text_field" | ||||
|   field :option_list ,:type => Hash,:default => {} | ||||
|   field :markup_options,:type => Hash | ||||
|   field :locale, :type => Boolean, :default => true | ||||
|   # field :locale, :type => Boolean, :default => true | ||||
|   # field :list_options, :type => Array | ||||
|   field :built_in, :type => Boolean, :default => false | ||||
|   field :disabled, :type => Boolean, :default => false | ||||
|   field :add_more,:type => Boolean, :default => false | ||||
|   field :to_delete,:type=> Boolean,:default => false | ||||
|   field :typeA,:type=> Hash,:default=>{} | ||||
|   field :typeB,:type=> Hash,:default=>{} | ||||
|   field :typeC,:type=> Hash,:default=>{:claendar=>"west_claendar"} | ||||
|   field :typeD,:type=> Hash,:default=>{} | ||||
|   field :typeE,:type=> Hash,:default=>{} | ||||
| 
 | ||||
| 
 | ||||
|   #field :title, localize: true | ||||
| 
 | ||||
|   field :locale_title, localize: true | ||||
|   field :neutral_title | ||||
|   field :neutral_for | ||||
|   field :title, localize: true | ||||
|    | ||||
| 
 | ||||
|   belongs_to :attribute | ||||
|   # belongs_to :role | ||||
|   has_many :attribute_values,:autosave => true, :dependent => :destroy | ||||
|    | ||||
|   before_save :check_option_list | ||||
|   # validates_uniqueness_of :key | ||||
|   def add_more | ||||
|      (get_data["add_more"] == "true" ? true : false) rescue false | ||||
|   end | ||||
| 
 | ||||
|   def locale | ||||
|     default = true | ||||
|     if get_data["locale"].nil?  | ||||
|       return default | ||||
|     else | ||||
|       (get_data["locale"] == "true"  ? true : false) rescue default | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   def self_defined_markup_options? | ||||
|     (self.attribute.role.method(self[:key].pluralize.to_sym)  && self.attribute.role.method(self[:key].pluralize+"_for_"+markup)) rescue false | ||||
|  | @ -36,16 +53,16 @@ class AttributeField | |||
|     end | ||||
|   end | ||||
| 
 | ||||
|   def markup_value | ||||
|   def option_list | ||||
|     if self_defined_markup_options? | ||||
|       #Class need to have corresponding field and value agent  | ||||
|      # Ex: For "status" the class must have field called "statuses" for the relation and "statuses_for_select" for the select function  | ||||
|      method = self.attribute.role.method(self[:key].pluralize+"_for_"+markup) | ||||
|       return  (method.call rescue {}) | ||||
|     elsif self[:markup_value].nil?  || (self[:markup_value].empty?) | ||||
|     elsif self[:option_list].nil?  || (self[:option_list].empty?) | ||||
|       return {} | ||||
|     else | ||||
|       return self[:markup_value] | ||||
|       return self[:option_list] | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|  | @ -68,36 +85,49 @@ class AttributeField | |||
|     self.attribute.role | ||||
|   end | ||||
| 
 | ||||
|   def title_translations | ||||
|     if locale | ||||
|       return locale_title_translations | ||||
|     else | ||||
|       return Hash[VALID_LOCALES.map{|d| [d,neutral_title]}] | ||||
|     end | ||||
|   def panel | ||||
|     panel  = LIST[:markups][self[:markup]]["panel"] | ||||
|   end | ||||
| 
 | ||||
|   def title_translations=(var) | ||||
|      if locale | ||||
|       self.locale_title_translations = var | ||||
|     end | ||||
|   def get_data | ||||
|     self[panel] | ||||
|   end | ||||
| 
 | ||||
|   def title | ||||
|     if locale | ||||
|       return self.locale_title | ||||
|     else | ||||
|       return self.neutral_title | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   def title=(var) | ||||
|     # binding.pry | ||||
|      if locale  | ||||
|       self.locale_title = var | ||||
|     else | ||||
|       self.neutral_title = var | ||||
|     end | ||||
|   end | ||||
|   # def title_translations | ||||
|   #   if locale | ||||
|   #     return self.locale_title_translations | ||||
|   #   else | ||||
|   #     return  self[:neutral_title] #Hash[VALID_LOCALES.map{|d| [d,neutral_title]}] | ||||
|   #   end | ||||
|   # end | ||||
| 
 | ||||
|   # def title_translations=(var) | ||||
|   #    if locale | ||||
|   #     self.locale_title_translations = var | ||||
|   #   end | ||||
|   # end | ||||
| 
 | ||||
|   # def title | ||||
|   #   if locale | ||||
|   #     return self.locale_title | ||||
|   #   else | ||||
|   #     return self.neutral_title | ||||
|   #   end | ||||
|   # end | ||||
| 
 | ||||
|   # def check_title | ||||
|   #    if locale  | ||||
|   #     self.locale_title_translations = self[:temp_title] | ||||
|   #   else | ||||
|   #     self.neutral_title = self[:temp_title] | ||||
|   #   end     | ||||
|   #   self.unset("temp_title") | ||||
|   # end | ||||
| 
 | ||||
|   # def title=(var) | ||||
|   #    self["temp_title"] = var | ||||
|   # end | ||||
| 
 | ||||
|   # # Convert the string list_options into an array | ||||
|   # def select_list_options=(var) | ||||
|  | @ -117,4 +147,9 @@ class AttributeField | |||
|     self.disabled | ||||
|   end | ||||
| 
 | ||||
| protected | ||||
|   def check_option_list | ||||
|     self[:option_list] = self[panel]["option_list"] | ||||
|   end | ||||
| 
 | ||||
| end | ||||
|  |  | |||
|  | @ -10,11 +10,56 @@ class AttributeValue | |||
|   belongs_to :user | ||||
| 
 | ||||
|   before_save :check_key | ||||
| 
 | ||||
|   before_save :data_proc | ||||
|   # NO_MULTI_TAG = ["select","date","radio_button","checkbox","date_durnation"] | ||||
| 
 | ||||
| 
 | ||||
|   def data_proc | ||||
|     # binding.pry | ||||
|     # binding.pry if self.attribute_field.markup == 'radio_button' | ||||
|     # if self.attribute_field | ||||
|         case self.attribute_field.markup | ||||
|         when 'text_field','text_area' | ||||
|           # binding.pry | ||||
|             self[:temp_data].each{|key,val|  | ||||
|               self[key] = val | ||||
|             }  unless self[:temp_data].nil? | ||||
|           when 'select','date','radio_button' | ||||
|             self["val"] = self[:temp_data] | ||||
|           when 'checkbox' | ||||
|             self["val"] = self[:temp_data].keys rescue {} | ||||
|         end #end of case | ||||
|       else # if not locale | ||||
|         case self.attribute_field.markup | ||||
|         when 'text_field','text_area' | ||||
|               self["val"] = self[:temp_data] | ||||
|           when 'select','date','radio_button' | ||||
|             self["val"] = self[:temp_data] | ||||
|           when 'checkbox' | ||||
|             self["val"] = self[:temp_data].keys rescue {} | ||||
|         end #end of case | ||||
|     # end #of if self.attribute_field | ||||
|     self.unset('temp_data') | ||||
|   end | ||||
| 
 | ||||
|   def value | ||||
|      | ||||
|     result="" | ||||
|     if self.attribute_field.locale && (self.attribute_field.markup == "text_field" || self.attribute_field.markup == "text_area") | ||||
|       result= Hash[VALID_LOCALES.collect{|lang|  [lang,self[lang.to_sym]]}] | ||||
|     else | ||||
|       result = self["val"]   | ||||
|     end | ||||
|     result | ||||
|   end | ||||
| 
 | ||||
|   def value=(value) | ||||
|     #save everything to temp_data waiting for futher process | ||||
|     # binding | ||||
|     self[:temp_data] = value | ||||
|   end | ||||
| 
 | ||||
|   def check_key | ||||
|       binding.pry if  attribute_field.nil? | ||||
|     self.key = attribute_field.key | ||||
|   end | ||||
| 
 | ||||
|  | @ -27,45 +72,46 @@ class AttributeValue | |||
|   end | ||||
|    | ||||
|   def get_value_by_locale(locale) | ||||
| 
 | ||||
|     case self.attribute_field.markup | ||||
|       when "text_field" | ||||
|         self.attribute_field.locale ? self[locale]  : self[:value] | ||||
|         self.attribute_field.locale ? self[locale.to_s]  : self.value | ||||
|       when "select" | ||||
|         markup_values = self.attribute_field.self_defined_markup_options? ? self.attribute_field.markup_value : eval(self.attribute_field.markup_value) | ||||
|         markup_values[self[:value]][locale.to_s] rescue 'NoData' | ||||
|         markup_values[self.value][locale.to_s] rescue 'NoData' | ||||
|       when "text_area" | ||||
|         self.attribute_field.locale ? self[locale]  : self[:value] | ||||
|         self.attribute_field.locale ? self[locale.to_s]  : self.value | ||||
|       when "date" | ||||
|         Date.new(self[:value]["(1i)"].to_i,self[:value]["(2i)"].to_i,self[:value]["(3i)"].to_i) rescue nil | ||||
|         Date.new(self[:val]["(1i)"].to_i,self[:val]["(2i)"].to_i,self[:val]["(3i)"].to_i) rescue nil | ||||
|       when "addr" | ||||
|         self[:value] | ||||
|         self.value | ||||
|       when "radio_button" | ||||
|         markup_values = eval(self.attribute_field.markup_value) | ||||
|         markup_values[self[:value].first[0]][locale.to_s] | ||||
|         markup_values[:value][locale.to_s] | ||||
|       when "checkbox"  | ||||
|         markup_values = eval(self.attribute_field.markup_value) | ||||
|         self[:value].keys.collect{|key| markup_values[key][locale.to_s] }.join(",") | ||||
|         markup_values = self.attribute_field.markup_value | ||||
|         self[:value].keys.collect{|key| markup_values[key][locale.to_s]}.join(",") | ||||
|       when "date_durnation" | ||||
|         self[:value] | ||||
|         self.value | ||||
|       else | ||||
|         self.attribute_field.locale ? self[locale]  : self[:value] | ||||
|         self.attribute_field.locale ? self[locale.to_s]  : self.value | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
|   def get_values | ||||
|     unless ['select','checkbox','radio_button'].include?(self.attribute_field.markup ) | ||||
|       if self.attribute_field.locale && LIST[:markups][self.attribute_field.markup]["muti_lang_input_supprt"] | ||||
|         return Hash[VALID_LOCALES.collect{|lang|  [lang,get_value_by_locale(lang.to_sym)]}] | ||||
|       else | ||||
|           return get_value_by_locale("") | ||||
|       end | ||||
|     else | ||||
|       if self.attribute_field.markup == "select" | ||||
|         self[:value]   | ||||
|       else | ||||
|         self[:value].keys rescue self[:value] | ||||
|       end | ||||
|     end | ||||
|   end | ||||
|   # def get_values | ||||
|   #   unless ['select','checkbox','radio_button'].include?(self.attribute_field.markup ) | ||||
|   #     if self.attribute_field.locale && LIST[:markups][self.attribute_field.markup]["muti_lang_input_supprt"] | ||||
|   #       return Hash[VALID_LOCALES.collect{|lang|  [lang,get_value_by_locale(lang.to_sym)]}] | ||||
|   #     else | ||||
|   #         return get_value_by_locale("") | ||||
|   #     end | ||||
|   #   else | ||||
|   #     if self.attribute_field.markup == "select" | ||||
|   #       self[:value]   | ||||
|   #     else | ||||
|   #       self[:value].keys rescue self[:value] | ||||
|   #     end | ||||
|   #   end | ||||
|   # end | ||||
| 
 | ||||
| end | ||||
|  |  | |||
|  | @ -35,7 +35,8 @@ class User | |||
|   before_save :save_roles | ||||
|   scope :remote_account, where(:nccu_id.ne => nil) | ||||
| 
 | ||||
|   validates_uniqueness_of :email,:message=> I18n.t("devise.registrations.email_not_unique") | ||||
|   # validates_uniqueness_of :email,:message=> I18n.t("devise.registrations.email_not_unique") | ||||
|    | ||||
|   # def new_attribute_values=(vars) | ||||
|   #   binding.pry | ||||
|   # end | ||||
|  | @ -176,7 +177,7 @@ class User | |||
|   end | ||||
|    | ||||
|   def initialize_desktop | ||||
|     self.build_desktop | ||||
|    self.build_desktop(desktop_widget_ids: DesktopWidget.all.collect{|widget| widget.id}) | ||||
|   end | ||||
|    | ||||
|   protected | ||||
|  |  | |||
|  | @ -1,14 +1,139 @@ | |||
| <% content_for :secondary do %> | ||||
| 	<%= render 'admin/users/side_bar' %> | ||||
| <% end %> | ||||
|             <%= form_for @attribute,:url => admin_info_path(@attribute) ,:class=> "form-horizontal" do |f| %> | ||||
|             <div class="site-map role-block"> | ||||
|                 <div class="map-block back"> | ||||
|                     <h4><span><%= t("admin.info")%></span></h4> | ||||
|                                         <div class="form-horizontal"> | ||||
|                         <div class="clear"> | ||||
|                             <div class="control-group pull-left"> | ||||
|                                 <label class="control-label" for="key"><%= t("admin.key") %></label> | ||||
|                                 <div class="controls"> | ||||
|                                     <% if @attribute.new_record? %> | ||||
|                                         <%= f.text_field :key,:placeholder=>"Key" %> | ||||
|                                     <% else %> | ||||
|                                         <div><%= @attribute.key%></div> | ||||
|                                     <% end %> | ||||
|                                 </div> | ||||
|                             </div> | ||||
|                             <%= render :partial=>"placeholder_block",:locals=>{:value=>@attribute.title_translations,:class_ext=>"pull-left",:label_ext=>t("admin.infos.item_name"),:field_name=>"info[title_translations]"}%> | ||||
|                             | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </div> | ||||
|                         <div class="map-block back attributes"> | ||||
|                             <h4><span><%= t("admin.attributes")%></span></h4> | ||||
|                             <%= render :partial=>"attribute_field",:collection=>@attribute.attribute_fields%> | ||||
|                         </div> | ||||
|                     </div> | ||||
|             <div class="form-actions form-fixed pagination-right"> | ||||
|                 <%= link_to content_tag(:i,t("admin.infos.add_attribute_field"),:class=>"icon-plus icon-white"),admin_info_add_attribute_field_path(@attribute),:class=>"btn btn-primary",:remote => true%> | ||||
|                 <%= f.submit t("admin.infos.save"),:class=>"btn btn-primary"%> | ||||
|                  | ||||
| <div id="profile"> | ||||
| 	<%= form_for @attribute, :url => eval("admin_#{@attribute_type}_path(@attribute)") do |f| %> | ||||
|     <%= f.error_messages %> | ||||
|     <%= render :partial => "admin/#{@attribute_type}s/form", :locals => { :f => f, :is_new => false } %> | ||||
|     <div class='button_bar'> | ||||
|     	<%= link_back %> | ||||
| 			<%= link_to t('update'), "#", :onclick=>"$('#edit_#{@attribute_type}_#{@attribute.id}').submit()" %> | ||||
|             </div> | ||||
|         <% end %> | ||||
| </div> | ||||
| <% content_for :page_specific_css do -%> | ||||
|     <%= stylesheet_link_tag "member" %> | ||||
|     <%= stylesheet_link_tag "site-map" %> | ||||
| <% end %> | ||||
| 
 | ||||
| <% content_for :page_specific_javascript do -%> | ||||
|     <script> | ||||
|                 var CloneTarget ; | ||||
| 
 | ||||
|                 var NewNode; | ||||
|                  | ||||
|         $(document).ready(function(){ | ||||
|             // function mas(){ | ||||
|             //     $('.site-map').masonry({ | ||||
|             //         itemSelector: '.map-block', | ||||
|             //         columnWidth: 450, | ||||
|             //         isAnimated: true | ||||
|             //     }); | ||||
|             // } | ||||
| 
 | ||||
|             function checkSwitch() { | ||||
|                 $(".groups").addClass('disabled').has('.groups > .form-horizontal > div:not(.hide)').removeClass('disabled'); | ||||
|             } | ||||
|             function checkMultipleInput() { | ||||
|                 $(".multipleInput").each(function() { | ||||
|                     $(this).find('.controls').length==1 ? $(this).addClass("plural") : $(this).removeClass("plural") | ||||
|                 }); | ||||
|             } | ||||
|             function removeInput(){ | ||||
|                 $(".removeInput").live('click',function (){ | ||||
|                     $(this).parents(".controls").remove(); | ||||
|                     checkMultipleInput(); | ||||
|                     return false; | ||||
|                 }); | ||||
|             } | ||||
|             checkSwitch(); | ||||
|             checkMultipleInput(); | ||||
|             removeInput(); | ||||
|             $(".remove_attribute").live('click',function(){ | ||||
|                 $(this).siblings(".attribute_field_to_delete").val("true"); | ||||
|                 $(this).parents(".form-horizontal").fadeOut("slow", function () { $(this).hide(); }); | ||||
|             }); | ||||
| 
 | ||||
|             $(".help-block a").live('click',function (){ | ||||
|                 CloneTarget = $(this).parents(".controls").prev(".multipleInput").find('.controls:last'); | ||||
|                 NewNode = CloneTarget.clone(); | ||||
|                 var index; | ||||
|                 NewNode.find("input").each(function(k,v){  | ||||
|                   index = CloneTarget.parents("div.control-group").find(".list_count").val() | ||||
|                   field_name = CloneTarget.parents("div.control-group").find(".field_name").val() | ||||
|                   ori_str = $(v).attr("name").replace(field_name,""); | ||||
|                   lang = ori_str.match(/\[\D*\]/); | ||||
|                   new_field_name = (field_name+"[" + (parseInt(index)+1) + "]" + lang); | ||||
|                   $(v).attr("name",new_field_name); | ||||
|                   }) | ||||
| 
 | ||||
|                 $(this).parents("div.control-group").find(".list_count").val(parseInt(index)+1) | ||||
|                 $(this).parents(".controls").prev(".multipleInput").append(NewNode); | ||||
|                 $(this).parents(".controls").prev(".multipleInput").find('.controls:last input').val(""); | ||||
|                 removeInput(); | ||||
|                 checkMultipleInput(); | ||||
|                 return false; | ||||
|             }) | ||||
|             $(".status select").each(function (i) { | ||||
|                 $(this).change(function () { | ||||
|                     $(".status option:selected").eq(i).each(function () { | ||||
|                         if($(this).attr("value")=="alumna") { | ||||
|                             $(this).parents(".status").nextAll(".graduated").removeClass("hide"); | ||||
|                             $(this).parents(".status").nextAll(".graduated").find("select").removeAttr("disabled"); | ||||
|                         }else{ | ||||
|                             $(this).parents(".status").nextAll(".graduated").addClass("hide"); | ||||
|                             $(this).parents(".status").nextAll(".graduated").find("select").attr({disabled:''}); | ||||
|                         } | ||||
|                     }); | ||||
|                 }) | ||||
|             }) | ||||
|             $('.onoff').live('click',function () { | ||||
|                 if($(this).parents("h4").length==1) { | ||||
|                     $(this).parents(".map-block").toggleClass("disabled"); | ||||
|                     $(this).parents(".map-block").find(".form-horizontal").toggleClass("hide"); | ||||
|                     if($(this).parents(".map-block").hasClass("disabled")){ | ||||
|                         $(this).text("OFF"); | ||||
|                     }else{ | ||||
|                         $(this).text("ON"); | ||||
|                     } | ||||
|                 } | ||||
|                 if($(this).parents("legend").length==1) { | ||||
|                     $(this).toggleClass("disabled"); | ||||
|                     $(this).parents("legend").next("div").toggleClass("hide"); | ||||
|                     if($(this).parents("legend").next("div").hasClass("hide")){ | ||||
|                         $(this).text("OFF"); | ||||
|                         $(this).siblings(".attribute_field_disabled").val("true"); | ||||
|                     }else{ | ||||
|                         $(this).text("ON"); | ||||
|                         $(this).siblings(".attribute_field_disabled").val("false"); | ||||
|                     } | ||||
|                     checkSwitch(); | ||||
|                 } | ||||
|                return false; | ||||
|             }); | ||||
|             $(".dataType").change(function () { | ||||
|                         $(this).parents("legend").next("div").find("div[class^='type']").addClass("hide"); | ||||
|                         $(this).parents("legend").next("div").find("."+$(this).find("option:selected").attr("ref")).removeClass("hide"); | ||||
|                 }) | ||||
|         }); | ||||
|     </script> | ||||
| <% end -%> | ||||
|  |  | |||
|  | @ -1,3 +1,100 @@ | |||
| <%= f.fields_for :attribute_fields, attribute_field do |f| %> | ||||
| 	<%= render :partial => 'admin/attributes/attribute_field', :object => attribute_field, :locals => {:f => f} %> | ||||
| <% end %> | ||||
|   <div class="form-horizontal"> | ||||
|       <legend> | ||||
|           <button class="onoff pull-right <%= attribute_field.disabled ?  'disabled' : ''%>">ON</button> | ||||
|           <%= hidden_field "info[attribute_fields][#{attribute_field_counter}]","disabled",:value=>attribute_field.disabled,:class=>"attribute_field_disabled"%> | ||||
|           <%= hidden_field "info[attribute_fields][#{attribute_field_counter}]","to_delete",:value=>false,:class=>"attribute_field_to_delete"%> | ||||
|           <a class="btn btn-small pull-right btn-danger remove_attribute" href="#"><i class="icon-trash icon-large"></i> <%= t("delete")%></a> | ||||
|           <div class="clear"> | ||||
|               <div class="control-group pull-left"> | ||||
|                   <label class="control-label" for="key"><%= t("admin.key") %></label> | ||||
|                   <div class="multipleInput"> | ||||
|                       <div class="controls"> | ||||
|                         <%= text_field "info[attribute_fields][#{attribute_field_counter}]","key",:value=>attribute_field.key%> | ||||
|                       </div> | ||||
|                   </div> | ||||
|               </div> | ||||
|               <%= render :partial=>"placeholder_block",:locals=>{:values=>attribute_field.title_translations,:class_ext=>"pull-left",:label_ext=>t("admin.infos.name"),:field_name=>"info[attribute_fields][#{attribute_field_counter}][title_translations]"}%> | ||||
|               <div class="control-group pull-left"> | ||||
|                   <label class="control-label" for=""><%= t("admin.infos.type")%></label> | ||||
|                   <div class="controls"> | ||||
|                       <%#= select_tag "info[attribute_fields][#{attribute_field_counter}][markup]" do %> | ||||
|                        <select class="dataType" name=<%= "info[attribute_fields][#{attribute_field_counter}][markup]"%>> | ||||
|                         <%LIST[:markups].each do |key,val|%> | ||||
|                              <option  value="<%= key %>" <%= attribute_field.markup == key ?  'selected="selected"' : '' %> ref="<%=val["panel"]%>"><%=t("lists.markups."+key)%></option > | ||||
|                         <% end %> | ||||
|                     </select> | ||||
|                   </div> | ||||
|               </div> | ||||
|           </div> | ||||
|       </legend> | ||||
|       <div class="<%= attribute_field.disabled ?  'hide' : ''%>"> | ||||
|           <%= content_tag :div,:class=>show_type_panel(attribute_field,"typeA") do%> | ||||
|               <div class="control-group"> | ||||
|                   <label class="control-label"><%= t("admin.infos.options")%></label> | ||||
|                   <div class="controls"> | ||||
|                       <label class="checkbox inline"> | ||||
|                             <%= check_box_tag("info[attribute_fields][#{attribute_field_counter}][typeA][multilingual]","true",attribute_field["typeA"]["multilingual"]) %> | ||||
|                             <%=  t("admin.infos.multilingual")%> | ||||
|                       </label> | ||||
|                       <label class="checkbox inline"> | ||||
|                           <%= check_box_tag("info[attribute_fields][#{attribute_field_counter}][typeA][add_more]","true",attribute_field["typeA"]["add_more"]) %> | ||||
|                           <%= t("admin.infos.add_more")%> | ||||
|                       </label> | ||||
|                   </div> | ||||
|               </div> | ||||
|               <%= render :partial=> "placeholder_block",:locals=>{:values=>attribute_field["typeA"]["placeholder"],:field_name=>"info[attribute_fields][#{attribute_field_counter}][typeA][placeholder]"}%> | ||||
|           <% end %> | ||||
| 
 | ||||
|           <%= content_tag :div,:class=>show_type_panel(attribute_field,"typeB") do %> | ||||
|               <%= render :partial=> "placeholder_block",:locals=>{:label_ext=>t("admin.infos.initial"),:values=>attribute_field["typeB"]["initial"],:field_name=>"info[attribute_fields][#{attribute_field_counter}][typeB][initial]"}%> | ||||
| 
 | ||||
|               <%= render :partial=>"list_block",:locals=>{:values=>attribute_field["option_list"],:field_name=> "info[attribute_fields][#{attribute_field_counter}][typeB][option_list]"} %> | ||||
|           <% end %> | ||||
|           <%= content_tag :div,:class=>show_type_panel(attribute_field,"typeC") do %> | ||||
|               <div class="control-group"> | ||||
|                   <label class="control-label"><%= t("admin.infos.date.format")%></label> | ||||
|                   <div class="controls"> | ||||
|                         <%= select "info[attribute_fields][#{attribute_field_counter}][typeC]","format",Admin::AttributeValuesViewHelper::OPT,:class=>"dataType",:selected=>attribute_field["typeC"]["format"] %> | ||||
|                   </div> | ||||
|               </div> | ||||
|               <div class="control-group"> | ||||
|                   <label class="control-label"><%= t("admin.infos.date.range")%></label> | ||||
|                   <div class="controls"> | ||||
|                       <label class="radio inline"> | ||||
|                           <%= radio_button("info[attribute_fields][#{attribute_field_counter}][typeC]", "is_range", "false",:checked => (attribute_field["typeC"]["is_range"]== "false" ? true : false)) %><%= t("admin.infos.not_range")%> | ||||
|                       </label> | ||||
|                       <label class="radio inline"> | ||||
|                         <%= radio_button("info[attribute_fields][#{attribute_field_counter}][typeC]", "is_range", "true",:checked => (attribute_field["typeC"]["is_range"]== "true" ? true : false)) %><%= t("admin.infos.is_range")%> | ||||
|                       </label> | ||||
|                   </div> | ||||
|               </div> | ||||
|               <div class="control-group"> | ||||
|                   <label class="control-label"><%= t("admin.infos.date.claendar")%></label> | ||||
|                   <div class="controls"> | ||||
|                       <label class="radio inline"> | ||||
|                           <%= radio_button("info[attribute_fields][#{attribute_field_counter}][typeC]", "claendar", "west_claendar",:checked =>(attribute_field["typeC"]["claendar"]== "west_claendar" ? true : false)) %><%= t("admin.infos.date.west_claendar")%> | ||||
|                       </label> | ||||
|                       <label class="radio inline"> | ||||
|                           <%= radio_button("info[attribute_fields][#{attribute_field_counter}][typeC]", "claendar", "tw_claendar",:checked =>(attribute_field["typeC"]["claendar"]== "tw_claendar" ? true : false)) %><%= t("admin.infos.date.tw_claendar")%> | ||||
|                       </label> | ||||
|                   </div> | ||||
|               </div> | ||||
|           <% end %> | ||||
|           <%= content_tag :div,:class=>show_type_panel(attribute_field,"typeD") do%> | ||||
|               <div class="control-group"> | ||||
|                   <label class="control-label"><%= t("admin.infos.options")%></label> | ||||
|                   <div class="controls"> | ||||
|                       <label class="checkbox inline"> | ||||
|                         <%= check_box_tag("info[attribute_fields][#{attribute_field_counter}][typeD][multilingual]","true",attribute_field["typeD"]["multilingual"]) %> | ||||
|                         <%= t("admin.infos.multilingual")%> | ||||
|                       </label> | ||||
|                   </div> | ||||
|               </div> | ||||
|               <%= render :partial=> "placeholder_block",:locals=>{:field_name=>"info[attribute_fields][#{attribute_field_counter}][typeD][placeholder]",:values=>attribute_field["typeD"]["placeholder"]} %> | ||||
|           <% end %> | ||||
|           <%= content_tag :div,:class=>show_type_panel(attribute_field,"typeE") do%> | ||||
|               <%= render :partial=>"list_block",:locals=>{:field_name=>"info[attribute_fields][#{attribute_field_counter}][typeE][option_list]",:values=>attribute_field["option_list"]}%> | ||||
|           <% end %> | ||||
|       </div> | ||||
|       <%= hidden_field "info[attribute_fields][#{attribute_field_counter}]","id",:value=>attribute_field.id%> | ||||
|   </div> | ||||
|  |  | |||
|  | @ -0,0 +1,45 @@ | |||
|               <% temp_field_name = field_name.gsub /\[\D*\]$/,'[temp]'%> | ||||
|               <div class="control-group"> | ||||
|                 <%= hidden_field_tag "#{temp_field_name}[count]",((values.keys.collect{|t| t.to_i}.max rescue nil)  || 0 ),:class=>"list_count"%> | ||||
|                 <%= hidden_field_tag "#{temp_field_name}[name]",field_name,:class=>"field_name"%> | ||||
|                   <label class="control-label" ><%= t("admin.infos.list")%></label> | ||||
|                   <div class="multipleInput"> | ||||
|                     <%if values.blank? %> | ||||
|                         <div class="controls"> | ||||
|                           <% @site_valid_locales.each do |locale| %> | ||||
|                               <% last = (locale == @site_valid_locales.last ? true : false) %> | ||||
|                               <% p_value = value[locale.to_s] rescue nil%> | ||||
|                               <%= content_tag :div,:class=>"input-append #{"unRadius" if last }" do%> | ||||
|                                 <%= text_field("#{field_name}[0]", locale,:placeholder=>t("langs.#{locale}")) %> | ||||
|                                 <% if last %> | ||||
|                                   <a href="#" class="btn removeInput" type="button"><i class="icon-trash"></i></a> | ||||
|                                 <% end %> | ||||
|                             <% end %> | ||||
|                           <% end %> | ||||
|                       </div> | ||||
|                     <%else%> | ||||
|                       <%values.each do |index,value|%> | ||||
| 
 | ||||
|                         <div class="controls"> | ||||
| 
 | ||||
|                           <% @site_valid_locales.each do |locale| %> | ||||
|                               <% last = (locale == @site_valid_locales.last ? true : false) %> | ||||
|                               <% p_value = value[locale.to_s] rescue nil%> | ||||
|                               <%= content_tag :div,:class=>"input-append #{"unRadius" if last }" do%> | ||||
|                                 <%= text_field("#{field_name}[#{index}]", locale,:value=>p_value,:placeholder=>t("langs.#{locale}")) %> | ||||
|                                 <% if last %> | ||||
|                                   <a href="#" class="btn removeInput" type="button"><i class="icon-trash"></i></a> | ||||
|                                 <% end %> | ||||
|                             <% end %> | ||||
|                           <% end %> | ||||
| 
 | ||||
|                       </div> | ||||
|                     <% end %> | ||||
|                   <% end %> | ||||
|                   </div> | ||||
|                   <div class="controls"> | ||||
|                       <span class="help-block"> | ||||
|                           <a href="#"><i class="icon-plus-sign"></i><%= t("admin.infos.add") %></a> | ||||
|                       </span> | ||||
|                   </div> | ||||
|               </div> | ||||
|  | @ -0,0 +1,25 @@ | |||
|               <% values ||=[]%> | ||||
|               <%= content_tag :div,:class=>"control-group language-swich #{class_ext rescue "" }" do%> | ||||
|                   <label class="control-label" for=""><%= (defined? label_ext) ?  label_ext : t("admin.infos.placeholder") %></label> | ||||
|                   <div class="controls"> | ||||
|                       <div class="tabbable"> | ||||
|                           <div class="tab-content"> | ||||
|                             <% @site_valid_locales.each do |locale| %> | ||||
|                               <% active = (locale == @site_valid_locales.first ? "active in" : "'") %> | ||||
|                               <%= content_tag :div,:class=>"tab-pane fade #{active}",:id=>"#{name_to_id(field_name)}_#{locale}" do%> | ||||
|                               <% value = values[locale.to_s] rescue nil%> | ||||
|                               <%= text_field(field_name, locale,:value=>value,:placeholder=>t("langs.#{locale}")) %> | ||||
|                             <% end %> | ||||
|                             <% end %> | ||||
|                           </div> | ||||
|                           <ul class="nav nav-pills "> | ||||
|                             <% @site_valid_locales.each do |locale| %> | ||||
|                               <% active = (locale == @site_valid_locales.first ? "active" : "'") %> | ||||
|                               <%=content_tag :li,:class=>active do %> | ||||
|                                 <%= link_to t("langs.#{locale}"),"##{name_to_id(field_name)}_#{locale}",:data=>{:toggle=>"tab"}%> | ||||
|                               <% end %> | ||||
|                             <% end %> | ||||
|                           </ul> | ||||
|                       </div> | ||||
|                   </div> | ||||
|               <% end %> | ||||
|  | @ -0,0 +1,6 @@ | |||
| $(".attributes").append('<%= escape_javascript(render :partial=>"attribute_field",:locals=>{:attribute_field=>@attribute_field,:attribute_field_counter=>@attribute_field_counter} )%>'); | ||||
|             $(".dataType").change(function () { | ||||
|                         $(this).parents("legend").next("div").find("div[class^='type']").addClass("hide"); | ||||
|                         $(this).parents("legend").next("div").find("."+$(this).find("option:selected").attr("ref")).removeClass("hide"); | ||||
| 
 | ||||
|                 }) | ||||
|  | @ -14,7 +14,7 @@ | |||
| <% end -%> | ||||
| 
 | ||||
| 
 | ||||
| <%= content_tag :div,:class=>"user-role site-map"  do%> | ||||
| <%= content_tag :div,:class=>"user-role site-map role-block"  do%> | ||||
| 
 | ||||
|     <%= form_for @user, :url => admin_users_new_interface_path(@user), :html => { :multipart => true } do |f| %> | ||||
|       <%= f.error_messages %> | ||||
|  |  | |||
|  | @ -61,6 +61,18 @@ | |||
| 			</ul> | ||||
| 		</div> | ||||
| 	</div> | ||||
| 	<div class="hh2 hp sdm"> | ||||
| 		<div class="sdm_t hh2" id='ns'>New Share</div> | ||||
| 		<div class="admbg sdm_o"> | ||||
| 			<ul> | ||||
| 				<li><a class="hp hh2 admtxt remote_url" href="<%= panel_personal_journal_plugin_writing_journals_path %>">Full</a></li> | ||||
| 				<li><a class="hp hh2 admtxt" href="">Abstract</a></li> | ||||
| 				<li><a class="hp hh2 admtxt" href="">Friends</a></li> | ||||
| 				<li><a class="hp hh2 admtxt" href="">Private</a></li> | ||||
| 				<li><a class="hp hh2 admtxt" href="">Group</a></li> | ||||
| 			</ul> | ||||
| 		</div> | ||||
| 	</div> | ||||
| 	<div class="hh2 hp sdm"> | ||||
| 		<div class="sdm_t hh2"><span class="icon-question-sign"></span></div> | ||||
| 	</div> | ||||
|  | @ -73,3 +85,18 @@ | |||
| 		</div> | ||||
| 	</div> | ||||
| </div> | ||||
| Panel::PersonalJournal::Plugin::WritingJournals | ||||
| <script type="text/javascript"> | ||||
| orbitDesktop.prototype.bindItems = function(){ | ||||
| 	var bindHandlers = function(){ | ||||
| 
 | ||||
| 	} | ||||
| 	$(".remote_url").click(function(){ | ||||
| 		$(".overview").load($(this).attr("href"),function(){ | ||||
| 			bindHandlers(); | ||||
| 		}) | ||||
| 		return false; | ||||
| 	}) | ||||
| } | ||||
| o.bindItems(); | ||||
| </script> | ||||
|  |  | |||
|  | @ -0,0 +1,12 @@ | |||
| <h4>Upload Widget Package </h4> | ||||
| <div class="main2"> | ||||
| 	<%= form_tag '',:multipart => true,:action=>"post" do |f| %> | ||||
| 
 | ||||
| 	<p> | ||||
| 	<%= file_field :desktop_widget,:package_file %> | ||||
| 	</p> | ||||
| 	<%= submit_tag  %> | ||||
| 
 | ||||
| 	<% end %> | ||||
| 
 | ||||
| </div> | ||||
|  | @ -81,7 +81,7 @@ | |||
|   <% end -%> | ||||
| <% end %> | ||||
| 
 | ||||
| <%= content_tag :li, :class => active_for_controllers('archive_files', 'tags', 'archive_file_categorys') do -%> | ||||
| <%= content_tag :li, :class => active_for_controllers('archive_files', 'panel/archive/back_end/tags', 'archive_file_categorys') do -%> | ||||
|   <%= link_to content_tag(:i, nil, :class => 'icons-asset') + content_tag(:span, t('admin.archive')), panel_archive_back_end_archive_files_path %> | ||||
|     <%= content_tag :ul, :class => ("nav nav-list " + visible_for_controllers('archive_files', 'tags', 'archive_file_categorys')) do -%> | ||||
|     <%= content_tag :li, link_to((t('admin.all_articles') + content_tag(:i, nil, :class => 'icon-chevron-right')).html_safe, panel_archive_back_end_archive_files_path), :class => active_for_action('archive_file', 'index') %> | ||||
|  | @ -91,14 +91,14 @@ | |||
|   <% end -%> | ||||
| <% end -%> | ||||
| 
 | ||||
| <%= content_tag :li, :class => active_for_controllers('cals') || active_for_app_auth("calendar") do -%> | ||||
| <%= content_tag :li, :class => active_for_controllers('cals','panel/calendar/back_end/tags') || active_for_app_auth("calendar") do -%> | ||||
|   <%= link_to content_tag(:i, nil, :class => 'icons-calendar') + content_tag(:span, t('admin.calendar')), panel_calendar_back_end_cals_path %> | ||||
|   <%= content_tag :ul, :class => ("nav nav-list " + visible_for_controllers('cals','calendar_categories') ) do -%> | ||||
|     <%#= content_tag :li, link_to(t('admin.ad.all_banners'), admin_ad_banners_path), :class => active_for_action('ad_banners', 'index') %> | ||||
|     <%#= content_tag :li, link_to(t('admin.ad.new_banner'), new_admin_ad_banner_path), :class => active_for_action('ad_banners', 'new') %> | ||||
|     <%#= content_tag :li, link_to(t('admin.ad.new_image'), new_ad_image_admin_ad_banners_path), :class => active_for_action('ad_images', 'new') %> | ||||
|   <%= content_tag :li, link_to((t('calendar.calendars') + content_tag(:i, nil, :class => 'icon-chevron-right')).html_safe, new_panel_calendar_back_end_cal_path), :class => active_for_action('cals','new') %> | ||||
|   <%#= content_tag :li, link_to(t('gallery.tags'), panel_gallery_back_end_tags_path), :class => active_for_action('/panel/gallery/back_end/tags', 'index') %> | ||||
|   <%= content_tag :li, link_to((t('admin.calendars') + content_tag(:i, nil, :class => 'icon-chevron-right')).html_safe, new_panel_calendar_back_end_cal_path), :class => active_for_action('cals','new') %> | ||||
|   <%= content_tag :li, link_to(t('admin.tags'), panel_calendar_back_end_tags_path), :class => active_for_action('/panel/calendar/back_end/tags', 'index') %> | ||||
|   <%#= content_tag :li, link_to(t('admin.module.authorization'),admin_module_app_manager_auth_proc_path(ModuleApp.first(conditions: {key: "gallery"}))), :class => active_for_app_auth('gallery')  if (is_admin? rescue nil) %> | ||||
|   <% end -%> | ||||
| <% end %> | ||||
|  |  | |||
|  | @ -0,0 +1,13 @@ | |||
| <div class="modal hide fade" id="address-edit" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true" style="display: none; "> | ||||
|     <div class="modal-header"> | ||||
|         <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button> | ||||
|         <h3 id="myModalLabel">Modal header</h3> | ||||
|     </div> | ||||
|     <div class="modal-body"> | ||||
|         <p>One fine body…</p> | ||||
|     </div> | ||||
|     <div class="modal-footer"> | ||||
|         <button class="btn" data-dismiss="modal" aria-hidden="true">Close</button> | ||||
|         <button class="btn btn-primary">Save changes</button> | ||||
|     </div> | ||||
| </div> | ||||
|  | @ -33,6 +33,7 @@ module Orbit | |||
|     config.autoload_paths += %W(#{config.root}/app/models/meta) | ||||
|     config.autoload_paths += %W(#{config.root}/app/models/purchase) | ||||
|     config.autoload_paths += %W(#{config.root}/app/models/user) | ||||
|     config.autoload_paths += %W(#{config.root}/app/models/desktop) | ||||
| 
 | ||||
|     # Include all helpers | ||||
|     # 'helper :all' must be removed in ApplicationController | ||||
|  |  | |||
|  | @ -9,21 +9,27 @@ markups: | |||
|   text_field: | ||||
|     muti_lang_input_supprt: true | ||||
|     ext_support: true | ||||
|     panel: typeA | ||||
|   select: | ||||
|     muti_lang_input_supprt: false | ||||
|     ext_support: false | ||||
|     panel: typeB | ||||
|   date: | ||||
|     muti_lang_input_supprt: false | ||||
|     ext_support: false | ||||
|     panel: typeC | ||||
|   text_area: | ||||
|     muti_lang_input_supprt: true | ||||
|     ext_support: false | ||||
|     panel: typeD | ||||
|   radio_button: | ||||
|     muti_lang_input_supprt: false | ||||
|     ext_support: false | ||||
|     panel: typeE | ||||
|   checkbox: | ||||
|     muti_lang_input_supprt: false | ||||
|     ext_support: false | ||||
|     panel: typeE | ||||
|   # date_durnation: | ||||
|   #   muti_lang_input_supprt: false | ||||
|   #   ext_support: false | ||||
|  |  | |||
|  | @ -158,6 +158,14 @@ en: | |||
|     user: Users list | ||||
|   list_: List | ||||
|   list_lower: list | ||||
|   lists: | ||||
|     markups: | ||||
|       text_field: Text Field | ||||
|       select: Select | ||||
|       date: Date | ||||
|       text_area: Text Area | ||||
|       radio_button: Radio button | ||||
|       checkbox: Checkbox | ||||
|   login: Login | ||||
|   logout: Logout | ||||
|   mail: | ||||
|  | @ -407,7 +415,7 @@ en: | |||
|     attributes: Attributes | ||||
|     author: Author | ||||
|     calendar: Calendar | ||||
|     gprs: GPRS | ||||
|     gprs: GPS | ||||
|     cant_delete_self: You can not delete yourself. | ||||
|     cant_revoke_self_admin: You can not revoke your admin role yourself. | ||||
|     category: Category | ||||
|  |  | |||
|  | @ -158,6 +158,14 @@ zh_tw: | |||
|     user: 使用者列表 | ||||
|   list_: 列表 | ||||
|   list_lower: 列表 | ||||
|   lists: | ||||
|     markups: | ||||
|       text_field: 文字輸入框 | ||||
|       select: 下拉選單 | ||||
|       date: 日期 | ||||
|       text_area: 文字輸入方塊 | ||||
|       radio_button: 單選 | ||||
|       checkbox: 多選 | ||||
|   login: 登入 | ||||
|   logout: 登出 | ||||
|   mail: | ||||
|  | @ -342,8 +350,30 @@ zh_tw: | |||
| # : ======= | ||||
|   errors: | ||||
|     at_least_one: 必須至少有一個值 | ||||
|      | ||||
|   admin: | ||||
|     infos: | ||||
|       add_attribute_field: 新增 | ||||
|       save: 儲存 | ||||
|       initial: 起始值 | ||||
|       markup: 輸入模式 | ||||
|       item_name: 資料表名稱 | ||||
|       name: 名稱 | ||||
|       options: 選項 | ||||
|       multilingual: 多語言輸入 | ||||
|       add_more: 使用者可自行延伸欄位 | ||||
|       add: 新增 | ||||
|       placeholder: 輸入協助 | ||||
|       type: 類型 | ||||
|       placeholder: 提示內容 | ||||
|       list: 自定選單 | ||||
|       is_range: 是 | ||||
|       not_range: 否 | ||||
|       date: | ||||
|         claendar: 紀年法 | ||||
|         range: 本欄為時間區段 | ||||
|         format: 格式 | ||||
|         tw_claendar: 民國 | ||||
|         west_claendar: 西元 | ||||
|     access: | ||||
|       denied: | ||||
|         app: | ||||
|  |  | |||
|  | @ -141,7 +141,17 @@ Orbit::Application.routes.draw do | |||
|     resources :users | ||||
|   end | ||||
| 
 | ||||
|   match '/desktop/'=>'desktop#index' | ||||
|   resources :desktop_widgets do | ||||
|     collection do | ||||
|         get 'upload' | ||||
|         get 'delete' | ||||
|         post 'upload' | ||||
|     end | ||||
|   end | ||||
| 
 | ||||
| namespace :desktop do | ||||
|    | ||||
|   match "/"=>"desktop#index" | ||||
| 
 | ||||
|   # Sinatra Routes start | ||||
| 
 | ||||
|  | @ -176,46 +186,50 @@ Orbit::Application.routes.draw do | |||
|    | ||||
|   # Sinatra Routes end | ||||
|    | ||||
|   match '/desktop/desktop'=>'desktop#desktop' | ||||
|   match '/desktop/app_manager'=>'desktop#app_manager' | ||||
|   match '/desktop/sections'=>'desktop#sections' | ||||
|   match '/desktop/settings'=>'desktop#settings' | ||||
|   match '/desktop/get_desktop_settings/'=>'desktop#get_desktop_settings' | ||||
|   match '/desktop/save_desktop_settings/'=>'desktop#save_desktop_settings' | ||||
|   match '/desktop/getgroups/'=>'desktop#getgroups' | ||||
|   match '/desktop/getsectionlist/'=>'desktop#getsectionlist' | ||||
|   match '/desktop/settingthemes/'=>'desktop#settingthemes' | ||||
|   match '/desktop/settingsections/'=>'desktop#settingsections' | ||||
|   match '/desktop/getapplist/'=>'desktop#getapplist' | ||||
|   match '/desktop/newpositions/'=>'desktop#newpositions' | ||||
|   match '/desktop/settingconnection/'=>'desktop#settingconnection' | ||||
|   match '/desktop'=>'desktop#desktop' | ||||
|   match '/app_manager'=>'desktop#app_manager' | ||||
|   match '/sections'=>'desktop#sections' | ||||
|   match '/settings'=>'desktop#settings' | ||||
|   match '/get_desktop_settings/'=>'desktop#get_desktop_settings' | ||||
|   match '/save_desktop_settings/'=>'desktop#save_desktop_settings' | ||||
|   match '/getgroups/'=>'desktop#getgroups' | ||||
|   match '/getsectionlist/'=>'desktop#getsectionlist' | ||||
|   match '/settingthemes/'=>'desktop#settingthemes' | ||||
|   match '/settingsections/'=>'desktop#settingsections' | ||||
|   match '/getapplist/'=>'desktop#getapplist' | ||||
|   match '/newpositions/'=>'desktop#newpositions' | ||||
|   match '/settingconnection/'=>'desktop#settingconnection' | ||||
|   match '/widget_layout' => 'desktop#widget_layout' | ||||
| 
 | ||||
| 
 | ||||
|   match '/desktop/journal_p/'=>'desktop_publications#journal_p' | ||||
|   match '/desktop/journal_p_list/'=>'desktop_publications#journal_p_list' | ||||
|   match '/desktop/journal_p_add/'=>'desktop_publications#journal_p_add' | ||||
|   match '/desktop_publications/getjournals' => 'desktop_publications#getjournals' | ||||
|   match '/desktop/books' => 'desktop_publications#books' | ||||
|   match '/desktop/books_list/'=>'desktop_publications#books_list' | ||||
|   match '/desktop/books_add/'=>'desktop_publications#books_add' | ||||
|   match '/journal_p/'=>'desktop_publications#journal_p' | ||||
|   match '/journal_p_list/'=>'desktop_publications#journal_p_list' | ||||
|   match '/journal_p_add/'=>'desktop_publications#journal_p_add' | ||||
|   match '/books' => 'desktop_publications#books' | ||||
|   match '/books_list/'=>'desktop_publications#books_list' | ||||
|   match '/books_add/'=>'desktop_publications#books_add' | ||||
| 
 | ||||
|   match '/desktop/seminar_p' => 'desktop_publications#seminar_p' | ||||
|   match '/desktop/seminar_p_list/'=>'desktop_publications#seminar_p_list' | ||||
|   match '/desktop/seminar_p_add/'=>'desktop_publications#seminar_p_add' | ||||
|   match '/seminar_p' => 'desktop_publications#seminar_p' | ||||
|   match '/seminar_p_list/'=>'desktop_publications#seminar_p_list' | ||||
|   match '/seminar_p_add/'=>'desktop_publications#seminar_p_add' | ||||
| 
 | ||||
|   match '/desktop/research_d' => 'desktop_research#research_d' | ||||
|   match '/desktop/research_d_list/' => 'desktop_research#research_d_list' | ||||
|   match '/desktop/research_d_add' => 'desktop_research#research_d_add' | ||||
|   match '/research_d' => 'desktop_research#research_d' | ||||
|   match '/research_d_list/' => 'desktop_research#research_d_list' | ||||
|   match '/research_d_add' => 'desktop_research#research_d_add' | ||||
| 
 | ||||
|   match '/desktop/research_p' => 'desktop_research#research_p' | ||||
|   match '/desktop/research_p_list/' => 'desktop_research#research_p_list' | ||||
|   match '/desktop/research_p_add' => 'desktop_research#research_p_add' | ||||
|   match '/research_p' => 'desktop_research#research_p' | ||||
|   match '/research_p_list/' => 'desktop_research#research_p_list' | ||||
|   match '/research_p_add' => 'desktop_research#research_p_add' | ||||
| 
 | ||||
| 
 | ||||
|   match '/desktop/twitter/'=>'otheraccounts#twitter' | ||||
|   match '/desktop/forgmail/'=>'otheraccounts#gmail' | ||||
|   match '/desktop/getaccounts'=>'otheraccounts#getaccounts' | ||||
|   match '/desktop/save_account_info/'=>'otheraccounts#saveaccountinfo' | ||||
| 
 | ||||
|   match '/temp_func/'=>'desktop#temp_func' | ||||
| end | ||||
| 
 | ||||
|   match '/twitter/'=>'otheraccounts#twitter' | ||||
|   match '/forgmail/'=>'otheraccounts#gmail' | ||||
|   match '/getaccounts'=>'otheraccounts#getaccounts' | ||||
|   match '/save_account_info/'=>'otheraccounts#saveaccountinfo' | ||||
| 
 | ||||
|   match '/desktop_appstore/appstore'=>'desktop_appstore#appstore' | ||||
|   match '/desktop_appstore/widgets'=>'desktop_appstore#widgets' | ||||
|  | @ -226,13 +240,14 @@ Orbit::Application.routes.draw do | |||
| 
 | ||||
|   match '/desktop_orbit/eventajaxload'=> 'desktop_orbit#eventajaxload' | ||||
|   match '/desktop_orbit/gettimelinespan' => 'desktop_orbit#gettimelinespan' | ||||
|   match '/desktop_publications/getjournals' => 'desktop_publications#getjournals' | ||||
| 
 | ||||
|    #match '/desktop_orbit/eventajaxload' => 'desktop_publications#create_journal' | ||||
|   #match '/desktop_orbit/eventajaxload' => 'desktop_publications#delete_journal' | ||||
|   # match '/desktop_orbit/eventajaxload' => 'desktop_publications#update_journal' | ||||
| 
 | ||||
| 
 | ||||
|   match '/desktop/temp_func/'=>'desktop#temp_func' | ||||
|    | ||||
|    | ||||
|   match '/panel/:app_name/front_end/:app_action/:id(/:controller_action)' => 'pages#show_from_link', :constraints => lambda { |request| | ||||
|     !request.query_string.include?("inner=true") | ||||
|  |  | |||
|  | @ -0,0 +1,22 @@ | |||
| module ParserLayoutWidget | ||||
|   require 'nokogiri' | ||||
| 
 | ||||
|   def parse_widget_for_images(widget) | ||||
|     content = widget.widget_layout.file.read.force_encoding("UTF-8") | ||||
|     widge = Nokogiri::HTML(content) | ||||
|     a = [] | ||||
|     b = [] | ||||
|     widge.css('.widget_image').each do |page_image| | ||||
|       image = widget.images.where( file: File.basename(page_image['src']))[0] | ||||
|       a << page_image['src'] | ||||
|       b << image.file | ||||
|       image.update_attributes(:html_id => page_image['id'], :html_class => page_image['class'], :in_html => true) if image | ||||
|     end | ||||
|     a.each_with_index do |img,i| | ||||
|       content = content.gsub(img,b[i].to_s) | ||||
|     end | ||||
|     widget.widget_layout.update_attributes(:body => content) | ||||
|   end | ||||
| 
 | ||||
| 
 | ||||
| end | ||||
| Before Width: | Height: | Size: 16 KiB | 
| Before Width: | Height: | Size: 15 KiB | 
| Before Width: | Height: | Size: 16 KiB | 
|  | @ -1,69 +0,0 @@ | |||
| .clock{ | ||||
| 	/* The .clock div. Created dynamically by jQuery */ | ||||
| 	/*background-color:#252525;*/ | ||||
| 	height:200px; | ||||
| 	width:200px; | ||||
| 	position:relative; | ||||
| 	overflow:hidden; | ||||
| 	float:left; | ||||
| } | ||||
| 
 | ||||
| .clock .rotate{ | ||||
| 	/* There are two .rotate divs - one for each half of the background */ | ||||
| 	position:absolute; | ||||
| 	width:200px; | ||||
| 	height:200px; | ||||
| 	top:0; | ||||
| 	left:0; | ||||
| } | ||||
| 
 | ||||
| .rotate.right{ | ||||
| 	display:none; | ||||
| 	z-index:11; | ||||
| } | ||||
| 
 | ||||
| .clock .bg, .clock .front{ | ||||
| 	width:100px; | ||||
| 	height:200px; | ||||
| 	/*background-color:#252525;*/ | ||||
| 	position:absolute; | ||||
| 	top:0; | ||||
| } | ||||
| 
 | ||||
| .clock .display{ | ||||
| 	/* Holds the number of seconds, minutes or hours respectfully */ | ||||
| 	position:absolute; | ||||
| 	width:200px; | ||||
| 	font-family:"Lucida Sans Unicode", "Lucida Grande", sans-serif; | ||||
| 	z-index:20; | ||||
| 	color:#F5F5F5; | ||||
| 	font-size:60px; | ||||
| 	text-align:center; | ||||
| 	top:65px; | ||||
| 	left:0; | ||||
| 	 | ||||
| 	/* CSS3 text shadow: */ | ||||
| 	text-shadow:4px 4px 5px #333333; | ||||
| } | ||||
| 
 | ||||
| /* The left part of the background: */ | ||||
| 
 | ||||
| .clock .bg.left{ left:0; } | ||||
| 
 | ||||
| /* Individual styles for each color: */ | ||||
| .orange .bg.left{ background:url(bg_orange.png) no-repeat left top; } | ||||
| .green .bg.left{ background:url(bg_green.png) no-repeat left top; } | ||||
| .blue .bg.left{	background:url(bg_blue.png) no-repeat left top; } | ||||
| 
 | ||||
| /* The right part of the background: */ | ||||
| .clock .bg.right{ left:100px; } | ||||
| 
 | ||||
| .orange .bg.right{ background:url(bg_orange.png) no-repeat right top; } | ||||
| .green .bg.right{ background:url(bg_green.png) no-repeat right top; } | ||||
| .blue .bg.right{ background:url(bg_blue.png) no-repeat right top; } | ||||
| 
 | ||||
| 
 | ||||
| .clock .front.left{ | ||||
| 	left:0; | ||||
| 	z-index:10; | ||||
| } | ||||
|  | @ -1,45 +0,0 @@ | |||
| <style type="text/css"> | ||||
| 	.g_weather { position: relative; height: 198px; } | ||||
| 	.g_weather img { float: left; display: block; margin: 0; padding: 12px; } | ||||
| 	.g_weather .gw_recent {  | ||||
| 		overflow: hidden; | ||||
| 		height: 96%; | ||||
| 		padding-top: 4%; | ||||
| 		} | ||||
| 	.g_weather .gw_weekly { display: none; } | ||||
| 	.g_weather .gw_location { | ||||
| 		position: absolute; | ||||
| 		left: 0; | ||||
| 		bottom: 0; | ||||
| 		font-size: 15px; | ||||
| 		line-height: 20px; | ||||
| 	} | ||||
| 	.g_weather .gw_condition_des { font-size: 22px; } | ||||
| 	.g_weather .gw_temp { margin-top: 26px; } | ||||
| 	.g_weather .gw_temp_num { font-size: 56px; } | ||||
| 	.g_weather .gw_temp_unit { font-size: 26px; } | ||||
| 	.g_weather .gw_forecast { | ||||
| 		position: absolute; | ||||
| 		right: 0; | ||||
| 		bottom: 0; | ||||
| 		font-size: 13px; | ||||
| 		line-height: 20px; | ||||
| 	} | ||||
| </style> | ||||
| <div class="g_weather"> | ||||
| 	<div class="gw_recent"> | ||||
| 		<img src="desktop_widgets/4fa7817cc88514014d7c59c2/img/sunny.png" alt="sunny" class="gw_condition"> | ||||
| 		<div class="gw_temp"> | ||||
| 			<span class="gw_temp_num thmtxt">29</span><span class="gw_temp_unit thmtxt">°C</span> | ||||
| 		</div> | ||||
| 		<div class="gw_condition_des thmtxt">Sunny</div> | ||||
| 	</div> | ||||
| 	<div class="gw_weekly"> | ||||
| 		weekly report | ||||
| 	</div> | ||||
| 	<div class="gw_location thmtxt">Hsin-Chu</div> | ||||
| 	<a href="" class="gw_forecast thmtxt">> Weekly Report</a> | ||||
| </div> | ||||
| <script type="text/javascript"> | ||||
| 	g_weather(); | ||||
| </script> | ||||
|  | @ -0,0 +1 @@ | |||
| /* No Css */ | ||||
|  | @ -0,0 +1,6 @@ | |||
| { | ||||
| 	"author" : "Harry", | ||||
| 	"name" : "Browser", | ||||
| 	"shape" : "w2 h1", | ||||
| 	"version" : "1.0" | ||||
| } | ||||
|  | @ -1,5 +1,3 @@ | |||
| <link href="http://fonts.googleapis.com/css?family=Rationale|Orbitron" rel="stylesheet" type="text/css"> | ||||
| <style> | ||||
| .clock{ | ||||
| 	/* The .clock div. Created dynamically by jQuery */ | ||||
| 	background-color:#111; | ||||
|  | @ -74,8 +72,3 @@ | |||
| 	left: 50%; | ||||
| 	margin: -36px 0 0 -114px; | ||||
| } | ||||
| </style> | ||||
| <div id="fancyClock"></div> | ||||
| <script> | ||||
| $('#fancyClock').tzineClock(); | ||||
| </script> | ||||
| Before Width: | Height: | Size: 9.4 KiB After Width: | Height: | Size: 9.4 KiB | 
| Before Width: | Height: | Size: 6.7 KiB After Width: | Height: | Size: 6.7 KiB | 
| Before Width: | Height: | Size: 9.5 KiB After Width: | Height: | Size: 9.5 KiB | 
|  | @ -0,0 +1,7 @@ | |||
| { | ||||
| 	"author" : "Harry", | ||||
| 	"name" : "Clock", | ||||
| 	"shape" : "w2 h1", | ||||
| 	"version" : "1.0" | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,5 @@ | |||
| <link href="http://fonts.googleapis.com/css?family=Rationale|Orbitron" rel="stylesheet" type="text/css"> | ||||
| <div id="fancyClock"></div> | ||||
| <script> | ||||
| $('#fancyClock').tzineClock(); | ||||
| </script> | ||||
							
								
								
									
										14
									
								
								public/desktop_widgets/4fa78140c88514014d7c59be/index.html.erb → public/desktop_widgets/googlesearch/default.css
								
								
								
								
									
									
									Normal file → Executable file
								
							
							
						
						|  | @ -1,4 +1,3 @@ | |||
| <style> | ||||
| #search{border-radius: 5px; margin:10px;margin-top:25px;} | ||||
| input { | ||||
| 	border:none;  | ||||
|  | @ -19,16 +18,3 @@ input { | |||
| 	color: #222; | ||||
| 	text-shadow: 0px 1px 1px #555; | ||||
| } | ||||
| </style> | ||||
| <center> | ||||
| <form id="search"> | ||||
| <img src="desktop_widgets/4fa78140c88514014d7c59be/img/google_64.png" style='margin-right:10px;'><br /> | ||||
| <input id="googlesearch"> | ||||
| <input type="submit" style="display:none;"> | ||||
| <br> | ||||
| <span id="eric">Powered by Eric</span> | ||||
| </form> | ||||
| </center> | ||||
| <script> | ||||
| search(); | ||||
| </script> | ||||
| Before Width: | Height: | Size: 5.3 KiB After Width: | Height: | Size: 5.3 KiB | 
|  | @ -0,0 +1,7 @@ | |||
| { | ||||
| 	"author" : "Eric", | ||||
| 	"name" : "Google Search", | ||||
| 	"shape" : "w2 h1", | ||||
| 	"version" : "1.0" | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,13 @@ | |||
| 
 | ||||
| <center> | ||||
| <form id="search"> | ||||
| <img src="desktop_widgets/4fa78140c88514014d7c59be/img/google_64.png" style='margin-right:10px;' class="widget_image"><br /> | ||||
| <input id="googlesearch"> | ||||
| <input type="submit" style="display:none;"> | ||||
| <br> | ||||
| <span id="eric">Powered by Eric</span> | ||||
| </form> | ||||
| </center> | ||||
| <script> | ||||
| search(); | ||||
| </script> | ||||
|  | @ -0,0 +1,26 @@ | |||
| .g_weather { position: relative; height: 198px; } | ||||
| 	.g_weather img { float: left; display: block; margin: 0; padding: 12px; } | ||||
| 	.g_weather .gw_recent {  | ||||
| 		overflow: hidden; | ||||
| 		height: 96%; | ||||
| 		padding-top: 4%; | ||||
| 		} | ||||
| 	.g_weather .gw_weekly { display: none; } | ||||
| 	.g_weather .gw_location { | ||||
| 		position: absolute; | ||||
| 		left: 0; | ||||
| 		bottom: 0; | ||||
| 		font-size: 15px; | ||||
| 		line-height: 20px; | ||||
| 	} | ||||
| 	.g_weather .gw_condition_des { font-size: 22px; } | ||||
| 	.g_weather .gw_temp { margin-top: 26px; } | ||||
| 	.g_weather .gw_temp_num { font-size: 56px; } | ||||
| 	.g_weather .gw_temp_unit { font-size: 26px; } | ||||
| 	.g_weather .gw_forecast { | ||||
| 		position: absolute; | ||||
| 		right: 0; | ||||
| 		bottom: 0; | ||||
| 		font-size: 13px; | ||||
| 		line-height: 20px; | ||||
| } | ||||
| Before Width: | Height: | Size: 2.2 KiB After Width: | Height: | Size: 2.2 KiB | 
|  | @ -0,0 +1,7 @@ | |||
| { | ||||
| 	"author" : "Devin", | ||||
| 	"name" : "Weather", | ||||
| 	"shape" : "w2 h2", | ||||
| 	"version" : "0.0" | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,17 @@ | |||
| <div class="g_weather"> | ||||
| 	<div class="gw_recent"> | ||||
| 		<img src="desktop_widgets/4fa7817cc88514014d7c59c2/img/sunny.png" alt="sunny" class="gw_condition widget_image"> | ||||
| 		<div class="gw_temp"> | ||||
| 			<span class="gw_temp_num thmtxt">29</span><span class="gw_temp_unit thmtxt">°C</span> | ||||
| 		</div> | ||||
| 		<div class="gw_condition_des thmtxt">Sunny</div> | ||||
| 	</div> | ||||
| 	<div class="gw_weekly"> | ||||
| 		weekly report | ||||
| 	</div> | ||||
| 	<div class="gw_location thmtxt">Hsin-Chu</div> | ||||
| 	<a href="" class="gw_forecast thmtxt">> Weekly Report</a> | ||||
| </div> | ||||
| <script type="text/javascript"> | ||||
| 	g_weather(); | ||||
| </script> | ||||
|  | @ -0,0 +1,78 @@ | |||
| #encoding: UTF-8 | ||||
| require 'spec_helper' | ||||
| 
 | ||||
| describe AttributeFieldsHelper do | ||||
|   describe "#attribute_field" do | ||||
|     context "In the HTML,there should always be 'value' tag in it's name" | ||||
| 
 | ||||
|     before(:all) do | ||||
|       @user = User.where(email:'chris@rulingcom.com').first | ||||
|     end #end before | ||||
|     # binding.pry | ||||
|     LIST[:markups].each do |markup| | ||||
|         it "should have 'value' when it's #{markup[0]} (no locale)" do | ||||
|           title = "標題" | ||||
|           pre_set_markup_value = case markup[0] | ||||
|           when "select","checkbox","radio_button" | ||||
|             '{"1"=>{"en"=>"Male", "zh_tw"=>"男性"}, "2"=>{"en"=>"Female", "zh_tw"=>"女性"}, "3"=>{"en"=>"Not public", "zh_tw"=>"不公開"}}' | ||||
|           else | ||||
|             nil | ||||
|           end | ||||
| 
 | ||||
|           attribute_field=AttributeField.find_or_create_by(key:'Test',markup: markup[0],markup_value: pre_set_markup_value,:title=>title) | ||||
| 
 | ||||
|           html = attribute_field.block_helper(@user,1) | ||||
| 
 | ||||
|           nodes = Nokogiri::HTML.fragment(html).search('*[@func="input_unit"]') | ||||
| 
 | ||||
|           nodes.each do |input| | ||||
|             attri = input.attributes["name"]  | ||||
|             attri = input.children().first.attributes["name"] if (markup[0] == 'checkbox'  ||  markup[0] == 'radio_button' ) | ||||
|             attri.to_s.should match /user\[.*attribute_values\]\[\d*\]\[value\].*/ | ||||
|             # user[attribute_values][1][id] | ||||
|             # user[attribute_values][1][value][en] | ||||
|           end #end of input loop | ||||
|         end # end of it | ||||
|     end #end markups | ||||
| 
 | ||||
|         LIST[:markups].each do |markup| | ||||
|           if markup[1]["muti_lang_input_supprt"] | ||||
|             [true,false].each do |locale_sat| | ||||
|               title = locale_sat ? {"en"=>"Title", "zh_tw"=>"標題"} : "標題"  | ||||
|               it "should have 'value' when it's #{markup[0]} for locale => #{locale_sat}" do | ||||
|                 pre_set_markup_value = case markup[0] | ||||
|                 when "select","checkbox","radio_button" | ||||
|                   '{"1"=>{"en"=>"Male", "zh_tw"=>"男性"}, "2"=>{"en"=>"Female", "zh_tw"=>"女性"}, "3"=>{"en"=>"Not public", "zh_tw"=>"不公開"}}' | ||||
|                 else | ||||
|                   nil | ||||
|                 end | ||||
|                 if (markup[0] == "text_field" || markup[0] == "text_area") && (locale_sat == false) | ||||
|                   # binding.pry  | ||||
|                 end | ||||
|                 attribute_field=AttributeField.find_or_create_by(key:'Test',markup: markup[0],markup_value: pre_set_markup_value,:title=>title,:locale => locale_sat) | ||||
|                  | ||||
|                 html = attribute_field.block_helper(@user,1) | ||||
|                  | ||||
|                 # p html | ||||
|                 nodes = Nokogiri::HTML.fragment(html).search('*[@func="input_unit"]') | ||||
|                 nodes.each do |input| | ||||
|                   input.attributes["name"].to_s.should match /user\[.*attribute_values\]\[\d*\]\[value\].*/ | ||||
|                   # user[attribute_values][1][id] | ||||
|                   # user[attribute_values][1][value][en] | ||||
|                 end #end of input loop | ||||
|                 nodes = Nokogiri::HTML.fragment(html).search('*[@func="field_label"]') | ||||
| 
 | ||||
|                 nodes.each do |input| | ||||
|                   # p input.to_s | ||||
|                   # binding.pry if  | ||||
| 
 | ||||
|                   input.children.text.should match "標題" | ||||
|                 end # end of field_label loop | ||||
|               end # end of it | ||||
|             end # end of T/F | ||||
|           end# end of if support | ||||
|     end #end markups | ||||
| 
 | ||||
| 
 | ||||
|   end | ||||
| end | ||||
|  | @ -1,218 +1,218 @@ | |||
| require 'spec_helper' | ||||
| require 'ruby-debug' | ||||
| # require 'spec_helper' | ||||
| # require 'ruby-debug' | ||||
| 
 | ||||
| 
 | ||||
| describe AppAuth do  | ||||
| # describe AppAuth do  | ||||
|    | ||||
|   before  do | ||||
|     User.all.destroy | ||||
|     Role.all.destroy | ||||
|     SubRole.all.destroy | ||||
|     AppAuth.all.destroy | ||||
|     ModuleApp.all.destroy | ||||
| #   before  do | ||||
| #     User.all.destroy | ||||
| #     Role.all.destroy | ||||
| #     SubRole.all.destroy | ||||
| #     AppAuth.all.destroy | ||||
| #     ModuleApp.all.destroy | ||||
|      | ||||
|     #Create some fixtures of Main Role | ||||
|     main_role_key = ["Stud","Teacher","Staff"] | ||||
|     @new_main_role_list = main_role_key.each do |role| | ||||
|       new_role = Role.new :key => role | ||||
|       new_role.save | ||||
|     end | ||||
|     #Create Some SubRoles | ||||
|     sub_role_key = ["graduated_school","undergraduated_school","TA","Senior"] | ||||
|     @new_main_role_list = sub_role_key.each do |role| | ||||
|       new_role = SubRole.new :key => role | ||||
|       new_role.save | ||||
|     end | ||||
| #     #Create some fixtures of Main Role | ||||
| #     main_role_key = ["Stud","Teacher","Staff"] | ||||
| #     @new_main_role_list = main_role_key.each do |role| | ||||
| #       new_role = Role.new :key => role | ||||
| #       new_role.save | ||||
| #     end | ||||
| #     #Create Some SubRoles | ||||
| #     sub_role_key = ["graduated_school","undergraduated_school","TA","Senior"] | ||||
| #     @new_main_role_list = sub_role_key.each do |role| | ||||
| #       new_role = SubRole.new :key => role | ||||
| #       new_role.save | ||||
| #     end | ||||
|      | ||||
|     #Create some users of User | ||||
|     user_emails = ["a_good_ug_stud_1","a_good_ug_stud_2","a_bad_ug_stud","a_good_g_stud","a_bad_g_stud","a_teacher","a_staff"] | ||||
|     user_emails.each do |user_email| | ||||
|       email=user_email+"@rulingcom.com" | ||||
|       new_user = User.new :email=> email | ||||
|       new_user.save | ||||
|     end | ||||
|     #MRK = Member Role Key    SRK=Sub Role Key | ||||
|     @stud_MRK = Role.first(conditions:{key:"Stud"}) | ||||
|     @teacher_MRK = Role.first(conditions:{key:"Teacher"}) | ||||
|     @staff_MRK = Role.first(conditions:{key:"Staff"}) | ||||
| #     #Create some users of User | ||||
| #     user_emails = ["a_good_ug_stud_1","a_good_ug_stud_2","a_bad_ug_stud","a_good_g_stud","a_bad_g_stud","a_teacher","a_staff"] | ||||
| #     user_emails.each do |user_email| | ||||
| #       email=user_email+"@rulingcom.com" | ||||
| #       new_user = User.new :email=> email | ||||
| #       new_user.save | ||||
| #     end | ||||
| #     #MRK = Member Role Key    SRK=Sub Role Key | ||||
| #     @stud_MRK = Role.first(conditions:{key:"Stud"}) | ||||
| #     @teacher_MRK = Role.first(conditions:{key:"Teacher"}) | ||||
| #     @staff_MRK = Role.first(conditions:{key:"Staff"}) | ||||
|      | ||||
|     @graduated_SRK = SubRole.first(conditions:{key:"graduated_school"}) | ||||
|     @under_graduated_SRK = SubRole.first(conditions:{key:"undergraduated_school"}) | ||||
|     @ta_SRK = SubRole.first(conditions:{key:"TA"}) | ||||
|     @senior_SRK = SubRole.first(conditions:{key:"Senior"}) | ||||
| #     @graduated_SRK = SubRole.first(conditions:{key:"graduated_school"}) | ||||
| #     @under_graduated_SRK = SubRole.first(conditions:{key:"undergraduated_school"}) | ||||
| #     @ta_SRK = SubRole.first(conditions:{key:"TA"}) | ||||
| #     @senior_SRK = SubRole.first(conditions:{key:"Senior"}) | ||||
|      | ||||
|     @stud_MRK.sub_roles += [@graduated,@under_graduated,@ta] | ||||
|     @stud_MRK.save! | ||||
| #     @stud_MRK.sub_roles += [@graduated,@under_graduated,@ta] | ||||
| #     @stud_MRK.save! | ||||
|      | ||||
|     @teacher_MRK.sub_roles = [@senior] | ||||
|     @teacher_MRK.save! | ||||
| #     @teacher_MRK.sub_roles = [@senior] | ||||
| #     @teacher_MRK.save! | ||||
|      | ||||
|     @good_ug_stu_1 = User.first(conditions:{email:"a_good_ug_stud_1@rulingcom.com"})     | ||||
|     @good_ug_stu_2 = User.first(conditions:{email:"a_good_ug_stud_2@rulingcom.com"}) | ||||
|     @bad_ug_stu = User.first(conditions:{email:"a_bad_ug_stud@rulingcom.com"}) | ||||
| #     @good_ug_stu_1 = User.first(conditions:{email:"a_good_ug_stud_1@rulingcom.com"})     | ||||
| #     @good_ug_stu_2 = User.first(conditions:{email:"a_good_ug_stud_2@rulingcom.com"}) | ||||
| #     @bad_ug_stu = User.first(conditions:{email:"a_bad_ug_stud@rulingcom.com"}) | ||||
|      | ||||
|     @good_g_stu = User.first(conditions:{email:"a_good_g_stud@rulingcom.com"}) | ||||
|     @bad_g_stu = User.first(conditions:{email:"a_bad_g_stud@rulingcom.com"}) | ||||
|     @teacher = User.first(conditions:{email:"a_teacher@rulingcom.com"}) | ||||
|     @staff =  User.first(conditions:{email:"a_staff@rulingcom.com"}) | ||||
| #     @good_g_stu = User.first(conditions:{email:"a_good_g_stud@rulingcom.com"}) | ||||
| #     @bad_g_stu = User.first(conditions:{email:"a_bad_g_stud@rulingcom.com"}) | ||||
| #     @teacher = User.first(conditions:{email:"a_teacher@rulingcom.com"}) | ||||
| #     @staff =  User.first(conditions:{email:"a_staff@rulingcom.com"}) | ||||
|      | ||||
|     #setting Roles for users | ||||
|     @good_g_stu.role = @stud_MRK | ||||
|     @bad_g_stu.role = @stud_MRK | ||||
|     @good_ug_stu_1.role = @stud_MRK | ||||
|     @good_ug_stu_2.role = @stud_MRK | ||||
|     @bad_ug_stu.role = @stud_MRK | ||||
| #     #setting Roles for users | ||||
| #     @good_g_stu.role = @stud_MRK | ||||
| #     @bad_g_stu.role = @stud_MRK | ||||
| #     @good_ug_stu_1.role = @stud_MRK | ||||
| #     @good_ug_stu_2.role = @stud_MRK | ||||
| #     @bad_ug_stu.role = @stud_MRK | ||||
|      | ||||
|     @good_g_stu.sub_roles = [@graduated_SRK,@ta_SRK] | ||||
|     @bad_g_stu.sub_roles << @graduated_SRK | ||||
|     @good_ug_stu_1.sub_roles << @under_graduated_SRK | ||||
|     @good_ug_stu_2.sub_roles << @under_graduated_SRK | ||||
|     @bad_ug_stu.sub_roles << @under_graduated_SRK | ||||
| #     @good_g_stu.sub_roles = [@graduated_SRK,@ta_SRK] | ||||
| #     @bad_g_stu.sub_roles << @graduated_SRK | ||||
| #     @good_ug_stu_1.sub_roles << @under_graduated_SRK | ||||
| #     @good_ug_stu_2.sub_roles << @under_graduated_SRK | ||||
| #     @bad_ug_stu.sub_roles << @under_graduated_SRK | ||||
| 
 | ||||
|     @teacher.role = @teacher_MRK | ||||
|     @staff.role = @staff_MRK | ||||
| #     @teacher.role = @teacher_MRK | ||||
| #     @staff.role = @staff_MRK | ||||
| 
 | ||||
|     @good_g_stu.save! | ||||
|     @bad_g_stu.save! | ||||
|     @good_ug_stu_1.save! | ||||
|     @good_ug_stu_2.save! | ||||
|     @bad_ug_stu.save! | ||||
| #     @good_g_stu.save! | ||||
| #     @bad_g_stu.save! | ||||
| #     @good_ug_stu_1.save! | ||||
| #     @good_ug_stu_2.save! | ||||
| #     @bad_ug_stu.save! | ||||
|      | ||||
|     @teacher.save! | ||||
|     @staff.save! | ||||
| #     @teacher.save! | ||||
| #     @staff.save! | ||||
| 
 | ||||
|   end | ||||
|   describe "Starting a ClassBulletin Auth for teacher , staff and ta" do | ||||
|     before do | ||||
|       @bulletin_app_auth = AppAuth.new() | ||||
|       #all teacher and staff has access right | ||||
|       @bulletin_app_auth.roles = [@teacher_MRK,@staff_MRK] | ||||
|       #all person with TA sub_role has access right | ||||
|       @bulletin_app_auth.sub_roles << @ta_SRK | ||||
| #   end | ||||
| #   describe "Starting a ClassBulletin Auth for teacher , staff and ta" do | ||||
| #     before do | ||||
| #       @bulletin_app_auth = AppAuth.new() | ||||
| #       #all teacher and staff has access right | ||||
| #       @bulletin_app_auth.roles = [@teacher_MRK,@staff_MRK] | ||||
| #       #all person with TA sub_role has access right | ||||
| #       @bulletin_app_auth.sub_roles << @ta_SRK | ||||
| 
 | ||||
|       #a_bad_ug_stud add to block to bulletin_app_auth  | ||||
|       #@bulletin_app_auth.blocked_users << @bad_ug_stu | ||||
| #       #a_bad_ug_stud add to block to bulletin_app_auth  | ||||
| #       #@bulletin_app_auth.blocked_users << @bad_ug_stu | ||||
| 
 | ||||
|       #all teacher has access right | ||||
|       # @bulletin_app_auth.roles << @teacher_MRK | ||||
| #       #all teacher has access right | ||||
| #       # @bulletin_app_auth.roles << @teacher_MRK | ||||
| 
 | ||||
|       # @bulletin_app_auth.privilege_users << @staff | ||||
|       @bulletin_app_auth.save! | ||||
|     end | ||||
|     context "Should just initialize all obj that is needed" do | ||||
| #       # @bulletin_app_auth.privilege_users << @staff | ||||
| #       @bulletin_app_auth.save! | ||||
| #     end | ||||
| #     context "Should just initialize all obj that is needed" do | ||||
| 
 | ||||
|       it "Testing @bulletin_app_auth init result" do | ||||
|         @bulletin_app_auth.roles.should have(2).item     #teacher staff | ||||
|         @bulletin_app_auth.sub_roles.should have(1).item  #ta | ||||
|       end | ||||
| #       it "Testing @bulletin_app_auth init result" do | ||||
| #         @bulletin_app_auth.roles.should have(2).item     #teacher staff | ||||
| #         @bulletin_app_auth.sub_roles.should have(1).item  #ta | ||||
| #       end | ||||
| 
 | ||||
|       it "@bulletin_app_auth should have Roles: Staff , Teacher " do | ||||
|         key_ary = @bulletin_app_auth.roles.collect do |role| | ||||
|           role.key | ||||
|         end | ||||
|         key_ary.sort.should == ["Staff","Teacher"].sort | ||||
|       end | ||||
| #       it "@bulletin_app_auth should have Roles: Staff , Teacher " do | ||||
| #         key_ary = @bulletin_app_auth.roles.collect do |role| | ||||
| #           role.key | ||||
| #         end | ||||
| #         key_ary.sort.should == ["Staff","Teacher"].sort | ||||
| #       end | ||||
|        | ||||
|       it "bulletin_app_auth should have 3 auth users" do | ||||
|         user_ary = [@teacher,@staff,@good_g_stu] | ||||
|        @bulletin_app_auth.auth_users.sort.should == user_ary.sort   | ||||
|        check_user_has_app user_ary | ||||
|       end | ||||
| #       it "bulletin_app_auth should have 3 auth users" do | ||||
| #         user_ary = [@teacher,@staff,@good_g_stu] | ||||
| #        @bulletin_app_auth.auth_users.sort.should == user_ary.sort   | ||||
| #        check_user_has_app user_ary | ||||
| #       end | ||||
|        | ||||
|       it "Adding a undergraduate stud into app_auth by privilege list" do | ||||
|         user_ary = [@teacher,@staff,@good_g_stu,@good_ug_stu_1] | ||||
|        @bulletin_app_auth.add_user_to_privilege_list  @good_ug_stu_1 | ||||
|        @bulletin_app_auth.auth_users.sort.should == user_ary.sort   | ||||
|        check_user_has_app user_ary        | ||||
|       end | ||||
| #       it "Adding a undergraduate stud into app_auth by privilege list" do | ||||
| #         user_ary = [@teacher,@staff,@good_g_stu,@good_ug_stu_1] | ||||
| #        @bulletin_app_auth.add_user_to_privilege_list  @good_ug_stu_1 | ||||
| #        @bulletin_app_auth.auth_users.sort.should == user_ary.sort   | ||||
| #        check_user_has_app user_ary        | ||||
| #       end | ||||
|        | ||||
|       it "Adding all graudated-stud into app_auth" do | ||||
|        user_ary = [@teacher,@staff,@good_g_stu,@bad_g_stu] | ||||
|        @bulletin_app_auth.add_sub_role  @graduated_SRK | ||||
|        @bulletin_app_auth.auth_users.sort.should == user_ary.sort   | ||||
|        check_user_has_app user_ary | ||||
|       end | ||||
| #       it "Adding all graudated-stud into app_auth" do | ||||
| #        user_ary = [@teacher,@staff,@good_g_stu,@bad_g_stu] | ||||
| #        @bulletin_app_auth.add_sub_role  @graduated_SRK | ||||
| #        @bulletin_app_auth.auth_users.sort.should == user_ary.sort   | ||||
| #        check_user_has_app user_ary | ||||
| #       end | ||||
|        | ||||
|       it "Blocking bad-graduate student" do | ||||
|         user_ary =[@teacher,@staff,@good_g_stu] | ||||
|        @bulletin_app_auth.add_sub_role  @graduated_SRK | ||||
|        @bulletin_app_auth.add_user_to_black_list @bad_g_stu | ||||
|        @bulletin_app_auth.auth_users_after_block_list.sort.should == user_ary.sort   | ||||
|        check_user_has_app user_ary | ||||
|       end | ||||
| #       it "Blocking bad-graduate student" do | ||||
| #         user_ary =[@teacher,@staff,@good_g_stu] | ||||
| #        @bulletin_app_auth.add_sub_role  @graduated_SRK | ||||
| #        @bulletin_app_auth.add_user_to_black_list @bad_g_stu | ||||
| #        @bulletin_app_auth.auth_users_after_block_list.sort.should == user_ary.sort   | ||||
| #        check_user_has_app user_ary | ||||
| #       end | ||||
|        | ||||
|       it "Removing all graudated-stud from app_auth" do | ||||
|         user_ary =[@teacher,@staff,@good_g_stu] | ||||
|         @bulletin_app_auth.add_sub_role  @graduated_SRK | ||||
|         @bulletin_app_auth.remove_sub_role  @graduated_SRK | ||||
|        @bulletin_app_auth.auth_users.sort.should == user_ary.sort   | ||||
|        check_user_has_app user_ary | ||||
|       end | ||||
| #       it "Removing all graudated-stud from app_auth" do | ||||
| #         user_ary =[@teacher,@staff,@good_g_stu] | ||||
| #         @bulletin_app_auth.add_sub_role  @graduated_SRK | ||||
| #         @bulletin_app_auth.remove_sub_role  @graduated_SRK | ||||
| #        @bulletin_app_auth.auth_users.sort.should == user_ary.sort   | ||||
| #        check_user_has_app user_ary | ||||
| #       end | ||||
|        | ||||
| 
 | ||||
|       # it "@bulletin_app_auth should have one Privialage user which is belongs to Staff" do | ||||
|       #   p_user_ary = @bulletin_app_auth.privilege_users.collect do |p_user| | ||||
|       #     p_user.roles.key | ||||
|       #   end | ||||
|       #   p_user_ary.should include("Staff") | ||||
|       # end | ||||
| #       # it "@bulletin_app_auth should have one Privialage user which is belongs to Staff" do | ||||
| #       #   p_user_ary = @bulletin_app_auth.privilege_users.collect do |p_user| | ||||
| #       #     p_user.roles.key | ||||
| #       #   end | ||||
| #       #   p_user_ary.should include("Staff") | ||||
| #       # end | ||||
|        | ||||
|       # it "@bulletin_app_auth should have one student listed at blocklist" do | ||||
|       #   @bad_stu = User.first(conditions:{email:"a_bad_g_stud@rulingcom.com"}) | ||||
|       #   @bulletin_app_auth.blocked_users.should have(1).item | ||||
|       #   @bulletin_app_auth.blocked_users.should include(@bad_stu) | ||||
|       # end | ||||
| #       # it "@bulletin_app_auth should have one student listed at blocklist" do | ||||
| #       #   @bad_stu = User.first(conditions:{email:"a_bad_g_stud@rulingcom.com"}) | ||||
| #       #   @bulletin_app_auth.blocked_users.should have(1).item | ||||
| #       #   @bulletin_app_auth.blocked_users.should include(@bad_stu) | ||||
| #       # end | ||||
|            | ||||
|     #   it "[Development #1]-1.Authorizing roles: roles + blocklist" do | ||||
|     #     @good_stu = User.first(conditions:{email:"a_good_g_stud@rulingcom.com"}) | ||||
|     #     @teacher = User.first(conditions:{email:"a_teacher@rulingcom.com"}) | ||||
|     #     @staff =  User.first(conditions:{email:"a_staff@rulingcom.com"}) | ||||
|     #     ary = [@good_stu,@teacher,@staff] | ||||
|     #     @bulletin_app_auth.auth_users_after_block_list.should == ary | ||||
|     #   end | ||||
|     #    | ||||
|     #   it "[Development #1]-2.Authorizing single users: list of users [new_user1~2]" do | ||||
|     #     user_emails = ["new_user1","new_user2","new_user3","new_user4"] | ||||
|     #     user_emails.each do |user_email| | ||||
|     #       email=user_email+"@rulingcom.com" | ||||
|     #       new_user = User.new :email=> email | ||||
|     #       new_user.save | ||||
|     #     end | ||||
|     #     user1= User.first(conditions:{email:"new_user1@rulingcom.com"}) | ||||
|     #     user2= User.first(conditions:{email:"new_user2@rulingcom.com"}) | ||||
|     #     user3= User.first(conditions:{email:"new_user3@rulingcom.com"}) | ||||
|     #     user4= User.first(conditions:{email:"new_user4@rulingcom.com"}) | ||||
|     #      | ||||
|     #     @bulletin_app_auth.privilege_users << user1 | ||||
|     #     @bulletin_app_auth.privilege_users << user2 | ||||
|     #      | ||||
|     #     @bulletin_app_auth.auth_users_after_block_list.should include(user1,user2) | ||||
|     #     @bulletin_app_auth.auth_users_after_block_list.should_not include(user3,user4) | ||||
|     #      | ||||
|     #   end | ||||
|     #    | ||||
|     #   it "[Development #1]-3.Authorizing roles and single users: roles + blocklist + list of users" do | ||||
|     #     @bulletin_app_auth.auth_users.should have(7).item  | ||||
|     #   end | ||||
|     #    | ||||
|     #   it "[Development #1]-4.Authorizing all: blocklist" do | ||||
|     #     @bad_stu = User.first(conditions:{email:"a_bad_g_stud@rulingcom.com"}) | ||||
|     #     @new_bulletin_app_auth = (AppAuth.new :all => true) | ||||
|     #     @new_bulletin_app_auth.blocked_users << @bad_stu  | ||||
|     #      | ||||
|     #     @new_bulletin_app_auth.auth_users.should == User.all.entries | ||||
|     #     @new_bulletin_app_auth.auth_users_after_block_list.should_not include(@bad_stu) | ||||
|     #     @new_bulletin_app_auth.save! | ||||
|     #   end | ||||
|       def check_user_has_app(user_ary) | ||||
|         user_ary.each do |user| | ||||
|          user.avb_apps.should include(@bulletin_app_auth)  | ||||
|         end | ||||
|       end | ||||
|      end | ||||
| #     #   it "[Development #1]-1.Authorizing roles: roles + blocklist" do | ||||
| #     #     @good_stu = User.first(conditions:{email:"a_good_g_stud@rulingcom.com"}) | ||||
| #     #     @teacher = User.first(conditions:{email:"a_teacher@rulingcom.com"}) | ||||
| #     #     @staff =  User.first(conditions:{email:"a_staff@rulingcom.com"}) | ||||
| #     #     ary = [@good_stu,@teacher,@staff] | ||||
| #     #     @bulletin_app_auth.auth_users_after_block_list.should == ary | ||||
| #     #   end | ||||
| #     #    | ||||
| #     #   it "[Development #1]-2.Authorizing single users: list of users [new_user1~2]" do | ||||
| #     #     user_emails = ["new_user1","new_user2","new_user3","new_user4"] | ||||
| #     #     user_emails.each do |user_email| | ||||
| #     #       email=user_email+"@rulingcom.com" | ||||
| #     #       new_user = User.new :email=> email | ||||
| #     #       new_user.save | ||||
| #     #     end | ||||
| #     #     user1= User.first(conditions:{email:"new_user1@rulingcom.com"}) | ||||
| #     #     user2= User.first(conditions:{email:"new_user2@rulingcom.com"}) | ||||
| #     #     user3= User.first(conditions:{email:"new_user3@rulingcom.com"}) | ||||
| #     #     user4= User.first(conditions:{email:"new_user4@rulingcom.com"}) | ||||
| #     #      | ||||
| #     #     @bulletin_app_auth.privilege_users << user1 | ||||
| #     #     @bulletin_app_auth.privilege_users << user2 | ||||
| #     #      | ||||
| #     #     @bulletin_app_auth.auth_users_after_block_list.should include(user1,user2) | ||||
| #     #     @bulletin_app_auth.auth_users_after_block_list.should_not include(user3,user4) | ||||
| #     #      | ||||
| #     #   end | ||||
| #     #    | ||||
| #     #   it "[Development #1]-3.Authorizing roles and single users: roles + blocklist + list of users" do | ||||
| #     #     @bulletin_app_auth.auth_users.should have(7).item  | ||||
| #     #   end | ||||
| #     #    | ||||
| #     #   it "[Development #1]-4.Authorizing all: blocklist" do | ||||
| #     #     @bad_stu = User.first(conditions:{email:"a_bad_g_stud@rulingcom.com"}) | ||||
| #     #     @new_bulletin_app_auth = (AppAuth.new :all => true) | ||||
| #     #     @new_bulletin_app_auth.blocked_users << @bad_stu  | ||||
| #     #      | ||||
| #     #     @new_bulletin_app_auth.auth_users.should == User.all.entries | ||||
| #     #     @new_bulletin_app_auth.auth_users_after_block_list.should_not include(@bad_stu) | ||||
| #     #     @new_bulletin_app_auth.save! | ||||
| #     #   end | ||||
| #       def check_user_has_app(user_ary) | ||||
| #         user_ary.each do |user| | ||||
| #          user.avb_apps.should include(@bulletin_app_auth)  | ||||
| #         end | ||||
| #       end | ||||
| #      end | ||||
|      | ||||
|      | ||||
|      | ||||
|   end | ||||
| #   end | ||||
| 
 | ||||
| end | ||||
| # end | ||||
|  | @ -1,81 +1,81 @@ | |||
| require 'spec_helper' | ||||
| require 'ruby-debug' | ||||
| # require 'spec_helper' | ||||
| # require 'ruby-debug' | ||||
| 
 | ||||
| describe AppAuth do  | ||||
| # describe AppAuth do  | ||||
|    | ||||
|   before(:all)  do | ||||
|      @app_ary = [ | ||||
|                 {"name" => "G_app_1" , "all" => false,"blockusers" => ["a_bad_stud@rulingcom.com"]}, | ||||
|                 {"name" => "G_app_2" , "all" => true,"blockusers" => ["a_bad_stud@rulingcom.com"]}, | ||||
|                 {"name" => "G_app_3_for_bad" , "all" => true,"blockusers" => []} | ||||
|       ] | ||||
| #   before(:all)  do | ||||
| #      @app_ary = [ | ||||
| #                 {"name" => "G_app_1" , "all" => false,"blockusers" => ["a_bad_stud@rulingcom.com"]}, | ||||
| #                 {"name" => "G_app_2" , "all" => true,"blockusers" => ["a_bad_stud@rulingcom.com"]}, | ||||
| #                 {"name" => "G_app_3_for_bad" , "all" => true,"blockusers" => []} | ||||
| #       ] | ||||
|        | ||||
|       @app_ary.each do |t| | ||||
|         a = ModuleApp.new :title => t["name"] | ||||
|         blocked_users = t["blockusers"].collect do |b_user| | ||||
|           User.first(conditions:{email:b_user}) | ||||
|         end | ||||
|         a.create_app_auth :all=> t["all"],:blocked_users => blocked_users | ||||
|         a.save! | ||||
|       end       | ||||
|       @good_stud_become_bad = User.first(conditions:{email:"a_good_stud@rulingcom.com"}) | ||||
|       @bad_stud_become_good = User.first(conditions:{email:"a_bad_stud@rulingcom.com"}) | ||||
|       @g_app_1 = ModuleApp.first(conditions:{title:"G_app_1"}) | ||||
|       @g_app_2 = ModuleApp.first(conditions:{title:"G_app_2"}) | ||||
|       @g_app_3 = ModuleApp.first(conditions:{title:"G_app_3_for_bad"}) | ||||
|   end | ||||
| #       @app_ary.each do |t| | ||||
| #         a = ModuleApp.new :title => t["name"] | ||||
| #         blocked_users = t["blockusers"].collect do |b_user| | ||||
| #           User.first(conditions:{email:b_user}) | ||||
| #         end | ||||
| #         a.create_app_auth :all=> t["all"],:blocked_users => blocked_users | ||||
| #         a.save! | ||||
| #       end       | ||||
| #       @good_stud_become_bad = User.first(conditions:{email:"a_good_stud@rulingcom.com"}) | ||||
| #       @bad_stud_become_good = User.first(conditions:{email:"a_bad_stud@rulingcom.com"}) | ||||
| #       @g_app_1 = ModuleApp.first(conditions:{title:"G_app_1"}) | ||||
| #       @g_app_2 = ModuleApp.first(conditions:{title:"G_app_2"}) | ||||
| #       @g_app_3 = ModuleApp.first(conditions:{title:"G_app_3_for_bad"}) | ||||
| #   end | ||||
|    | ||||
|   describe "[Init status check]" do | ||||
|     it "bad_stud_become_good status " do | ||||
|       @bad_stud_become_good.avb_apps.should_not include @g_app_1.app_auth | ||||
|       @bad_stud_become_good.avb_apps.should_not include @g_app_2.app_auth | ||||
|       @bad_stud_become_good.avb_apps.should include @g_app_3.app_auth | ||||
|     end | ||||
| #   describe "[Init status check]" do | ||||
| #     it "bad_stud_become_good status " do | ||||
| #       @bad_stud_become_good.avb_apps.should_not include @g_app_1.app_auth | ||||
| #       @bad_stud_become_good.avb_apps.should_not include @g_app_2.app_auth | ||||
| #       @bad_stud_become_good.avb_apps.should include @g_app_3.app_auth | ||||
| #     end | ||||
|      | ||||
|     it "good_stud_become_bad status " do | ||||
|       @good_stud_become_bad.avb_apps.should_not include @g_app_1.app_auth | ||||
|       @good_stud_become_bad.avb_apps.should include @g_app_2.app_auth | ||||
|       @good_stud_become_bad.avb_apps.should include @g_app_3.app_auth | ||||
|     end | ||||
|   end | ||||
| #     it "good_stud_become_bad status " do | ||||
| #       @good_stud_become_bad.avb_apps.should_not include @g_app_1.app_auth | ||||
| #       @good_stud_become_bad.avb_apps.should include @g_app_2.app_auth | ||||
| #       @good_stud_become_bad.avb_apps.should include @g_app_3.app_auth | ||||
| #     end | ||||
| #   end | ||||
|    | ||||
|   describe ".add_user_to_black_list sutd" do | ||||
|     it "When good stud is blocked with app1 and app2" do | ||||
|       @g_app_1.app_auth.add_user_to_black_list @good_stud_become_bad | ||||
|       @g_app_2.app_auth.add_user_to_black_list @good_stud_become_bad | ||||
|       @good_stud_become_bad.avb_apps.should_not include @g_app_1.app_auth | ||||
|       @good_stud_become_bad.avb_apps.should_not include @g_app_2.app_auth | ||||
|     end | ||||
|   end | ||||
| #   describe ".add_user_to_black_list sutd" do | ||||
| #     it "When good stud is blocked with app1 and app2" do | ||||
| #       @g_app_1.app_auth.add_user_to_black_list @good_stud_become_bad | ||||
| #       @g_app_2.app_auth.add_user_to_black_list @good_stud_become_bad | ||||
| #       @good_stud_become_bad.avb_apps.should_not include @g_app_1.app_auth | ||||
| #       @good_stud_become_bad.avb_apps.should_not include @g_app_2.app_auth | ||||
| #     end | ||||
| #   end | ||||
|    | ||||
|   describe ".remove_user_from_black_list sutd" do | ||||
|     it "When bad stud is authed with app1 and app2" do | ||||
|       @g_app_1.app_auth.remove_user_from_black_list @bad_stud_become_good | ||||
|       @g_app_2.app_auth.remove_user_from_black_list @bad_stud_become_good | ||||
|       #@bad_stud_become_good.avb_apps.should include @g_app_1.app_auth | ||||
|       @bad_stud_become_good.avb_apps.should include @g_app_2.app_auth | ||||
|     end | ||||
|   end | ||||
| #   describe ".remove_user_from_black_list sutd" do | ||||
| #     it "When bad stud is authed with app1 and app2" do | ||||
| #       @g_app_1.app_auth.remove_user_from_black_list @bad_stud_become_good | ||||
| #       @g_app_2.app_auth.remove_user_from_black_list @bad_stud_become_good | ||||
| #       #@bad_stud_become_good.avb_apps.should include @g_app_1.app_auth | ||||
| #       @bad_stud_become_good.avb_apps.should include @g_app_2.app_auth | ||||
| #     end | ||||
| #   end | ||||
|    | ||||
|   describe ".add_user_to_privilege_list sutd" do | ||||
|     it "When bad stud is auth for one more app" do | ||||
|       @bad_stud_become_good.avb_apps.should_not include @g_app_1.app_auth   #shouldn't have at first time since app1 is not sat for all | ||||
|       @g_app_1.app_auth.add_user_to_privilege_list @bad_stud_become_good  #change status | ||||
|       @bad_stud_become_good.avb_apps.should include @g_app_1.app_auth  #check | ||||
|     end | ||||
|   end | ||||
| #   describe ".add_user_to_privilege_list sutd" do | ||||
| #     it "When bad stud is auth for one more app" do | ||||
| #       @bad_stud_become_good.avb_apps.should_not include @g_app_1.app_auth   #shouldn't have at first time since app1 is not sat for all | ||||
| #       @g_app_1.app_auth.add_user_to_privilege_list @bad_stud_become_good  #change status | ||||
| #       @bad_stud_become_good.avb_apps.should include @g_app_1.app_auth  #check | ||||
| #     end | ||||
| #   end | ||||
|    | ||||
|   describe ".remove_user_from_privilege_list sutd" do | ||||
|     it "admin mistake. remove user from privilege list" do | ||||
|       @g_app_1.app_auth.remove_user_from_privilege_list @bad_stud_become_good | ||||
|       @bad_stud_become_good.avb_apps.should_not include @g_app_1.app_auth | ||||
|     end | ||||
|   end | ||||
| #   describe ".remove_user_from_privilege_list sutd" do | ||||
| #     it "admin mistake. remove user from privilege list" do | ||||
| #       @g_app_1.app_auth.remove_user_from_privilege_list @bad_stud_become_good | ||||
| #       @bad_stud_become_good.avb_apps.should_not include @g_app_1.app_auth | ||||
| #     end | ||||
| #   end | ||||
|    | ||||
|   after(:all) do | ||||
|     @app_ary.each do |item| | ||||
|       ModuleApp.first(conditions: {title: item["name"]}).destroy | ||||
|     end | ||||
|   end | ||||
| #   after(:all) do | ||||
| #     @app_ary.each do |item| | ||||
| #       ModuleApp.first(conditions: {title: item["name"]}).destroy | ||||
| #     end | ||||
| #   end | ||||
|    | ||||
| end | ||||
| # end | ||||
|  | @ -0,0 +1,12 @@ | |||
| require 'spec_helper' | ||||
| describe AttributeField do | ||||
|   describe "#list field" do | ||||
|     context "when field is in type text_field(without add more)" do | ||||
|       before(:each) do | ||||
|         @attribute_field = AttributeField.new(:key=>'test',:markup=>"text_field") | ||||
|          | ||||
|          | ||||
|       end | ||||
|     end | ||||
|   end | ||||
| end | ||||
|  | @ -0,0 +1,63 @@ | |||
| #encoding: UTF-8 | ||||
| require 'spec_helper' | ||||
| 
 | ||||
| describe AttributeValue do | ||||
|   describe "#attribute_value" do | ||||
|     context "Data should be able to input and out put as aspect" | ||||
| 
 | ||||
|     before do | ||||
|       @af = AttributeField.find '5052cf9f2b5c49a742000005' | ||||
|       @user = User.where(email:'chris@rulingcom.com').first | ||||
|       @av = AttributeValue.last | ||||
|     end #end before | ||||
| 
 | ||||
|     [true,false].each do |locale_sat| | ||||
|       LIST[:markups].each do |markup| | ||||
|         @av = nil | ||||
|           it "[#{markup[0]}]Input: should save data at right way when local is set to #{locale_sat}" do | ||||
|             @af.markup = markup[0] | ||||
|             @av = nil | ||||
|             @input_value = assume_result = case markup[0] | ||||
|               when 'text_field','text_area' | ||||
|                   (locale_sat ?  {"en"=> "lalala","zh_tw"=>"拉拉拉"} : "hahaha") | ||||
|                 when 'select','radio_button' | ||||
|                   "1" | ||||
|                 when 'date' | ||||
|                   {"(1i)"=>Date.today.year.to_s,"(2i)"=>Date.today.month.to_s,"(3i)"=>Date.today.day.to_s} | ||||
|                 when 'checkbox' | ||||
|                   {"1"=>"true", "3"=>"true"} | ||||
|               end #end of case | ||||
|               assume_result = ["1","3"] if markup[0] == 'checkbox' | ||||
|               @af.locale = locale_sat | ||||
|               @af.save | ||||
|               @data_hash = {"attribute_field_id" => @af.id,"value" => @input_value} | ||||
|               @av = @user.attribute_values.build(@data_hash) | ||||
|               @av.save  | ||||
| 
 | ||||
|               @av.value.should == assume_result | ||||
|               # @av.destroy | ||||
|           end | ||||
| 
 | ||||
|           it "[#{markup[0]}]Output(just for show): should output data at right way when local is set to #{locale_sat}" do | ||||
|             locale = I18n.locale | ||||
|             assume_result = case markup[0] | ||||
|               when 'text_area' | ||||
|                 (locale_sat ?  "拉拉拉" : "hahaha") | ||||
|               when 'text_field' | ||||
|                   (locale_sat ?  "拉拉拉" : "hahaha") | ||||
|                 when 'select','radio_button' | ||||
|                   (locale_sat ?  "男性" : "男性") | ||||
|                 when 'date' | ||||
|                   Date.today | ||||
|                 when 'checkbox' | ||||
|                   (locale_sat ?  "男性,不公開" : "男性,不公開") | ||||
|               end #end of case | ||||
| 
 | ||||
|             @av.get_value_by_locale(locale).should == assume_result | ||||
|           end | ||||
|            | ||||
|       end #end of LIST loop | ||||
|     end | ||||
| 
 | ||||
|   end | ||||
| end | ||||
|  | @ -1,113 +1,113 @@ | |||
| require 'spec_helper' | ||||
|   # require 'spec_helper' | ||||
| 
 | ||||
| describe Role do  | ||||
|   before do | ||||
|     @role = Role.create(:key => 'teacher',  | ||||
|                         :i18n_variable => {:key => 'teacher', :en => 'Teacher', :zh_tw => 'Teacher in Chinese', :document_class => 'Role'}, | ||||
|                         :sub_roles => [{:key => 'undergrad',  | ||||
|                                         :i18n_variable => {:key => 'yeah', :en => 'Yeah', :zh_tw => 'Yeah', :document_class => 'Role'}, | ||||
|                                         :attribute_fields => [{:key => 'department'},  | ||||
|                                                               {:key => 'room'}]},  | ||||
|                                        {:key => 'master',  | ||||
|                                         :attribute_fields => [{:key => 'department'}]}]) | ||||
|   end | ||||
|   describe 'New role' do | ||||
|     describe '#Role' do | ||||
|       it 'should have :built_in false' do | ||||
|         @role.built_in.should be false | ||||
|       end | ||||
|       it 'should have :disabled false' do | ||||
|         @role.disabled.should be false | ||||
|       end | ||||
|       it 'should have a i18n_variable' do | ||||
|         @role.i18n_variable.should be_an_instance_of I18nVariable | ||||
|       end | ||||
|       it 'should create sub_roles' do | ||||
|         @role.should have(2).sub_roles | ||||
|       end | ||||
|       it 'should create attribute_fields' do | ||||
|         @role.sub_roles[1].should have(1).attribute_fields | ||||
|       end | ||||
|     end | ||||
|     describe '#SubRole' do | ||||
|       it 'should have :built_in false' do | ||||
|         @role.sub_roles[0].built_in.should be false | ||||
|       end | ||||
|       it 'should have :disabled false' do | ||||
|         @role.sub_roles[0].disabled.should be false | ||||
|       end | ||||
|       it 'should have a i18n_variable' do | ||||
|         @role.sub_roles[0].i18n_variable.should be_an_instance_of I18nVariable | ||||
|       end | ||||
|     end | ||||
|     describe '#AttributeField' do | ||||
|       it 'should have :built_in false' do | ||||
|         @role.sub_roles[0].attribute_fields[0].built_in.should be false | ||||
|       end | ||||
|       it 'should have :disabled false' do | ||||
|         @role.sub_roles[0].attribute_fields[0].disabled.should be false | ||||
|       end | ||||
|     end | ||||
|   end | ||||
|   describe 'Edit role' do | ||||
|     describe '#Role' do | ||||
|       before do | ||||
|         @role.update_attributes({:key => 'student', :i18n_variable => {:en => 'Student'}, | ||||
|                                   :sub_roles => [{:key => 'new',  | ||||
|                                                   :attribute_fields => [{:key => 'bob'},  | ||||
|                                                                         {:key => 'great'}]}, | ||||
|                                                   {:id => @role.sub_roles[0].id}, | ||||
|                                                   {:id => @role.sub_roles[1].id}]}) | ||||
|       end | ||||
|       it 'should not be the old :key' do | ||||
|         @role.key.should_not == 'teacher' | ||||
|       end | ||||
|       it 'should be the new :key' do | ||||
|         @role.key.should == 'student' | ||||
|       end | ||||
|       it 'should not be the old :i18n_variable[:en]' do | ||||
|         @role.i18n_variable[:en].should_not == 'Teacher' | ||||
|       end | ||||
|       it 'should be the new :i18n_variable[:en]' do | ||||
|         @role.i18n_variable[:en].should == 'Student' | ||||
|       end | ||||
|       it 'should have one more SubRole' do | ||||
|         @role.should have(3).sub_roles | ||||
|       end | ||||
|     end | ||||
|   end   | ||||
|   describe 'Destroy' do | ||||
|     describe '#AttributeField' do | ||||
|       before do | ||||
|         @role.update_attributes(:key => 'teacher',  | ||||
|                             :i18n_variable => {:key => 'teacher', :en => 'Teacher', :zh_tw => 'Teacher in Chinese', :document_class => 'Role'}, | ||||
|                             :sub_roles_attributes => {'0' => {:id => @role.sub_roles[0].id, | ||||
|                                             :key => 'undergrad',  | ||||
|                                             :attribute_fields_attributes => {'0' => {:id => @role.sub_roles[0].attribute_fields[0].id, | ||||
|                                                                    :key => 'department'},  | ||||
|                                                                   '1' => {:id => @role.sub_roles[0].attribute_fields[1].id, | ||||
|                                                                    :key => 'room', :_destroy => true}}}}) | ||||
|       end | ||||
|       it 'should have only one AttributeField for the first SubRole' do | ||||
|         @role.sub_roles[0].should have(1).attribute_fields | ||||
|       end | ||||
|     end   | ||||
|     describe '#I18nVariable' do | ||||
|       before do | ||||
|         @role.update_attributes(:key => 'teacher',  | ||||
|                             :i18n_variable_attributes => {:id => @role.i18n_variable.id, :key => 'teacher', :en => 'Teacher', :zh_tw => 'Teacher in Chinese', :document_class => 'Role', :_destroy => true}) | ||||
|       end | ||||
|       it 'should not have a I18nVariable' do | ||||
|         @role.i18n_variable.should_not be_an_instance_of I18nVariable | ||||
|       end | ||||
|     end | ||||
|     describe '#Role' do | ||||
|       it 'should destroy the I18nVariable' do | ||||
|         id = @role.i18n_variable.id | ||||
|         @role.destroy | ||||
|         lambda {I18nVariable.find(id)}.should raise_error | ||||
|       end | ||||
|     end | ||||
|   end | ||||
| # describe Role do  | ||||
| #   before do | ||||
| #     @role = Role.create(:key => 'teacher',  | ||||
| #                         :i18n_variable => {:key => 'teacher', :en => 'Teacher', :zh_tw => 'Teacher in Chinese', :document_class => 'Role'}, | ||||
| #                         :sub_roles => [{:key => 'undergrad',  | ||||
| #                                         :i18n_variable => {:key => 'yeah', :en => 'Yeah', :zh_tw => 'Yeah', :document_class => 'Role'}, | ||||
| #                                         :attribute_fields => [{:key => 'department'},  | ||||
| #                                                               {:key => 'room'}]},  | ||||
| #                                        {:key => 'master',  | ||||
| #                                         :attribute_fields => [{:key => 'department'}]}]) | ||||
| #   end | ||||
| #   describe 'New role' do | ||||
| #     describe '#Role' do | ||||
| #       it 'should have :built_in false' do | ||||
| #         @role.built_in.should be false | ||||
| #       end | ||||
| #       it 'should have :disabled false' do | ||||
| #         @role.disabled.should be false | ||||
| #       end | ||||
| #       it 'should have a i18n_variable' do | ||||
| #         @role.i18n_variable.should be_an_instance_of I18nVariable | ||||
| #       end | ||||
| #       it 'should create sub_roles' do | ||||
| #         @role.should have(2).sub_roles | ||||
| #       end | ||||
| #       it 'should create attribute_fields' do | ||||
| #         @role.sub_roles[1].should have(1).attribute_fields | ||||
| #       end | ||||
| #     end | ||||
| #     describe '#SubRole' do | ||||
| #       it 'should have :built_in false' do | ||||
| #         @role.sub_roles[0].built_in.should be false | ||||
| #       end | ||||
| #       it 'should have :disabled false' do | ||||
| #         @role.sub_roles[0].disabled.should be false | ||||
| #       end | ||||
| #       it 'should have a i18n_variable' do | ||||
| #         @role.sub_roles[0].i18n_variable.should be_an_instance_of I18nVariable | ||||
| #       end | ||||
| #     end | ||||
| #     describe '#AttributeField' do | ||||
| #       it 'should have :built_in false' do | ||||
| #         @role.sub_roles[0].attribute_fields[0].built_in.should be false | ||||
| #       end | ||||
| #       it 'should have :disabled false' do | ||||
| #         @role.sub_roles[0].attribute_fields[0].disabled.should be false | ||||
| #       end | ||||
| #     end | ||||
| #   end | ||||
| #   describe 'Edit role' do | ||||
| #     describe '#Role' do | ||||
| #       before do | ||||
| #         @role.update_attributes({:key => 'student', :i18n_variable => {:en => 'Student'}, | ||||
| #                                   :sub_roles => [{:key => 'new',  | ||||
| #                                                   :attribute_fields => [{:key => 'bob'},  | ||||
| #                                                                         {:key => 'great'}]}, | ||||
| #                                                   {:id => @role.sub_roles[0].id}, | ||||
| #                                                   {:id => @role.sub_roles[1].id}]}) | ||||
| #       end | ||||
| #       it 'should not be the old :key' do | ||||
| #         @role.key.should_not == 'teacher' | ||||
| #       end | ||||
| #       it 'should be the new :key' do | ||||
| #         @role.key.should == 'student' | ||||
| #       end | ||||
| #       it 'should not be the old :i18n_variable[:en]' do | ||||
| #         @role.i18n_variable[:en].should_not == 'Teacher' | ||||
| #       end | ||||
| #       it 'should be the new :i18n_variable[:en]' do | ||||
| #         @role.i18n_variable[:en].should == 'Student' | ||||
| #       end | ||||
| #       it 'should have one more SubRole' do | ||||
| #         @role.should have(3).sub_roles | ||||
| #       end | ||||
| #     end | ||||
| #   end   | ||||
| #   describe 'Destroy' do | ||||
| #     describe '#AttributeField' do | ||||
| #       before do | ||||
| #         @role.update_attributes(:key => 'teacher',  | ||||
| #                             :i18n_variable => {:key => 'teacher', :en => 'Teacher', :zh_tw => 'Teacher in Chinese', :document_class => 'Role'}, | ||||
| #                             :sub_roles_attributes => {'0' => {:id => @role.sub_roles[0].id, | ||||
| #                                             :key => 'undergrad',  | ||||
| #                                             :attribute_fields_attributes => {'0' => {:id => @role.sub_roles[0].attribute_fields[0].id, | ||||
| #                                                                    :key => 'department'},  | ||||
| #                                                                   '1' => {:id => @role.sub_roles[0].attribute_fields[1].id, | ||||
| #                                                                    :key => 'room', :_destroy => true}}}}) | ||||
| #       end | ||||
| #       it 'should have only one AttributeField for the first SubRole' do | ||||
| #         @role.sub_roles[0].should have(1).attribute_fields | ||||
| #       end | ||||
| #     end   | ||||
| #     describe '#I18nVariable' do | ||||
| #       before do | ||||
| #         @role.update_attributes(:key => 'teacher',  | ||||
| #                             :i18n_variable_attributes => {:id => @role.i18n_variable.id, :key => 'teacher', :en => 'Teacher', :zh_tw => 'Teacher in Chinese', :document_class => 'Role', :_destroy => true}) | ||||
| #       end | ||||
| #       it 'should not have a I18nVariable' do | ||||
| #         @role.i18n_variable.should_not be_an_instance_of I18nVariable | ||||
| #       end | ||||
| #     end | ||||
| #     describe '#Role' do | ||||
| #       it 'should destroy the I18nVariable' do | ||||
| #         id = @role.i18n_variable.id | ||||
| #         @role.destroy | ||||
| #         lambda {I18nVariable.find(id)}.should raise_error | ||||
| #       end | ||||
| #     end | ||||
| #   end | ||||
| 
 | ||||
| end | ||||
| # end | ||||
|  | @ -38,6 +38,7 @@ Spork.prefork do | |||
|     # automatically. This will be the default behavior in future versions of | ||||
|     # rspec-rails. | ||||
|     config.infer_base_class_for_anonymous_controllers = false | ||||
|      | ||||
|   end | ||||
| end | ||||
| 
 | ||||
|  |  | |||
|  | @ -1 +1,53 @@ | |||
| Hello~  I am your plugin profile | ||||
| <% | ||||
|   if @user | ||||
|     @bulletins = Bulletin.where(:create_user_id => @user.id).page(params[:page]).per(10) | ||||
|   else | ||||
|     @bulletins = Bulletin.all.page(params[:page]).per(10) | ||||
|   end | ||||
| 
 | ||||
| %> | ||||
| 
 | ||||
| <table class="table main-list"> | ||||
|   <thead> | ||||
|     <tr> | ||||
|       <th class="span1"><%= t('bulletin.category') %></th> | ||||
|       <th class="span3"><%= t('bulletin.title') %></th> | ||||
|       <th class="span1"><%= t('bulletin.start_date') %></th> | ||||
|       <th class="span1"><%= t('bulletin.end_date') %></th> | ||||
|       <th class="span1"><%= t('bulletin.tags') %></th> | ||||
|       <% if not @user%> | ||||
|         <th class="span1"><%= t('bulletin.last_modified') %></th> | ||||
|       <% end %> | ||||
|     </tr> | ||||
|   </thead> | ||||
|   <tbody id="tbody_bulletin" class="sort-holder"> | ||||
|     <% @bulletins.each do |bulletin| %>  | ||||
|       <tr id="<%= dom_id bulletin%>" class="with_action"> | ||||
|         <td><%= bulletin.bulletin_category.title%></td> | ||||
|         <td> | ||||
|           <% if bulletin.is_checked? %> | ||||
|             <%= link_to bulletin.title, panel_announcement_front_end_bulletin_path(bulletin, :category_id => bulletin.bulletin_category.id) rescue ''%> | ||||
|           <% else %> | ||||
|              <%= bulletin.title%> | ||||
|           <% end %> | ||||
|         </td> | ||||
|         <td><%= display_date_time(bulletin.postdate) %></td> | ||||
|         <% if not bulletin.deadline.nil?%> | ||||
|           <td><%= display_date_time(bulletin.deadline) %></td> | ||||
|         <%else%> | ||||
|           <td><%= t('bulletin.no_deadline') %></td> | ||||
|         <% end %> | ||||
|         <td> | ||||
|           <div class="label-group"> | ||||
|           <% bulletin.sorted_tags.each do |tag| %> | ||||
|             <span class="label label-tags"><%= tag[I18n.locale] %></span> | ||||
|           <% end %> | ||||
|           </div> | ||||
|         </td> | ||||
|         <% if not @user%> | ||||
|           <td><%= User.find(bulletin.create_user_id).name %></td> | ||||
|         <% end %> | ||||
|       </tr> | ||||
|     <% end %>  | ||||
|   </tbody> | ||||
| </table> | ||||
|  |  | |||
|  | @ -37,7 +37,6 @@ class Panel::Archive::BackEnd::ArchiveFileCategorysController < OrbitBackendCont | |||
|   # GET /archive_files/1/edit | ||||
|   def edit | ||||
|     @archive_file_category = ArchiveFileCategory.find(params[:id]) | ||||
|     @i18n_variable = @archive_file_category.i18n_variable	 | ||||
| 	 | ||||
| 	@url = panel_archive_back_end_archive_file_category_path(@archive_file_category) | ||||
| 
 | ||||
|  |  | |||
|  | @ -55,7 +55,6 @@ class Panel::Archive::BackEnd::ArchiveFilesController < OrbitBackendController | |||
|   # POST /archive_files.xml | ||||
|   def create | ||||
|     @archive_file = ArchiveFile.new(params[:archive_file]) | ||||
| 	 | ||||
|     @archive_file.create_user_id = current_user.id | ||||
|     @archive_file.update_user_id = current_user.id | ||||
| 
 | ||||
|  | @ -64,6 +63,8 @@ class Panel::Archive::BackEnd::ArchiveFilesController < OrbitBackendController | |||
|         format.html { redirect_to(panel_archive_back_end_archive_files_url) } | ||||
|         format.xml  { render :xml => @archive_file, :status => :created, :location => @archive_file } | ||||
|       else | ||||
|         get_categorys | ||||
|         get_tags | ||||
|         format.html { render :action => "new" } | ||||
|         format.xml  { render :xml => @archive_file.errors, :status => :unprocessable_entity } | ||||
|       end | ||||
|  |  | |||
|  | @ -9,7 +9,7 @@ class Panel::Archive::FrontEnd::ArchiveFilesController < OrbitWidgetController | |||
|      | ||||
| 	@item = Page.find(params[:page_id]) | ||||
| 	 | ||||
| 	@title = @item.i18n_variable[I18n.locale] | ||||
| 	@title = @item.title | ||||
|    | ||||
|   	if @item.frontend_data_count | ||||
| 		@page_num = @item.frontend_data_count | ||||
|  | @ -41,7 +41,7 @@ class Panel::Archive::FrontEnd::ArchiveFilesController < OrbitWidgetController | |||
|      | ||||
| 	@item = Page.find(params[:page_id]) | ||||
| 	 | ||||
| 	@title = @item.i18n_variable[I18n.locale] | ||||
| 	@title = @item.title | ||||
| 	 | ||||
|     @archive_file = ArchiveFile.find(params[:id]) | ||||
| 	 | ||||
|  | @ -55,7 +55,7 @@ class Panel::Archive::FrontEnd::ArchiveFilesController < OrbitWidgetController | |||
|      | ||||
| 	@item = Page.find(params[:page_id]) | ||||
| 	 | ||||
| 	@title = @item.i18n_variable[I18n.locale] | ||||
| 	@title = @item.title | ||||
|    | ||||
|   	if @item.frontend_data_count | ||||
| 		@page_num = @item.frontend_data_count | ||||
|  |  | |||
|  | @ -26,7 +26,7 @@ class ArchiveFile | |||
| 
 | ||||
|   accepts_nested_attributes_for :archive_file_multiples, :allow_destroy => true | ||||
|    | ||||
|   validates_presence_of :title | ||||
|   validates :title, :at_least_one => true | ||||
|    | ||||
|   after_save :save_archive_file_multiples | ||||
| 
 | ||||
|  |  | |||
|  | @ -7,8 +7,10 @@ class ArchiveFileCategory | |||
|    | ||||
|   field :key | ||||
|    | ||||
|   has_one :i18n_variable, :as => :language_value, :autosave => true, :dependent => :destroy | ||||
|   field :title, localize: true | ||||
|    | ||||
|   has_many :archive_files | ||||
| 
 | ||||
|   validates :title, :at_least_one => true | ||||
|    | ||||
| end | ||||
|  | @ -9,8 +9,6 @@ class ArchiveFileMultiple | |||
|   # field :description | ||||
|   field :choose_lang, :type => Array, :default => nil | ||||
|    | ||||
|   # has_one :i18n_variable, :as => :language_value, :autosave => true, :dependent => :destroy | ||||
|    | ||||
|   field :should_destroy, :type => Boolean | ||||
| 
 | ||||
|   def choose_lang_display(lang) | ||||
|  |  | |||
|  | @ -11,6 +11,6 @@ | |||
| 			</div> | ||||
| 		</td> | ||||
| 		<% @site_valid_locales.each do |locale| %> | ||||
| 		<td><%= archive_file_category.i18n_variable[locale] rescue nil %></td> | ||||
| 		<td><%= archive_file_category.title_translations[locale] rescue nil %></td> | ||||
| 		<% end %> | ||||
| 	</tr> | ||||
|  | @ -10,12 +10,12 @@ | |||
| 	</div> | ||||
| 	 | ||||
| 	<div id="widget-title"> | ||||
| 		<%= f.fields_for :i18n_variable, (@archive_file_category.new_record? ? @archive_file_category.build_i18n_variable : @archive_file_category.i18n_variable) do |f| %> | ||||
| 		<%= f.fields_for :title_translations do |f| %> | ||||
| 		  <% @site_valid_locales.each do |locale| %> | ||||
| 				<div class="control-group"> | ||||
| 					<%= label_tag "name-#{locale}", "Name-#{I18nVariable.from_locale(locale)}", :class => 'control-label' %> | ||||
| 					<div class="controls"> | ||||
| 						<%= f.text_field locale, :class => 'input-xxlarge' %> | ||||
| 						<%= f.text_field locale, :class =>' input-xxlarge', :value => (@archive_file_category.title[locale] rescue nil) %> | ||||
| 					</div> | ||||
| 				</div> | ||||
| 		  <% end %> | ||||
|  |  | |||
|  | @ -17,7 +17,7 @@ | |||
| 			</ul> | ||||
| 		</div> | ||||
| 	</td> | ||||
| 	<td><%= post.archive_file_category.i18n_variable[I18n.locale] %></td> | ||||
| 	<td><%= post.archive_file_category.title %></td> | ||||
| 	<td> | ||||
| 	<%= link_to post.title, panel_archive_front_end_archive_file_path(post) %> | ||||
| 	</td> | ||||
|  |  | |||
|  | @ -43,7 +43,7 @@ | |||
| 		<div id="post-body-content" class="clear"> | ||||
| 		 | ||||
| 			<%= f.label :category %> | ||||
| 			<%= f.select :archive_file_category_id, @archive_file_categorys.collect {|t| [ t.i18n_variable[I18n.locale], t.id ]} %> | ||||
| 			<%= f.select :archive_file_category_id, @archive_file_categorys.collect {|t| [ t.title, t.id ]} %> | ||||
| 			 | ||||
| 			<ul class="nav nav-tabs"> | ||||
| 				<% @site_valid_locales.each_with_index do |locale, i| %> | ||||
|  | @ -74,7 +74,7 @@ | |||
| 			 | ||||
| 			<div> | ||||
| 						 | ||||
| 				<div id='archive_file_multiples' class="archive_file_multiples_block"> | ||||
| 				<div class="archive_file_multiples_block"> | ||||
| 					 | ||||
| 				<table class="table table-condensed"> | ||||
| 					<thead> | ||||
|  |  | |||
|  | @ -1,219 +0,0 @@ | |||
| /* | ||||
|  * jQuery File Upload File Processing Plugin 1.0 | ||||
|  * https://github.com/blueimp/jQuery-File-Upload
 | ||||
|  * | ||||
|  * Copyright 2012, Sebastian Tschan | ||||
|  * https://blueimp.net
 | ||||
|  * | ||||
|  * Licensed under the MIT license: | ||||
|  * http://www.opensource.org/licenses/MIT
 | ||||
|  */ | ||||
| 
 | ||||
| /*jslint nomen: true, unparam: true, regexp: true */ | ||||
| /*global define, window, document */ | ||||
| 
 | ||||
| (function (factory) { | ||||
|     'use strict'; | ||||
|     if (typeof define === 'function' && define.amd) { | ||||
|         // Register as an anonymous AMD module:
 | ||||
|         define([ | ||||
|             'jquery', | ||||
|             'load-image', | ||||
|             'canvas-to-blob', | ||||
|             './jquery.fileupload' | ||||
|         ], factory); | ||||
|     } else { | ||||
|         // Browser globals:
 | ||||
|         factory( | ||||
|             window.jQuery, | ||||
|             window.loadImage | ||||
|         ); | ||||
|     } | ||||
| }(function ($, loadImage) { | ||||
|     'use strict'; | ||||
| 
 | ||||
|     // The File Upload IP version extends the basic fileupload widget
 | ||||
|     // with file processing functionality:
 | ||||
|     $.widget('blueimpFP.fileupload', $.blueimp.fileupload, { | ||||
| 
 | ||||
|         options: { | ||||
|             // The list of file processing actions:
 | ||||
|             process: [ | ||||
|             /* | ||||
|                 { | ||||
|                     action: 'load', | ||||
|                     fileTypes: /^image\/(gif|jpeg|png)$/, | ||||
|                     maxFileSize: 20000000 // 20MB
 | ||||
|                 }, | ||||
|                 { | ||||
|                     action: 'resize', | ||||
|                     maxWidth: 1920, | ||||
|                     maxHeight: 1200, | ||||
|                     minWidth: 800, | ||||
|                     minHeight: 600 | ||||
|                 }, | ||||
|                 { | ||||
|                     action: 'save' | ||||
|                 } | ||||
|             */ | ||||
|             ], | ||||
| 
 | ||||
|             // The add callback is invoked as soon as files are added to the
 | ||||
|             // fileupload widget (via file input selection, drag & drop or add
 | ||||
|             // API call). See the basic file upload widget for more information:
 | ||||
|             add: function (e, data) { | ||||
|                 $(this).fileupload('process', data).done(function () { | ||||
|                     data.submit(); | ||||
|                 }); | ||||
|             } | ||||
|         }, | ||||
| 
 | ||||
|         processActions: { | ||||
|             // Loads the image given via data.files and data.index
 | ||||
|             // as canvas element.
 | ||||
|             // Accepts the options fileTypes (regular expression)
 | ||||
|             // and maxFileSize (integer) to limit the files to load:
 | ||||
|             load: function (data, options) { | ||||
|                 var that = this, | ||||
|                     file = data.files[data.index], | ||||
|                     dfd = $.Deferred(); | ||||
|                 if (window.HTMLCanvasElement && | ||||
|                         window.HTMLCanvasElement.prototype.toBlob && | ||||
|                         ($.type(options.maxFileSize) !== 'number' || | ||||
|                             file.size < options.maxFileSize) && | ||||
|                         (!options.fileTypes || | ||||
|                             options.fileTypes.test(file.type))) { | ||||
|                     loadImage( | ||||
|                         file, | ||||
|                         function (canvas) { | ||||
|                             data.canvas = canvas; | ||||
|                             dfd.resolveWith(that, [data]); | ||||
|                         }, | ||||
|                         {canvas: true} | ||||
|                     ); | ||||
|                 } else { | ||||
|                     dfd.rejectWith(that, [data]); | ||||
|                 } | ||||
|                 return dfd.promise(); | ||||
|             }, | ||||
|             // Resizes the image given as data.canvas and updates
 | ||||
|             // data.canvas with the resized image.
 | ||||
|             // Accepts the options maxWidth, maxHeight, minWidth and
 | ||||
|             // minHeight to scale the given image:
 | ||||
|             resize: function (data, options) { | ||||
|                 if (data.canvas) { | ||||
|                     var canvas = loadImage.scale(data.canvas, options); | ||||
|                     if (canvas.width !== data.canvas.width || | ||||
|                             canvas.height !== data.canvas.height) { | ||||
|                         data.canvas = canvas; | ||||
|                         data.processed = true; | ||||
|                     } | ||||
|                 } | ||||
|                 return data; | ||||
|             }, | ||||
|             // Saves the processed image given as data.canvas
 | ||||
|             // inplace at data.index of data.files:
 | ||||
|             save: function (data, options) { | ||||
|                 // Do nothing if no processing has happened:
 | ||||
|                 if (!data.canvas || !data.processed) { | ||||
|                     return data; | ||||
|                 } | ||||
|                 var that = this, | ||||
|                     file = data.files[data.index], | ||||
|                     name = file.name, | ||||
|                     dfd = $.Deferred(), | ||||
|                     callback = function (blob) { | ||||
|                         if (!blob.name) { | ||||
|                             if (file.type === blob.type) { | ||||
|                                 blob.name = file.name; | ||||
|                             } else if (file.name) { | ||||
|                                 blob.name = file.name.replace( | ||||
|                                     /\..+$/, | ||||
|                                     '.' + blob.type.substr(6) | ||||
|                                 ); | ||||
|                             } | ||||
|                         } | ||||
|                         // Store the created blob at the position
 | ||||
|                         // of the original file in the files list:
 | ||||
|                         data.files[data.index] = blob; | ||||
|                         dfd.resolveWith(that, [data]); | ||||
|                     }; | ||||
|                 // Use canvas.mozGetAsFile directly, to retain the filename, as
 | ||||
|                 // Gecko doesn't support the filename option for FormData.append:
 | ||||
|                 if (data.canvas.mozGetAsFile) { | ||||
|                     callback(data.canvas.mozGetAsFile( | ||||
|                         (/^image\/(jpeg|png)$/.test(file.type) && name) || | ||||
|                             ((name && name.replace(/\..+$/, '')) || | ||||
|                                 'blob') + '.png', | ||||
|                         file.type | ||||
|                     )); | ||||
|                 } else { | ||||
|                     data.canvas.toBlob(callback, file.type); | ||||
|                 } | ||||
|                 return dfd.promise(); | ||||
|             } | ||||
|         }, | ||||
| 
 | ||||
|         // Resizes the file at the given index and stores the created blob at
 | ||||
|         // the original position of the files list, returns a Promise object:
 | ||||
|         _processFile: function (files, index, options) { | ||||
|             var that = this, | ||||
|                 dfd = $.Deferred().resolveWith(that, [{ | ||||
|                     files: files, | ||||
|                     index: index | ||||
|                 }]), | ||||
|                 chain = dfd.promise(); | ||||
|             that._processing += 1; | ||||
|             $.each(options.process, function (i, settings) { | ||||
|                 chain = chain.pipe(function (data) { | ||||
|                     return that.processActions[settings.action] | ||||
|                         .call(this, data, settings); | ||||
|                 }); | ||||
|             }); | ||||
|             chain.always(function () { | ||||
|                 that._processing -= 1; | ||||
|                 if (that._processing === 0) { | ||||
|                     that.element | ||||
|                         .removeClass('fileupload-processing'); | ||||
|                 } | ||||
|             }); | ||||
|             if (that._processing === 1) { | ||||
|                 that.element.addClass('fileupload-processing'); | ||||
|             } | ||||
|             return chain; | ||||
|         }, | ||||
| 
 | ||||
|         // Processes the files given as files property of the data parameter,
 | ||||
|         // returns a Promise object that allows to bind a done handler, which
 | ||||
|         // will be invoked after processing all files (inplace) is done:
 | ||||
|         process: function (data) { | ||||
|             var that = this, | ||||
|                 options = $.extend({}, this.options, data); | ||||
|             if (options.process && options.process.length && | ||||
|                     this._isXHRUpload(options)) { | ||||
|                 $.each(data.files, function (index, file) { | ||||
|                     that._processingQueue = that._processingQueue.pipe( | ||||
|                         function () { | ||||
|                             var dfd = $.Deferred(); | ||||
|                             that._processFile(data.files, index, options) | ||||
|                                 .always(function () { | ||||
|                                     dfd.resolveWith(that); | ||||
|                                 }); | ||||
|                             return dfd.promise(); | ||||
|                         } | ||||
|                     ); | ||||
|                 }); | ||||
|             } | ||||
|             return this._processingQueue; | ||||
|         }, | ||||
| 
 | ||||
|         _create: function () { | ||||
|             $.blueimp.fileupload.prototype._create.call(this); | ||||
|             this._processing = 0; | ||||
|             this._processingQueue = $.Deferred().resolveWith(this) | ||||
|                 .promise(); | ||||
|         } | ||||
| 
 | ||||
|     }); | ||||
| 
 | ||||
| })); | ||||