Support for custom themes.

This commit is contained in:
Jonathan Bernard 2016-12-23 02:00:16 -06:00
parent 25ee179427
commit f2745d8b72
27 changed files with 438 additions and 227 deletions

View File

@ -15,9 +15,9 @@ body {
color: white;
font-family: Exo2; }
.bg {
#background-image {
opacity: 1;
display: block;
opacity: 0;
transition: 1s;
position: fixed;
width: 100%;
@ -25,18 +25,6 @@ body {
right: 0;
z-index: -1; }
.morning #bg-morning {
opacity: 1; }
.afternoon #bg-afternoon {
opacity: 1; }
.evening #bg-evening {
opacity: 1; }
.night #bg-night {
opacity: 1; }
#ui-container {
position: fixed;
top: 0;
@ -158,77 +146,4 @@ body {
.throb {
animation: alternate infinite 2s throb; }
.evening #clock-panel {
border-bottom: 2px solid white;
text-align: right;
position: absolute;
right: 0;
top: 0; }
.evening #login-panel {
position: absolute;
bottom: 2vw;
left: 1vw; }
.evening #session-panel {
position: absolute;
bottom: 0.5vw;
left: 1vw; }
.morning #clock-panel, .night #clock-panel, .afternoon #clock-panel {
border-top: 2px solid white;
position: absolute;
left: 0;
bottom: 0; }
.morning #login-panel, .night #login-panel, .afternoon #login-panel {
position: absolute;
bottom: 2vw;
left: 20vw; }
.morning #session-panel, .night #session-panel, .afternoon #session-panel {
position: absolute;
bottom: 0.5vw;
left: 20vw; }
.morning #clock-panel {
text-shadow: 0 0 0.2vw #446688; }
.morning #users:hover #user-display, .morning #sessions:hover #session-display,
.morning #users-list li:hover, .morning #sessions-list li.session:hover {
color: #0088aa;
text-shadow: 0 0 0.5vw black; }
.morning #power-panel {
opacity: 0.7; }
.afternoon #clock-panel {
text-shadow: 0 0 2vw #448844; }
.afternoon #users:hover #user-display, .afternoon #sessions:hover #session-display,
.afternoon #users-list li:hover, .afternoon #sessions-list li.session:hover {
color: #00aa00;
text-shadow: 0 0 0.5vw black; }
.evening #clock-panel {
text-shadow: 0 0 2vw #faaa3b; }
.evening #users:hover #user-display, .evening #sessions:hover #session-display,
.evening #users-list li:hover, .evening #sessions-list li.session:hover {
color: orange;
text-shadow: 0 0 0.5vw black; }
.evening #power-panel {
opacity: 0.7; }
.night #clock-panel {
text-shadow: 0 0 2vw #884488; }
.night #users:hover #user-display, .night #sessions:hover #session-display,
.night #users-list li:hover, .night #sessions-list li.session:hover {
color: #8822bb;
text-shadow: 0 0 0.2vw black; }
/*.night {
#clock-panel {
}
#login-panel {
position: absolute;
bottom: 2vw;
left: 2vw;
}
}*/
/*# sourceMappingURL=lightdm-uestibulum.css.map */

View File

@ -1,6 +1,6 @@
{
"version": 3,
"mappings": "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",
"mappings": "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",
"sources": ["lightdm-uestibulum.scss"],
"names": [],
"file": "lightdm-uestibulum.css"

View File

@ -10,18 +10,14 @@
h1 { font-size: 1.5vw; }
h2 { font-size: 1vw; }
$colorFG: white;
$colorBG: black;
$colorAccent: orange;
body {
color: $colorFG;
color: white;
font-family: Exo2
}
.bg {
#background-image {
opacity: 1;
display: block;
opacity: 0;
transition: 1s;
position: fixed;
@ -31,11 +27,6 @@ body {
z-index: -1;
}
.morning #bg-morning { opacity: 1; }
.afternoon #bg-afternoon { opacity: 1; }
.evening #bg-evening { opacity: 1; }
.night #bg-night { opacity: 1; }
#ui-container {
position: fixed;
top: 0;
@ -100,8 +91,8 @@ body {
input[type=password] {
background: none;
border: none;
border-bottom: 2px solid $colorFG;
color: $colorFG;
border-bottom: 2px solid white;
color: white;
font-size: 1vw;
margin-top: 0.5em;
opacity: 0;
@ -189,99 +180,3 @@ body {
}
.throb { animation: alternate infinite 2s throb; }
.evening {
#clock-panel {
border-bottom: 2px solid $colorFG;
text-align: right;
position: absolute;
right: 0;
top: 0;
}
#login-panel {
position: absolute;
bottom: 2vw;
left: 1vw;
}
#session-panel {
position: absolute;
bottom: 0.5vw;
left: 1vw;
}
}
.morning, .night, .afternoon {
#clock-panel {
border-top: 2px solid $colorFG;
position: absolute;
left: 0;
bottom: 0;
}
#login-panel {
position: absolute;
bottom: 2vw;
left: 20vw;
}
#session-panel {
position: absolute;
bottom: 0.5vw;
left: 20vw;
}
}
.morning {
#clock-panel { text-shadow: 0 0 0.2vw #446688; }
#users:hover #user-display, #sessions:hover #session-display,
#users-list li:hover, #sessions-list li.session:hover {
color: #0088aa;
text-shadow: 0 0 0.5vw black;
}
#power-panel { opacity: 0.7; }
}
.afternoon {
#clock-panel { text-shadow: 0 0 2vw #448844; }
#users:hover #user-display, #sessions:hover #session-display,
#users-list li:hover, #sessions-list li.session:hover {
color: #00aa00;
text-shadow: 0 0 0.5vw black;
}
}
.evening {
#clock-panel { text-shadow: 0 0 2vw #faaa3b; }
#users:hover #user-display, #sessions:hover #session-display,
#users-list li:hover, #sessions-list li.session:hover {
color: orange;
text-shadow: 0 0 0.5vw black;
}
#power-panel { opacity: 0.7; }
}
.night {
#clock-panel { text-shadow: 0 0 2vw #884488; }
#users:hover #user-display, #sessions:hover #session-display,
#users-list li:hover, #sessions-list li.session:hover {
color: #8822bb;
text-shadow: 0 0 0.2vw black;
}
}
/*.night {
#clock-panel {
}
#login-panel {
position: absolute;
bottom: 2vw;
left: 2vw;
}
}*/

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.6 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 160 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 8.8 MiB

View File

@ -9,10 +9,7 @@
</head>
<body>
<img id=bg-morning class=bg src="img/morning.png">
<img id=bg-afternoon class=bg src="img/afternoon.png">
<img id=bg-evening class=bg src="img/evening.png">
<img id=bg-night class=bg src="img/night.gif">
<img id=background-image>
<div id=ui-container>
<div id=power-panel>
@ -37,7 +34,7 @@
</h1>
<input type=password name=pwd placeholder='password...'>
<i class='fa fa-exclamation-circle' id=fail-msg></i>
<div id=checking-credentials>checking credentials
<div id=checking-credentials>checking credentials!
<span id=c1>.</span><span id=c2>.</span><span id=c3>.</span>
</div>
</div>

View File

@ -96,6 +96,7 @@ if (!('lightdm' in window)) {
lightdm.timed_login_user =
lightdm.timed_login_delay > 0 ? lightdm.users[0] : null;
lightdm.get_str = function () {};
lightdm.get_string_property = function () {};
lightdm.get_integer_property = function () {};
lightdm.get_boolean_property = function () {};

View File

@ -1,10 +1,54 @@
(function() {
var U = window.uestibulum = {};
var U = window.uestibulum = {
config { theme: 'jdb', hidpi: true },
themes: {}
};
_.templateSettings = {
interpolate: /\{\{(.+?)\}\}/g
};
U.load = function(tag, url) {
return new Promise(function(resolve, reject) {
var element = document.createElement(tag);
var parent = 'body';
var attr = 'src';
element.onload = resolve;
element.onerror = reject;
switch (tag) {
case 'script': element.async = true; break;
case 'link':
element.type = 'text/css';
element.rel = 'stylesheet';
attr = 'href';
parent = 'head';
break;
default:
}
element[attr] = url;
document[parent].appendChild(element);
});
};
U.ImageModel = Backbone.Model.extend({
defaults: { url: 'img/black.png' } });
U.BackgroundView = Backbone.View.extend({
el: '#background-image',
initialize: function(options) {
_.bindAll(this, 'render');
this.imgModel = options.imageModel;
this.imgModel.on('change:url', this.render);
},
render: function() { this.$el.attr('src', this.imgModel.get('url')); }
});
U.ClockView = Backbone.View.extend({
el: '#clock-panel',
@ -73,7 +117,8 @@
authComplete: function() {
console.log('authComplete. is_authenticated: ' + lightdm.is_authenticated);
if (lightdm.is_authenticated) {
console.log('Logging in: lightdm.login(' + this.user.name, this.sessionView.key);
console.log('Logging in: lightdm.login(' + this.user.name + ',' +
this.sessionView.key + ')');
//lightdm.start_session(this.sessionView.session.key);
this.$el.removeClass('checking');
lightdm.login(this.user, this.sessionView.session.key);
@ -92,7 +137,6 @@
render: function() {
this.undelegateEvents();
var greeting = 'Good ' + this.uiView.timePeriod;
var $userListEl = this.$el.find('#users-list');
$userListEl.html(
@ -102,9 +146,10 @@
}, this).join('\n'));
if (this.user) {
this.$el.find('#greeting').text(greeting);
this.$el.find('#greeting').text(this.uiView.getGreeting());
this.$el.find('#user-display').text(this.getUserName(this.user));
}
this.delegateEvents();
},
@ -159,6 +204,7 @@
_.bindAll(this, 'render', 'showSessionSelect', 'selectSession');
this.session = lightdm.sessions[0];
this.render();
},
render: function() {
@ -189,46 +235,52 @@
events: {},
initialize: function(options) {
_.bindAll(this, 'render', 'checkTimePeriod');
_.bindAll(this, 'render', 'setTheme');
window.autologin_timer_expired = function() {};
if (lightdm.lock_hint) this.$el.addClass('lock-screen');
this.timePeriod = 'day';
this.bgImgModel = new U.ImageModel
this.backgroundView = new U.BackgroundView({imageModel: this.bgImgModel});
this.sessionView = new U.SessionView();
this.loginView = new U.LoginView({uiView: this, sessionView: this.sessionView});
this.clockView = new U.ClockView();
this.powerView = new U.PowerView();
this.render();
this.setTheme(U.config.theme || 'jdb')
.then(this.render);
},
render: function() {
var prevTimePeriod = this.timePeriod;
this.checkTimePeriod();
render: function() { this.theme.render(this); },
if (this.timePeriod != prevTimePeriod) {
this.$el.removeClass(prevTimePeriod);
this.$el.addClass(this.timePeriod);
this.loginView.render();
this.sessionView.render();
getGreeting: function() { this.theme.getGreeting(); },
setTheme: function(themeName) {
var promise;
var uiView = this;
if (U.themes[themeName]) promise = Promise.resolve(U.themes[themeName]);
else {
promise = Promise.all([
U.load('script', 'themes/' + themeName + '/index.js'),
U.load('link', 'themes/' + themeName + '/style.css') ]);
}
},
checkTimePeriod: function() {
var now = new Date();
if (now.getHours() >= 21 || now.getHours() < 4) this.timePeriod = 'night';
else if (now.getHours() < 12) this.timePeriod = 'morning';
else if (now.getHours() < 18) this.timePeriod = 'afternoon';
else this.timePeriod = 'evening';
return promise.then(function() {
if (uiView.theme) uiView.theme.unload(uiView);
uiView.theme = U.themes[themeName];
uiView.theme.init(uiView);
return uiView.theme;
});
}
});
$(document).ready(function() {
U.uiView = new U.UIView();
console.log('window: ' + Object.getOwnPropertyNames(window).join(', '));
});
})();

1
js/require1k.min.js vendored Normal file
View File

@ -0,0 +1 @@
R=function(e,n,v1){function t(e,o,u,a){if(e.g)return o(e.e,e);var c=e.g=e.l,f=new XMLHttpRequest;f.onload=function(i,l){function s(){l--||o(n,e)}200==f.status||e.t?(i=[],(e.t=e.t||f.response).replace(/(?:^|[^\w\$_.])require\s*\(\s*["']([^"']*)["']\s*\)/g,function(e,n){i.push(n)}),l=i.length,i.map(function(o){t(r(e.l,o),s,"."!=o[0]?c+"/../":n,o)}),s()):u?t(e.n=r(u+="../",a),o,u,a):(e.e=f,o(f,e))},e.t?f.onload():(f.open("GET",c,!0),f.send())}function r(e,n,t){if(e.e)throw e.e;return n?(f.href=e,i.href="."!=n[0]?"./node_modules/"+n:n,t=i.href+".js",f.href="",u[t]=u[t]||{l:t}):e.n?r(e.n):(e[c]||(e.f||a("(function(require,"+c+",module){"+e.t+"\n})//# sourceURL="+e.l))(function(n){return r(r(e.l,n))},e[c]={},e),e[c])}function o(e,n){t(e.call?{l:"",t:""+e,f:e}:r("",e),function(t,o){try{e=r(o)}catch(u){t=u}n&&n(t,e)})}var u={},a=eval,c="createElement",f=e[c]("base"),i=e[c]("a");return e.head.appendChild(f),c=e.querySelector("script[data-main]"),c&&o(c.dataset.main),c="exports",o}(document);

23
package.json Normal file
View File

@ -0,0 +1,23 @@
{
"name": "lightdm-uestibulum",
"version": "1.0.0",
"description": "Custom theme for lightdm-webkit2-greeter.",
"main": "js/light-uestibulum.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"repository": {
"type": "git",
"url": "git.jdb-labs.com:jdb/lightdm-uestibulum.git"
},
"keywords": [
"lightdm",
"greeter"
],
"author": "Jonathan Bernard <jonathan@jdbernard.com>",
"license": "MIT",
"dependencies": {
"backbone": "^1.3.3",
"jquery": "^3.1.1"
}
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.1 MiB

BIN
themes/jdb/img/evening.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 MiB

View File

Before

Width:  |  Height:  |  Size: 14 MiB

After

Width:  |  Height:  |  Size: 14 MiB

View File

Before

Width:  |  Height:  |  Size: 4.3 MiB

After

Width:  |  Height:  |  Size: 4.3 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 15 MiB

After

Width:  |  Height:  |  Size: 15 MiB

View File

@ -0,0 +1 @@
../night.gif

BIN
themes/jdb/img/morning.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.0 MiB

View File

Before

Width:  |  Height:  |  Size: 498 KiB

After

Width:  |  Height:  |  Size: 498 KiB

52
themes/jdb/index.js Normal file
View File

@ -0,0 +1,52 @@
(function() {
var U = window.uestibulum;
function currentTimePeriod() {
var now = new Date();
if (now.getHours() >= 21 || now.getHours() < 4) return 'night';
else if (now.getHours() < 12) return 'morning';
else if (now.getHours() < 18) return 'afternoon';
else return 'evening';
}
var curTimePeriod;
var hidpi = U.config.hidpi;
var imagesByName = {
morning: 'morning.png',
afternoon: 'afternoon.png',
evening: 'evening.png',
night: 'night.gif' };
var T = {
name: 'jdb',
init: function(uiView) {
uiView.$el.addClass('theme-' + uiView.theme.name);
},
render: function(uiView, manualTimePeriod) {
var prevTimePeriod = curTimePeriod;
curTimePeriod = manualTimePeriod || currentTimePeriod();
if (curTimePeriod != prevTimePeriod) {
uiView.$el.removeClass(prevTimePeriod);
uiView.$el.addClass(curTimePeriod);
uiView.loginView.render();
uiView.bgImgModel.set('url', 'themes/jdb/img/' +
(hidpi ? 'hidpi/' : '') + imagesByName[curTimePeriod])
}
},
unload: function(uiView) {
uiView.$el.removeClass('theme-' + uiView.theme.name);
uiView.$el.removeClass(curTimePeriod);
},
getGreeting: function() { return 'Good ' + curTimePeriod; }
};
U.themes['jdb'] = T;
})();

69
themes/jdb/style.css Normal file
View File

@ -0,0 +1,69 @@
.theme-jdb {
/*&.night {
#clock-panel {
}
#login-panel {
position: absolute;
bottom: 2vw;
left: 2vw;
}
}*/ }
.theme-jdb.evening #clock-panel {
border-bottom: 2px solid white;
text-align: right;
position: absolute;
right: 0;
top: 0; }
.theme-jdb.evening #login-panel {
position: absolute;
bottom: 2vw;
left: 1vw; }
.theme-jdb.evening #session-panel {
position: absolute;
bottom: 0.5vw;
left: 1vw; }
.theme-jdb.morning #clock-panel, .theme-jdb.night #clock-panel, .theme-jdb.afternoon #clock-panel {
border-top: 2px solid white;
position: absolute;
left: 0;
bottom: 0; }
.theme-jdb.morning #login-panel, .theme-jdb.night #login-panel, .theme-jdb.afternoon #login-panel {
position: absolute;
bottom: 2vw;
left: 20vw; }
.theme-jdb.morning #session-panel, .theme-jdb.night #session-panel, .theme-jdb.afternoon #session-panel {
position: absolute;
bottom: 0.5vw;
left: 20vw; }
.theme-jdb.morning #clock-panel {
text-shadow: 0 0 0.2vw #446688; }
.theme-jdb.morning #users:hover #user-display, .theme-jdb.morning #sessions:hover #session-display,
.theme-jdb.morning #users-list li:hover, .theme-jdb.morning #sessions-list li.session:hover {
color: #0088aa;
text-shadow: 0 0 0.5vw black; }
.theme-jdb.morning #power-panel {
opacity: 0.7; }
.theme-jdb.afternoon #clock-panel {
text-shadow: 0 0 2vw #448844; }
.theme-jdb.afternoon #users:hover #user-display, .theme-jdb.afternoon #sessions:hover #session-display,
.theme-jdb.afternoon #users-list li:hover, .theme-jdb.afternoon #sessions-list li.session:hover {
color: #00aa00;
text-shadow: 0 0 0.5vw black; }
.theme-jdb.evening #clock-panel {
text-shadow: 0 0 2vw #faaa3b; }
.theme-jdb.evening #users:hover #user-display, .theme-jdb.evening #sessions:hover #session-display,
.theme-jdb.evening #users-list li:hover, .theme-jdb.evening #sessions-list li.session:hover {
color: orange;
text-shadow: 0 0 0.5vw black; }
.theme-jdb.evening #power-panel {
opacity: 0.7; }
.theme-jdb.night #clock-panel {
text-shadow: 0 0 2vw #884488; }
.theme-jdb.night #users:hover #user-display, .theme-jdb.night #sessions:hover #session-display,
.theme-jdb.night #users-list li:hover, .theme-jdb.night #sessions-list li.session:hover {
color: #8822bb;
text-shadow: 0 0 0.2vw black; }
/*# sourceMappingURL=style.css.map */

7
themes/jdb/style.css.map Normal file
View File

@ -0,0 +1,7 @@
{
"version": 3,
"mappings": "AAKA,UAAW;AAqFT;;;;;;;;;;KAUG;EA5FD,+BAAa;IACX,aAAa,EAAE,eAAkB;IACjC,UAAU,EAAE,KAAK;IAEjB,QAAQ,EAAE,QAAQ;IAClB,KAAK,EAAE,CAAC;IACR,GAAG,EAAE,CAAC;EAGR,+BAAa;IACX,QAAQ,EAAE,QAAQ;IAClB,MAAM,EAAE,GAAG;IACX,IAAI,EAAE,GAAG;EAGX,iCAAe;IACb,QAAQ,EAAE,QAAQ;IAClB,MAAM,EAAE,KAAK;IACb,IAAI,EAAE,GAAG;EAKX,iGAAa;IACX,UAAU,EAAE,eAAkB;IAE9B,QAAQ,EAAE,QAAQ;IAClB,IAAI,EAAE,CAAC;IACP,MAAM,EAAE,CAAC;EAGX,iGAAa;IACX,QAAQ,EAAE,QAAQ;IAClB,MAAM,EAAE,GAAG;IACX,IAAI,EAAE,IAAI;EAGZ,uGAAe;IACb,QAAQ,EAAE,QAAQ;IAClB,MAAM,EAAE,KAAK;IACb,IAAI,EAAE,IAAI;EAKZ,+BAAa;IAAE,WAAW,EAAE,iBAAiB;EAC7C;6FACsD;IACpD,KAAK,EAAE,OAAO;IACd,WAAW,EAAE,eAAe;EAE9B,+BAAa;IAAE,OAAO,EAAE,GAAG;EAI3B,iCAAa;IAAE,WAAW,EAAE,eAAe;EAC3C;iGACsD;IACpD,KAAK,EAAE,OAAO;IACd,WAAW,EAAE,eAAe;EAK9B,+BAAa;IAAE,WAAW,EAAE,eAAe;EAC3C;6FACsD;IACpD,KAAK,EAAE,MAAM;IACb,WAAW,EAAE,eAAe;EAE9B,+BAAa;IAAE,OAAO,EAAE,GAAG;EAI3B,6BAAa;IAAE,WAAW,EAAE,eAAe;EAC3C;yFACsD;IACpD,KAAK,EAAE,OAAO;IACd,WAAW,EAAE,eAAe",
"sources": ["style.scss"],
"names": [],
"file": "style.css"
}

102
themes/jdb/style.scss Normal file
View File

@ -0,0 +1,102 @@
$colorFG: white;
$colorBG: black;
$colorAccent: orange;
.theme-jdb {
&.evening {
#clock-panel {
border-bottom: 2px solid $colorFG;
text-align: right;
position: absolute;
right: 0;
top: 0;
}
#login-panel {
position: absolute;
bottom: 2vw;
left: 1vw;
}
#session-panel {
position: absolute;
bottom: 0.5vw;
left: 1vw;
}
}
&.morning, &.night, &.afternoon {
#clock-panel {
border-top: 2px solid $colorFG;
position: absolute;
left: 0;
bottom: 0;
}
#login-panel {
position: absolute;
bottom: 2vw;
left: 20vw;
}
#session-panel {
position: absolute;
bottom: 0.5vw;
left: 20vw;
}
}
&.morning {
#clock-panel { text-shadow: 0 0 0.2vw #446688; }
#users:hover #user-display, #sessions:hover #session-display,
#users-list li:hover, #sessions-list li.session:hover {
color: #0088aa;
text-shadow: 0 0 0.5vw black;
}
#power-panel { opacity: 0.7; }
}
&.afternoon {
#clock-panel { text-shadow: 0 0 2vw #448844; }
#users:hover #user-display, #sessions:hover #session-display,
#users-list li:hover, #sessions-list li.session:hover {
color: #00aa00;
text-shadow: 0 0 0.5vw black;
}
}
&.evening {
#clock-panel { text-shadow: 0 0 2vw #faaa3b; }
#users:hover #user-display, #sessions:hover #session-display,
#users-list li:hover, #sessions-list li.session:hover {
color: orange;
text-shadow: 0 0 0.5vw black;
}
#power-panel { opacity: 0.7; }
}
&.night {
#clock-panel { text-shadow: 0 0 2vw #884488; }
#users:hover #user-display, #sessions:hover #session-display,
#users-list li:hover, #sessions-list li.session:hover {
color: #8822bb;
text-shadow: 0 0 0.2vw black;
}
}
/*&.night {
#clock-panel {
}
#login-panel {
position: absolute;
bottom: 2vw;
left: 2vw;
}
}*/
}

78
themes/music/index.js Normal file
View File

@ -0,0 +1,78 @@
(function() {
var U = window.uestibulum;
function guessEvent() {
var now = new Date();
var day = now.getDay();
var hour = now.getHours();
switch (day) {
// Sunday
case 0:
if (hour >= 8 && hour < 10) return 'rehearsal';
else if (hour >= 10 && hour < 13) return 'service';
else if (hour >= 13 && hour < 15) return 'mixing';
else if (hour >= 15 && hour < 18) return 'rehearsal';
else if (hour >= 18 && hour < 21) return 'service';
break;
// Wednesday
case 3:
if (hour == 18) return 'rehearsal';
else if (hour >= 19 && hour < 21) return 'service';
break;
// Tuesday, Thursday
case 2: case 4:
if (hour >= 19 && hour < 21) return 'rehearsal';
break;
// Monday, Friday, Saturday
default:
}
return 'other';
}
var curEvent;
var hidpi = U.config.hidpi;
var imagesByName = {
mixing: [],
rehearsal: [],
service: [],
other: [] }
var T = {
name: 'music',
init: function(uiView) {
uiView.$el.addClass('theme-' + uiView.theme.name);
},
render: function(uiView, manualEvent) {
var prevEvent = curEvent;
curEvent = manualEvent || guessEvent();
if (curEvent != prevEvent) {
uiView.$el.removeClass(prevEvent);
uiView.$el.addClass(curEvent);
uiView.loginView.render();
uiView.bgImgModel.set('url', 'themes/music/img/' +
(hidpi ? 'hidpi/' : '') + imagesByName[curEvent])
}
},
unload: function(uiView) {
uiView.$el.removeClass('theme-' + uiView.theme.name);
uiView.$el.removeClass(curEvent);
},
getGreeting: function() { return 'Good ' + curEvent; }
};
U.themes['jdb'] = T;
})();

3
themes/music/style.css Normal file
View File

@ -0,0 +1,3 @@
/*# sourceMappingURL=style.css.map */

View File

@ -0,0 +1,7 @@
{
"version": 3,
"mappings": "",
"sources": [],
"names": [],
"file": "style.css"
}

8
themes/music/style.scss Normal file
View File

@ -0,0 +1,8 @@
$colorFG: white;
$colorBG: black;
$colorAccent: orange;
.theme-music {
}