Ad banner close complete,need validation
This commit is contained in:
		
							parent
							
								
									68cea1ea49
								
							
						
					
					
						commit
						394099c388
					
				|  | @ -15,4 +15,4 @@ $('a.remove_mark').live("click",function(){ | |||
|   $(this).next().remove(); | ||||
|   $(this).remove(); | ||||
|   return false; | ||||
| }); | ||||
| }); | ||||
|  |  | |||
|  | @ -18,6 +18,13 @@ class AdBanner | |||
|    | ||||
|   FX_TYPES = ["blindX","blindY","blindZ","cover","curtainX","curtainY","fade","fadeZoom","growX","growY","scrollUp","scrollDown","scrollLeft","scrollRight","scrollHorz","scrollVert","shuffle","slideX","slideY","toss","turnUp","turnDown","turnLeft","turnRight","uncover","wipe","zoom"] | ||||
|    | ||||
|   def display? | ||||
|     if (self.post_date <= Date.today && (self.unpost_date.nil? || self.unpost_date>= Date.today))      | ||||
|       return true | ||||
|     end | ||||
|       return false | ||||
|   end | ||||
|    | ||||
|   def new_ad_images=(*attrs) | ||||
|      attrs[0].each  do |attr|   #Loop by JSs,Themes,Imgs | ||||
|        unless attr[:file].nil? | ||||
|  |  | |||
|  | @ -7,10 +7,23 @@ class AdImage | |||
|   field :time_to_next #Weight | ||||
|   field :picture_intro | ||||
|   field :out_link | ||||
|   field :link_open | ||||
|    | ||||
|   field :to_save, :type => Boolean | ||||
|   field :to_destroy, :type => Boolean | ||||
|    | ||||
|   LINK_OPEN_TYPES = ["new_window","local"] | ||||
|    | ||||
|    | ||||
|   embedded_in :ad_banner | ||||
| 
 | ||||
|   def get_delay_time | ||||
|     time = '' | ||||
|     if self.time_to_next.nil? | ||||
|       time = '1000' | ||||
|     else | ||||
|       time = (self.time_to_next.to_i * 1000).to_s | ||||
|     end | ||||
|     time | ||||
|   end | ||||
| end | ||||
|  |  | |||
|  | @ -1,7 +1,8 @@ | |||
| <div id="basic_block" class="roles_block"> | ||||
| 	<%= image_tag ad_image.file %>  | ||||
| 	Time to next: <%= ad_image.time_to_next %> | ||||
| 	Intro: <%= ad_image.picture_intro %> | ||||
| 	Out Link <%= link_to ad_image.out_link %>   | ||||
| 	<%= render :partial => "ad_image_update", :locals => { :ad_image => ad_image } %> | ||||
| 	<p> | ||||
| 		Time to next: <%= ad_image.time_to_next %> | ||||
| 		Intro: <%= ad_image.picture_intro %> | ||||
| 		Out Link <%= link_to ad_image.out_link %>  by <%= ad_image.link_open %> | ||||
| 	</p> | ||||
| </div>	 | ||||
|  |  | |||
|  | @ -1,3 +1,5 @@ | |||
| Time: <%= f.text_field :time_to_next ,:class=> 'ad_time'%> | ||||
| Link:<%= f.text_field :out_link ,:class=> 'ad_out_link'%> | ||||
| Open Type <%= f.select :link_open ,AdImage::LINK_OPEN_TYPES %> | ||||
| 
 | ||||
| <%= f.hidden_field :to_save %> | ||||
|  | @ -22,8 +22,7 @@ | |||
| 
 | ||||
| <p> | ||||
| 	<%= f.label :unpost_date, t('admin.unpost_date') %> | ||||
|   <%= f.date_select :unpost_date, :order => [:year, :month, :day], :use_month_numbers => true %> | ||||
| 
 | ||||
