Add support for rotating banners, add banners for SOTM, SOTMUS
This commit is contained in:
parent
ee1cc2aa51
commit
5e27978d3c
7 changed files with 99 additions and 11 deletions
0
app/assets/images/banners/.keep
Normal file
0
app/assets/images/banners/.keep
Normal file
BIN
app/assets/images/banners/sotm-2016.jpg
Normal file
BIN
app/assets/images/banners/sotm-2016.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 79 KiB |
BIN
app/assets/images/banners/sotmus-2016.jpg
Normal file
BIN
app/assets/images/banners/sotmus-2016.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 62 KiB |
|
@ -161,17 +161,27 @@ $(document).ready(function () {
|
||||||
map.getLayersCode(),
|
map.getLayersCode(),
|
||||||
map._object);
|
map._object);
|
||||||
|
|
||||||
$.removeCookie("_osm_location");
|
$.removeCookie('_osm_location');
|
||||||
$.cookie("_osm_location", OSM.locationCookie(map), { expires: expiry, path: "/" });
|
$.cookie('_osm_location', OSM.locationCookie(map), { expires: expiry, path: '/' });
|
||||||
});
|
});
|
||||||
|
|
||||||
if ($.cookie('_osm_welcome') === 'hide') {
|
if ($.cookie('_osm_welcome') === 'hide') {
|
||||||
$('.welcome').hide();
|
$('.welcome').hide();
|
||||||
}
|
}
|
||||||
|
|
||||||
$('.welcome .close').on('click', function() {
|
$('.welcome .close-wrap').on('click', function() {
|
||||||
$('.welcome').hide();
|
$('.welcome').hide();
|
||||||
$.cookie("_osm_welcome", 'hide', { expires: expiry });
|
$.cookie('_osm_welcome', 'hide', { expires: expiry });
|
||||||
|
});
|
||||||
|
|
||||||
|
$('#banner .close-wrap').on('click', function(e) {
|
||||||
|
debugger;
|
||||||
|
var cookieId = e.target.id;
|
||||||
|
$('#banner').hide();
|
||||||
|
e.preventDefault();
|
||||||
|
if (cookieId) {
|
||||||
|
$.cookie(cookieId, 'hide', { expires: expiry });
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
if (OSM.PIWIK) {
|
if (OSM.PIWIK) {
|
||||||
|
|
|
@ -173,6 +173,7 @@ small, aside {
|
||||||
.icon.clipboard { background-position: -160px 0; }
|
.icon.clipboard { background-position: -160px 0; }
|
||||||
.icon.link { background-position: -180px 0; }
|
.icon.link { background-position: -180px 0; }
|
||||||
.icon.close { background-position: -200px 0; }
|
.icon.close { background-position: -200px 0; }
|
||||||
|
.close-wrap:hover .icon.close,
|
||||||
.icon.close:hover { background-position: -200px -20px; }
|
.icon.close:hover { background-position: -200px -20px; }
|
||||||
.icon.check { background-position: -220px 0; }
|
.icon.check { background-position: -220px 0; }
|
||||||
.icon.note { background-position: -240px 0; }
|
.icon.note { background-position: -240px 0; }
|
||||||
|
@ -546,6 +547,13 @@ body.compact {
|
||||||
background: #fff;
|
background: #fff;
|
||||||
font-size: 12px;
|
font-size: 12px;
|
||||||
|
|
||||||
|
> div {
|
||||||
|
position: relative;
|
||||||
|
float: left;
|
||||||
|
clear: both;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
h2 {
|
h2 {
|
||||||
padding: $lineheight $lineheight $lineheight/2;
|
padding: $lineheight $lineheight $lineheight/2;
|
||||||
}
|
}
|
||||||
|
@ -556,9 +564,24 @@ body.compact {
|
||||||
font-size: 13px;
|
font-size: 13px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.close-wrap {
|
||||||
|
cursor: pointer;
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
right: 0;
|
||||||
|
width: 60px;
|
||||||
|
height: 60px;
|
||||||
|
|
||||||
|
.icon.close {
|
||||||
|
pointer-events: none;
|
||||||
|
position: absolute;
|
||||||
|
right: 20px;
|
||||||
|
top: 20px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.icon.close {
|
.icon.close {
|
||||||
float: right;
|
float: right;
|
||||||
cursor: pointer;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
p.error {
|
p.error {
|
||||||
|
@ -568,25 +591,25 @@ body.compact {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.welcome {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.overlay-sidebar #sidebar {
|
.overlay-sidebar #sidebar {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
z-index: 1000;
|
z-index: 1000;
|
||||||
height: auto;
|
height: auto;
|
||||||
border-bottom-right-radius: 5px;
|
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
|
|
||||||
.welcome {
|
.welcome {
|
||||||
display: block;
|
display: block;
|
||||||
}
|
}
|
||||||
|
|
||||||
#sidebar_content {
|
#sidebar_content {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.welcome {
|
.welcome {
|
||||||
|
display: none;
|
||||||
|
padding-bottom: 5px;
|
||||||
|
|
||||||
p {
|
p {
|
||||||
padding: $lineheight/2 $lineheight $lineheight;
|
padding: $lineheight/2 $lineheight $lineheight;
|
||||||
font-size: 110%;
|
font-size: 110%;
|
||||||
|
@ -607,6 +630,15 @@ body.compact {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#banner {
|
||||||
|
display: block;
|
||||||
|
|
||||||
|
img {
|
||||||
|
display: block;
|
||||||
|
width: $sidebarWidth;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#map {
|
#map {
|
||||||
height: 100%;
|
height: 100%;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
|
|
41
app/views/layouts/_banner.html.erb
Normal file
41
app/views/layouts/_banner.html.erb
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
<% active_banners = {
|
||||||
|
:sotmus2016 => {
|
||||||
|
:alt => 'State of the Map US 2016',
|
||||||
|
:link => 'http://stateofthemap.us/',
|
||||||
|
:img => 'banners/sotmus-2016.jpg'
|
||||||
|
},
|
||||||
|
:sotm2016 => {
|
||||||
|
:alt => 'State of the Map 2016',
|
||||||
|
:link => 'http://2016.stateofthemap.org/',
|
||||||
|
:img => 'banners/sotm-2016.jpg'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bannerSym = nil
|
||||||
|
cookieStr = nil
|
||||||
|
queuePos = active_banners.length
|
||||||
|
|
||||||
|
# pick least recently seen banner that is not hidden
|
||||||
|
active_banners.each_key do |k|
|
||||||
|
c = '_osm_banner_' + k.to_s
|
||||||
|
val = cookies[c.to_sym] || 0
|
||||||
|
next if val == 'hide'
|
||||||
|
|
||||||
|
if val.to_i > 0
|
||||||
|
cookies[c.to_sym] = val.to_i - 1
|
||||||
|
end
|
||||||
|
|
||||||
|
if val.to_i <= queuePos
|
||||||
|
bannerSym = k
|
||||||
|
cookieStr = c
|
||||||
|
queuePos = val.to_i
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
unless bannerSym.nil?
|
||||||
|
banner = active_banners[bannerSym]
|
||||||
|
cookies[cookieStr.to_sym] = active_banners.length # bump to end of queue
|
||||||
|
%>
|
||||||
|
<%= link_to (image_tag banner[:img], :alt => banner[:alt], :title => banner[:alt]), banner[:link] %>
|
||||||
|
<div class="close-wrap" id="<%= cookieStr %>"><span class="icon close"></span></div>
|
||||||
|
<% end %>
|
|
@ -46,12 +46,17 @@
|
||||||
|
|
||||||
<% unless @user %>
|
<% unless @user %>
|
||||||
<div class="welcome">
|
<div class="welcome">
|
||||||
<h2><a><span class="icon close"></span></a><%= t 'layouts.intro_header' %></h2>
|
<h2><%= t 'layouts.intro_header' %></h2>
|
||||||
|
<div class="close-wrap"><span class="icon close"></span></div>
|
||||||
<p><%= t 'layouts.intro_text' %></p>
|
<p><%= t 'layouts.intro_text' %></p>
|
||||||
<a class="button learn-more" href="<%= about_path %>"><%= t('layouts.learn_more') %></a>
|
<a class="button learn-more" href="<%= about_path %>"><%= t('layouts.learn_more') %></a>
|
||||||
<a class="button sign-up" href="<%= user_new_path %>"><%= t('layouts.start_mapping') %></a>
|
<a class="button sign-up" href="<%= user_new_path %>"><%= t('layouts.start_mapping') %></a>
|
||||||
</div>
|
</div>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
||||||
|
<div id="banner">
|
||||||
|
<%= render :partial => "layouts/banner" %>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<noscript>
|
<noscript>
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue