Permalink
Browse files

1. Added option for launching_date in lauching_soon.yml. 1. Added cou…

…ntdown timer
  • Loading branch information...
1 parent 7a9b766 commit c4857f2383ef90c007500cd5f3e79d5105372b76 @Satish Satish committed Jul 8, 2009
@@ -7,6 +7,7 @@ development:
mail_chimp_api_key:
mail_chimp_list_id:
csv_file_name: data.csv
+ launching_date: July 9, 2020 00:00:00
test:
css_file_name: launching_soon.css
@@ -17,6 +18,7 @@ test:
mail_chimp_api_key:
mail_chimp_list_id:
csv_file_name: data.csv
+ launching_date: July 9, 2020 00:00:00
production:
css_file_name: launching_soon.css
@@ -26,4 +28,5 @@ production:
campaign_monitor_list_id:
mail_chimp_api_key:
mail_chimp_list_id:
- csv_file_name: data.csv
+ csv_file_name: data.csv
+ launching_date: July 9, 2020 00:00:00
View
@@ -1,10 +1,15 @@
# Install hook code here
puts 'Copying stylesheet'
FileUtils.cp File.join(File.dirname(__FILE__), 'public', 'stylesheets', 'launching_soon.css'), File.join(RAILS_ROOT, 'public', 'stylesheets')
+puts 'Copying javascripts'
+FileUtils.cp File.join(File.dirname(__FILE__), 'public', 'javascripts', 'countdown.js'), File.join(RAILS_ROOT, 'public', 'javascripts')
puts 'Copying config file'
FileUtils.cp File.join(File.dirname(__FILE__), 'config', 'launching_soon.yml'), File.join(RAILS_ROOT, 'config')
puts 'Copying views'
FileUtils.cp File.join(File.dirname(__FILE__), 'lib', 'app', 'views', 'layouts', 'launching_soon.html.erb'), File.join(RAILS_ROOT, 'app', 'views', 'layouts')
FileUtils.cp File.join(File.dirname(__FILE__), 'lib', 'app', 'views', 'default.html.erb'), FileUtils.mkdir_p(File.join(RAILS_ROOT, 'app', 'views', 'launching_soon'))
puts 'Copying images'
-FileUtils.cp File.join(File.dirname(__FILE__), 'public', 'images', 'spinner.gif'), FileUtils.mkdir_p(File.join(RAILS_ROOT, 'public', 'images', 'launching_soon'))
+destination = File.join(RAILS_ROOT, 'public/images/launching_soon')
+source = File.dirname(__FILE__) + '/public/images/'
+FileUtils.mkdir_p(destination)
+FileUtils.cp_r(Dir.glob(source + '*.*'), destination)
@@ -4,7 +4,7 @@
<div class="notifyForm">
<h3>Notifier</h3>
<% form_remote_for :news_letter_subscriber, :url => news_letter_subscribers_path, :loading => "$('progress_indicator').show();" , :success => "$('progress_indicator').hide();" do -%>
- <%= text_field_tag :email, nil, :class => "subscriberEmail" -%>
+ <%= text_field_tag :email, 'Enter your email here', :class => "subscriberEmail", :onfocus => "if(this.value == 'Enter your email here'){ this.value = '' }", :onblur => "if(this.value == ''){ this.value = 'Enter your email here' }" -%>
<%= submit_tag "", :class => "notifyMeButton" -%><%= image_tag('launching_soon/spinner.gif', :style => "margin-left:10px; display:none", :id => 'progress_indicator') -%>
<% end %>
<span>* We never spam</span>
@@ -24,8 +24,14 @@
<div class="lauchTime">
<p>
<label>Launching In:</label>
- 400 days 10 hours 50 minutes and 10 seconds
+ <span id="cdcontainer"></span>
</p>
- </div>
- <p class="note">* Edit the files in “ app > views” folder to make your changes.</p>
+ <script type="text/javascript">
+ //cdLocalTime("ID_of_DIV_container", "server_mode", LocaltimeoffsetMinutes, "target_date", "opt_debug_mode")
+ //Note: "launchdate" should be an arbitrary but unique variable for each instance of a countdown on your page:
+ var launchdate=new cdLocalTime("cdcontainer", "", 0, "<%= @launching_date -%>")
+ launchdate.displaycountdown("days", formatresults2)
+ </script>
+ </div>
+ <p class="note">* Edit the files in “app > views > launching_soon” folder to make your changes.</p>
</div>
@@ -3,7 +3,10 @@
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8" />
<title>Launching Soon</title>
- <%= javascript_include_tag :defaults -%>
+ <script type="text/javascript">
+ var currenttime = "<%= Time.now -%>";
+ </script>
+ <%= javascript_include_tag :defaults, 'countdown', :cache => true -%>
<%= stylesheet_link_tag @css_file %>
</head>
<body>
@@ -13,6 +16,14 @@
</div>
<h2 class="tagline">Every Web site needs a launching page, have yours in minutes</h2>
<%= yield -%>
+ <div id="footer">
+ <span class="footer-text">
+ &copy; 2009
+ <%= link_to "www.vinsol.com", "http://vinsol.com" -%> |
+ <%= link_to "Contact Us", "http://vinsol.com/contact-us" -%> |
+ Powered by <%= link_to "LaunchingSoon", "http://github.com/Satish/launching_soon/tree/master" -%>
+ <span>
+ </div>
</div>
</body>
</html>
@@ -51,6 +51,7 @@ def self.included(controller)
# with a css file from public/stylesheets/LAUNCHING_SOON_CONFIG[:css_file_name] path (eg. public/stylesheets/launching_soon.css).
def setup_launching_soon_page
@css_file = LAUNCHING_SOON_CONFIG[:css_file_name]
+ @launching_date = LAUNCHING_SOON_CONFIG[:launching_date]
render :template => File.join('launching_soon', LAUNCHING_SOON_CONFIG[:html_file_name]), :layout => "launching_soon"
end
@@ -0,0 +1,97 @@
+/***********************************************
+* Universal Countdown script- © Dynamic Drive (http://www.dynamicdrive.com)
+* This notice MUST stay intact for legal use
+* Visit http://www.dynamicdrive.com/ for this script and 100s more.
+***********************************************/
+
+function cdLocalTime(container, servermode, offsetMinutes, targetdate, debugmode){
+if (!document.getElementById || !document.getElementById(container)) return
+this.container=document.getElementById(container)
+var servertimestring=(servermode=="server-php")? '<? print date("F d, Y H:i:s", time())?>' : (servermode=="server-ssi")? '<!--#config timefmt="%B %d, %Y %H:%M:%S"--><!--#echo var="DATE_LOCAL" -->' : currenttime
+this.localtime=this.serverdate=new Date(servertimestring)
+this.targetdate=new Date(targetdate)
+this.debugmode=(typeof debugmode!="undefined")? 1 : 0
+this.timesup=false
+this.localtime.setTime(this.serverdate.getTime()+offsetMinutes*60*1000) //add user offset to server time
+this.updateTime()
+}
+
+cdLocalTime.prototype.updateTime=function(){
+var thisobj=this
+this.localtime.setSeconds(this.localtime.getSeconds()+1)
+setTimeout(function(){thisobj.updateTime()}, 1000) //update time every second
+}
+
+cdLocalTime.prototype.displaycountdown=function(baseunit, functionref){
+this.baseunit=baseunit
+this.formatresults=functionref
+this.showresults()
+}
+
+cdLocalTime.prototype.showresults=function(){
+var thisobj=this
+var debugstring=(this.debugmode)? "<p style=\"background-color: #FCD6D6; color: black; padding: 5px\"><big>Debug Mode on!</big><br /><b>Current Local time:</b> "+this.localtime.toLocaleString()+"<br />Verify this is the correct current local time, in other words, time zone of count down date.<br /><br /><b>Target Time:</b> "+this.targetdate.toLocaleString()+"<br />Verify this is the date/time you wish to count down to (should be a future date).</p>" : ""
+
+var timediff=(this.targetdate-this.localtime)/1000 //difference btw target date and current date, in seconds
+if (timediff<0){ //if time is up
+this.timesup=true
+this.container.innerHTML=debugstring+this.formatresults()
+return
+}
+var oneMinute=60 //minute unit in seconds
+var oneHour=60*60 //hour unit in seconds
+var oneDay=60*60*24 //day unit in seconds
+var dayfield=Math.floor(timediff/oneDay)
+var hourfield=Math.floor((timediff-dayfield*oneDay)/oneHour)
+var minutefield=Math.floor((timediff-dayfield*oneDay-hourfield*oneHour)/oneMinute)
+var secondfield=Math.floor((timediff-dayfield*oneDay-hourfield*oneHour-minutefield*oneMinute))
+if (this.baseunit=="hours"){ //if base unit is hours, set "hourfield" to be topmost level
+hourfield=dayfield*24+hourfield
+dayfield="n/a"
+}
+else if (this.baseunit=="minutes"){ //if base unit is minutes, set "minutefield" to be topmost level
+minutefield=dayfield*24*60+hourfield*60+minutefield
+dayfield=hourfield="n/a"
+}
+else if (this.baseunit=="seconds"){ //if base unit is seconds, set "secondfield" to be topmost level
+var secondfield=timediff
+dayfield=hourfield=minutefield="n/a"
+}
+this.container.innerHTML=debugstring+this.formatresults(dayfield, hourfield, minutefield, secondfield)
+setTimeout(function(){thisobj.showresults()}, 1000) //update results every second
+}
+
+/////CUSTOM FORMAT OUTPUT FUNCTIONS BELOW//////////////////////////////
+
+//Create your own custom format function to pass into cdLocalTime.displaycountdown()
+//Use arguments[0] to access "Days" left
+//Use arguments[1] to access "Hours" left
+//Use arguments[2] to access "Minutes" left
+//Use arguments[3] to access "Seconds" left
+
+//The values of these arguments may change depending on the "baseunit" parameter of cdLocalTime.displaycountdown()
+//For example, if "baseunit" is set to "hours", arguments[0] becomes meaningless and contains "n/a"
+//For example, if "baseunit" is set to "minutes", arguments[0] and arguments[1] become meaningless etc
+
+//1) Display countdown using plain text
+function formatresults(){
+if (this.timesup==false){//if target date/time not yet met
+var displaystring="<span style='background-color: #CFEAFE'>"+arguments[1]+" hours "+arguments[2]+" minutes "+arguments[3]+" seconds</span> left until launch time"
+}
+else{ //else if target date/time met
+var displaystring="Launch time!"
+}
+return displaystring
+}
+
+//2) Display countdown with a stylish LCD look, and display an alert on target date/time
+function formatresults2(){
+if (this.timesup==false){ //if target date/time not yet met
+var displaystring="<span class='lcdstyle'>"+arguments[0]+" days "+arguments[1]+" hours "+arguments[2]+" minutes "+arguments[3]+" seconds</span>"
+}
+else{ //else if target date/time met
+var displaystring="" //Don't display any text
+alert("Launch time!") //Instead, perform a custom alert
+}
+return displaystring
+}
Oops, something went wrong.

0 comments on commit c4857f2

Please sign in to comment.