|   <%= f.date_select :unpost_date, :order => [:year, :month, :day], :use_month_numbers => true,:prompt => { :day => t('form.date_unlimited'), :month => t('form.date_unlimited'), :year => t('form.date_unlimited') } %> | ||||
| </p> | ||||
| <p> | ||||
| 	<%= f.label :context, t('admin.context') %> | ||||
|  |  | |||
|  | @ -20,6 +20,7 @@ | |||
|     <td><%= t('admin.unpost_date') %></td> | ||||
|     <td><%= t('admin.context') %></td> | ||||
|     <td><%= t('admin.direct_to_after_click') %></td> | ||||
|     <td><%= t('admin.now_display?') %></td> | ||||
|   </tr> | ||||
| </thead> | ||||
| <% @ad_banners.each do |ad_banner| %> | ||||
|  | @ -27,10 +28,11 @@ | |||
|     <td><%= ad_banner.title %></td> | ||||
|     <td><%= ad_banner.picture_position %></td> | ||||
|     <td><%= ad_banner.post_date %></td> | ||||
|     <td><%= ad_banner.unpost_date %></td> | ||||
|     <td><%= ad_banner.unpost_date.nil?? t('form.date_unlimited'): ad_banner.unpost_date %></td> | ||||
|     <td><%= ad_banner.context %></td> | ||||
|     <td><%= ad_banner.direct_to_after_click %></td> | ||||
|     <td class="action"> | ||||
|     <td><%= ad_banner.display?  %></td>  | ||||
|    <td class="action"> | ||||
| 			<%= link_to t(:show), admin_ad_banner_path(ad_banner), :class => 'show' %> | ||||
|       <%= link_to t(:edit), edit_admin_ad_banner_path(ad_banner), :class => 'edit'  %> | ||||
|       <%= link_to t(:delete), admin_ad_banner_path(ad_banner), :confirm => t('sure?'), :method => :delete, :class => 'delete' %> | ||||
|  |  | |||
|  | @ -85,14 +85,28 @@ module ParserFrontEnd | |||
|       c.define_tag 'adbanner' do |tag| | ||||
|         res = '' | ||||
|         ad_banner = AdBanner.first(conditions:{title: tag.attr["name"]}) | ||||
|         res << "<script type='text/javascript' src='http://cloud.github.com/downloads/malsup/cycle/jquery.cycle.all.latest.js'></script>" | ||||
|         res << "<script type='text/javascript'> $(document).ready(function() { $('.slideshow').cycle({ fx: '#{ad_banner.ad_fx.nil?? 'fade': ad_banner.ad_fx}' }); }); </script>" | ||||
|         | ||||
|         res << "<div class='slideshow'>" | ||||
|          ad_banner.ad_images.each do |ad_image| | ||||
|            res << "<img src='#{ad_image.file}' />" | ||||
|           end | ||||
|         res << "</div>" | ||||
|         if ad_banner.display? | ||||
|           res << "<script type='text/javascript' src='http://cloud.github.com/downloads/malsup/cycle/jquery.cycle.all.latest.js'></script>" | ||||
|           res << "<script type='text/javascript'>function onAfter(e) {  | ||||
|               var parent = $(this).parent(); | ||||
|               var time_to_next = $(this).attr('time_to_next'); | ||||
|               parent.cycle('pause'); | ||||
|               setTimeout(function(){parent.cycle('resume')},time_to_next); | ||||
| 
 | ||||
|           } $(document).ready(function() { $('.slideshow').cycle({after:   onAfter,timeout:1 ,fx: '#{ad_banner.ad_fx.nil?? 'fade': ad_banner.ad_fx}' }).children('img').click(function(){if($(this).attr('link_open')=='new_window'){window.open($(this).attr('link_url'));} else{document.location.href=$(this).attr('link_url');}});; }); </script>" | ||||
| 
 | ||||
|           res << "<div class='slideshow'>" | ||||
|            ad_banner.ad_images.each do |ad_image| | ||||
|              res << "<img src='#{ad_image.file}' " | ||||
|              res << "alt='#{ad_image.picture_intro || ' '}' " | ||||
|              res << "time_to_next='#{ad_image.get_delay_time}' " | ||||
|              res << "link_open='#{ad_image.link_open}' " | ||||
|              res << "link_url='#{(ad_banner.direct_to_after_click?? ad_image.out_link : ad_banner.context) || ' '}' " | ||||
|              res << "/>" | ||||
|             end | ||||
|           res << "</div>" | ||||
|         end | ||||
|         res | ||||
|       end | ||||
|       c.define_tag 'image' do |tag| | ||||
|         image = page.custom_images.detect{|image| image.name.eql?(tag.attr['name']) } | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue