diff --git a/.gitignore b/.gitignore
index ff8333e..7f5ab31 100644
--- a/.gitignore
+++ b/.gitignore
@@ -98,7 +98,7 @@ crashlytics-build.properties
# gitignore contributors: remember to update Global/Xcode.gitignore, Objective-C.gitignore & Swift.gitignore
## Build generated
-build/
+# build/
DerivedData
## Various settings
@@ -174,7 +174,7 @@ node_modules
# See http://help.github.com/ignore-files/ for more about ignoring files.
# compiled output
-/dist
+# /dist
/tmp
# dependencies
diff --git a/app/js/modules/bitcoin.js b/app/js/modules/bitcoin.js
index 91e7b64..39bce8d 100644
--- a/app/js/modules/bitcoin.js
+++ b/app/js/modules/bitcoin.js
@@ -180,6 +180,8 @@ const BitcoinModel = Backbone.Model.extend({
self.recalc();
}
});
+
+
const Bitcoin = Backbone.View.extend({
'tagName': 'div',
'initialize': function () {
diff --git a/dist/build/bundle.css b/dist/build/bundle.css
new file mode 100644
index 0000000..e82dbae
--- /dev/null
+++ b/dist/build/bundle.css
@@ -0,0 +1,23 @@
+.svelte-oqm7j5{font-size:90%}
+.routeBox.svelte-12mw410{border:1px dotted silver}
+#timer.svelte-izlfdv.svelte-izlfdv{display:flex;color:#333;flex-direction:column;align-items:center;justify-content:center}.timer-value.svelte-izlfdv.svelte-izlfdv{display:flex;color:#333;flex-direction:row;align-items:center;justify-content:center;font-size:24px;height:100%;width:100%}.timer-value.svelte-izlfdv small.svelte-izlfdv{font-size:18px;margin-left:4px}
+.card.svelte-1y1eghs{position:relative;background-color:#fff;min-height:72px}.mui--text-display3.svelte-1y1eghs{font-family:"Roboto Slab", "Helvetica Neue", Helvetica, Arial}.temp0.svelte-1y1eghs,.temp1.svelte-1y1eghs,.temp2.svelte-1y1eghs,.temp3.svelte-1y1eghs,.temp4.svelte-1y1eghs,.temp5.svelte-1y1eghs{color:rgb(80, 181, 221)
+ }.temp6.svelte-1y1eghs{color:rgb(78, 178, 206)
+ }.temp7.svelte-1y1eghs{color:rgb(76, 176, 190)
+ }.temp8.svelte-1y1eghs{color:rgb(73, 173, 175)
+ }.temp9.svelte-1y1eghs{color:rgb(72, 171, 159)
+ }.temp10.svelte-1y1eghs{color:rgb(70, 168, 142)
+ }.temp11.svelte-1y1eghs{color:rgb(68, 166, 125)
+ }.temp12.svelte-1y1eghs{color:rgb(66, 164, 108)
+ }.temp13.svelte-1y1eghs{color:rgb(102, 173, 94)
+ }.temp14.svelte-1y1eghs{color:rgb(135, 190, 64)
+ }.temp15.svelte-1y1eghs{color:rgb(179, 204, 26)
+ }.temp16.svelte-1y1eghs{color:rgb(214, 213, 28)
+ }.temp17.svelte-1y1eghs{color:rgb(249, 202, 3)
+ }.temp18.svelte-1y1eghs{color:rgb(246, 181, 3)
+ }.temp19.svelte-1y1eghs{color:rgb(244, 150, 26)
+ }.temp20.svelte-1y1eghs{color:rgb(236, 110, 5)
+ }.day.svelte-1y1eghs{font-family:"Roboto Slab", "Helvetica Neue", Helvetica, Arial, SansSerif;text-transform:uppercase}.summary.svelte-1y1eghs::first-letter{text-transform:capitalize
+ }
+
+/*# sourceMappingURL=bundle.css.map */
\ No newline at end of file
diff --git a/dist/build/bundle.css.map b/dist/build/bundle.css.map
new file mode 100644
index 0000000..e729f05
--- /dev/null
+++ b/dist/build/bundle.css.map
@@ -0,0 +1,18 @@
+{
+ "version": 3,
+ "file": "bundle.css",
+ "sources": [
+ "../../Fx.svelte",
+ "../../Route.svelte",
+ "../../Timer.svelte",
+ "../../Weather.svelte"
+ ],
+ "sourcesContent": [
+ "\n\n\n\n{#if fxData.gpbe}\n\n £1 = ${parseFloat(fxData.gpbe.toFixed(2))} = { parseFloat(fxData.sekex.toFixed(2))} SEK\n\n\n{/if}\n\n\n",
+ "\n\n\n\n{#if visible}\n
\n
{routeData.fromName} TO {routeData.toName}
\n
\n \n \n Destination | \n Time | \n Status | \n Platform | \n
\n \n\n \n {#each services as item}\n \n\n {item.icon}{item.location} {@html item.via} | \n {item.time} | \n {#if !item.isCancelled}\n {item.status} | \n {item.platform} | \n {:else}\n ❌ {item.cancelReason} | \n {/if}\n
\n {/each}\n \n
\n\n
\n{/if}\n\n",
+ "\n\n\n\n
\n {#if timerVisible}\n
\n \n\n
\n
\n {minutes}mins\n {seconds}s\n
\n {/if}\n
\n",
+ "\n\n\n\n\n\n {#if weatherData}\n {#each weatherData as item}\n
\n
\n
{item.day}
\n
{item.date}
\n
\n
\n
\n \n {item.tempHigh}° /\n {item.tempLow}°\n
\n
{item.summary}
\n
\n
\n
{item.tempMorn}°
\n
{item.tempDay}°
\n
{item.tempEve}°
\n
{item.tempNight}°
\n
\n
\n {/each}\n {/if}\n\n
\n"
+ ],
+ "names": [],
+ "mappings": "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"
+}
\ No newline at end of file
diff --git a/dist/build/bundle.js b/dist/build/bundle.js
new file mode 100644
index 0000000..d51781b
--- /dev/null
+++ b/dist/build/bundle.js
@@ -0,0 +1 @@
+var app=function(){"use strict";function t(){}const e=t=>t;function n(t,e){for(const n in e)t[n]=e[n];return t}function a(t){return t()}function i(){return Object.create(null)}function r(t){t.forEach(a)}function o(t){return"function"==typeof t}function l(t,e){return t!=t?e==e:t!==e||t&&"object"==typeof t||"function"==typeof t}function s(e,...n){if(null==e)return t;const a=e.subscribe(...n);return a.unsubscribe?()=>a.unsubscribe():a}function c(t,e,a,i){return t[1]&&i?n(a.ctx.slice(),t[1](i(e))):a.ctx}function u(t){return null==t?"":t}function m(t,e,n=e){return t.set(n),e}const h="undefined"!=typeof window;let p=h?()=>window.performance.now():()=>Date.now(),f=h?t=>requestAnimationFrame(t):t;const d=new Set;function w(t){d.forEach(e=>{e.c(t)||(d.delete(e),e.f())}),0!==d.size&&f(w)}function g(t,e){t.appendChild(e)}function $(t,e,n){t.insertBefore(e,n||null)}function b(t){t.parentNode.removeChild(t)}function v(t,e){for(let n=0;nt.removeEventListener(e,n,a)}function T(t){return function(e){return e.stopPropagation(),t.call(this,e)}}function C(t,e,n){null==n?t.removeAttribute(e):t.getAttribute(e)!==n&&t.setAttribute(e,n)}function L(t,e){e=""+e,t.data!==e&&(t.data=e)}function D(t,e){(null!=e||t.value)&&(t.value=e)}function E(t,e,n,a){t.style.setProperty(e,n,a?"important":"")}class H{constructor(t,e=null){this.e=y("div"),this.a=e,this.u(t)}m(t,e=null){for(let n=0;n{U.delete(t),a&&(n&&t.d(1),a())}),t.o(e)}}function q(t){t&&t.c()}function X(t,e,n){const{fragment:i,on_mount:l,on_destroy:s,after_update:c}=t.$$;i&&i.m(e,n),W(()=>{const e=l.map(a).filter(o);s?s.push(...e):r(e),t.$$.on_mount=[]}),c.forEach(W)}function Z(t,e){const n=t.$$;null!==n.fragment&&(r(n.on_destroy),n.fragment&&n.fragment.d(e),n.on_destroy=n.fragment=null,n.ctx=[])}function Q(t,e){-1===t.$$.dirty[0]&&(F.push(t),_||(_=!0,Y.then(I)),t.$$.dirty.fill(0)),t.$$.dirty[e/31|0]|=1<{const i=a.length?a[0]:n;return h.ctx&&l(h.ctx[t],h.ctx[t]=i)&&(h.bound[t]&&h.bound[t](i),p&&Q(e,t)),n}):[],h.update(),p=!0,r(h.before_update),h.fragment=!!o&&o(h.ctx),n.target){if(n.hydrate){const t=function(t){return Array.from(t.childNodes)}(n.target);h.fragment&&h.fragment.l(t),t.forEach(b)}else h.fragment&&h.fragment.c();n.intro&&J(e.$$.fragment),X(e,n.target,n.anchor),I()}B(u)}class tt{$destroy(){Z(this,1),this.$destroy=t}$on(t,e){const n=this.$$.callbacks[t]||(this.$$.callbacks[t]=[]);return n.push(e),()=>{const t=n.indexOf(e);-1!==t&&n.splice(t,1)}}$set(){}}function et(t){let e,n;const a=t[1].default,i=function(t,e,n,a){if(t){const i=c(t,e,n,a);return t[0](i)}}(a,t,t[0],null);return{c(){e=y("div"),i&&i.c(),C(e,"class","mui-col-md-4")},m(t,a){$(t,e,a),i&&i.m(e,null),n=!0},p(t,[e]){i&&i.p&&1&e&&i.p(c(a,t,t[0],null),function(t,e,n,a){if(t[2]&&a){const i=t[2](a(n));if(void 0===e.dirty)return i;if("object"==typeof i){const t=[],n=Math.max(e.dirty.length,i.length);for(let a=0;a{"$$scope"in t&&n(0,i=t.$$scope)},[i,a]}class at extends tt{constructor(t){super(),V(this,t,nt,et,l,{})}}function it(e){let n;return{c(){n=y("div"),n.innerHTML='\n Slack\n
',C(n,"class","mui-appbar mui--appbar-line-height")},m(t,e){$(t,n,e)},p:t,i:t,o:t,d(t){t&&b(n)}}}class rt extends tt{constructor(t){super(),V(this,t,null,it,l,{})}}function ot(t,e,n){const a=t.slice();return a[3]=e[n],a}function lt(t){let e,n,a,i,r,o,l,s=t[3].label+"",c=t[3].days+"",u=t[3].weeks+"";return{c(){e=y("div"),n=x(s),a=k(),i=x(c),r=x(" days / "),o=x(u),l=x(" weeks\n "),C(e,"class","mui-col-xs-12 mui-col-md-3")},m(t,s){$(t,e,s),g(e,n),g(e,a),g(e,i),g(e,r),g(e,o),g(e,l)},p(t,e){1&e&&s!==(s=t[3].label+"")&&L(n,s),1&e&&c!==(c=t[3].days+"")&&L(i,c),1&e&&u!==(u=t[3].weeks+"")&&L(o,u)},d(t){t&&b(e)}}}function st(e){let n,a,i=e[0],r=[];for(let t=0;t{i()});const i=()=>{const t=new Date,e=36e5-t.getTime()%36e5;n(0,a=a.map(e=>(e.days=Math.ceil(r(t,e.event)),e.weeks=Math.ceil(r(t,e.event)/7),e)));setTimeout(function(){i()}.bind(this),e+10)},r=(t,e)=>{let n,a,i;return a=t.getTime(),i=e.getTime(),n=(i-a)/864e5,n};return t.$set=t=>{"events"in t&&n(0,a=t.events)},[a]}class ut extends tt{constructor(t){super(),V(this,t,ct,st,l,{events:0})}}function mt(t){let e,n,a,i,r,o,l;return{c(){e=y("div"),n=y("div"),a=x("Long: "),i=x(t[0]),r=y("div"),o=x("Short: "),l=x(t[1]),C(e,"id","passwordOut"),C(e,"class","password")},m(t,s){$(t,e,s),g(e,n),g(n,a),g(n,i),g(e,r),g(r,o),g(r,l)},p(t,e){1&e&&L(i,t[0]),2&e&&L(l,t[1])},d(t){t&&b(e)}}}function ht(e){let n,a,i,r,o=e[0]&&mt(e);return{c(){n=y("div"),a=y("button"),a.textContent="Generate Password",i=k(),o&&o.c(),C(a,"class","mui-btn mui-btn--flat"),C(a,"id","newPassword"),C(n,"id","passwords")},m(t,l,s){$(t,n,l),g(n,a),g(n,i),o&&o.m(n,null),s&&r(),r=M(a,"click",e[2])},p(t,[e]){t[0]?o?o.p(t,e):(o=mt(t),o.c(),o.m(n,null)):o&&(o.d(1),o=null)},i:t,o:t,d(t){t&&b(n),o&&o.d(),r()}}}function pt(t,e,n){let a,i;Array.prototype.random=function(){return this[Math.floor(Math.random()*this.length)]};const r=["a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z","A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z","0","1","2","3","4","5","6","7","8","9"],o=["0","1","2","3","4","5","6","7","8","9"],l=["Alabama","Alaska","Arizona","Maryland","Nevada","Mexico","Texas","Utah","Glasgow","Inverness","Edinburgh","Dumbarton","Balloch","Renton","Cardross","Dundee","Paisley","Hamilton","Greenock","Falkirk","Irvine","Renfrew","Erskine","London","Hammersmith","Islington","Silver","Black","Yellow","Purple","White","Pink","Red","Orange","Brown","Green","Blue","Amber","Aqua","Azure","Bronze","Coral","Copper","Crimson","Cyan","Ginger","Gold","Indigo","Jade","Ruby","Cedar","Cream","Peach","Sepcia","Mercyful","Cyber","Ultra","Hunter","Electric","Steel","Fire","Smoke","Thunder","Pewter","Stone","Iron","Shadow","Grey","Mocha","Wood","Space","Manic","Grunt","X-Ray","Sabbra","Atomic"],s=["Aganju","Cygni","Akeron","Antares","Aragoth","Ardus","Carpenter","Cooper","Dahin","Capella","Endriago","Gallina","Fenris","Freya","Glenn","Grissom","Jotunheim","Kailaasa","Lagarto","Muspelheim","Nifleheim","Primus","Vega","Ragnarok","Shepard","Slayton","Tarsis","Mercury","Venus","Mars","Earth","Terra","Jupiter","Saturn","Uranus","Neptune","Pluto","Europa","Ganymede","Callisto","Titan","Juno","Eridanus","Scorpius","Crux","Cancer","Taurus","Lyra","Andromeda","Virgo","Aquarius","Cygnus","Corvus","Taurus","Draco","Perseus","Pegasus","Gemini","Columbia","Bootes","Orion","Deneb","Merope","Agate","Amber","Beryl","Calcite","Citrine","Coral","Diamond","Emerald","Garnet","Jade","Lapis","Moonstone","Obsidian","Onyx","Opal","Pearl","Quartz","Ruby","Sapphire","Topaz","Iron","Lead","Nickel","Copper","Zinc","Tin","Manes","Argon","Neon","Alpha","Bravo","Charlie","Delta","Echo","Foxtrot","Golf","Hotel","India","Juliett","Kilo","Lima","Mike","November","Oscar","Papa","Quebec","Romeo","Sierra","Tango","Uniform","Victor","Whisky","Xray","Yankee","Zulu","Fate","Miner","Blaster","Click","Noise","Cadabra","Shotgun"];function c(t){let e="";for(let n=0;n{const t=i.indexOf(s);-1!==t&&i.splice(t,1),0===i.length&&(a(),a=null)}}}}function gt(t){let e,n,a,i,r,o,l,s=t[0].toFixed(2)+"",c=t[1].toFixed(2)+"";return{c(){e=y("span"),n=k(),a=y("span"),i=x("$"),r=x(s),o=x(" / £"),l=x(c),C(e,"id","trend"),C(e,"class",t[3]),C(a,"id","btc"),C(a,"class",t[2])},m(t,s){$(t,e,s),$(t,n,s),$(t,a,s),g(a,i),g(a,r),g(a,o),g(a,l)},p(t,n){8&n&&C(e,"class",t[3]),1&n&&s!==(s=t[0].toFixed(2)+"")&&L(r,s),2&n&&c!==(c=t[1].toFixed(2)+"")&&L(l,c),4&n&&C(a,"class",t[2])},d(t){t&&b(e),t&&b(n),t&&b(a)}}}function $t(e){let n,a=0!==e[0]&>(e);return{c(){a&&a.c(),n=S()},m(t,e){a&&a.m(t,e),$(t,n,e)},p(t,[e]){0!==t[0]?a?a.p(t,e):(a=gt(t),a.c(),a.m(n.parentNode,n)):a&&(a.d(1),a=null)},i:t,o:t,d(t){a&&a.d(t),t&&b(n)}}}function bt(t,e,n){let a,i=0,r="",o="";const l=wt({lastGBP:0,lastUSD:0,lows:{gbp:0,usd:0},highs:{gbp:0,usd:0},eclass:"",balance:0,trend:0});return l.subscribe(t=>{n(0,i=t.lastUSD),n(1,a=t.lastGBP),n(2,r=t.eclass)}),N(async()=>{await async function t(){await async function(){const t=await fetch("https://silvrtree.co.uk/btc"),e=await t.json();e&&function(t){let e=function(t){let e;return s(t,t=>e=t)(),e}(l);e.gbp=t.bpi.GBP.rate_float,e.usd=t.bpi.USD.rate_float,e.trend=t.trend;let a,i=e.lastGBP;const r=e.gbp,c=e.usd,u=e.lows,m=e.highs;let h=e.eclass;const p=e.balance;let f=e.trend;null==f&&(f=1);void 0!==r&&(0!==e.lastGBP?h=r>i?"up":"down":(u.gbp=r,u.usd=c,m.gbp=r,m.usd=c,h=""),i=r,a=c,r1?"trendUp":f<1?"trendDown":""),e={lastGBP:i,lastUSD:a,lows:u,highs:m,eclass:h,balance:p,trend:f});e.stub=Math.random(Number.MAX_SAFE_INTEGER).toString(32),l.set(e)}(e)}();const e=3e5-(new Date).getTime()%3e5;setTimeout(function(){t()}.bind(this),e+10)}()}),[i,a,r,o]}class vt extends tt{constructor(t){super(),V(this,t,bt,$t,l,{})}}var yt=/d{1,4}|M{1,4}|YY(?:YY)?|S{1,3}|Do|ZZ|Z|([HhMsDm])\1?|[aA]|"[^"]*"|'[^']*'/g,xt=/\[([^]*?)\]/gm;function kt(t,e){for(var n=[],a=0,i=t.length;a3?0:(t-t%10!=10?1:0)*t%10]}}),Dt=function(t,e){for(void 0===e&&(e=2),t=String(t);t.length0?"-":"+")+Dt(100*Math.floor(Math.abs(e)/60)+Math.abs(e)%60,4)},Z:function(t){var e=t.getTimezoneOffset();return(e>0?"-":"+")+Dt(Math.floor(Math.abs(e)/60),2)+":"+Dt(Math.abs(e)%60,2)}},Ht={default:"ddd MMM DD YYYY HH:mm:ss",shortDate:"M/D/YY",mediumDate:"MMM D, YYYY",longDate:"MMMM D, YYYY",fullDate:"dddd, MMMM D, YYYY",isoDate:"YYYY-MM-DD",isoDateTime:"YYYY-MM-DDTHH:mm:ssZ",shortTime:"HH:mm",mediumTime:"HH:mm:ss",longTime:"HH:mm:ss.SSS"},At=function(t,e,n){if(void 0===e&&(e=Ht.default),void 0===n&&(n={}),"number"==typeof t&&(t=new Date(t)),"[object Date]"!==Object.prototype.toString.call(t)||isNaN(t.getTime()))throw new Error("Invalid Date pass to format");var a=[];e=(e=Ht[e]||e).replace(xt,(function(t,e){return a.push(e),"@@@"}));var i=St(St({},Lt),n);return(e=e.replace(yt,(function(e){return Et[e](t,i)}))).replace(/@@@/g,(function(){return a.shift()}))};function Bt(t,e,n){const a=t.slice();return a[4]=e[n],a}function Nt(t){let e,n=t[0],a=[];for(let e=0;e{await async function t(){await async function(){const t=await fetch("https://silvrtree.co.uk/weather"),e=await t.json();e&&n(0,a=e.list.map(t=>function(t){const e=new Date(1e3*t.dt),n=t.weather[0];return{timestamp:t.dt,icon:`wi-owm-${n.id}`,summary:n.description,tempHigh:parseInt(t.temp.max,10),tempLow:parseInt(t.temp.min,10),tempMorn:parseInt(t.temp.morn,10),tempDay:parseInt(t.temp.day,10),tempEve:parseInt(t.temp.eve,10),tempNight:parseInt(t.temp.night,10),datelong:At(e,"isoDateTime"),time:t.dt,date:At(e,"D/M"),day:At(e,"ddd"),tempHighClass:`temp${parseInt(t.temp.max,10)}`,tempLowClass:`temp${parseInt(t.temp.min,10)}`}}(t)))}();const e=18e5-(new Date).getTime()%18e5;setTimeout(function(){t()}.bind(this),e+10)}()}),[a]}class Pt extends tt{constructor(t){super(),V(this,t,jt,Gt,l,{})}}function Yt(t){let e,n,a,i,r,o,l=parseFloat(t[0].gpbe.toFixed(2))+"",s=parseFloat(t[0].sekex.toFixed(2))+"";return{c(){e=y("span"),n=x("£1 = $"),a=x(l),i=x(" = "),r=x(s),o=x(" SEK"),C(e,"class","svelte-oqm7j5")},m(t,l){$(t,e,l),g(e,n),g(e,a),g(e,i),g(e,r),g(e,o)},p(t,e){1&e&&l!==(l=parseFloat(t[0].gpbe.toFixed(2))+"")&&L(a,l),1&e&&s!==(s=parseFloat(t[0].sekex.toFixed(2))+"")&&L(r,s)},d(t){t&&b(e)}}}function _t(e){let n,a=e[0].gpbe&&Yt(e);return{c(){a&&a.c(),n=S()},m(t,e){a&&a.m(t,e),$(t,n,e)},p(t,[e]){t[0].gpbe?a?a.p(t,e):(a=Yt(t),a.c(),a.m(n.parentNode,n)):a&&(a.d(1),a=null)},i:t,o:t,d(t){a&&a.d(t),t&&b(n)}}}function Wt(t,e,n){let a={};return N(async()=>{await async function t(){await async function(){const t=await fetch("https://silvrtree.co.uk/fx"),e=await t.json();e&&function(t){if(void 0!==t.rates){const e=1/t.rates.GBP,i=e*t.rates.SEK;n(0,a={usd:1,gbp:t.rates.GBP,sek:t.rates.SEK,gpbe:e,sekex:i})}}(e)}();const e=18e5-(new Date).getTime()%18e5;setTimeout(function(){t()}.bind(this),e+10)}()}),[a]}class Rt extends tt{constructor(t){super(),V(this,t,Wt,_t,l,{})}}const Ot=wt({fromStation:"",toStation:""});function It(e){let n,a,i,r,o,l,s,c=e[0].title+"",u=e[0].output+"";return{c(){n=y("div"),a=x(c),i=x(": "),r=y("span"),o=x(u),C(r,"class",l=e[0].status),C(n,"class","mui-col-xs-12 mui-col-md-6")},m(t,l,c){$(t,n,l),g(n,a),g(n,i),g(n,r),g(r,o),c&&s(),s=M(n,"click",e[1])},p(t,[e]){1&e&&c!==(c=t[0].title+"")&&L(a,c),1&e&&u!==(u=t[0].output+"")&&L(o,u),1&e&&l!==(l=t[0].status)&&C(r,"class",l)},i:t,o:t,d(t){t&&b(n),s()}}}function zt(t,e,n){let a,{fromStation:i}=e,{toStation:r}=e,o={eta:"OFF",sta:"OFF"},l={title:"TRAIN",status:"delayed",output:"OFF"};return N(async()=>{await async function t(){await async function(){const t=await fetch(a),e=await t.json();e&&(console.log(e),n(5,o=e))}();const e=12e4-(new Date).getTime()%12e4;setTimeout(function(){t()}.bind(this),e+10)}()}),t.$set=t=>{"fromStation"in t&&n(2,i=t.fromStation),"toStation"in t&&n(3,r=t.toStation)},t.$$.update=()=>{12&t.$$.dirty&&(a=`https://traintimes.silvrtree.co.uk/getnexttraintimes?from=${i}&to=${r}`,n(0,l.title=`${i.toUpperCase()}${r.toUpperCase()}`,l)),32&t.$$.dirty&&(n(0,l.output="on time"===o.eta.toLowerCase()?o.sta:o.eta,l),n(0,l.status="on time"===o.eta.toLowerCase()?"ontime":"delayed",l))},[l,function(){console.log("click",o),Ot.set({fromStation:i,toStation:r})},i,r]}class Ut extends tt{constructor(t){super(),V(this,t,zt,It,l,{fromStation:2,toStation:3})}}function Jt(t,e,n){const a=t.slice();return a[10]=e[n],a}function Kt(t){let e,n,a,i,r,o,l,s,c,u,m=t[1].fromName+"",h=t[1].toName+"",p=t[2],f=[];for(let e=0;eDestination | \n Time | \n Status | \n Platform | ",c=k(),u=y("tbody");for(let t=0;t{console.log(">> route",t),a=t.fromStation,i=t.toStation,n(0,o=""!==a&&!o),r=`https://traintimes.silvrtree.co.uk/gettrains?from=${a}&to=${i}`,""!==a&&o&&await async function t(){await async function(){console.log("Get route",r);const t=await fetch(r),e=await t.json();e&&(console.log(e),function(t){const e={};if(e.fromName=t.locationName,e.toName=t.filterLocationName,e.services=[],"object"==typeof t.trainServices&&null!==t.trainServices)for(const n of t.trainServices){const t=n.destination[0],a=null!==t.via?`${t.via}`:"",i=null!==n.platform?n.platform:"💠",r=null!==n.sta?n.sta:`D ${n.std}`,o=null!==n.eta?n.eta:n.etd,l="on time"===o.toLowerCase()?"ontime":"delayed";e.services.push({location:t.locationName,time:r,via:a,class:l,status:o,platform:i,cancelReason:n.cancelReason,type:"train",isCancelled:n.isCancelled,icon:""})}if("object"==typeof t.busServices&&null!==t.busServices)for(const n of t.busServices){const t=n.destination[0],a=null!==t.via?`${t.via}`:"",i=null!==n.platform?n.platform:"",r=null!==n.sta?n.sta:`D ${n.std}`,o=null!==n.eta?n.eta:n.etd,l="on time"===o.toLowerCase()?"ontime":"delayed";e.services.push({location:t.locationName,time:r,via:a,class:l,status:o,platform:i,cancelReason:n.cancelReason,type:"bus",isCancelled:n.isCancelled,icon:"🚌 "})}n(1,l=e),n(2,s=e.services),console.log(l)}(e))}();const e=18e4-(new Date).getTime()%18e4,a=function(){t()};o&&setTimeout(a.bind(this),e+10)}()}),[o,l,s]}class te extends tt{constructor(t){super(),V(this,t,Vt,Qt,l,{})}}function ee(t){return"[object Date]"===Object.prototype.toString.call(t)}function ne(t,e){if(t===e||t!=t)return()=>t;const n=typeof t;if(n!==typeof e||Array.isArray(t)!==Array.isArray(e))throw new Error("Cannot interpolate values of different type");if(Array.isArray(t)){const n=e.map((e,n)=>ne(t[n],e));return t=>n.map(e=>e(t))}if("object"===n){if(!t||!e)throw new Error("Object cannot be null");if(ee(t)&&ee(e)){t=t.getTime();const n=(e=e.getTime())-t;return e=>new Date(t+e*n)}const n=Object.keys(e),a={};return n.forEach(n=>{a[n]=ne(t[n],e[n])}),t=>{const e={};return n.forEach(n=>{e[n]=a[n](t)}),e}}if("number"===n){const n=e-t;return e=>t+e*n}throw new Error(`Cannot interpolate ${n} values`)}function ae(t,a={}){const i=wt(t);let r,o=t;function l(l,s){if(null==t)return i.set(t=l),Promise.resolve();o=l;let c=r,u=!1,{delay:m=0,duration:h=400,easing:g=e,interpolate:$=ne}=n(n({},a),s);const b=p()+m;let v;return r=function(t){let e;return 0===d.size&&f(w),{promise:new Promise(n=>{d.add(e={c:t,f:n})}),abort(){d.delete(e)}}}(e=>{if(eh?(i.set(t=l),!1):(i.set(t=v(g(n/h))),!0)}),r.promise}return{set:l,update:(e,n)=>l(e(o,t),n),subscribe:i.subscribe}}function ie(t){let e,n,a,i,o,l,s,c,u,m,h,p,f,d,w;function v(t,e){return 0===t[2]?oe:re}let S=v(t),T=S(t);return{c(){e=y("div"),n=y("label"),a=y("input"),i=k(),o=y("button"),T.c(),l=k(),s=y("div"),c=y("span"),u=x(t[4]),m=x("mins"),h=k(),p=y("small"),f=x(t[5]),d=x("s"),C(a,"type","range"),C(a,"min","1"),C(a,"max","60"),C(o,"class","mui-btn mui-btn--flat"),C(p,"class","svelte-izlfdv"),C(s,"class","timer-value svelte-izlfdv"),E(s,"color","hsl("+120*(1-t[6])+"deg, 50%, 50%)",1)},m(b,v,y){$(b,e,v),g(e,n),g(n,a),D(a,t[1]),g(n,i),g(n,o),T.m(o,null),$(b,l,v),$(b,s,v),g(s,c),g(c,u),g(c,m),g(s,h),g(s,p),g(p,f),g(p,d),y&&r(w),w=[M(a,"change",t[17]),M(a,"input",t[17]),M(o,"click",t[9])]},p(t,e){2&e&&D(a,t[1]),S!==(S=v(t))&&(T.d(1),T=S(t),T&&(T.c(),T.m(o,null))),16&e&&L(u,t[4]),32&e&&L(f,t[5]),64&e&&E(s,"color","hsl("+120*(1-t[6])+"deg, 50%, 50%)",1)},d(t){t&&b(e),T.d(),t&&b(l),t&&b(s),r(w)}}}function re(t){let e;return{c(){e=x("Stop")},m(t,n){$(t,e,n)},d(t){t&&b(e)}}}function oe(t){let e;return{c(){e=x("Start")},m(t,n){$(t,e,n)},d(t){t&&b(e)}}}function le(e){let n,a,i,r,o=e[0]&&ie(e);return{c(){n=y("div"),a=y("button"),a.textContent="Timer",i=k(),o&&o.c(),C(a,"class","mui-btn mui-btn--flat"),C(a,"id","newPassword"),C(n,"id","timer"),C(n,"class","svelte-izlfdv")},m(t,l,s){$(t,n,l),g(n,a),g(n,i),o&&o.m(n,null),s&&r(),r=M(a,"click",e[8])},p(t,[e]){t[0]?o?o.p(t,e):(o=ie(t),o.c(),o.m(n,null)):o&&(o.d(1),o=null)},i:t,o:t,d(t){t&&b(n),o&&o.d(),r()}}}function se(e,n,a){let i,r,o=t;e.$$.on_destroy.push(()=>o());let l,c=!1,u=25,h=0;const p=ae(0,{duration:1e3});var f,d;function w(){l=new Audio("stuff/bell.mp3"),l.play()}function g(){clearInterval(h),a(2,h=0)}let $,b,v,y,x;return f=p,d=t=>a(6,r=t),e.$$.on_destroy.push(s(f,d)),e.$$.update=()=>{2&e.$$.dirty&&a(11,$=60*u),2048&e.$$.dirty&&(a(3,b=ae($)),o(),o=s(b,t=>a(12,i=t))),4096&e.$$.dirty&&a(4,v=Math.floor(i/60)),16&e.$$.dirty&&(y=v>1?"mins":"min"),4112&e.$$.dirty&&a(5,x=Math.floor(i-60*v)),6144&e.$$.dirty&&m(p,r=1-i/$)},[c,u,h,b,v,x,r,p,function(){a(0,c=!c),c||g()},function(){0!==h?g():a(2,h=setInterval(()=>{i>0?m(b,i--,i):(g(),w())},1e3))},l,$,i,y,void 0,w,g,function(){var t;t=this.value,u=""===t?void 0:+t,a(1,u)}]}class ce extends tt{constructor(t){super(),V(this,t,se,le,l,{})}}function ue(t){let e,n,a;return{c(){e=y("div"),e.textContent="Starting Points/Metasites",n=k(),a=y("ul"),a.innerHTML='Today \n Events \n Cinema \n Feedly \n Reddit \n Facebook \n Yahoo! \n Journal Editor \n Slack Bookmarks \n Paleo Mix \n Hive Status',C(e,"class","mui--text-title mui-text-black")},m(t,i){$(t,e,i),$(t,n,i),$(t,a,i)},d(t){t&&b(e),t&&b(n),t&&b(a)}}}function me(t){let e,n,a,i,r,o;const l=new ft({}),s=new ce({});return{c(){e=y("div"),e.textContent="Tools",n=k(),a=y("ul"),a.innerHTML='Cleaner \n Kanban Flow \n Linode \n CSS Gradient Generator \n XML to JSON \n CSV to JSON \n Cubic Bezier \n RegEx Tool \n Closure Compiler \n JSON Lint \n JSON Editor \n Base64 Decoder \n JS Beautifier \n Spritepad \n Sprite Sheet Generator \n CSS Optimizer \n Icon Font Generator \n HTML to Jade \n Cloudflare JS CDN \n HTML Minifier \n XSS Cheat Sheet \n JSFiddle \n JS Bin \n Draftin \n Android Asset \n Password Generator \n Password Checker \n Archive Today \n Static Map Generator \n AJAX Endpoints \n WebSSH \n Jade Tester \n ES6 Console \n Cron Guru \n FontDrop',i=k(),q(l.$$.fragment),r=k(),q(s.$$.fragment),C(e,"class","mui--text-title mui-text-black")},m(t,c){$(t,e,c),$(t,n,c),$(t,a,c),$(t,i,c),X(l,t,c),$(t,r,c),X(s,t,c),o=!0},i(t){o||(J(l.$$.fragment,t),J(s.$$.fragment,t),o=!0)},o(t){K(l.$$.fragment,t),K(s.$$.fragment,t),o=!1},d(t){t&&b(e),t&&b(n),t&&b(a),t&&b(i),Z(l,t),t&&b(r),Z(s,t)}}}function he(e){let n,a,i,r,o,l,s,c,u,m,h,p,f,d,w,v,S,L,D,H,A,B,N,F,G,j,P,Y,_,W,R,O,I,z,U,Q;const V=new vt({});return{c(){n=y("div"),a=x("Bitcoin "),q(V.$$.fragment),i=k(),r=y("ul"),o=y("li"),o.innerHTML='Bitstamp',l=k(),s=y("li"),s.innerHTML='Kraken',c=k(),u=y("li"),u.innerHTML='Cryptowat.ch',m=k(),h=y("li"),h.innerHTML='BTC Chart',p=k(),f=y("li"),f.innerHTML='BTC Chart 2',d=k(),w=y("li"),w.innerHTML='BitStamp Chart',v=k(),S=y("li"),S.innerHTML='Bitstamp Chart 2',L=k(),D=y("li"),D.innerHTML='BitBargin UK',H=k(),A=y("li"),A.innerHTML='Yacuna UK',B=k(),N=y("li"),N.innerHTML='Blockchain',F=k(),G=y("li"),G.innerHTML='Bitminter',j=k(),P=y("li"),P.innerHTML='BTC Exchange Rate',Y=k(),_=y("li"),W=y("a"),W.textContent="CFT Watcher",R=k(),O=y("span"),I=y("img"),C(n,"class","mui--text-title mui-text-black"),C(W,"href","http://www.silvrtree.co.uk/watch.html"),I.src!==(z="gfx/popout.png")&&C(I,"src","gfx/popout.png"),C(I,"alt","CFT Watcher"),C(I,"data-url","http://www.silvrtree.co.uk/watch.html"),E(O,"cursor","pointer"),C(O,"data-url","http://www.silvrtree.co.uk/watch.html")},m(t,e,b){$(t,n,e),g(n,a),X(V,n,null),$(t,i,e),$(t,r,e),g(r,o),g(r,l),g(r,s),g(r,c),g(r,u),g(r,m),g(r,h),g(r,p),g(r,f),g(r,d),g(r,w),g(r,v),g(r,S),g(r,L),g(r,D),g(r,H),g(r,A),g(r,B),g(r,N),g(r,F),g(r,G),g(r,j),g(r,P),g(r,Y),g(r,_),g(_,W),g(_,R),g(_,O),g(O,I),U=!0,b&&Q(),Q=M(I,"click",T(ke))},p:t,i(t){U||(J(V.$$.fragment,t),U=!0)},o(t){K(V.$$.fragment,t),U=!1},d(t){t&&b(n),Z(V),t&&b(i),t&&b(r),Q()}}}function pe(t){let e,n,a;return{c(){e=y("div"),e.textContent="Package Tracking",n=k(),a=y("ul"),a.innerHTML='UPS',C(e,"class","mui--text-title mui-text-black")},m(t,i){$(t,e,i),$(t,n,i),$(t,a,i)},d(t){t&&b(e),t&&b(n),t&&b(a)}}}function fe(t){let e,n,a;return{c(){e=y("div"),e.textContent="Weather",n=k(),a=y("ul"),a.innerHTML='Dumbarton\n Weather \n WU\n Dumbarton Weather \n Y! Dumbarton Weather \n Glasgow\n Weather \n WU\n Glasgow Weather \n Live Lightning \n Other Live Lightning \n Closer Live Lightning \n Multiple Lightning \n European Lightning \n East Kilbride Lightning \n Borders Lightning \n Best Live Lightning \n Ships \n Rain Today',C(e,"class","mui--text-title mui-text-black")},m(t,i){$(t,e,i),$(t,n,i),$(t,a,i)},d(t){t&&b(e),t&&b(n),t&&b(a)}}}function de(t){let e,n,a;return{c(){e=y("div"),e.textContent="Free Email WEBpages",n=k(),a=y("ul"),a.innerHTML='Gmail \n Unmajestic Webmail \n Artizan Webmail \n Yahoo Mail \n Guerrilla Mail Anti Spam',C(e,"class","mui--text-title mui-text-black")},m(t,i){$(t,e,i),$(t,n,i),$(t,a,i)},d(t){t&&b(e),t&&b(n),t&&b(a)}}}function we(t){let e,n,a;return{c(){e=y("div"),e.textContent="Contracting",n=k(),a=y("ul"),a.innerHTML='Outsauce Timesheets \n CF Timesheets \n monster \n cwjobs \n s1jobs \n jobserve \n jobsite \n IT Jobs Watch Scotland',C(e,"class","mui--text-title mui-text-black")},m(t,i){$(t,e,i),$(t,n,i),$(t,a,i)},d(t){t&&b(e),t&&b(n),t&&b(a)}}}function ge(t){let e,n,a;return{c(){e=y("div"),e.textContent="Entertainment",n=k(),a=y("ul"),a.innerHTML='Amazing Radio Chill \n Cineworld \n Showcase \n Imdb \n EPGuides \n Eztv \n Mininova \n Scrapetorrent \n Whats on In Glasgow \n Local Events \n Nectarine \n STR - Space Travel Radio \n musik.drumstep',C(e,"class","mui--text-title mui-text-black")},m(t,i){$(t,e,i),$(t,n,i),$(t,a,i)},d(t){t&&b(e),t&&b(n),t&&b(a)}}}function $e(e){let n,a,i,r,o,l,s,c,u,m,h,p,f,d,w,v,S,L,D,H,A,B,N,F,G,j,P,Y,_,W,R,O,I,z,U,Q,V,tt,et,nt,at,it,rt,ot,lt,st,ct,ut,mt,ht,pt,ft,dt,wt,gt,$t,bt,vt,yt,xt,kt,St,Mt,Tt,Ct,Lt,Dt;const Et=new Rt({}),Ht=new Ut({props:{fromStation:"dbe",toStation:"glq"}}),At=new Ut({props:{fromStation:"glq",toStation:"dbe"}}),Bt=new te({});return{c(){n=y("div"),a=x("Travel "),q(Et.$$.fragment),i=k(),r=y("div"),q(Ht.$$.fragment),o=k(),q(At.$$.fragment),l=k(),s=y("div"),q(Bt.$$.fragment),c=k(),u=y("ul"),m=y("li"),m.innerHTML='Journey Check',h=k(),p=y("li"),p.innerHTML='Train Mapper',f=k(),d=y("li"),d.innerHTML='Traffic Scotland',w=k(),v=y("li"),v.innerHTML='AA Traffic News',S=k(),L=y("li"),L.innerHTML='DBE->WES\n /\n Advanced',D=k(),H=y("li"),A=y("a"),A.textContent="WES->DBE",B=k(),N=y("span"),F=y("img"),j=x("\n /\n "),P=y("a"),P.textContent="Advanced",Y=k(),_=y("li"),_.innerHTML='DBE Board\n /\n Advanced',W=k(),R=y("li"),R.innerHTML='GLQ Trains /\n Adv /\n GLQ->DBE',O=k(),I=y("li"),I.innerHTML='Kayak',z=k(),U=y("li"),U.innerHTML='Travelocity',Q=k(),V=y("li"),V.innerHTML='Travel.com',tt=k(),et=y("li"),et.innerHTML='Airlines',nt=k(),at=y("li"),at.innerHTML='Landings',it=k(),rt=y("li"),rt.innerHTML='Maps',ot=k(),lt=y("li"),lt.innerHTML='Maps2',st=k(),ct=y("li"),ct.innerHTML='ITN',ut=k(),mt=y("li"),mt.innerHTML='HAFAS',ht=k(),pt=y("li"),pt.innerHTML='DieBahn',ft=k(),dt=y("li"),dt.innerHTML='RailUSA',wt=k(),gt=y("li"),gt.innerHTML='TrainWeb',$t=k(),bt=y("li"),bt.innerHTML='RailWorld',vt=k(),yt=y("li"),yt.innerHTML='Currency Converter',xt=k(),kt=y("li"),kt.innerHTML='CIA',St=k(),Mt=y("li"),Mt.innerHTML='GMaps',Tt=k(),Ct=y("li"),Ct.innerHTML='Tube Status',C(n,"class","mui--text-title mui-text-black"),C(A,"href","http://ojp.nationalrail.co.uk/service/ldbboard/dep/WES/DBE/To?ar=true"),F.src!==(G="gfx/popout.png")&&C(F,"src","gfx/popout.png"),C(F,"data-url","http://ojp.nationalrail.co.uk/service/ldbboard/dep/WES/DBE/To?ar=true#skip-content-hold"),E(N,"cursor","pointer"),C(P,"href","http://www.traintime.uk/index.php?view=desktop&from=WES&to=DBE")},m(t,e,b){$(t,n,e),g(n,a),X(Et,n,null),$(t,i,e),$(t,r,e),X(Ht,r,null),g(r,o),X(At,r,null),$(t,l,e),$(t,s,e),X(Bt,s,null),$(t,c,e),$(t,u,e),g(u,m),g(u,h),g(u,p),g(u,f),g(u,d),g(u,w),g(u,v),g(u,S),g(u,L),g(u,D),g(u,H),g(H,A),g(H,B),g(H,N),g(N,F),g(H,j),g(H,P),g(u,Y),g(u,_),g(u,W),g(u,R),g(u,O),g(u,I),g(u,z),g(u,U),g(u,Q),g(u,V),g(u,tt),g(u,et),g(u,nt),g(u,at),g(u,it),g(u,rt),g(u,ot),g(u,lt),g(u,st),g(u,ct),g(u,ut),g(u,mt),g(u,ht),g(u,pt),g(u,ft),g(u,dt),g(u,wt),g(u,gt),g(u,$t),g(u,bt),g(u,vt),g(u,yt),g(u,xt),g(u,kt),g(u,St),g(u,Mt),g(u,Tt),g(u,Ct),Lt=!0,b&&Dt(),Dt=M(F,"click",T(Se))},p:t,i(t){Lt||(J(Et.$$.fragment,t),J(Ht.$$.fragment,t),J(At.$$.fragment,t),J(Bt.$$.fragment,t),Lt=!0)},o(t){K(Et.$$.fragment,t),K(Ht.$$.fragment,t),K(At.$$.fragment,t),K(Bt.$$.fragment,t),Lt=!1},d(t){t&&b(n),Z(Et),t&&b(i),t&&b(r),Z(Ht),Z(At),t&&b(l),t&&b(s),Z(Bt),t&&b(c),t&&b(u),Dt()}}}function be(t){let e,n,a;return{c(){e=y("div"),e.textContent="Computer Software, etc.",n=k(),a=y("ul"),a.innerHTML='Portable Apps \n NewFreeware \n Portable Software \n Portable Freeware Collection',C(e,"class","mui--text-title mui-text-black")},m(t,i){$(t,e,i),$(t,n,i),$(t,a,i)},d(t){t&&b(e),t&&b(n),t&&b(a)}}}function ve(t){let e,n,a;return{c(){e=y("div"),e.textContent="Reference & Special sites",n=k(),a=y("ul"),a.innerHTML='Glossaries \n Converters \n DECODE \n Drugs \n Medline \n Translation \n One Look \n US Military \n US Fed \n Legal \n NIH \n RefDESK \n Britannica \n States \n PackTrack \n Acronym \n V-Thes \n Timelines \n Wikipedia',C(e,"class","mui--text-title mui-text-black")},m(t,i){$(t,e,i),$(t,n,i),$(t,a,i)},d(t){t&&b(e),t&&b(n),t&&b(a)}}}function ye(t){let e,n,a;return{c(){e=y("div"),e.textContent="Earth and Beyond",n=k(),a=y("ul"),a.innerHTML='ENB Arsenal \n ENB Wikia \n Gear List \n Emu Forum \n Net 7 Wiki \n Space Engineers Wiki \n Space Engineers Forum',C(e,"class","mui--text-title mui-text-black")},m(t,i){$(t,e,i),$(t,n,i),$(t,a,i)},d(t){t&&b(e),t&&b(n),t&&b(a)}}}function xe(t){let e,n,a,i,r,o,l,s,c,u,m,h,p,f,d,w,v,x,S,M,T,L;const D=new rt({}),E=new ut({props:{events:t[0]}}),H=new at({props:{$$slots:{default:[ue]},$$scope:{ctx:t}}}),A=new at({props:{$$slots:{default:[me]},$$scope:{ctx:t}}}),B=new at({props:{$$slots:{default:[he]},$$scope:{ctx:t}}}),N=new at({props:{$$slots:{default:[pe]},$$scope:{ctx:t}}}),F=new at({props:{$$slots:{default:[fe]},$$scope:{ctx:t}}}),G=new at({props:{$$slots:{default:[de]},$$scope:{ctx:t}}}),j=new at({props:{$$slots:{default:[we]},$$scope:{ctx:t}}}),P=new at({props:{$$slots:{default:[ge]},$$scope:{ctx:t}}}),Y=new at({props:{$$slots:{default:[$e]},$$scope:{ctx:t}}}),_=new at({props:{$$slots:{default:[be]},$$scope:{ctx:t}}}),W=new at({props:{$$slots:{default:[ve]},$$scope:{ctx:t}}}),R=new at({props:{$$slots:{default:[ye]},$$scope:{ctx:t}}}),O=new Pt({});return{c(){e=y("main"),q(D.$$.fragment),n=k(),a=y("div"),q(E.$$.fragment),i=k(),r=y("div"),o=y("div"),q(H.$$.fragment),l=k(),q(A.$$.fragment),s=k(),q(B.$$.fragment),c=k(),u=y("div"),q(N.$$.fragment),m=k(),q(F.$$.fragment),h=k(),q(G.$$.fragment),p=k(),f=y("div"),q(j.$$.fragment),d=k(),q(P.$$.fragment),w=k(),q(Y.$$.fragment),v=k(),x=y("div"),q(_.$$.fragment),S=k(),q(W.$$.fragment),M=k(),q(R.$$.fragment),T=k(),q(O.$$.fragment),C(o,"class","mui-row"),C(u,"class","mui-row"),C(f,"class","mui-row"),C(x,"class","mui-row"),C(r,"class","mui-panel"),C(a,"class","mui-container")},m(t,b){$(t,e,b),X(D,e,null),g(e,n),g(e,a),X(E,a,null),g(a,i),g(a,r),g(r,o),X(H,o,null),g(o,l),X(A,o,null),g(o,s),X(B,o,null),g(r,c),g(r,u),X(N,u,null),g(u,m),X(F,u,null),g(u,h),X(G,u,null),g(r,p),g(r,f),X(j,f,null),g(f,d),X(P,f,null),g(f,w),X(Y,f,null),g(r,v),g(r,x),X(_,x,null),g(x,S),X(W,x,null),g(x,M),X(R,x,null),g(a,T),X(O,a,null),L=!0},p(t,[e]){const n={};1&e&&(n.events=t[0]),E.$set(n);const a={};2&e&&(a.$$scope={dirty:e,ctx:t}),H.$set(a);const i={};2&e&&(i.$$scope={dirty:e,ctx:t}),A.$set(i);const r={};2&e&&(r.$$scope={dirty:e,ctx:t}),B.$set(r);const o={};2&e&&(o.$$scope={dirty:e,ctx:t}),N.$set(o);const l={};2&e&&(l.$$scope={dirty:e,ctx:t}),F.$set(l);const s={};2&e&&(s.$$scope={dirty:e,ctx:t}),G.$set(s);const c={};2&e&&(c.$$scope={dirty:e,ctx:t}),j.$set(c);const u={};2&e&&(u.$$scope={dirty:e,ctx:t}),P.$set(u);const m={};2&e&&(m.$$scope={dirty:e,ctx:t}),Y.$set(m);const h={};2&e&&(h.$$scope={dirty:e,ctx:t}),_.$set(h);const p={};2&e&&(p.$$scope={dirty:e,ctx:t}),W.$set(p);const f={};2&e&&(f.$$scope={dirty:e,ctx:t}),R.$set(f)},i(t){L||(J(D.$$.fragment,t),J(E.$$.fragment,t),J(H.$$.fragment,t),J(A.$$.fragment,t),J(B.$$.fragment,t),J(N.$$.fragment,t),J(F.$$.fragment,t),J(G.$$.fragment,t),J(j.$$.fragment,t),J(P.$$.fragment,t),J(Y.$$.fragment,t),J(_.$$.fragment,t),J(W.$$.fragment,t),J(R.$$.fragment,t),J(O.$$.fragment,t),L=!0)},o(t){K(D.$$.fragment,t),K(E.$$.fragment,t),K(H.$$.fragment,t),K(A.$$.fragment,t),K(B.$$.fragment,t),K(N.$$.fragment,t),K(F.$$.fragment,t),K(G.$$.fragment,t),K(j.$$.fragment,t),K(P.$$.fragment,t),K(Y.$$.fragment,t),K(_.$$.fragment,t),K(W.$$.fragment,t),K(R.$$.fragment,t),K(O.$$.fragment,t),L=!1},d(t){t&&b(e),Z(D),Z(E),Z(H),Z(A),Z(B),Z(N),Z(F),Z(G),Z(j),Z(P),Z(Y),Z(_),Z(W),Z(R),Z(O)}}}function ke(t){if(t.target.dataset.url){let e=window.open(t.target.dataset.url,"name","height=400,width=520");return window.focus&&e.focus(),!1}}function Se(t){if(t.target.dataset.url){let e=window.open(t.target.dataset.url,"name","height=600,width=570");return window.focus&&e.focus(),!1}}function Me(t,e,n){let{events:a=[]}=e;return t.$set=t=>{"events"in t&&n(0,a=t.events)},[a]}return new class extends tt{constructor(t){super(),V(this,t,Me,xe,l,{events:0})}}({target:document.body,props:{events:[{event:new Date(2020,0,1),label:"Contract Ends:"}]}})}();
diff --git a/dist/build/bundle.js.map b/dist/build/bundle.js.map
new file mode 100644
index 0000000..2227cca
--- /dev/null
+++ b/dist/build/bundle.js.map
@@ -0,0 +1 @@
+{"version":3,"file":"bundle.js","sources":["../../node_modules/svelte/internal/index.mjs","../../src/components/Events.svelte","../../src/components/Password.svelte","../../node_modules/svelte/store/index.mjs","../../src/components/Bitcoin.svelte","../../node_modules/fecha/lib/fecha.js","../../src/components/Weather.svelte","../../src/components/Fx.svelte","../../src/components/store.js","../../src/components/Train.svelte","../../src/components/Route.svelte","../../src/App.svelte","../../src/main.js"],"sourcesContent":["function noop() { }\nconst identity = x => x;\nfunction assign(tar, src) {\n // @ts-ignore\n for (const k in src)\n tar[k] = src[k];\n return tar;\n}\nfunction is_promise(value) {\n return value && typeof value === 'object' && typeof value.then === 'function';\n}\nfunction add_location(element, file, line, column, char) {\n element.__svelte_meta = {\n loc: { file, line, column, char }\n };\n}\nfunction run(fn) {\n return fn();\n}\nfunction blank_object() {\n return Object.create(null);\n}\nfunction run_all(fns) {\n fns.forEach(run);\n}\nfunction is_function(thing) {\n return typeof thing === 'function';\n}\nfunction safe_not_equal(a, b) {\n return a != a ? b == b : a !== b || ((a && typeof a === 'object') || typeof a === 'function');\n}\nfunction not_equal(a, b) {\n return a != a ? b == b : a !== b;\n}\nfunction validate_store(store, name) {\n if (store != null && typeof store.subscribe !== 'function') {\n throw new Error(`'${name}' is not a store with a 'subscribe' method`);\n }\n}\nfunction subscribe(store, ...callbacks) {\n if (store == null) {\n return noop;\n }\n const unsub = store.subscribe(...callbacks);\n return unsub.unsubscribe ? () => unsub.unsubscribe() : unsub;\n}\nfunction get_store_value(store) {\n let value;\n subscribe(store, _ => value = _)();\n return value;\n}\nfunction component_subscribe(component, store, callback) {\n component.$$.on_destroy.push(subscribe(store, callback));\n}\nfunction create_slot(definition, ctx, $$scope, fn) {\n if (definition) {\n const slot_ctx = get_slot_context(definition, ctx, $$scope, fn);\n return definition[0](slot_ctx);\n }\n}\nfunction get_slot_context(definition, ctx, $$scope, fn) {\n return definition[1] && fn\n ? assign($$scope.ctx.slice(), definition[1](fn(ctx)))\n : $$scope.ctx;\n}\nfunction get_slot_changes(definition, $$scope, dirty, fn) {\n if (definition[2] && fn) {\n const lets = definition[2](fn(dirty));\n if ($$scope.dirty === undefined) {\n return lets;\n }\n if (typeof lets === 'object') {\n const merged = [];\n const len = Math.max($$scope.dirty.length, lets.length);\n for (let i = 0; i < len; i += 1) {\n merged[i] = $$scope.dirty[i] | lets[i];\n }\n return merged;\n }\n return $$scope.dirty | lets;\n }\n return $$scope.dirty;\n}\nfunction exclude_internal_props(props) {\n const result = {};\n for (const k in props)\n if (k[0] !== '$')\n result[k] = props[k];\n return result;\n}\nfunction compute_rest_props(props, keys) {\n const rest = {};\n keys = new Set(keys);\n for (const k in props)\n if (!keys.has(k) && k[0] !== '$')\n rest[k] = props[k];\n return rest;\n}\nfunction once(fn) {\n let ran = false;\n return function (...args) {\n if (ran)\n return;\n ran = true;\n fn.call(this, ...args);\n };\n}\nfunction null_to_empty(value) {\n return value == null ? '' : value;\n}\nfunction set_store_value(store, ret, value = ret) {\n store.set(value);\n return ret;\n}\nconst has_prop = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop);\nfunction action_destroyer(action_result) {\n return action_result && is_function(action_result.destroy) ? action_result.destroy : noop;\n}\n\nconst is_client = typeof window !== 'undefined';\nlet now = is_client\n ? () => window.performance.now()\n : () => Date.now();\nlet raf = is_client ? cb => requestAnimationFrame(cb) : noop;\n// used internally for testing\nfunction set_now(fn) {\n now = fn;\n}\nfunction set_raf(fn) {\n raf = fn;\n}\n\nconst tasks = new Set();\nfunction run_tasks(now) {\n tasks.forEach(task => {\n if (!task.c(now)) {\n tasks.delete(task);\n task.f();\n }\n });\n if (tasks.size !== 0)\n raf(run_tasks);\n}\n/**\n * For testing purposes only!\n */\nfunction clear_loops() {\n tasks.clear();\n}\n/**\n * Creates a new task that runs on each raf frame\n * until it returns a falsy value or is aborted\n */\nfunction loop(callback) {\n let task;\n if (tasks.size === 0)\n raf(run_tasks);\n return {\n promise: new Promise(fulfill => {\n tasks.add(task = { c: callback, f: fulfill });\n }),\n abort() {\n tasks.delete(task);\n }\n };\n}\n\nfunction append(target, node) {\n target.appendChild(node);\n}\nfunction insert(target, node, anchor) {\n target.insertBefore(node, anchor || null);\n}\nfunction detach(node) {\n node.parentNode.removeChild(node);\n}\nfunction destroy_each(iterations, detaching) {\n for (let i = 0; i < iterations.length; i += 1) {\n if (iterations[i])\n iterations[i].d(detaching);\n }\n}\nfunction element(name) {\n return document.createElement(name);\n}\nfunction element_is(name, is) {\n return document.createElement(name, { is });\n}\nfunction object_without_properties(obj, exclude) {\n const target = {};\n for (const k in obj) {\n if (has_prop(obj, k)\n // @ts-ignore\n && exclude.indexOf(k) === -1) {\n // @ts-ignore\n target[k] = obj[k];\n }\n }\n return target;\n}\nfunction svg_element(name) {\n return document.createElementNS('http://www.w3.org/2000/svg', name);\n}\nfunction text(data) {\n return document.createTextNode(data);\n}\nfunction space() {\n return text(' ');\n}\nfunction empty() {\n return text('');\n}\nfunction listen(node, event, handler, options) {\n node.addEventListener(event, handler, options);\n return () => node.removeEventListener(event, handler, options);\n}\nfunction prevent_default(fn) {\n return function (event) {\n event.preventDefault();\n // @ts-ignore\n return fn.call(this, event);\n };\n}\nfunction stop_propagation(fn) {\n return function (event) {\n event.stopPropagation();\n // @ts-ignore\n return fn.call(this, event);\n };\n}\nfunction self(fn) {\n return function (event) {\n // @ts-ignore\n if (event.target === this)\n fn.call(this, event);\n };\n}\nfunction attr(node, attribute, value) {\n if (value == null)\n node.removeAttribute(attribute);\n else if (node.getAttribute(attribute) !== value)\n node.setAttribute(attribute, value);\n}\nfunction set_attributes(node, attributes) {\n // @ts-ignore\n const descriptors = Object.getOwnPropertyDescriptors(node.__proto__);\n for (const key in attributes) {\n if (attributes[key] == null) {\n node.removeAttribute(key);\n }\n else if (key === 'style') {\n node.style.cssText = attributes[key];\n }\n else if (key === '__value' || descriptors[key] && descriptors[key].set) {\n node[key] = attributes[key];\n }\n else {\n attr(node, key, attributes[key]);\n }\n }\n}\nfunction set_svg_attributes(node, attributes) {\n for (const key in attributes) {\n attr(node, key, attributes[key]);\n }\n}\nfunction set_custom_element_data(node, prop, value) {\n if (prop in node) {\n node[prop] = value;\n }\n else {\n attr(node, prop, value);\n }\n}\nfunction xlink_attr(node, attribute, value) {\n node.setAttributeNS('http://www.w3.org/1999/xlink', attribute, value);\n}\nfunction get_binding_group_value(group) {\n const value = [];\n for (let i = 0; i < group.length; i += 1) {\n if (group[i].checked)\n value.push(group[i].__value);\n }\n return value;\n}\nfunction to_number(value) {\n return value === '' ? undefined : +value;\n}\nfunction time_ranges_to_array(ranges) {\n const array = [];\n for (let i = 0; i < ranges.length; i += 1) {\n array.push({ start: ranges.start(i), end: ranges.end(i) });\n }\n return array;\n}\nfunction children(element) {\n return Array.from(element.childNodes);\n}\nfunction claim_element(nodes, name, attributes, svg) {\n for (let i = 0; i < nodes.length; i += 1) {\n const node = nodes[i];\n if (node.nodeName === name) {\n let j = 0;\n while (j < node.attributes.length) {\n const attribute = node.attributes[j];\n if (attributes[attribute.name]) {\n j++;\n }\n else {\n node.removeAttribute(attribute.name);\n }\n }\n return nodes.splice(i, 1)[0];\n }\n }\n return svg ? svg_element(name) : element(name);\n}\nfunction claim_text(nodes, data) {\n for (let i = 0; i < nodes.length; i += 1) {\n const node = nodes[i];\n if (node.nodeType === 3) {\n node.data = '' + data;\n return nodes.splice(i, 1)[0];\n }\n }\n return text(data);\n}\nfunction claim_space(nodes) {\n return claim_text(nodes, ' ');\n}\nfunction set_data(text, data) {\n data = '' + data;\n if (text.data !== data)\n text.data = data;\n}\nfunction set_input_value(input, value) {\n if (value != null || input.value) {\n input.value = value;\n }\n}\nfunction set_input_type(input, type) {\n try {\n input.type = type;\n }\n catch (e) {\n // do nothing\n }\n}\nfunction set_style(node, key, value, important) {\n node.style.setProperty(key, value, important ? 'important' : '');\n}\nfunction select_option(select, value) {\n for (let i = 0; i < select.options.length; i += 1) {\n const option = select.options[i];\n if (option.__value === value) {\n option.selected = true;\n return;\n }\n }\n}\nfunction select_options(select, value) {\n for (let i = 0; i < select.options.length; i += 1) {\n const option = select.options[i];\n option.selected = ~value.indexOf(option.__value);\n }\n}\nfunction select_value(select) {\n const selected_option = select.querySelector(':checked') || select.options[0];\n return selected_option && selected_option.__value;\n}\nfunction select_multiple_value(select) {\n return [].map.call(select.querySelectorAll(':checked'), option => option.__value);\n}\nfunction add_resize_listener(element, fn) {\n if (getComputedStyle(element).position === 'static') {\n element.style.position = 'relative';\n }\n const object = document.createElement('object');\n object.setAttribute('style', 'display: block; position: absolute; top: 0; left: 0; height: 100%; width: 100%; overflow: hidden; pointer-events: none; z-index: -1;');\n object.setAttribute('aria-hidden', 'true');\n object.type = 'text/html';\n object.tabIndex = -1;\n let win;\n object.onload = () => {\n win = object.contentDocument.defaultView;\n win.addEventListener('resize', fn);\n };\n if (/Trident/.test(navigator.userAgent)) {\n element.appendChild(object);\n object.data = 'about:blank';\n }\n else {\n object.data = 'about:blank';\n element.appendChild(object);\n }\n return {\n cancel: () => {\n win && win.removeEventListener && win.removeEventListener('resize', fn);\n element.removeChild(object);\n }\n };\n}\nfunction toggle_class(element, name, toggle) {\n element.classList[toggle ? 'add' : 'remove'](name);\n}\nfunction custom_event(type, detail) {\n const e = document.createEvent('CustomEvent');\n e.initCustomEvent(type, false, false, detail);\n return e;\n}\nfunction query_selector_all(selector, parent = document.body) {\n return Array.from(parent.querySelectorAll(selector));\n}\nclass HtmlTag {\n constructor(html, anchor = null) {\n this.e = element('div');\n this.a = anchor;\n this.u(html);\n }\n m(target, anchor = null) {\n for (let i = 0; i < this.n.length; i += 1) {\n insert(target, this.n[i], anchor);\n }\n this.t = target;\n }\n u(html) {\n this.e.innerHTML = html;\n this.n = Array.from(this.e.childNodes);\n }\n p(html) {\n this.d();\n this.u(html);\n this.m(this.t, this.a);\n }\n d() {\n this.n.forEach(detach);\n }\n}\n\nconst active_docs = new Set();\nlet active = 0;\n// https://github.com/darkskyapp/string-hash/blob/master/index.js\nfunction hash(str) {\n let hash = 5381;\n let i = str.length;\n while (i--)\n hash = ((hash << 5) - hash) ^ str.charCodeAt(i);\n return hash >>> 0;\n}\nfunction create_rule(node, a, b, duration, delay, ease, fn, uid = 0) {\n const step = 16.666 / duration;\n let keyframes = '{\\n';\n for (let p = 0; p <= 1; p += step) {\n const t = a + (b - a) * ease(p);\n keyframes += p * 100 + `%{${fn(t, 1 - t)}}\\n`;\n }\n const rule = keyframes + `100% {${fn(b, 1 - b)}}\\n}`;\n const name = `__svelte_${hash(rule)}_${uid}`;\n const doc = node.ownerDocument;\n active_docs.add(doc);\n const stylesheet = doc.__svelte_stylesheet || (doc.__svelte_stylesheet = doc.head.appendChild(element('style')).sheet);\n const current_rules = doc.__svelte_rules || (doc.__svelte_rules = {});\n if (!current_rules[name]) {\n current_rules[name] = true;\n stylesheet.insertRule(`@keyframes ${name} ${rule}`, stylesheet.cssRules.length);\n }\n const animation = node.style.animation || '';\n node.style.animation = `${animation ? `${animation}, ` : ``}${name} ${duration}ms linear ${delay}ms 1 both`;\n active += 1;\n return name;\n}\nfunction delete_rule(node, name) {\n const previous = (node.style.animation || '').split(', ');\n const next = previous.filter(name\n ? anim => anim.indexOf(name) < 0 // remove specific animation\n : anim => anim.indexOf('__svelte') === -1 // remove all Svelte animations\n );\n const deleted = previous.length - next.length;\n if (deleted) {\n node.style.animation = next.join(', ');\n active -= deleted;\n if (!active)\n clear_rules();\n }\n}\nfunction clear_rules() {\n raf(() => {\n if (active)\n return;\n active_docs.forEach(doc => {\n const stylesheet = doc.__svelte_stylesheet;\n let i = stylesheet.cssRules.length;\n while (i--)\n stylesheet.deleteRule(i);\n doc.__svelte_rules = {};\n });\n active_docs.clear();\n });\n}\n\nfunction create_animation(node, from, fn, params) {\n if (!from)\n return noop;\n const to = node.getBoundingClientRect();\n if (from.left === to.left && from.right === to.right && from.top === to.top && from.bottom === to.bottom)\n return noop;\n const { delay = 0, duration = 300, easing = identity, \n // @ts-ignore todo: should this be separated from destructuring? Or start/end added to public api and documentation?\n start: start_time = now() + delay, \n // @ts-ignore todo:\n end = start_time + duration, tick = noop, css } = fn(node, { from, to }, params);\n let running = true;\n let started = false;\n let name;\n function start() {\n if (css) {\n name = create_rule(node, 0, 1, duration, delay, easing, css);\n }\n if (!delay) {\n started = true;\n }\n }\n function stop() {\n if (css)\n delete_rule(node, name);\n running = false;\n }\n loop(now => {\n if (!started && now >= start_time) {\n started = true;\n }\n if (started && now >= end) {\n tick(1, 0);\n stop();\n }\n if (!running) {\n return false;\n }\n if (started) {\n const p = now - start_time;\n const t = 0 + 1 * easing(p / duration);\n tick(t, 1 - t);\n }\n return true;\n });\n start();\n tick(0, 1);\n return stop;\n}\nfunction fix_position(node) {\n const style = getComputedStyle(node);\n if (style.position !== 'absolute' && style.position !== 'fixed') {\n const { width, height } = style;\n const a = node.getBoundingClientRect();\n node.style.position = 'absolute';\n node.style.width = width;\n node.style.height = height;\n add_transform(node, a);\n }\n}\nfunction add_transform(node, a) {\n const b = node.getBoundingClientRect();\n if (a.left !== b.left || a.top !== b.top) {\n const style = getComputedStyle(node);\n const transform = style.transform === 'none' ? '' : style.transform;\n node.style.transform = `${transform} translate(${a.left - b.left}px, ${a.top - b.top}px)`;\n }\n}\n\nlet current_component;\nfunction set_current_component(component) {\n current_component = component;\n}\nfunction get_current_component() {\n if (!current_component)\n throw new Error(`Function called outside component initialization`);\n return current_component;\n}\nfunction beforeUpdate(fn) {\n get_current_component().$$.before_update.push(fn);\n}\nfunction onMount(fn) {\n get_current_component().$$.on_mount.push(fn);\n}\nfunction afterUpdate(fn) {\n get_current_component().$$.after_update.push(fn);\n}\nfunction onDestroy(fn) {\n get_current_component().$$.on_destroy.push(fn);\n}\nfunction createEventDispatcher() {\n const component = get_current_component();\n return (type, detail) => {\n const callbacks = component.$$.callbacks[type];\n if (callbacks) {\n // TODO are there situations where events could be dispatched\n // in a server (non-DOM) environment?\n const event = custom_event(type, detail);\n callbacks.slice().forEach(fn => {\n fn.call(component, event);\n });\n }\n };\n}\nfunction setContext(key, context) {\n get_current_component().$$.context.set(key, context);\n}\nfunction getContext(key) {\n return get_current_component().$$.context.get(key);\n}\n// TODO figure out if we still want to support\n// shorthand events, or if we want to implement\n// a real bubbling mechanism\nfunction bubble(component, event) {\n const callbacks = component.$$.callbacks[event.type];\n if (callbacks) {\n callbacks.slice().forEach(fn => fn(event));\n }\n}\n\nconst dirty_components = [];\nconst intros = { enabled: false };\nconst binding_callbacks = [];\nconst render_callbacks = [];\nconst flush_callbacks = [];\nconst resolved_promise = Promise.resolve();\nlet update_scheduled = false;\nfunction schedule_update() {\n if (!update_scheduled) {\n update_scheduled = true;\n resolved_promise.then(flush);\n }\n}\nfunction tick() {\n schedule_update();\n return resolved_promise;\n}\nfunction add_render_callback(fn) {\n render_callbacks.push(fn);\n}\nfunction add_flush_callback(fn) {\n flush_callbacks.push(fn);\n}\nlet flushing = false;\nconst seen_callbacks = new Set();\nfunction flush() {\n if (flushing)\n return;\n flushing = true;\n do {\n // first, call beforeUpdate functions\n // and update components\n for (let i = 0; i < dirty_components.length; i += 1) {\n const component = dirty_components[i];\n set_current_component(component);\n update(component.$$);\n }\n dirty_components.length = 0;\n while (binding_callbacks.length)\n binding_callbacks.pop()();\n // then, once components are updated, call\n // afterUpdate functions. This may cause\n // subsequent updates...\n for (let i = 0; i < render_callbacks.length; i += 1) {\n const callback = render_callbacks[i];\n if (!seen_callbacks.has(callback)) {\n // ...so guard against infinite loops\n seen_callbacks.add(callback);\n callback();\n }\n }\n render_callbacks.length = 0;\n } while (dirty_components.length);\n while (flush_callbacks.length) {\n flush_callbacks.pop()();\n }\n update_scheduled = false;\n flushing = false;\n seen_callbacks.clear();\n}\nfunction update($$) {\n if ($$.fragment !== null) {\n $$.update();\n run_all($$.before_update);\n const dirty = $$.dirty;\n $$.dirty = [-1];\n $$.fragment && $$.fragment.p($$.ctx, dirty);\n $$.after_update.forEach(add_render_callback);\n }\n}\n\nlet promise;\nfunction wait() {\n if (!promise) {\n promise = Promise.resolve();\n promise.then(() => {\n promise = null;\n });\n }\n return promise;\n}\nfunction dispatch(node, direction, kind) {\n node.dispatchEvent(custom_event(`${direction ? 'intro' : 'outro'}${kind}`));\n}\nconst outroing = new Set();\nlet outros;\nfunction group_outros() {\n outros = {\n r: 0,\n c: [],\n p: outros // parent group\n };\n}\nfunction check_outros() {\n if (!outros.r) {\n run_all(outros.c);\n }\n outros = outros.p;\n}\nfunction transition_in(block, local) {\n if (block && block.i) {\n outroing.delete(block);\n block.i(local);\n }\n}\nfunction transition_out(block, local, detach, callback) {\n if (block && block.o) {\n if (outroing.has(block))\n return;\n outroing.add(block);\n outros.c.push(() => {\n outroing.delete(block);\n if (callback) {\n if (detach)\n block.d(1);\n callback();\n }\n });\n block.o(local);\n }\n}\nconst null_transition = { duration: 0 };\nfunction create_in_transition(node, fn, params) {\n let config = fn(node, params);\n let running = false;\n let animation_name;\n let task;\n let uid = 0;\n function cleanup() {\n if (animation_name)\n delete_rule(node, animation_name);\n }\n function go() {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n if (css)\n animation_name = create_rule(node, 0, 1, duration, delay, easing, css, uid++);\n tick(0, 1);\n const start_time = now() + delay;\n const end_time = start_time + duration;\n if (task)\n task.abort();\n running = true;\n add_render_callback(() => dispatch(node, true, 'start'));\n task = loop(now => {\n if (running) {\n if (now >= end_time) {\n tick(1, 0);\n dispatch(node, true, 'end');\n cleanup();\n return running = false;\n }\n if (now >= start_time) {\n const t = easing((now - start_time) / duration);\n tick(t, 1 - t);\n }\n }\n return running;\n });\n }\n let started = false;\n return {\n start() {\n if (started)\n return;\n delete_rule(node);\n if (is_function(config)) {\n config = config();\n wait().then(go);\n }\n else {\n go();\n }\n },\n invalidate() {\n started = false;\n },\n end() {\n if (running) {\n cleanup();\n running = false;\n }\n }\n };\n}\nfunction create_out_transition(node, fn, params) {\n let config = fn(node, params);\n let running = true;\n let animation_name;\n const group = outros;\n group.r += 1;\n function go() {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n if (css)\n animation_name = create_rule(node, 1, 0, duration, delay, easing, css);\n const start_time = now() + delay;\n const end_time = start_time + duration;\n add_render_callback(() => dispatch(node, false, 'start'));\n loop(now => {\n if (running) {\n if (now >= end_time) {\n tick(0, 1);\n dispatch(node, false, 'end');\n if (!--group.r) {\n // this will result in `end()` being called,\n // so we don't need to clean up here\n run_all(group.c);\n }\n return false;\n }\n if (now >= start_time) {\n const t = easing((now - start_time) / duration);\n tick(1 - t, t);\n }\n }\n return running;\n });\n }\n if (is_function(config)) {\n wait().then(() => {\n // @ts-ignore\n config = config();\n go();\n });\n }\n else {\n go();\n }\n return {\n end(reset) {\n if (reset && config.tick) {\n config.tick(1, 0);\n }\n if (running) {\n if (animation_name)\n delete_rule(node, animation_name);\n running = false;\n }\n }\n };\n}\nfunction create_bidirectional_transition(node, fn, params, intro) {\n let config = fn(node, params);\n let t = intro ? 0 : 1;\n let running_program = null;\n let pending_program = null;\n let animation_name = null;\n function clear_animation() {\n if (animation_name)\n delete_rule(node, animation_name);\n }\n function init(program, duration) {\n const d = program.b - t;\n duration *= Math.abs(d);\n return {\n a: t,\n b: program.b,\n d,\n duration,\n start: program.start,\n end: program.start + duration,\n group: program.group\n };\n }\n function go(b) {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n const program = {\n start: now() + delay,\n b\n };\n if (!b) {\n // @ts-ignore todo: improve typings\n program.group = outros;\n outros.r += 1;\n }\n if (running_program) {\n pending_program = program;\n }\n else {\n // if this is an intro, and there's a delay, we need to do\n // an initial tick and/or apply CSS animation immediately\n if (css) {\n clear_animation();\n animation_name = create_rule(node, t, b, duration, delay, easing, css);\n }\n if (b)\n tick(0, 1);\n running_program = init(program, duration);\n add_render_callback(() => dispatch(node, b, 'start'));\n loop(now => {\n if (pending_program && now > pending_program.start) {\n running_program = init(pending_program, duration);\n pending_program = null;\n dispatch(node, running_program.b, 'start');\n if (css) {\n clear_animation();\n animation_name = create_rule(node, t, running_program.b, running_program.duration, 0, easing, config.css);\n }\n }\n if (running_program) {\n if (now >= running_program.end) {\n tick(t = running_program.b, 1 - t);\n dispatch(node, running_program.b, 'end');\n if (!pending_program) {\n // we're done\n if (running_program.b) {\n // intro — we can tidy up immediately\n clear_animation();\n }\n else {\n // outro — needs to be coordinated\n if (!--running_program.group.r)\n run_all(running_program.group.c);\n }\n }\n running_program = null;\n }\n else if (now >= running_program.start) {\n const p = now - running_program.start;\n t = running_program.a + running_program.d * easing(p / running_program.duration);\n tick(t, 1 - t);\n }\n }\n return !!(running_program || pending_program);\n });\n }\n }\n return {\n run(b) {\n if (is_function(config)) {\n wait().then(() => {\n // @ts-ignore\n config = config();\n go(b);\n });\n }\n else {\n go(b);\n }\n },\n end() {\n clear_animation();\n running_program = pending_program = null;\n }\n };\n}\n\nfunction handle_promise(promise, info) {\n const token = info.token = {};\n function update(type, index, key, value) {\n if (info.token !== token)\n return;\n info.resolved = value;\n let child_ctx = info.ctx;\n if (key !== undefined) {\n child_ctx = child_ctx.slice();\n child_ctx[key] = value;\n }\n const block = type && (info.current = type)(child_ctx);\n let needs_flush = false;\n if (info.block) {\n if (info.blocks) {\n info.blocks.forEach((block, i) => {\n if (i !== index && block) {\n group_outros();\n transition_out(block, 1, 1, () => {\n info.blocks[i] = null;\n });\n check_outros();\n }\n });\n }\n else {\n info.block.d(1);\n }\n block.c();\n transition_in(block, 1);\n block.m(info.mount(), info.anchor);\n needs_flush = true;\n }\n info.block = block;\n if (info.blocks)\n info.blocks[index] = block;\n if (needs_flush) {\n flush();\n }\n }\n if (is_promise(promise)) {\n const current_component = get_current_component();\n promise.then(value => {\n set_current_component(current_component);\n update(info.then, 1, info.value, value);\n set_current_component(null);\n }, error => {\n set_current_component(current_component);\n update(info.catch, 2, info.error, error);\n set_current_component(null);\n });\n // if we previously had a then/catch block, destroy it\n if (info.current !== info.pending) {\n update(info.pending, 0);\n return true;\n }\n }\n else {\n if (info.current !== info.then) {\n update(info.then, 1, info.value, promise);\n return true;\n }\n info.resolved = promise;\n }\n}\n\nconst globals = (typeof window !== 'undefined' ? window : global);\n\nfunction destroy_block(block, lookup) {\n block.d(1);\n lookup.delete(block.key);\n}\nfunction outro_and_destroy_block(block, lookup) {\n transition_out(block, 1, 1, () => {\n lookup.delete(block.key);\n });\n}\nfunction fix_and_destroy_block(block, lookup) {\n block.f();\n destroy_block(block, lookup);\n}\nfunction fix_and_outro_and_destroy_block(block, lookup) {\n block.f();\n outro_and_destroy_block(block, lookup);\n}\nfunction update_keyed_each(old_blocks, dirty, get_key, dynamic, ctx, list, lookup, node, destroy, create_each_block, next, get_context) {\n let o = old_blocks.length;\n let n = list.length;\n let i = o;\n const old_indexes = {};\n while (i--)\n old_indexes[old_blocks[i].key] = i;\n const new_blocks = [];\n const new_lookup = new Map();\n const deltas = new Map();\n i = n;\n while (i--) {\n const child_ctx = get_context(ctx, list, i);\n const key = get_key(child_ctx);\n let block = lookup.get(key);\n if (!block) {\n block = create_each_block(key, child_ctx);\n block.c();\n }\n else if (dynamic) {\n block.p(child_ctx, dirty);\n }\n new_lookup.set(key, new_blocks[i] = block);\n if (key in old_indexes)\n deltas.set(key, Math.abs(i - old_indexes[key]));\n }\n const will_move = new Set();\n const did_move = new Set();\n function insert(block) {\n transition_in(block, 1);\n block.m(node, next, lookup.has(block.key));\n lookup.set(block.key, block);\n next = block.first;\n n--;\n }\n while (o && n) {\n const new_block = new_blocks[n - 1];\n const old_block = old_blocks[o - 1];\n const new_key = new_block.key;\n const old_key = old_block.key;\n if (new_block === old_block) {\n // do nothing\n next = new_block.first;\n o--;\n n--;\n }\n else if (!new_lookup.has(old_key)) {\n // remove old block\n destroy(old_block, lookup);\n o--;\n }\n else if (!lookup.has(new_key) || will_move.has(new_key)) {\n insert(new_block);\n }\n else if (did_move.has(old_key)) {\n o--;\n }\n else if (deltas.get(new_key) > deltas.get(old_key)) {\n did_move.add(new_key);\n insert(new_block);\n }\n else {\n will_move.add(old_key);\n o--;\n }\n }\n while (o--) {\n const old_block = old_blocks[o];\n if (!new_lookup.has(old_block.key))\n destroy(old_block, lookup);\n }\n while (n)\n insert(new_blocks[n - 1]);\n return new_blocks;\n}\nfunction validate_each_keys(ctx, list, get_context, get_key) {\n const keys = new Set();\n for (let i = 0; i < list.length; i++) {\n const key = get_key(get_context(ctx, list, i));\n if (keys.has(key)) {\n throw new Error(`Cannot have duplicate keys in a keyed each`);\n }\n keys.add(key);\n }\n}\n\nfunction get_spread_update(levels, updates) {\n const update = {};\n const to_null_out = {};\n const accounted_for = { $$scope: 1 };\n let i = levels.length;\n while (i--) {\n const o = levels[i];\n const n = updates[i];\n if (n) {\n for (const key in o) {\n if (!(key in n))\n to_null_out[key] = 1;\n }\n for (const key in n) {\n if (!accounted_for[key]) {\n update[key] = n[key];\n accounted_for[key] = 1;\n }\n }\n levels[i] = n;\n }\n else {\n for (const key in o) {\n accounted_for[key] = 1;\n }\n }\n }\n for (const key in to_null_out) {\n if (!(key in update))\n update[key] = undefined;\n }\n return update;\n}\nfunction get_spread_object(spread_props) {\n return typeof spread_props === 'object' && spread_props !== null ? spread_props : {};\n}\n\n// source: https://html.spec.whatwg.org/multipage/indices.html\nconst boolean_attributes = new Set([\n 'allowfullscreen',\n 'allowpaymentrequest',\n 'async',\n 'autofocus',\n 'autoplay',\n 'checked',\n 'controls',\n 'default',\n 'defer',\n 'disabled',\n 'formnovalidate',\n 'hidden',\n 'ismap',\n 'loop',\n 'multiple',\n 'muted',\n 'nomodule',\n 'novalidate',\n 'open',\n 'playsinline',\n 'readonly',\n 'required',\n 'reversed',\n 'selected'\n]);\n\nconst invalid_attribute_name_character = /[\\s'\">/=\\u{FDD0}-\\u{FDEF}\\u{FFFE}\\u{FFFF}\\u{1FFFE}\\u{1FFFF}\\u{2FFFE}\\u{2FFFF}\\u{3FFFE}\\u{3FFFF}\\u{4FFFE}\\u{4FFFF}\\u{5FFFE}\\u{5FFFF}\\u{6FFFE}\\u{6FFFF}\\u{7FFFE}\\u{7FFFF}\\u{8FFFE}\\u{8FFFF}\\u{9FFFE}\\u{9FFFF}\\u{AFFFE}\\u{AFFFF}\\u{BFFFE}\\u{BFFFF}\\u{CFFFE}\\u{CFFFF}\\u{DFFFE}\\u{DFFFF}\\u{EFFFE}\\u{EFFFF}\\u{FFFFE}\\u{FFFFF}\\u{10FFFE}\\u{10FFFF}]/u;\n// https://html.spec.whatwg.org/multipage/syntax.html#attributes-2\n// https://infra.spec.whatwg.org/#noncharacter\nfunction spread(args, classes_to_add) {\n const attributes = Object.assign({}, ...args);\n if (classes_to_add) {\n if (attributes.class == null) {\n attributes.class = classes_to_add;\n }\n else {\n attributes.class += ' ' + classes_to_add;\n }\n }\n let str = '';\n Object.keys(attributes).forEach(name => {\n if (invalid_attribute_name_character.test(name))\n return;\n const value = attributes[name];\n if (value === true)\n str += \" \" + name;\n else if (boolean_attributes.has(name.toLowerCase())) {\n if (value)\n str += \" \" + name;\n }\n else if (value != null) {\n str += ` ${name}=\"${String(value).replace(/\"/g, '"').replace(/'/g, ''')}\"`;\n }\n });\n return str;\n}\nconst escaped = {\n '\"': '"',\n \"'\": ''',\n '&': '&',\n '<': '<',\n '>': '>'\n};\nfunction escape(html) {\n return String(html).replace(/[\"'&<>]/g, match => escaped[match]);\n}\nfunction each(items, fn) {\n let str = '';\n for (let i = 0; i < items.length; i += 1) {\n str += fn(items[i], i);\n }\n return str;\n}\nconst missing_component = {\n $$render: () => ''\n};\nfunction validate_component(component, name) {\n if (!component || !component.$$render) {\n if (name === 'svelte:component')\n name += ' this={...}';\n throw new Error(`<${name}> is not a valid SSR component. You may need to review your build config to ensure that dependencies are compiled, rather than imported as pre-compiled modules`);\n }\n return component;\n}\nfunction debug(file, line, column, values) {\n console.log(`{@debug} ${file ? file + ' ' : ''}(${line}:${column})`); // eslint-disable-line no-console\n console.log(values); // eslint-disable-line no-console\n return '';\n}\nlet on_destroy;\nfunction create_ssr_component(fn) {\n function $$render(result, props, bindings, slots) {\n const parent_component = current_component;\n const $$ = {\n on_destroy,\n context: new Map(parent_component ? parent_component.$$.context : []),\n // these will be immediately discarded\n on_mount: [],\n before_update: [],\n after_update: [],\n callbacks: blank_object()\n };\n set_current_component({ $$ });\n const html = fn(result, props, bindings, slots);\n set_current_component(parent_component);\n return html;\n }\n return {\n render: (props = {}, options = {}) => {\n on_destroy = [];\n const result = { title: '', head: '', css: new Set() };\n const html = $$render(result, props, {}, options);\n run_all(on_destroy);\n return {\n html,\n css: {\n code: Array.from(result.css).map(css => css.code).join('\\n'),\n map: null // TODO\n },\n head: result.title + result.head\n };\n },\n $$render\n };\n}\nfunction add_attribute(name, value, boolean) {\n if (value == null || (boolean && !value))\n return '';\n return ` ${name}${value === true ? '' : `=${typeof value === 'string' ? JSON.stringify(escape(value)) : `\"${value}\"`}`}`;\n}\nfunction add_classes(classes) {\n return classes ? ` class=\"${classes}\"` : ``;\n}\n\nfunction bind(component, name, callback) {\n const index = component.$$.props[name];\n if (index !== undefined) {\n component.$$.bound[index] = callback;\n callback(component.$$.ctx[index]);\n }\n}\nfunction create_component(block) {\n block && block.c();\n}\nfunction claim_component(block, parent_nodes) {\n block && block.l(parent_nodes);\n}\nfunction mount_component(component, target, anchor) {\n const { fragment, on_mount, on_destroy, after_update } = component.$$;\n fragment && fragment.m(target, anchor);\n // onMount happens before the initial afterUpdate\n add_render_callback(() => {\n const new_on_destroy = on_mount.map(run).filter(is_function);\n if (on_destroy) {\n on_destroy.push(...new_on_destroy);\n }\n else {\n // Edge case - component was destroyed immediately,\n // most likely as a result of a binding initialising\n run_all(new_on_destroy);\n }\n component.$$.on_mount = [];\n });\n after_update.forEach(add_render_callback);\n}\nfunction destroy_component(component, detaching) {\n const $$ = component.$$;\n if ($$.fragment !== null) {\n run_all($$.on_destroy);\n $$.fragment && $$.fragment.d(detaching);\n // TODO null out other refs, including component.$$ (but need to\n // preserve final state?)\n $$.on_destroy = $$.fragment = null;\n $$.ctx = [];\n }\n}\nfunction make_dirty(component, i) {\n if (component.$$.dirty[0] === -1) {\n dirty_components.push(component);\n schedule_update();\n component.$$.dirty.fill(0);\n }\n component.$$.dirty[(i / 31) | 0] |= (1 << (i % 31));\n}\nfunction init(component, options, instance, create_fragment, not_equal, props, dirty = [-1]) {\n const parent_component = current_component;\n set_current_component(component);\n const prop_values = options.props || {};\n const $$ = component.$$ = {\n fragment: null,\n ctx: null,\n // state\n props,\n update: noop,\n not_equal,\n bound: blank_object(),\n // lifecycle\n on_mount: [],\n on_destroy: [],\n before_update: [],\n after_update: [],\n context: new Map(parent_component ? parent_component.$$.context : []),\n // everything else\n callbacks: blank_object(),\n dirty\n };\n let ready = false;\n $$.ctx = instance\n ? instance(component, prop_values, (i, ret, ...rest) => {\n const value = rest.length ? rest[0] : ret;\n if ($$.ctx && not_equal($$.ctx[i], $$.ctx[i] = value)) {\n if ($$.bound[i])\n $$.bound[i](value);\n if (ready)\n make_dirty(component, i);\n }\n return ret;\n })\n : [];\n $$.update();\n ready = true;\n run_all($$.before_update);\n // `false` as a special case of no DOM component\n $$.fragment = create_fragment ? create_fragment($$.ctx) : false;\n if (options.target) {\n if (options.hydrate) {\n const nodes = children(options.target);\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n $$.fragment && $$.fragment.l(nodes);\n nodes.forEach(detach);\n }\n else {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n $$.fragment && $$.fragment.c();\n }\n if (options.intro)\n transition_in(component.$$.fragment);\n mount_component(component, options.target, options.anchor);\n flush();\n }\n set_current_component(parent_component);\n}\nlet SvelteElement;\nif (typeof HTMLElement === 'function') {\n SvelteElement = class extends HTMLElement {\n constructor() {\n super();\n this.attachShadow({ mode: 'open' });\n }\n connectedCallback() {\n // @ts-ignore todo: improve typings\n for (const key in this.$$.slotted) {\n // @ts-ignore todo: improve typings\n this.appendChild(this.$$.slotted[key]);\n }\n }\n attributeChangedCallback(attr, _oldValue, newValue) {\n this[attr] = newValue;\n }\n $destroy() {\n destroy_component(this, 1);\n this.$destroy = noop;\n }\n $on(type, callback) {\n // TODO should this delegate to addEventListener?\n const callbacks = (this.$$.callbacks[type] || (this.$$.callbacks[type] = []));\n callbacks.push(callback);\n return () => {\n const index = callbacks.indexOf(callback);\n if (index !== -1)\n callbacks.splice(index, 1);\n };\n }\n $set() {\n // overridden by instance, if it has props\n }\n };\n}\nclass SvelteComponent {\n $destroy() {\n destroy_component(this, 1);\n this.$destroy = noop;\n }\n $on(type, callback) {\n const callbacks = (this.$$.callbacks[type] || (this.$$.callbacks[type] = []));\n callbacks.push(callback);\n return () => {\n const index = callbacks.indexOf(callback);\n if (index !== -1)\n callbacks.splice(index, 1);\n };\n }\n $set() {\n // overridden by instance, if it has props\n }\n}\n\nfunction dispatch_dev(type, detail) {\n document.dispatchEvent(custom_event(type, Object.assign({ version: '3.20.1' }, detail)));\n}\nfunction append_dev(target, node) {\n dispatch_dev(\"SvelteDOMInsert\", { target, node });\n append(target, node);\n}\nfunction insert_dev(target, node, anchor) {\n dispatch_dev(\"SvelteDOMInsert\", { target, node, anchor });\n insert(target, node, anchor);\n}\nfunction detach_dev(node) {\n dispatch_dev(\"SvelteDOMRemove\", { node });\n detach(node);\n}\nfunction detach_between_dev(before, after) {\n while (before.nextSibling && before.nextSibling !== after) {\n detach_dev(before.nextSibling);\n }\n}\nfunction detach_before_dev(after) {\n while (after.previousSibling) {\n detach_dev(after.previousSibling);\n }\n}\nfunction detach_after_dev(before) {\n while (before.nextSibling) {\n detach_dev(before.nextSibling);\n }\n}\nfunction listen_dev(node, event, handler, options, has_prevent_default, has_stop_propagation) {\n const modifiers = options === true ? [\"capture\"] : options ? Array.from(Object.keys(options)) : [];\n if (has_prevent_default)\n modifiers.push('preventDefault');\n if (has_stop_propagation)\n modifiers.push('stopPropagation');\n dispatch_dev(\"SvelteDOMAddEventListener\", { node, event, handler, modifiers });\n const dispose = listen(node, event, handler, options);\n return () => {\n dispatch_dev(\"SvelteDOMRemoveEventListener\", { node, event, handler, modifiers });\n dispose();\n };\n}\nfunction attr_dev(node, attribute, value) {\n attr(node, attribute, value);\n if (value == null)\n dispatch_dev(\"SvelteDOMRemoveAttribute\", { node, attribute });\n else\n dispatch_dev(\"SvelteDOMSetAttribute\", { node, attribute, value });\n}\nfunction prop_dev(node, property, value) {\n node[property] = value;\n dispatch_dev(\"SvelteDOMSetProperty\", { node, property, value });\n}\nfunction dataset_dev(node, property, value) {\n node.dataset[property] = value;\n dispatch_dev(\"SvelteDOMSetDataset\", { node, property, value });\n}\nfunction set_data_dev(text, data) {\n data = '' + data;\n if (text.data === data)\n return;\n dispatch_dev(\"SvelteDOMSetData\", { node: text, data });\n text.data = data;\n}\nfunction validate_each_argument(arg) {\n if (typeof arg !== 'string' && !(arg && typeof arg === 'object' && 'length' in arg)) {\n let msg = '{#each} only iterates over array-like objects.';\n if (typeof Symbol === 'function' && arg && Symbol.iterator in arg) {\n msg += ' You can use a spread to convert this iterable into an array.';\n }\n throw new Error(msg);\n }\n}\nfunction validate_slots(name, slot, keys) {\n for (const slot_key of Object.keys(slot)) {\n if (!~keys.indexOf(slot_key)) {\n console.warn(`<${name}> received an unexpected slot \"${slot_key}\".`);\n }\n }\n}\nclass SvelteComponentDev extends SvelteComponent {\n constructor(options) {\n if (!options || (!options.target && !options.$$inline)) {\n throw new Error(`'target' is a required option`);\n }\n super();\n }\n $destroy() {\n super.$destroy();\n this.$destroy = () => {\n console.warn(`Component was already destroyed`); // eslint-disable-line no-console\n };\n }\n $capture_state() { }\n $inject_state() { }\n}\nfunction loop_guard(timeout) {\n const start = Date.now();\n return () => {\n if (Date.now() - start > timeout) {\n throw new Error(`Infinite loop detected`);\n }\n };\n}\n\nexport { HtmlTag, SvelteComponent, SvelteComponentDev, SvelteElement, action_destroyer, add_attribute, add_classes, add_flush_callback, add_location, add_render_callback, add_resize_listener, add_transform, afterUpdate, append, append_dev, assign, attr, attr_dev, beforeUpdate, bind, binding_callbacks, blank_object, bubble, check_outros, children, claim_component, claim_element, claim_space, claim_text, clear_loops, component_subscribe, compute_rest_props, createEventDispatcher, create_animation, create_bidirectional_transition, create_component, create_in_transition, create_out_transition, create_slot, create_ssr_component, current_component, custom_event, dataset_dev, debug, destroy_block, destroy_component, destroy_each, detach, detach_after_dev, detach_before_dev, detach_between_dev, detach_dev, dirty_components, dispatch_dev, each, element, element_is, empty, escape, escaped, exclude_internal_props, fix_and_destroy_block, fix_and_outro_and_destroy_block, fix_position, flush, getContext, get_binding_group_value, get_current_component, get_slot_changes, get_slot_context, get_spread_object, get_spread_update, get_store_value, globals, group_outros, handle_promise, has_prop, identity, init, insert, insert_dev, intros, invalid_attribute_name_character, is_client, is_function, is_promise, listen, listen_dev, loop, loop_guard, missing_component, mount_component, noop, not_equal, now, null_to_empty, object_without_properties, onDestroy, onMount, once, outro_and_destroy_block, prevent_default, prop_dev, query_selector_all, raf, run, run_all, safe_not_equal, schedule_update, select_multiple_value, select_option, select_options, select_value, self, setContext, set_attributes, set_current_component, set_custom_element_data, set_data, set_data_dev, set_input_type, set_input_value, set_now, set_raf, set_store_value, set_style, set_svg_attributes, space, spread, stop_propagation, subscribe, svg_element, text, tick, time_ranges_to_array, to_number, toggle_class, transition_in, transition_out, update_keyed_each, validate_component, validate_each_argument, validate_each_keys, validate_slots, validate_store, xlink_attr };\n","\n\n\n
\n {#each events as event}\n
\n {event.label} {event.days} days / {event.weeks} weeks\n
\n\n {/each}\n
\n\n
\n\n","\n\n\n
\n {#if longPassword}\n
\n
Long: {longPassword}
Short: {shortPassword}
\n
\n {/if}\n
\n","import { noop, safe_not_equal, subscribe, run_all, is_function } from '../internal';\nexport { get_store_value as get } from '../internal';\n\nconst subscriber_queue = [];\n/**\n * Creates a `Readable` store that allows reading by subscription.\n * @param value initial value\n * @param {StartStopNotifier}start start and stop notifications for subscriptions\n */\nfunction readable(value, start) {\n return {\n subscribe: writable(value, start).subscribe,\n };\n}\n/**\n * Create a `Writable` store that allows both updating and reading by subscription.\n * @param {*=}value initial value\n * @param {StartStopNotifier=}start start and stop notifications for subscriptions\n */\nfunction writable(value, start = noop) {\n let stop;\n const subscribers = [];\n function set(new_value) {\n if (safe_not_equal(value, new_value)) {\n value = new_value;\n if (stop) { // store is ready\n const run_queue = !subscriber_queue.length;\n for (let i = 0; i < subscribers.length; i += 1) {\n const s = subscribers[i];\n s[1]();\n subscriber_queue.push(s, value);\n }\n if (run_queue) {\n for (let i = 0; i < subscriber_queue.length; i += 2) {\n subscriber_queue[i][0](subscriber_queue[i + 1]);\n }\n subscriber_queue.length = 0;\n }\n }\n }\n }\n function update(fn) {\n set(fn(value));\n }\n function subscribe(run, invalidate = noop) {\n const subscriber = [run, invalidate];\n subscribers.push(subscriber);\n if (subscribers.length === 1) {\n stop = start(set) || noop;\n }\n run(value);\n return () => {\n const index = subscribers.indexOf(subscriber);\n if (index !== -1) {\n subscribers.splice(index, 1);\n }\n if (subscribers.length === 0) {\n stop();\n stop = null;\n }\n };\n }\n return { set, update, subscribe };\n}\nfunction derived(stores, fn, initial_value) {\n const single = !Array.isArray(stores);\n const stores_array = single\n ? [stores]\n : stores;\n const auto = fn.length < 2;\n return readable(initial_value, (set) => {\n let inited = false;\n const values = [];\n let pending = 0;\n let cleanup = noop;\n const sync = () => {\n if (pending) {\n return;\n }\n cleanup();\n const result = fn(single ? values[0] : values, set);\n if (auto) {\n set(result);\n }\n else {\n cleanup = is_function(result) ? result : noop;\n }\n };\n const unsubscribers = stores_array.map((store, i) => subscribe(store, (value) => {\n values[i] = value;\n pending &= ~(1 << i);\n if (inited) {\n sync();\n }\n }, () => {\n pending |= (1 << i);\n }));\n inited = true;\n sync();\n return function stop() {\n run_all(unsubscribers);\n cleanup();\n };\n });\n}\n\nexport { derived, readable, writable };\n","\n\n{#if lastUSD!==0}\n \n ${lastUSD.toFixed(2)} / £{lastGBP.toFixed(2)}\n\n{/if}\n\n\n","var token = /d{1,4}|M{1,4}|YY(?:YY)?|S{1,3}|Do|ZZ|Z|([HhMsDm])\\1?|[aA]|\"[^\"]*\"|'[^']*'/g;\nvar twoDigitsOptional = \"[1-9]\\\\d?\";\nvar twoDigits = \"\\\\d\\\\d\";\nvar threeDigits = \"\\\\d{3}\";\nvar fourDigits = \"\\\\d{4}\";\nvar word = \"[^\\\\s]+\";\nvar literal = /\\[([^]*?)\\]/gm;\nfunction shorten(arr, sLen) {\n var newArr = [];\n for (var i = 0, len = arr.length; i < len; i++) {\n newArr.push(arr[i].substr(0, sLen));\n }\n return newArr;\n}\nvar monthUpdate = function (arrName) { return function (v, i18n) {\n var lowerCaseArr = i18n[arrName].map(function (v) { return v.toLowerCase(); });\n var index = lowerCaseArr.indexOf(v.toLowerCase());\n if (index > -1) {\n return index;\n }\n return null;\n}; };\nfunction assign(origObj) {\n var args = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n args[_i - 1] = arguments[_i];\n }\n for (var _a = 0, args_1 = args; _a < args_1.length; _a++) {\n var obj = args_1[_a];\n for (var key in obj) {\n // @ts-ignore ex\n origObj[key] = obj[key];\n }\n }\n return origObj;\n}\nvar dayNames = [\n \"Sunday\",\n \"Monday\",\n \"Tuesday\",\n \"Wednesday\",\n \"Thursday\",\n \"Friday\",\n \"Saturday\"\n];\nvar monthNames = [\n \"January\",\n \"February\",\n \"March\",\n \"April\",\n \"May\",\n \"June\",\n \"July\",\n \"August\",\n \"September\",\n \"October\",\n \"November\",\n \"December\"\n];\nvar monthNamesShort = shorten(monthNames, 3);\nvar dayNamesShort = shorten(dayNames, 3);\nvar defaultI18n = {\n dayNamesShort: dayNamesShort,\n dayNames: dayNames,\n monthNamesShort: monthNamesShort,\n monthNames: monthNames,\n amPm: [\"am\", \"pm\"],\n DoFn: function (dayOfMonth) {\n return (dayOfMonth +\n [\"th\", \"st\", \"nd\", \"rd\"][dayOfMonth % 10 > 3\n ? 0\n : ((dayOfMonth - (dayOfMonth % 10) !== 10 ? 1 : 0) * dayOfMonth) % 10]);\n }\n};\nvar globalI18n = assign({}, defaultI18n);\nvar setGlobalDateI18n = function (i18n) {\n return (globalI18n = assign(globalI18n, i18n));\n};\nvar regexEscape = function (str) {\n return str.replace(/[|\\\\{()[^$+*?.-]/g, \"\\\\$&\");\n};\nvar pad = function (val, len) {\n if (len === void 0) { len = 2; }\n val = String(val);\n while (val.length < len) {\n val = \"0\" + val;\n }\n return val;\n};\nvar formatFlags = {\n D: function (dateObj) { return String(dateObj.getDate()); },\n DD: function (dateObj) { return pad(dateObj.getDate()); },\n Do: function (dateObj, i18n) {\n return i18n.DoFn(dateObj.getDate());\n },\n d: function (dateObj) { return String(dateObj.getDay()); },\n dd: function (dateObj) { return pad(dateObj.getDay()); },\n ddd: function (dateObj, i18n) {\n return i18n.dayNamesShort[dateObj.getDay()];\n },\n dddd: function (dateObj, i18n) {\n return i18n.dayNames[dateObj.getDay()];\n },\n M: function (dateObj) { return String(dateObj.getMonth() + 1); },\n MM: function (dateObj) { return pad(dateObj.getMonth() + 1); },\n MMM: function (dateObj, i18n) {\n return i18n.monthNamesShort[dateObj.getMonth()];\n },\n MMMM: function (dateObj, i18n) {\n return i18n.monthNames[dateObj.getMonth()];\n },\n YY: function (dateObj) {\n return pad(String(dateObj.getFullYear()), 4).substr(2);\n },\n YYYY: function (dateObj) { return pad(dateObj.getFullYear(), 4); },\n h: function (dateObj) { return String(dateObj.getHours() % 12 || 12); },\n hh: function (dateObj) { return pad(dateObj.getHours() % 12 || 12); },\n H: function (dateObj) { return String(dateObj.getHours()); },\n HH: function (dateObj) { return pad(dateObj.getHours()); },\n m: function (dateObj) { return String(dateObj.getMinutes()); },\n mm: function (dateObj) { return pad(dateObj.getMinutes()); },\n s: function (dateObj) { return String(dateObj.getSeconds()); },\n ss: function (dateObj) { return pad(dateObj.getSeconds()); },\n S: function (dateObj) {\n return String(Math.round(dateObj.getMilliseconds() / 100));\n },\n SS: function (dateObj) {\n return pad(Math.round(dateObj.getMilliseconds() / 10), 2);\n },\n SSS: function (dateObj) { return pad(dateObj.getMilliseconds(), 3); },\n a: function (dateObj, i18n) {\n return dateObj.getHours() < 12 ? i18n.amPm[0] : i18n.amPm[1];\n },\n A: function (dateObj, i18n) {\n return dateObj.getHours() < 12\n ? i18n.amPm[0].toUpperCase()\n : i18n.amPm[1].toUpperCase();\n },\n ZZ: function (dateObj) {\n var offset = dateObj.getTimezoneOffset();\n return ((offset > 0 ? \"-\" : \"+\") +\n pad(Math.floor(Math.abs(offset) / 60) * 100 + (Math.abs(offset) % 60), 4));\n },\n Z: function (dateObj) {\n var offset = dateObj.getTimezoneOffset();\n return ((offset > 0 ? \"-\" : \"+\") +\n pad(Math.floor(Math.abs(offset) / 60), 2) +\n \":\" +\n pad(Math.abs(offset) % 60, 2));\n }\n};\nvar monthParse = function (v) { return +v - 1; };\nvar emptyDigits = [null, twoDigitsOptional];\nvar emptyWord = [null, word];\nvar amPm = [\n \"isPm\",\n word,\n function (v, i18n) {\n var val = v.toLowerCase();\n if (val === i18n.amPm[0]) {\n return 0;\n }\n else if (val === i18n.amPm[1]) {\n return 1;\n }\n return null;\n }\n];\nvar timezoneOffset = [\n \"timezoneOffset\",\n \"[^\\\\s]*?[\\\\+\\\\-]\\\\d\\\\d:?\\\\d\\\\d|[^\\\\s]*?Z?\",\n function (v) {\n var parts = (v + \"\").match(/([+-]|\\d\\d)/gi);\n if (parts) {\n var minutes = +parts[1] * 60 + parseInt(parts[2], 10);\n return parts[0] === \"+\" ? minutes : -minutes;\n }\n return 0;\n }\n];\nvar parseFlags = {\n D: [\"day\", twoDigitsOptional],\n DD: [\"day\", twoDigits],\n Do: [\"day\", twoDigitsOptional + word, function (v) { return parseInt(v, 10); }],\n M: [\"month\", twoDigitsOptional, monthParse],\n MM: [\"month\", twoDigits, monthParse],\n YY: [\n \"year\",\n twoDigits,\n function (v) {\n var now = new Date();\n var cent = +(\"\" + now.getFullYear()).substr(0, 2);\n return +(\"\" + (+v > 68 ? cent - 1 : cent) + v);\n }\n ],\n h: [\"hour\", twoDigitsOptional, undefined, \"isPm\"],\n hh: [\"hour\", twoDigits, undefined, \"isPm\"],\n H: [\"hour\", twoDigitsOptional],\n HH: [\"hour\", twoDigits],\n m: [\"minute\", twoDigitsOptional],\n mm: [\"minute\", twoDigits],\n s: [\"second\", twoDigitsOptional],\n ss: [\"second\", twoDigits],\n YYYY: [\"year\", fourDigits],\n S: [\"millisecond\", \"\\\\d\", function (v) { return +v * 100; }],\n SS: [\"millisecond\", twoDigits, function (v) { return +v * 10; }],\n SSS: [\"millisecond\", threeDigits],\n d: emptyDigits,\n dd: emptyDigits,\n ddd: emptyWord,\n dddd: emptyWord,\n MMM: [\"month\", word, monthUpdate(\"monthNamesShort\")],\n MMMM: [\"month\", word, monthUpdate(\"monthNames\")],\n a: amPm,\n A: amPm,\n ZZ: timezoneOffset,\n Z: timezoneOffset\n};\n// Some common format strings\nvar globalMasks = {\n default: \"ddd MMM DD YYYY HH:mm:ss\",\n shortDate: \"M/D/YY\",\n mediumDate: \"MMM D, YYYY\",\n longDate: \"MMMM D, YYYY\",\n fullDate: \"dddd, MMMM D, YYYY\",\n isoDate: \"YYYY-MM-DD\",\n isoDateTime: \"YYYY-MM-DDTHH:mm:ssZ\",\n shortTime: \"HH:mm\",\n mediumTime: \"HH:mm:ss\",\n longTime: \"HH:mm:ss.SSS\"\n};\nvar setGlobalDateMasks = function (masks) { return assign(globalMasks, masks); };\n/***\n * Format a date\n * @method format\n * @param {Date|number} dateObj\n * @param {string} mask Format of the date, i.e. 'mm-dd-yy' or 'shortDate'\n * @returns {string} Formatted date string\n */\nvar format = function (dateObj, mask, i18n) {\n if (mask === void 0) { mask = globalMasks[\"default\"]; }\n if (i18n === void 0) { i18n = {}; }\n if (typeof dateObj === \"number\") {\n dateObj = new Date(dateObj);\n }\n if (Object.prototype.toString.call(dateObj) !== \"[object Date]\" ||\n isNaN(dateObj.getTime())) {\n throw new Error(\"Invalid Date pass to format\");\n }\n mask = globalMasks[mask] || mask;\n var literals = [];\n // Make literals inactive by replacing them with @@@\n mask = mask.replace(literal, function ($0, $1) {\n literals.push($1);\n return \"@@@\";\n });\n var combinedI18nSettings = assign(assign({}, globalI18n), i18n);\n // Apply formatting rules\n mask = mask.replace(token, function ($0) {\n return formatFlags[$0](dateObj, combinedI18nSettings);\n });\n // Inline literal values back into the formatted value\n return mask.replace(/@@@/g, function () { return literals.shift(); });\n};\n/**\n * Parse a date string into a Javascript Date object /\n * @method parse\n * @param {string} dateStr Date string\n * @param {string} format Date parse format\n * @param {i18n} I18nSettingsOptional Full or subset of I18N settings\n * @returns {Date|null} Returns Date object. Returns null what date string is invalid or doesn't match format\n */\nfunction parse(dateStr, format, i18n) {\n if (i18n === void 0) { i18n = {}; }\n if (typeof format !== \"string\") {\n throw new Error(\"Invalid format in fecha parse\");\n }\n // Check to see if the format is actually a mask\n format = globalMasks[format] || format;\n // Avoid regular expression denial of service, fail early for really long strings\n // https://www.owasp.org/index.php/Regular_expression_Denial_of_Service_-_ReDoS\n if (dateStr.length > 1000) {\n return null;\n }\n // Default to the beginning of the year.\n var today = new Date();\n var dateInfo = {\n year: today.getFullYear(),\n month: 0,\n day: 1,\n hour: 0,\n minute: 0,\n second: 0,\n millisecond: 0,\n isPm: null,\n timezoneOffset: null\n };\n var parseInfo = [];\n var literals = [];\n // Replace all the literals with @@@. Hopefully a string that won't exist in the format\n var newFormat = format.replace(literal, function ($0, $1) {\n literals.push(regexEscape($1));\n return \"@@@\";\n });\n var specifiedFields = {};\n var requiredFields = {};\n // Change every token that we find into the correct regex\n newFormat = regexEscape(newFormat).replace(token, function ($0) {\n var info = parseFlags[$0];\n var field = info[0], regex = info[1], requiredField = info[3];\n // Check if the person has specified the same field twice. This will lead to confusing results.\n if (specifiedFields[field]) {\n throw new Error(\"Invalid format. \" + field + \" specified twice in format\");\n }\n specifiedFields[field] = true;\n // Check if there are any required fields. For instance, 12 hour time requires AM/PM specified\n if (requiredField) {\n requiredFields[requiredField] = true;\n }\n parseInfo.push(info);\n return \"(\" + regex + \")\";\n });\n // Check all the required fields are present\n Object.keys(requiredFields).forEach(function (field) {\n if (!specifiedFields[field]) {\n throw new Error(\"Invalid format. \" + field + \" is required in specified format\");\n }\n });\n // Add back all the literals after\n newFormat = newFormat.replace(/@@@/g, function () { return literals.shift(); });\n // Check if the date string matches the format. If it doesn't return null\n var matches = dateStr.match(new RegExp(newFormat, \"i\"));\n if (!matches) {\n return null;\n }\n var combinedI18nSettings = assign(assign({}, globalI18n), i18n);\n // For each match, call the parser function for that date part\n for (var i = 1; i < matches.length; i++) {\n var _a = parseInfo[i - 1], field = _a[0], parser = _a[2];\n var value = parser\n ? parser(matches[i], combinedI18nSettings)\n : +matches[i];\n // If the parser can't make sense of the value, return null\n if (value == null) {\n return null;\n }\n dateInfo[field] = value;\n }\n if (dateInfo.isPm === 1 && dateInfo.hour != null && +dateInfo.hour !== 12) {\n dateInfo.hour = +dateInfo.hour + 12;\n }\n else if (dateInfo.isPm === 0 && +dateInfo.hour === 12) {\n dateInfo.hour = 0;\n }\n var dateWithoutTZ = new Date(dateInfo.year, dateInfo.month, dateInfo.day, dateInfo.hour, dateInfo.minute, dateInfo.second, dateInfo.millisecond);\n var validateFields = [\n [\"month\", \"getMonth\"],\n [\"day\", \"getDate\"],\n [\"hour\", \"getHours\"],\n [\"minute\", \"getMinutes\"],\n [\"second\", \"getSeconds\"]\n ];\n for (var i = 0, len = validateFields.length; i < len; i++) {\n // Check to make sure the date field is within the allowed range. Javascript dates allows values\n // outside the allowed range. If the values don't match the value was invalid\n if (specifiedFields[validateFields[i][0]] &&\n dateInfo[validateFields[i][0]] !== dateWithoutTZ[validateFields[i][1]]()) {\n return null;\n }\n }\n if (dateInfo.timezoneOffset == null) {\n return dateWithoutTZ;\n }\n return new Date(Date.UTC(dateInfo.year, dateInfo.month, dateInfo.day, dateInfo.hour, dateInfo.minute - dateInfo.timezoneOffset, dateInfo.second, dateInfo.millisecond));\n}\nvar fecha = {\n format: format,\n parse: parse,\n defaultI18n: defaultI18n,\n setGlobalDateI18n: setGlobalDateI18n,\n setGlobalDateMasks: setGlobalDateMasks\n};\n\nexport default fecha;\nexport { assign, format, parse, defaultI18n, setGlobalDateI18n, setGlobalDateMasks };\n//# sourceMappingURL=fecha.js.map\n","\n\n\n\n\n\n {#if weatherData}\n {#each weatherData as item}\n
\n
\n
{item.day}
\n
{item.date}
\n
\n
\n
\n \n {item.tempHigh}° /\n {item.tempLow}°\n
\n
{item.summary}
\n
\n
\n
{item.tempMorn}°
\n
{item.tempDay}°
\n
{item.tempEve}°
\n
{item.tempNight}°
\n
\n
\n {/each}\n {/if}\n\n
\n","\n\n\n\n{#if fxData.gpbe}\n\n £1 = ${parseFloat(fxData.gpbe.toFixed(2))} = { parseFloat(fxData.sekex.toFixed(2))} SEK\n\n\n{/if}\n\n\n","import { writable } from 'svelte/store';\n\nconst route = writable({ 'fromStation':'', 'toStation':'' });\n\nexport { route };\n\n","\n\n\n\n{display.title}: {display.output}
\n\n","\n\n\n\n{#if visible}\n\n
{routeData.fromName} TO {routeData.toName}
\n
\n \n \n Destination | \n Time | \n Status | \n Platform | \n
\n \n\n \n {#each services as item}\n \n\n {item.icon}{item.location} {@html item.via} | \n {item.time} | \n {#if !item.isCancelled}\n {item.status} | \n {item.platform} | \n {:else}\n ❌ {item.cancelReason} | \n {/if}\n
\n {/each}\n \n
\n\n
\n{/if}\n\n","\n\n\n \n \n
\n\n \n
\n
\n Starting Points/Metasites
\n \n \n
\n Tools
\n \n \n \n\t\t\t\t
\n\t\t\t\t\tBitcoin
\n\t\t\t\t\t\n\t\t\t\t\n
\n\n
\n
\n Package Tracking
\n \n \n \n
\n Weather
\n \n\n \n
\n Free Email WEBpages
\n \n \n \n
\n\n\n
\n
\n Contracting
\n \n \n\n
\n Entertainment
\n \n \n \n\n
\n Travel
\n \n\n \n \n \n\n
\n \n \n
\n\n \n \n\n
\n\n
\n
\n Computer Software, etc.
\n \n \n\n
\n Reference & Special sites
\n \n \n \n\n
\n Earth and Beyond
\n \n \n \n
\n\n
\n\n\n\n \n \n\n\n\n","import App from './App.svelte';\n\nconst app = new App({\n 'target': document.body,\n 'props': {\n 'events' : [\n { 'event': new Date(2020, 0, 1), 'label': 'Contract Ends:' }\n ]\n\n }\n});\n\nexport default app;\n"],"names":["noop","run","fn","blank_object","Object","create","run_all","fns","forEach","is_function","thing","safe_not_equal","a","b","get_store_value","store","value","callbacks","unsub","subscribe","unsubscribe","_","get_slot_context","definition","ctx","$$scope","tar","src","k","assign","slice","null_to_empty","append","target","node","appendChild","insert","anchor","insertBefore","detach","parentNode","removeChild","destroy_each","iterations","detaching","i","length","d","element","name","document","createElement","text","data","createTextNode","space","empty","listen","event","handler","options","addEventListener","removeEventListener","stop_propagation","stopPropagation","call","this","attr","attribute","removeAttribute","getAttribute","setAttribute","set_data","set_style","key","important","style","setProperty","HtmlTag","[object Object]","html","e","u","n","t","innerHTML","Array","from","childNodes","m","current_component","set_current_component","component","onMount","Error","get_current_component","$$","on_mount","push","dirty_components","binding_callbacks","render_callbacks","flush_callbacks","resolved_promise","Promise","resolve","update_scheduled","add_render_callback","flushing","seen_callbacks","Set","flush","update","pop","callback","has","add","clear","fragment","before_update","dirty","p","after_update","outroing","transition_in","block","local","delete","transition_out","o","outros","c","create_component","mount_component","on_destroy","new_on_destroy","map","filter","destroy_component","make_dirty","then","fill","init","instance","create_fragment","not_equal","props","parent_component","prop_values","bound","context","Map","ready","ret","rest","hydrate","nodes","children","l","intro","SvelteComponent","$destroy","type","index","indexOf","splice","slot_ctx","lets","undefined","merged","len","Math","max","label","days","weeks","events","now","Date","mod","getTime","item","ceil","getDays","setTimeout","bind","startdate","enddate","r","s","longPassword","shortPassword","prototype","random","floor","alpha","numbers","left","right","randomAmount","str","split","join","subscriber_queue","writable","start","stop","subscribers","set","new_value","run_queue","invalidate","subscriber","toFixed","lastGBP","lastUSD","eclass","trendClass","btcData","lows","gbp","usd","highs","balance","trend","btcObj","res","fetch","json","freshBTC","get","bpi","GBP","rate_float","USD","g","stub","Number","MAX_SAFE_INTEGER","toString","recalc","getBtc","token","literal","shorten","arr","sLen","newArr","substr","origObj","args","_i","arguments","_a","args_1","obj","dayNames","monthNames","monthNamesShort","globalI18n","dayNamesShort","amPm","DoFn","dayOfMonth","pad","val","String","formatFlags","D","dateObj","getDate","DD","Do","i18n","getDay","dd","ddd","dddd","M","getMonth","MM","MMM","MMMM","YY","getFullYear","YYYY","h","getHours","hh","H","HH","getMinutes","mm","getSeconds","ss","S","round","getMilliseconds","SS","SSS","A","toUpperCase","ZZ","offset","getTimezoneOffset","abs","Z","globalMasks","default","shortDate","mediumDate","longDate","fullDate","isoDate","isoDateTime","shortTime","mediumTime","longTime","format","mask","isNaN","literals","replace","$0","$1","combinedI18nSettings","shift","day","date","tempHigh","tempLow","summary","tempMorn","tempDay","tempEve","tempNight","icon","tempHighClass","tempLowClass","weatherData","list","ts","dt","weatherBlock","weather","timestamp","id","description","parseInt","temp","min","morn","eve","night","datelong","time","reduceOpenWeather","getWeather","parseFloat","gpbe","sekex","fxData","rates","gpbex","SEK","sek","reduceFX","getFX","route","fromStation","toStation","title","output","status","url","eta","sta","display","console","log","getTrain","toLowerCase","fromName","toName","cancelReason","platform","class","location","via","isCancelled","visible","routeData","services","v","newData","locationName","filterLocationName","trainServices","dest","destination","std","etd","cls","busServices","reduceRoute","getRoute","routeUpdateFn","popitoutSmall","popitout","dataset","newwindow","window","open","focus","body"],"mappings":"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"}
\ No newline at end of file
diff --git a/dist/favicon.png b/dist/favicon.png
new file mode 100644
index 0000000..f7a4f79
Binary files /dev/null and b/dist/favicon.png differ
diff --git a/dist/gfx/popout.png b/dist/gfx/popout.png
new file mode 100644
index 0000000..2ff7fe5
Binary files /dev/null and b/dist/gfx/popout.png differ
diff --git a/dist/global.css b/dist/global.css
new file mode 100644
index 0000000..a65f726
--- /dev/null
+++ b/dist/global.css
@@ -0,0 +1,1961 @@
+/**
+ * MUI Colors module
+ */
+/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */
+/**
+ * 1. Set default font family to sans-serif.
+ * 2. Prevent iOS and IE text size adjust after device orientation change,
+ * without disabling user zoom.
+ */
+html {
+ font-family: sans-serif;
+ /* 1 */
+ -ms-text-size-adjust: 100%;
+ /* 2 */
+ -webkit-text-size-adjust: 100%;
+ /* 2 */ }
+
+/**
+ * Remove default margin.
+ */
+body {
+ margin: 0; }
+
+/* HTML5 display definitions
+ ========================================================================== */
+/**
+ * Correct `block` display not defined for any HTML5 element in IE 8/9.
+ * Correct `block` display not defined for `details` or `summary` in IE 10/11
+ * and Firefox.
+ * Correct `block` display not defined for `main` in IE 11.
+ */
+article,
+aside,
+details,
+figcaption,
+figure,
+footer,
+header,
+hgroup,
+main,
+menu,
+nav,
+section,
+summary {
+ display: block; }
+
+/**
+ * 1. Correct `inline-block` display not defined in IE 8/9.
+ * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
+ */
+audio,
+canvas,
+progress,
+video {
+ display: inline-block;
+ /* 1 */
+ vertical-align: baseline;
+ /* 2 */ }
+
+/**
+ * Prevent modern browsers from displaying `audio` without controls.
+ * Remove excess height in iOS 5 devices.
+ */
+audio:not([controls]) {
+ display: none;
+ height: 0; }
+
+/**
+ * Address `[hidden]` styling not present in IE 8/9/10.
+ * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.
+ */
+[hidden],
+template {
+ display: none; }
+
+/* Links
+ ========================================================================== */
+/**
+ * Remove the gray background color from active links in IE 10.
+ */
+a {
+ background-color: transparent; }
+
+/**
+ * Improve readability of focused elements when they are also in an
+ * active/hover state.
+ */
+a:active,
+a:hover {
+ outline: 0; }
+
+/* Text-level semantics
+ ========================================================================== */
+/**
+ * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
+ */
+abbr[title] {
+ border-bottom: 1px dotted; }
+
+/**
+ * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
+ */
+b,
+strong {
+ font-weight: bold; }
+
+/**
+ * Address styling not present in Safari and Chrome.
+ */
+dfn {
+ font-style: italic; }
+
+/**
+ * Address variable `h1` font-size and margin within `section` and `article`
+ * contexts in Firefox 4+, Safari, and Chrome.
+ */
+h1 {
+ font-size: 2em;
+ margin: 0.67em 0; }
+
+/**
+ * Address styling not present in IE 8/9.
+ */
+mark {
+ background: #ff0;
+ color: #000; }
+
+/**
+ * Address inconsistent and variable font size in all browsers.
+ */
+small {
+ font-size: 80%; }
+
+/**
+ * Prevent `sub` and `sup` affecting `line-height` in all browsers.
+ */
+sub,
+sup {
+ font-size: 75%;
+ line-height: 0;
+ position: relative;
+ vertical-align: baseline; }
+
+sup {
+ top: -0.5em; }
+
+sub {
+ bottom: -0.25em; }
+
+/* Embedded content
+ ========================================================================== */
+/**
+ * Remove border when inside `a` element in IE 8/9/10.
+ */
+img {
+ border: 0; }
+
+/**
+ * Correct overflow not hidden in IE 9/10/11.
+ */
+svg:not(:root) {
+ overflow: hidden; }
+
+/* Grouping content
+ ========================================================================== */
+/**
+ * Address margin not present in IE 8/9 and Safari.
+ */
+figure {
+ margin: 1em 40px; }
+
+/**
+ * Address differences between Firefox and other browsers.
+ */
+hr {
+ box-sizing: content-box;
+ height: 0; }
+
+/**
+ * Contain overflow in all browsers.
+ */
+pre {
+ overflow: auto; }
+
+/**
+ * Address odd `em`-unit font size rendering in all browsers.
+ */
+code,
+kbd,
+pre,
+samp {
+ font-family: monospace, monospace;
+ font-size: 1em; }
+
+/* Forms
+ ========================================================================== */
+/**
+ * Known limitation: by default, Chrome and Safari on OS X allow very limited
+ * styling of `select`, unless a `border` property is set.
+ */
+/**
+ * 1. Correct color not being inherited.
+ * Known issue: affects color of disabled elements.
+ * 2. Correct font properties not being inherited.
+ * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
+ */
+button,
+input,
+optgroup,
+select,
+textarea {
+ color: inherit;
+ /* 1 */
+ font: inherit;
+ /* 2 */
+ margin: 0;
+ /* 3 */ }
+
+/**
+ * Address `overflow` set to `hidden` in IE 8/9/10/11.
+ */
+button {
+ overflow: visible; }
+
+/**
+ * Address inconsistent `text-transform` inheritance for `button` and `select`.
+ * All other form control elements do not inherit `text-transform` values.
+ * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
+ * Correct `select` style inheritance in Firefox.
+ */
+button,
+select {
+ text-transform: none; }
+
+/**
+ * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
+ * and `video` controls.
+ * 2. Correct inability to style clickable `input` types in iOS.
+ * 3. Improve usability and consistency of cursor style between image-type
+ * `input` and others.
+ */
+button,
+html input[type="button"],
+input[type="reset"],
+input[type="submit"] {
+ -webkit-appearance: button;
+ /* 2 */
+ cursor: pointer;
+ /* 3 */ }
+
+/**
+ * Re-set default cursor for disabled elements.
+ */
+button[disabled],
+html input[disabled] {
+ cursor: default; }
+
+/**
+ * Remove inner padding and border in Firefox 4+.
+ */
+button::-moz-focus-inner,
+input::-moz-focus-inner {
+ border: 0;
+ padding: 0; }
+
+/**
+ * Address Firefox 4+ setting `line-height` on `input` using `!important` in
+ * the UA stylesheet.
+ */
+input {
+ line-height: normal; }
+
+/**
+ * It's recommended that you don't attempt to style these elements.
+ * Firefox's implementation doesn't respect box-sizing, padding, or width.
+ *
+ * 1. Address box sizing set to `content-box` in IE 8/9/10.
+ * 2. Remove excess padding in IE 8/9/10.
+ */
+input[type="checkbox"],
+input[type="radio"] {
+ box-sizing: border-box;
+ /* 1 */
+ padding: 0;
+ /* 2 */ }
+
+/**
+ * Fix the cursor style for Chrome's increment/decrement buttons. For certain
+ * `font-size` values of the `input`, it causes the cursor style of the
+ * decrement button to change from `default` to `text`.
+ */
+input[type="number"]::-webkit-inner-spin-button,
+input[type="number"]::-webkit-outer-spin-button {
+ height: auto; }
+
+/**
+ * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
+ * 2. Address `box-sizing` set to `border-box` in Safari and Chrome.
+ */
+input[type="search"] {
+ -webkit-appearance: textfield;
+ /* 1 */
+ box-sizing: content-box;
+ /* 2 */ }
+
+/**
+ * Remove inner padding and search cancel button in Safari and Chrome on OS X.
+ * Safari (but not Chrome) clips the cancel button when the search input has
+ * padding (and `textfield` appearance).
+ */
+input[type="search"]::-webkit-search-cancel-button,
+input[type="search"]::-webkit-search-decoration {
+ -webkit-appearance: none; }
+
+/**
+ * Define consistent border, margin, and padding.
+ */
+fieldset {
+ border: 1px solid #c0c0c0;
+ margin: 0 2px;
+ padding: 0.35em 0.625em 0.75em; }
+
+/**
+ * 1. Correct `color` not being inherited in IE 8/9/10/11.
+ * 2. Remove padding so people aren't caught out if they zero out fieldsets.
+ */
+legend {
+ border: 0;
+ /* 1 */
+ padding: 0;
+ /* 2 */ }
+
+/**
+ * Remove default vertical scrollbar in IE 8/9/10/11.
+ */
+textarea {
+ overflow: auto; }
+
+/**
+ * Don't inherit the `font-weight` (applied by a rule above).
+ * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
+ */
+optgroup {
+ font-weight: bold; }
+
+/* Tables
+ ========================================================================== */
+/**
+ * Remove most spacing between table cells.
+ */
+table {
+ border-collapse: collapse;
+ border-spacing: 0; }
+
+td,
+th {
+ padding: 0; }
+
+/**
+ * MUI Colors module
+ */
+/**
+ * MUI Reboot
+ */
+* {
+ box-sizing: border-box; }
+
+*:before,
+*:after {
+ box-sizing: border-box; }
+
+html {
+ font-size: 10px;
+ -webkit-tap-highlight-color: transparent; }
+
+body {
+ font-family: "Roboto Slab", "Helvetica Neue", Helvetica, Arial, Verdana, "Trebuchet MS";
+ font-size: 14px;
+ font-weight: 400;
+ line-height: 1.429;
+ color: rgba(0, 0, 0, 0.87);
+ background-color: #FFF; }
+
+input,
+button,
+select,
+textarea {
+ font-family: inherit;
+ font-size: inherit;
+ line-height: inherit; }
+
+a {
+ color: #009688;
+ text-decoration: none; }
+a:hover, a:focus {
+ color: #00796B;
+ text-decoration: underline; }
+a:focus {
+ outline: thin dotted;
+ outline: 5px auto -webkit-focus-ring-color;
+ outline-offset: -2px; }
+
+p {
+ margin: 0 0 10px; }
+
+ul,
+ol {
+ margin-top: 0;
+ margin-bottom: 10px; }
+
+figure {
+ margin: 0; }
+
+img {
+ vertical-align: middle; }
+
+hr {
+ margin-top: 20px;
+ margin-bottom: 20px;
+ border: 0;
+ height: 1px;
+ background-color: rgba(0, 0, 0, 0.12); }
+
+legend {
+ display: block;
+ width: 100%;
+ padding: 0;
+ margin-bottom: 10px;
+ font-size: 21px;
+ color: rgba(0, 0, 0, 0.87);
+ line-height: inherit;
+ border: 0; }
+
+input[type="search"] {
+ box-sizing: border-box;
+ -webkit-appearance: none; }
+
+input[type="file"]:focus,
+input[type="radio"]:focus,
+input[type="checkbox"]:focus {
+ outline: thin dotted;
+ outline: 5px auto -webkit-focus-ring-color;
+ outline-offset: -2px; }
+
+input[type="radio"]:disabled,
+input[type="checkbox"]:disabled {
+ cursor: not-allowed; }
+
+strong {
+ font-weight: 700; }
+
+abbr[title] {
+ cursor: help;
+ border-bottom: 1px dotted #009688; }
+
+h1, h2, h3 {
+ margin-top: 20px;
+ margin-bottom: 10px; }
+
+h4, h5, h6 {
+ margin-top: 10px;
+ margin-bottom: 10px; }
+
+/**
+ * MUI Appbar
+ */
+.mui--appbar-height {
+ height: 56px; }
+
+.mui--appbar-min-height, .mui-appbar {
+ min-height: 56px; }
+
+.mui--appbar-line-height {
+ line-height: 56px; }
+
+.mui--appbar-top {
+ top: 56px; }
+
+@media (orientation: landscape) and (max-height: 480px) {
+ .mui--appbar-height {
+ height: 48px; }
+ .mui--appbar-min-height, .mui-appbar {
+ min-height: 48px; }
+ .mui--appbar-line-height {
+ line-height: 48px; }
+ .mui--appbar-top {
+ top: 48px; } }
+
+@media (min-width: 480px) {
+ .mui--appbar-height {
+ height: 64px; }
+ .mui--appbar-min-height, .mui-appbar {
+ min-height: 64px; }
+ .mui--appbar-line-height {
+ line-height: 64px; }
+ .mui--appbar-top {
+ top: 64px; } }
+
+.mui-appbar {
+ background-color: #009688;
+ color: #FFF; }
+
+/**
+ * MUI Buttons
+ */
+.mui-btn {
+ animation-duration: 0.0001s;
+ animation-name: mui-node-inserted;
+ font-weight: 500;
+ font-size: 14px;
+ line-height: 18px;
+ text-transform: uppercase;
+ color: rgba(0, 0, 0, 0.87);
+ background-color: #FFF;
+ transition: all 0.2s ease-in-out;
+ display: inline-block;
+ height: 36px;
+ padding: 0 26px;
+ margin-top: 6px;
+ margin-bottom: 6px;
+ border: none;
+ border-radius: 2px;
+ cursor: pointer;
+ touch-action: manipulation;
+ background-image: none;
+ text-align: center;
+ line-height: 36px;
+ vertical-align: middle;
+ white-space: nowrap;
+ user-select: none;
+ font-size: 14px;
+ letter-spacing: 0.03em;
+ position: relative;
+ overflow: hidden; }
+.mui-btn:hover, .mui-btn:focus, .mui-btn:active {
+ color: rgba(0, 0, 0, 0.87);
+ background-color: white; }
+.mui-btn[disabled]:hover, .mui-btn[disabled]:focus, .mui-btn[disabled]:active {
+ color: rgba(0, 0, 0, 0.87);
+ background-color: #FFF; }
+.mui-btn.mui-btn--flat {
+ color: rgba(0, 0, 0, 0.87);
+ background-color: transparent; }
+.mui-btn.mui-btn--flat:hover, .mui-btn.mui-btn--flat:focus, .mui-btn.mui-btn--flat:active {
+ color: rgba(0, 0, 0, 0.87);
+ background-color: #f2f2f2; }
+.mui-btn.mui-btn--flat[disabled]:hover, .mui-btn.mui-btn--flat[disabled]:focus, .mui-btn.mui-btn--flat[disabled]:active {
+ color: rgba(0, 0, 0, 0.87);
+ background-color: transparent; }
+.mui-btn:hover, .mui-btn:focus, .mui-btn:active {
+ outline: 0;
+ text-decoration: none;
+ color: rgba(0, 0, 0, 0.87); }
+.mui-btn:hover, .mui-btn:focus {
+ box-shadow: 0 0px 2px rgba(0, 0, 0, 0.12), 0 2px 2px rgba(0, 0, 0, 0.2); }
+@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
+ .mui-btn:hover, .mui-btn:focus {
+ box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.12), -1px 0px 2px rgba(0, 0, 0, 0.12), 0 0px 2px rgba(0, 0, 0, 0.12), 0 2px 2px rgba(0, 0, 0, 0.2); } }
+.mui-btn:active {
+ box-shadow: 0 10px 20px rgba(0, 0, 0, 0.19), 0 6px 6px rgba(0, 0, 0, 0.23); }
+@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
+ .mui-btn:active {
+ box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.12), -1px 0px 2px rgba(0, 0, 0, 0.12), 0 10px 20px rgba(0, 0, 0, 0.19), 0 6px 6px rgba(0, 0, 0, 0.23); } }
+.mui-btn:disabled, .mui-btn.mui--is-disabled {
+ cursor: not-allowed;
+ pointer-events: none;
+ opacity: 0.60;
+ box-shadow: none; }
+
+.mui-btn + .mui-btn {
+ margin-left: 8px; }
+
+.mui-btn--flat {
+ background-color: transparent; }
+.mui-btn--flat:hover, .mui-btn--flat:focus, .mui-btn--flat:active {
+ box-shadow: none;
+ background-color: #f2f2f2; }
+
+.mui-btn--raised, .mui-btn--fab {
+ box-shadow: 0 0px 2px rgba(0, 0, 0, 0.12), 0 2px 2px rgba(0, 0, 0, 0.2); }
+@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
+ .mui-btn--raised, .mui-btn--fab {
+ box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.12), -1px 0px 2px rgba(0, 0, 0, 0.12), 0 0px 2px rgba(0, 0, 0, 0.12), 0 2px 2px rgba(0, 0, 0, 0.2); } }
+.mui-btn--raised:active, .mui-btn--fab:active {
+ box-shadow: 0 10px 20px rgba(0, 0, 0, 0.19), 0 6px 6px rgba(0, 0, 0, 0.23); }
+@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
+ .mui-btn--raised:active, .mui-btn--fab:active {
+ box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.12), -1px 0px 2px rgba(0, 0, 0, 0.12), 0 10px 20px rgba(0, 0, 0, 0.19), 0 6px 6px rgba(0, 0, 0, 0.23); } }
+
+.mui-btn--fab {
+ position: relative;
+ padding: 0;
+ width: 55px;
+ height: 55px;
+ line-height: 55px;
+ border-radius: 50%;
+ z-index: 1; }
+
+.mui-btn--primary {
+ color: #FFF;
+ background-color: #009688; }
+.mui-btn--primary:hover, .mui-btn--primary:focus, .mui-btn--primary:active {
+ color: #FFF;
+ background-color: #00b09f; }
+.mui-btn--primary[disabled]:hover, .mui-btn--primary[disabled]:focus, .mui-btn--primary[disabled]:active {
+ color: #FFF;
+ background-color: #009688; }
+.mui-btn--primary.mui-btn--flat {
+ color: #009688;
+ background-color: transparent; }
+.mui-btn--primary.mui-btn--flat:hover, .mui-btn--primary.mui-btn--flat:focus, .mui-btn--primary.mui-btn--flat:active {
+ color: #009688;
+ background-color: #f2f2f2; }
+.mui-btn--primary.mui-btn--flat[disabled]:hover, .mui-btn--primary.mui-btn--flat[disabled]:focus, .mui-btn--primary.mui-btn--flat[disabled]:active {
+ color: #009688;
+ background-color: transparent; }
+
+.mui-btn--dark {
+ color: #FFF;
+ background-color: #424242; }
+.mui-btn--dark:hover, .mui-btn--dark:focus, .mui-btn--dark:active {
+ color: #FFF;
+ background-color: #4f4f4f; }
+.mui-btn--dark[disabled]:hover, .mui-btn--dark[disabled]:focus, .mui-btn--dark[disabled]:active {
+ color: #FFF;
+ background-color: #424242; }
+.mui-btn--dark.mui-btn--flat {
+ color: #424242;
+ background-color: transparent; }
+.mui-btn--dark.mui-btn--flat:hover, .mui-btn--dark.mui-btn--flat:focus, .mui-btn--dark.mui-btn--flat:active {
+ color: #424242;
+ background-color: #f2f2f2; }
+.mui-btn--dark.mui-btn--flat[disabled]:hover, .mui-btn--dark.mui-btn--flat[disabled]:focus, .mui-btn--dark.mui-btn--flat[disabled]:active {
+ color: #424242;
+ background-color: transparent; }
+
+.mui-btn--danger {
+ color: #FFF;
+ background-color: #F44336; }
+.mui-btn--danger:hover, .mui-btn--danger:focus, .mui-btn--danger:active {
+ color: #FFF;
+ background-color: #f55a4e; }
+.mui-btn--danger[disabled]:hover, .mui-btn--danger[disabled]:focus, .mui-btn--danger[disabled]:active {
+ color: #FFF;
+ background-color: #F44336; }
+.mui-btn--danger.mui-btn--flat {
+ color: #F44336;
+ background-color: transparent; }
+.mui-btn--danger.mui-btn--flat:hover, .mui-btn--danger.mui-btn--flat:focus, .mui-btn--danger.mui-btn--flat:active {
+ color: #F44336;
+ background-color: #f2f2f2; }
+.mui-btn--danger.mui-btn--flat[disabled]:hover, .mui-btn--danger.mui-btn--flat[disabled]:focus, .mui-btn--danger.mui-btn--flat[disabled]:active {
+ color: #F44336;
+ background-color: transparent; }
+
+.mui-btn--accent {
+ color: #FFF;
+ background-color: #311B92; }
+.mui-btn--accent:hover, .mui-btn--accent:focus, .mui-btn--accent:active {
+ color: #FFF;
+ background-color: #381fa8; }
+.mui-btn--accent[disabled]:hover, .mui-btn--accent[disabled]:focus, .mui-btn--accent[disabled]:active {
+ color: #FFF;
+ background-color: #311B92; }
+.mui-btn--accent.mui-btn--flat {
+ color: #311B92;
+ background-color: transparent; }
+.mui-btn--accent.mui-btn--flat:hover, .mui-btn--accent.mui-btn--flat:focus, .mui-btn--accent.mui-btn--flat:active {
+ color: #311B92;
+ background-color: #f2f2f2; }
+.mui-btn--accent.mui-btn--flat[disabled]:hover, .mui-btn--accent.mui-btn--flat[disabled]:focus, .mui-btn--accent.mui-btn--flat[disabled]:active {
+ color: #311B92;
+ background-color: transparent; }
+
+.mui-btn--small {
+ height: 30.6px;
+ line-height: 30.6px;
+ padding: 0 16px;
+ font-size: 13px; }
+
+.mui-btn--large {
+ height: 54px;
+ line-height: 54px;
+ padding: 0 26px;
+ font-size: 14px; }
+
+.mui-btn--fab.mui-btn--small {
+ width: 44px;
+ height: 44px;
+ line-height: 44px; }
+
+.mui-btn--fab.mui-btn--large {
+ width: 75px;
+ height: 75px;
+ line-height: 75px; }
+
+/**
+ * MUI Checkboxe and Radio Components
+ */
+.mui-radio,
+.mui-checkbox {
+ position: relative;
+ display: block;
+ margin-top: 10px;
+ margin-bottom: 10px; }
+.mui-radio > label,
+.mui-checkbox > label {
+ min-height: 20px;
+ padding-left: 20px;
+ margin-bottom: 0;
+ font-weight: normal;
+ cursor: pointer; }
+
+.mui-radio > label > input[type="radio"],
+.mui-radio--inline > label > input[type="radio"],
+.mui-checkbox > label > input[type="checkbox"],
+.mui-checkbox--inline > label > input[type="checkbox"] {
+ position: absolute;
+ margin-left: -20px;
+ margin-top: 4px; }
+
+.mui-radio + .mui-radio,
+.mui-checkbox + .mui-checkbox {
+ margin-top: -5px; }
+
+.mui-radio--inline,
+.mui-checkbox--inline {
+ display: inline-block;
+ padding-left: 20px;
+ margin-bottom: 0;
+ vertical-align: middle;
+ font-weight: normal;
+ cursor: pointer; }
+.mui-radio--inline > input[type="radio"],
+.mui-radio--inline > input[type="checkbox"],
+.mui-radio--inline > label > input[type="radio"],
+.mui-radio--inline > label > input[type="checkbox"],
+.mui-checkbox--inline > input[type="radio"],
+.mui-checkbox--inline > input[type="checkbox"],
+.mui-checkbox--inline > label > input[type="radio"],
+.mui-checkbox--inline > label > input[type="checkbox"] {
+ margin: 4px 0 0;
+ line-height: normal; }
+
+.mui-radio--inline + .mui-radio--inline,
+.mui-checkbox--inline + .mui-checkbox--inline {
+ margin-top: 0;
+ margin-left: 10px; }
+
+/**
+ * MUI Container module
+ */
+.mui-container {
+ margin-right: auto;
+ margin-left: auto;
+ padding-left: 15px;
+ padding-right: 15px; }
+.mui-container:before, .mui-container:after {
+ content: " ";
+ display: table; }
+.mui-container:after {
+ clear: both; }
+@media (min-width: 544px) {
+ .mui-container {
+ max-width: 570px; } }
+@media (min-width: 768px) {
+ .mui-container {
+ max-width: 740px; } }
+@media (min-width: 992px) {
+ .mui-container {
+ max-width: 960px; } }
+@media (min-width: 1200px) {
+ .mui-container {
+ max-width: 1170px; } }
+
+.mui-container-fluid {
+ margin-right: auto;
+ margin-left: auto;
+ padding-left: 15px;
+ padding-right: 15px; }
+.mui-container-fluid:before, .mui-container-fluid:after {
+ content: " ";
+ display: table; }
+.mui-container-fluid:after {
+ clear: both; }
+
+/**
+ * MUI Divider Component and CSS Helpers
+ */
+.mui-divider {
+ display: block;
+ height: 1px;
+ background-color: rgba(0, 0, 0, 0.12); }
+
+.mui--divider-top {
+ border-top: 1px solid rgba(0, 0, 0, 0.12); }
+
+.mui--divider-bottom {
+ border-bottom: 1px solid rgba(0, 0, 0, 0.12); }
+
+.mui--divider-left {
+ border-left: 1px solid rgba(0, 0, 0, 0.12); }
+
+.mui--divider-right {
+ border-right: 1px solid rgba(0, 0, 0, 0.12); }
+
+/**
+ * MUI Dropdown module
+ */
+.mui-dropdown {
+ display: inline-block;
+ position: relative; }
+
+[data-mui-toggle="dropdown"] {
+ animation-duration: 0.0001s;
+ animation-name: mui-node-inserted;
+ outline: 0; }
+
+.mui-dropdown__menu {
+ position: absolute;
+ top: 100%;
+ left: 0;
+ display: none;
+ min-width: 160px;
+ padding: 5px 0;
+ margin: 2px 0 0;
+ list-style: none;
+ font-size: 14px;
+ text-align: left;
+ background-color: #FFF;
+ border-radius: 2px;
+ z-index: 1;
+ background-clip: padding-box; }
+.mui-dropdown__menu.mui--is-open {
+ display: block; }
+.mui-dropdown__menu > li > a {
+ display: block;
+ padding: 3px 20px;
+ clear: both;
+ font-weight: normal;
+ line-height: 1.429;
+ color: rgba(0, 0, 0, 0.87);
+ white-space: nowrap; }
+.mui-dropdown__menu > li > a:hover, .mui-dropdown__menu > li > a:focus {
+ text-decoration: none;
+ color: rgba(0, 0, 0, 0.87);
+ background-color: #EEEEEE; }
+.mui-dropdown__menu > .mui--is-disabled > a, .mui-dropdown__menu > .mui--is-disabled > a:hover, .mui-dropdown__menu > .mui--is-disabled > a:focus {
+ color: #EEEEEE; }
+.mui-dropdown__menu > .mui--is-disabled > a:hover, .mui-dropdown__menu > .mui--is-disabled > a:focus {
+ text-decoration: none;
+ background-color: transparent;
+ background-image: none;
+ cursor: not-allowed; }
+
+.mui-dropdown__menu--right {
+ left: auto;
+ right: 0; }
+
+/**
+ * MUI Form Component
+ */
+@media (min-width: 544px) {
+ .mui-form--inline > .mui-textfield {
+ display: inline-block;
+ margin-bottom: 0; }
+ .mui-form--inline > .mui-radio,
+ .mui-form--inline > .mui-checkbox {
+ display: inline-block;
+ margin-top: 0;
+ margin-bottom: 0;
+ vertical-align: middle; }
+ .mui-form--inline > .mui-radio > label,
+ .mui-form--inline > .mui-checkbox > label {
+ padding-left: 0; }
+ .mui-form--inline > .mui-radio > label > input[type="radio"],
+ .mui-form--inline > .mui-checkbox > label > input[type="checkbox"] {
+ position: relative;
+ margin-left: 0; }
+ .mui-form--inline > .mui-select {
+ display: inline-block; }
+ .mui-form--inline > .mui-btn {
+ margin-bottom: 0;
+ margin-top: 0;
+ vertical-align: bottom; } }
+
+/**
+ * MUI Grid module
+ */
+.mui-row {
+ margin-left: -15px;
+ margin-right: -15px; }
+.mui-row:before, .mui-row:after {
+ content: " ";
+ display: table; }
+.mui-row:after {
+ clear: both; }
+
+.mui-col-xs-1, .mui-col-sm-1, .mui-col-md-1, .mui-col-lg-1, .mui-col-xs-2, .mui-col-sm-2, .mui-col-md-2, .mui-col-lg-2, .mui-col-xs-3, .mui-col-sm-3, .mui-col-md-3, .mui-col-lg-3, .mui-col-xs-4, .mui-col-sm-4, .mui-col-md-4, .mui-col-lg-4, .mui-col-xs-5, .mui-col-sm-5, .mui-col-md-5, .mui-col-lg-5, .mui-col-xs-6, .mui-col-sm-6, .mui-col-md-6, .mui-col-lg-6, .mui-col-xs-7, .mui-col-sm-7, .mui-col-md-7, .mui-col-lg-7, .mui-col-xs-8, .mui-col-sm-8, .mui-col-md-8, .mui-col-lg-8, .mui-col-xs-9, .mui-col-sm-9, .mui-col-md-9, .mui-col-lg-9, .mui-col-xs-10, .mui-col-sm-10, .mui-col-md-10, .mui-col-lg-10, .mui-col-xs-11, .mui-col-sm-11, .mui-col-md-11, .mui-col-lg-11, .mui-col-xs-12, .mui-col-sm-12, .mui-col-md-12, .mui-col-lg-12 {
+ min-height: 1px;
+ padding-left: 15px;
+ padding-right: 15px; }
+
+.mui-col-xs-1, .mui-col-xs-2, .mui-col-xs-3, .mui-col-xs-4, .mui-col-xs-5, .mui-col-xs-6, .mui-col-xs-7, .mui-col-xs-8, .mui-col-xs-9, .mui-col-xs-10, .mui-col-xs-11, .mui-col-xs-12 {
+ float: left; }
+
+.mui-col-xs-1 {
+ width: 8.33333%; }
+
+.mui-col-xs-2 {
+ width: 16.66667%; }
+
+.mui-col-xs-3 {
+ width: 25%; }
+
+.mui-col-xs-4 {
+ width: 33.33333%; }
+
+.mui-col-xs-5 {
+ width: 41.66667%; }
+
+.mui-col-xs-6 {
+ width: 50%; }
+
+.mui-col-xs-7 {
+ width: 58.33333%; }
+
+.mui-col-xs-8 {
+ width: 66.66667%; }
+
+.mui-col-xs-9 {
+ width: 75%; }
+
+.mui-col-xs-10 {
+ width: 83.33333%; }
+
+.mui-col-xs-11 {
+ width: 91.66667%; }
+
+.mui-col-xs-12 {
+ width: 100%; }
+
+.mui-col-xs-offset-0 {
+ margin-left: 0%; }
+
+.mui-col-xs-offset-1 {
+ margin-left: 8.33333%; }
+
+.mui-col-xs-offset-2 {
+ margin-left: 16.66667%; }
+
+.mui-col-xs-offset-3 {
+ margin-left: 25%; }
+
+.mui-col-xs-offset-4 {
+ margin-left: 33.33333%; }
+
+.mui-col-xs-offset-5 {
+ margin-left: 41.66667%; }
+
+.mui-col-xs-offset-6 {
+ margin-left: 50%; }
+
+.mui-col-xs-offset-7 {
+ margin-left: 58.33333%; }
+
+.mui-col-xs-offset-8 {
+ margin-left: 66.66667%; }
+
+.mui-col-xs-offset-9 {
+ margin-left: 75%; }
+
+.mui-col-xs-offset-10 {
+ margin-left: 83.33333%; }
+
+.mui-col-xs-offset-11 {
+ margin-left: 91.66667%; }
+
+.mui-col-xs-offset-12 {
+ margin-left: 100%; }
+
+@media (min-width: 544px) {
+ .mui-col-sm-1, .mui-col-sm-2, .mui-col-sm-3, .mui-col-sm-4, .mui-col-sm-5, .mui-col-sm-6, .mui-col-sm-7, .mui-col-sm-8, .mui-col-sm-9, .mui-col-sm-10, .mui-col-sm-11, .mui-col-sm-12 {
+ float: left; }
+ .mui-col-sm-1 {
+ width: 8.33333%; }
+ .mui-col-sm-2 {
+ width: 16.66667%; }
+ .mui-col-sm-3 {
+ width: 25%; }
+ .mui-col-sm-4 {
+ width: 33.33333%; }
+ .mui-col-sm-5 {
+ width: 41.66667%; }
+ .mui-col-sm-6 {
+ width: 50%; }
+ .mui-col-sm-7 {
+ width: 58.33333%; }
+ .mui-col-sm-8 {
+ width: 66.66667%; }
+ .mui-col-sm-9 {
+ width: 75%; }
+ .mui-col-sm-10 {
+ width: 83.33333%; }
+ .mui-col-sm-11 {
+ width: 91.66667%; }
+ .mui-col-sm-12 {
+ width: 100%; }
+ .mui-col-sm-offset-0 {
+ margin-left: 0%; }
+ .mui-col-sm-offset-1 {
+ margin-left: 8.33333%; }
+ .mui-col-sm-offset-2 {
+ margin-left: 16.66667%; }
+ .mui-col-sm-offset-3 {
+ margin-left: 25%; }
+ .mui-col-sm-offset-4 {
+ margin-left: 33.33333%; }
+ .mui-col-sm-offset-5 {
+ margin-left: 41.66667%; }
+ .mui-col-sm-offset-6 {
+ margin-left: 50%; }
+ .mui-col-sm-offset-7 {
+ margin-left: 58.33333%; }
+ .mui-col-sm-offset-8 {
+ margin-left: 66.66667%; }
+ .mui-col-sm-offset-9 {
+ margin-left: 75%; }
+ .mui-col-sm-offset-10 {
+ margin-left: 83.33333%; }
+ .mui-col-sm-offset-11 {
+ margin-left: 91.66667%; }
+ .mui-col-sm-offset-12 {
+ margin-left: 100%; } }
+
+@media (min-width: 768px) {
+ .mui-col-md-1, .mui-col-md-2, .mui-col-md-3, .mui-col-md-4, .mui-col-md-5, .mui-col-md-6, .mui-col-md-7, .mui-col-md-8, .mui-col-md-9, .mui-col-md-10, .mui-col-md-11, .mui-col-md-12 {
+ float: left; }
+ .mui-col-md-1 {
+ width: 8.33333%; }
+ .mui-col-md-2 {
+ width: 16.66667%; }
+ .mui-col-md-3 {
+ width: 25%; }
+ .mui-col-md-4 {
+ width: 33.33333%; }
+ .mui-col-md-5 {
+ width: 41.66667%; }
+ .mui-col-md-6 {
+ width: 50%; }
+ .mui-col-md-7 {
+ width: 58.33333%; }
+ .mui-col-md-8 {
+ width: 66.66667%; }
+ .mui-col-md-9 {
+ width: 75%; }
+ .mui-col-md-10 {
+ width: 83.33333%; }
+ .mui-col-md-11 {
+ width: 91.66667%; }
+ .mui-col-md-12 {
+ width: 100%; }
+ .mui-col-md-offset-0 {
+ margin-left: 0%; }
+ .mui-col-md-offset-1 {
+ margin-left: 8.33333%; }
+ .mui-col-md-offset-2 {
+ margin-left: 16.66667%; }
+ .mui-col-md-offset-3 {
+ margin-left: 25%; }
+ .mui-col-md-offset-4 {
+ margin-left: 33.33333%; }
+ .mui-col-md-offset-5 {
+ margin-left: 41.66667%; }
+ .mui-col-md-offset-6 {
+ margin-left: 50%; }
+ .mui-col-md-offset-7 {
+ margin-left: 58.33333%; }
+ .mui-col-md-offset-8 {
+ margin-left: 66.66667%; }
+ .mui-col-md-offset-9 {
+ margin-left: 75%; }
+ .mui-col-md-offset-10 {
+ margin-left: 83.33333%; }
+ .mui-col-md-offset-11 {
+ margin-left: 91.66667%; }
+ .mui-col-md-offset-12 {
+ margin-left: 100%; } }
+
+@media (min-width: 992px) {
+ .mui-col-lg-1, .mui-col-lg-2, .mui-col-lg-3, .mui-col-lg-4, .mui-col-lg-5, .mui-col-lg-6, .mui-col-lg-7, .mui-col-lg-8, .mui-col-lg-9, .mui-col-lg-10, .mui-col-lg-11, .mui-col-lg-12 {
+ float: left; }
+ .mui-col-lg-1 {
+ width: 8.33333%; }
+ .mui-col-lg-2 {
+ width: 16.66667%; }
+ .mui-col-lg-3 {
+ width: 25%; }
+ .mui-col-lg-4 {
+ width: 33.33333%; }
+ .mui-col-lg-5 {
+ width: 41.66667%; }
+ .mui-col-lg-6 {
+ width: 50%; }
+ .mui-col-lg-7 {
+ width: 58.33333%; }
+ .mui-col-lg-8 {
+ width: 66.66667%; }
+ .mui-col-lg-9 {
+ width: 75%; }
+ .mui-col-lg-10 {
+ width: 83.33333%; }
+ .mui-col-lg-11 {
+ width: 91.66667%; }
+ .mui-col-lg-12 {
+ width: 100%; }
+ .mui-col-lg-offset-0 {
+ margin-left: 0%; }
+ .mui-col-lg-offset-1 {
+ margin-left: 8.33333%; }
+ .mui-col-lg-offset-2 {
+ margin-left: 16.66667%; }
+ .mui-col-lg-offset-3 {
+ margin-left: 25%; }
+ .mui-col-lg-offset-4 {
+ margin-left: 33.33333%; }
+ .mui-col-lg-offset-5 {
+ margin-left: 41.66667%; }
+ .mui-col-lg-offset-6 {
+ margin-left: 50%; }
+ .mui-col-lg-offset-7 {
+ margin-left: 58.33333%; }
+ .mui-col-lg-offset-8 {
+ margin-left: 66.66667%; }
+ .mui-col-lg-offset-9 {
+ margin-left: 75%; }
+ .mui-col-lg-offset-10 {
+ margin-left: 83.33333%; }
+ .mui-col-lg-offset-11 {
+ margin-left: 91.66667%; }
+ .mui-col-lg-offset-12 {
+ margin-left: 100%; } }
+
+@media (min-width: 1200px) {
+ .mui-col-xl-1, .mui-col-xl-2, .mui-col-xl-3, .mui-col-xl-4, .mui-col-xl-5, .mui-col-xl-6, .mui-col-xl-7, .mui-col-xl-8, .mui-col-xl-9, .mui-col-xl-10, .mui-col-xl-11, .mui-col-xl-12 {
+ float: left; }
+ .mui-col-xl-1 {
+ width: 8.33333%; }
+ .mui-col-xl-2 {
+ width: 16.66667%; }
+ .mui-col-xl-3 {
+ width: 25%; }
+ .mui-col-xl-4 {
+ width: 33.33333%; }
+ .mui-col-xl-5 {
+ width: 41.66667%; }
+ .mui-col-xl-6 {
+ width: 50%; }
+ .mui-col-xl-7 {
+ width: 58.33333%; }
+ .mui-col-xl-8 {
+ width: 66.66667%; }
+ .mui-col-xl-9 {
+ width: 75%; }
+ .mui-col-xl-10 {
+ width: 83.33333%; }
+ .mui-col-xl-11 {
+ width: 91.66667%; }
+ .mui-col-xl-12 {
+ width: 100%; }
+ .mui-col-xl-offset-0 {
+ margin-left: 0%; }
+ .mui-col-xl-offset-1 {
+ margin-left: 8.33333%; }
+ .mui-col-xl-offset-2 {
+ margin-left: 16.66667%; }
+ .mui-col-xl-offset-3 {
+ margin-left: 25%; }
+ .mui-col-xl-offset-4 {
+ margin-left: 33.33333%; }
+ .mui-col-xl-offset-5 {
+ margin-left: 41.66667%; }
+ .mui-col-xl-offset-6 {
+ margin-left: 50%; }
+ .mui-col-xl-offset-7 {
+ margin-left: 58.33333%; }
+ .mui-col-xl-offset-8 {
+ margin-left: 66.66667%; }
+ .mui-col-xl-offset-9 {
+ margin-left: 75%; }
+ .mui-col-xl-offset-10 {
+ margin-left: 83.33333%; }
+ .mui-col-xl-offset-11 {
+ margin-left: 91.66667%; }
+ .mui-col-xl-offset-12 {
+ margin-left: 100%; } }
+
+/**
+ * MUI Panel module
+ */
+.mui-panel {
+ padding: 15px;
+ margin-bottom: 20px;
+ border-radius: 0;
+ background-color: #FFF;
+ box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.16), 0 0px 2px 0 rgba(0, 0, 0, 0.12); }
+.mui-panel:before, .mui-panel:after {
+ content: " ";
+ display: table; }
+.mui-panel:after {
+ clear: both; }
+@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
+ .mui-panel {
+ box-shadow: 0 -1px 2px 0 rgba(0, 0, 0, 0.12), -1px 0px 2px 0 rgba(0, 0, 0, 0.12), 0 2px 2px 0 rgba(0, 0, 0, 0.16), 0 0px 2px 0 rgba(0, 0, 0, 0.12); } }
+
+/**
+ * MUI Select Component
+ */
+.mui-select {
+ display: block;
+ padding-top: 15px;
+ margin-bottom: 20px;
+ position: relative; }
+.mui-select:focus {
+ outline: 0; }
+.mui-select:focus > select {
+ height: 33px;
+ margin-bottom: -1px;
+ border-color: #009688;
+ border-width: 2px; }
+.mui-select > select {
+ animation-duration: 0.0001s;
+ animation-name: mui-node-inserted;
+ display: block;
+ height: 32px;
+ width: 100%;
+ appearance: none;
+ -webkit-appearance: none;
+ -moz-appearance: none;
+ outline: none;
+ border: none;
+ border-bottom: 1px solid rgba(0, 0, 0, 0.26);
+ border-radius: 0px;
+ box-shadow: none;
+ background-color: transparent;
+ background-image: url("");
+ background-repeat: no-repeat;
+ background-position: right center;
+ cursor: pointer;
+ color: rgba(0, 0, 0, 0.87);
+ font-size: 16px;
+ padding: 0 25px 0 0; }
+.mui-select > select::-ms-expand {
+ display: none; }
+.mui-select > select:focus {
+ outline: 0;
+ height: 33px;
+ margin-bottom: -1px;
+ border-color: #009688;
+ border-width: 2px; }
+.mui-select > select:disabled {
+ color: rgba(0, 0, 0, 0.38);
+ cursor: not-allowed;
+ background-color: transparent;
+ opacity: 1; }
+
+.mui-select__menu {
+ position: absolute;
+ z-index: 1;
+ min-width: 100%;
+ overflow-y: auto;
+ padding: 8px 0;
+ background-color: #FFF;
+ font-size: 16px; }
+@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
+ .mui-select__menu {
+ border-left: 1px solid rgba(0, 0, 0, 0.12);
+ border-top: 1px solid rgba(0, 0, 0, 0.12); } }
+.mui-select__menu > div {
+ padding: 0 22px;
+ height: 42px;
+ line-height: 42px;
+ cursor: pointer;
+ white-space: nowrap; }
+.mui-select__menu > div:hover {
+ background-color: #E0E0E0; }
+.mui-select__menu > div.mui--is-selected {
+ background-color: #EEEEEE; }
+
+/**
+ * MUI Table Component
+ */
+th {
+ text-align: left; }
+
+.mui-table {
+ width: 100%;
+ max-width: 100%;
+ margin-bottom: 20px; }
+.mui-table > thead > tr > th,
+.mui-table > thead > tr > td,
+.mui-table > tbody > tr > th,
+.mui-table > tbody > tr > td,
+.mui-table > tfoot > tr > th,
+.mui-table > tfoot > tr > td {
+ padding: 10px;
+ line-height: 1.429; }
+.mui-table > thead > tr > th {
+ border-bottom: 2px solid rgba(0, 0, 0, 0.12);
+ font-weight: 700; }
+.mui-table > tbody + tbody {
+ border-top: 2px solid rgba(0, 0, 0, 0.12); }
+.mui-table.mui-table--bordered > tbody > tr > td {
+ border-bottom: 1px solid rgba(0, 0, 0, 0.12); }
+
+/**
+ * MUI Tabs module
+ */
+.mui-tabs__bar {
+ list-style: none;
+ padding-left: 0;
+ margin-bottom: 0;
+ background-color: transparent;
+ white-space: nowrap;
+ overflow-x: auto; }
+.mui-tabs__bar > li {
+ display: inline-block; }
+.mui-tabs__bar > li > a {
+ display: block;
+ white-space: nowrap;
+ text-transform: uppercase;
+ font-weight: 500;
+ font-size: 14px;
+ color: rgba(0, 0, 0, 0.87);
+ cursor: default;
+ height: 48px;
+ line-height: 48px;
+ padding-left: 24px;
+ padding-right: 24px;
+ user-select: none; }
+.mui-tabs__bar > li > a:hover {
+ text-decoration: none; }
+.mui-tabs__bar > li.mui--is-active {
+ border-bottom: 2px solid #009688; }
+.mui-tabs__bar > li.mui--is-active > a {
+ color: #009688; }
+.mui-tabs__bar.mui-tabs__bar--justified {
+ display: table;
+ width: 100%;
+ table-layout: fixed; }
+.mui-tabs__bar.mui-tabs__bar--justified > li {
+ display: table-cell; }
+.mui-tabs__bar.mui-tabs__bar--justified > li > a {
+ text-align: center;
+ padding-left: 0px;
+ padding-right: 0px; }
+
+.mui-tabs__pane {
+ display: none; }
+.mui-tabs__pane.mui--is-active {
+ display: block; }
+
+[data-mui-toggle="tab"] {
+ animation-duration: 0.0001s;
+ animation-name: mui-node-inserted; }
+
+/**
+ * MUI Textfield Component
+ */
+.mui-textfield {
+ display: block;
+ padding-top: 15px;
+ margin-bottom: 20px;
+ position: relative; }
+.mui-textfield > label {
+ position: absolute;
+ top: 0;
+ display: block;
+ width: 100%;
+ color: rgba(0, 0, 0, 0.54);
+ font-size: 12px;
+ font-weight: 400;
+ line-height: 15px;
+ overflow-x: hidden;
+ text-overflow: ellipsis;
+ white-space: nowrap; }
+.mui-textfield > textarea {
+ padding-top: 5px; }
+.mui-textfield > input,
+.mui-textfield > textarea {
+ display: block; }
+.mui-textfield > input:focus ~ label,
+.mui-textfield > textarea:focus ~ label {
+ color: #009688; }
+
+.mui-textfield--float-label > label {
+ position: absolute;
+ transform: translate(0px, 15px);
+ font-size: 16px;
+ line-height: 32px;
+ color: rgba(0, 0, 0, 0.26);
+ text-overflow: clip;
+ cursor: text;
+ pointer-events: none; }
+
+.mui-textfield--float-label > input:focus ~ label,
+.mui-textfield--float-label > textarea:focus ~ label {
+ transform: translate(0px, 0px);
+ font-size: 12px;
+ line-height: 15px;
+ text-overflow: ellipsis; }
+
+.mui-textfield--float-label > input:not(:focus).mui--is-not-empty ~ label, .mui-textfield--float-label > input:not(:focus)[value]:not([value=""]):not(.mui--is-empty):not(.mui--is-not-empty) ~ label, .mui-textfield--float-label > input:not(:focus):not(:empty):not(.mui--is-empty):not(.mui--is-not-empty) ~ label,
+.mui-textfield--float-label > textarea:not(:focus).mui--is-not-empty ~ label,
+.mui-textfield--float-label > textarea:not(:focus)[value]:not([value=""]):not(.mui--is-empty):not(.mui--is-not-empty) ~ label,
+.mui-textfield--float-label > textarea:not(:focus):not(:empty):not(.mui--is-empty):not(.mui--is-not-empty) ~ label {
+ color: rgba(0, 0, 0, 0.54);
+ font-size: 12px;
+ line-height: 15px;
+ transform: translate(0px, 0px);
+ text-overflow: ellipsis; }
+
+.mui-textfield--wrap-label {
+ display: table;
+ width: 100%;
+ padding-top: 0px; }
+.mui-textfield--wrap-label:not(.mui-textfield--float-label) > label {
+ display: table-header-group;
+ position: static;
+ white-space: normal;
+ overflow-x: visible; }
+
+.mui-textfield > input,
+.mui-textfield > textarea {
+ animation-duration: 0.0001s;
+ animation-name: mui-node-inserted;
+ display: block;
+ background-color: transparent;
+ color: rgba(0, 0, 0, 0.87);
+ border: none;
+ border-bottom: 1px solid rgba(0, 0, 0, 0.26);
+ outline: none;
+ width: 100%;
+ font-size: 16px;
+ padding: 0;
+ box-shadow: none;
+ border-radius: 0px;
+ background-image: none; }
+.mui-textfield > input:focus,
+.mui-textfield > textarea:focus {
+ border-color: #009688;
+ border-width: 2px; }
+.mui-textfield > input:disabled, .mui-textfield > input:read-only,
+.mui-textfield > textarea:disabled,
+.mui-textfield > textarea:read-only {
+ cursor: not-allowed;
+ background-color: transparent;
+ opacity: 1; }
+.mui-textfield > input::placeholder,
+.mui-textfield > textarea::placeholder {
+ color: rgba(0, 0, 0, 0.26);
+ opacity: 1; }
+
+.mui-textfield > input {
+ height: 32px; }
+.mui-textfield > input:focus {
+ height: 33px;
+ margin-bottom: -1px; }
+
+.mui-textfield > textarea {
+ min-height: 64px; }
+.mui-textfield > textarea[rows]:not([rows="2"]):focus {
+ margin-bottom: -1px; }
+
+.mui-textfield > input:focus {
+ height: 33px;
+ margin-bottom: -1px; }
+
+.mui-textfield > input:invalid:not(:focus):not(:required), .mui-textfield > input:invalid:not(:focus):required.mui--is-not-empty, .mui-textfield > input:invalid:not(:focus):required.mui--is-empty.mui--is-dirty, .mui-textfield > input:invalid:not(:focus):required[value]:not([value=""]):not(.mui--is-empty):not(.mui--is-not-empty), .mui-textfield > input:invalid:not(:focus):required:not(:empty):not(.mui--is-empty):not(.mui--is-not-empty),
+.mui-textfield > textarea:invalid:not(:focus):not(:required),
+.mui-textfield > textarea:invalid:not(:focus):required.mui--is-not-empty,
+.mui-textfield > textarea:invalid:not(:focus):required.mui--is-empty.mui--is-dirty,
+.mui-textfield > textarea:invalid:not(:focus):required[value]:not([value=""]):not(.mui--is-empty):not(.mui--is-not-empty),
+.mui-textfield > textarea:invalid:not(:focus):required:not(:empty):not(.mui--is-empty):not(.mui--is-not-empty),
+.mui-textfield > input:not(:focus).mui--is-invalid:not(:required),
+.mui-textfield > input:not(:focus).mui--is-invalid:required.mui--is-not-empty,
+.mui-textfield > input:not(:focus).mui--is-invalid:required.mui--is-empty.mui--is-dirty,
+.mui-textfield > input:not(:focus).mui--is-invalid:required[value]:not([value=""]):not(.mui--is-empty):not(.mui--is-not-empty),
+.mui-textfield > input:not(:focus).mui--is-invalid:required:not(:empty):not(.mui--is-empty):not(.mui--is-not-empty),
+.mui-textfield > textarea:not(:focus).mui--is-invalid:not(:required),
+.mui-textfield > textarea:not(:focus).mui--is-invalid:required.mui--is-not-empty,
+.mui-textfield > textarea:not(:focus).mui--is-invalid:required.mui--is-empty.mui--is-dirty,
+.mui-textfield > textarea:not(:focus).mui--is-invalid:required[value]:not([value=""]):not(.mui--is-empty):not(.mui--is-not-empty),
+.mui-textfield > textarea:not(:focus).mui--is-invalid:required:not(:empty):not(.mui--is-empty):not(.mui--is-not-empty) {
+ border-color: #F44336;
+ border-width: 2px; }
+
+.mui-textfield > input:invalid:not(:focus):not(:required), .mui-textfield > input:invalid:not(:focus):required.mui--is-not-empty, .mui-textfield > input:invalid:not(:focus):required.mui--is-empty.mui--is-dirty, .mui-textfield > input:invalid:not(:focus):required[value]:not([value=""]):not(.mui--is-empty):not(.mui--is-not-empty), .mui-textfield > input:invalid:not(:focus):required:not(:empty):not(.mui--is-empty):not(.mui--is-not-empty),
+.mui-textfield > input:not(:focus).mui--is-invalid:not(:required),
+.mui-textfield > input:not(:focus).mui--is-invalid:required.mui--is-not-empty,
+.mui-textfield > input:not(:focus).mui--is-invalid:required.mui--is-empty.mui--is-dirty,
+.mui-textfield > input:not(:focus).mui--is-invalid:required[value]:not([value=""]):not(.mui--is-empty):not(.mui--is-not-empty),
+.mui-textfield > input:not(:focus).mui--is-invalid:required:not(:empty):not(.mui--is-empty):not(.mui--is-not-empty) {
+ height: 33px;
+ margin-bottom: -1px; }
+
+.mui-textfield > input:invalid:not(:focus):not(:required) ~ label, .mui-textfield > input:invalid:not(:focus):required.mui--is-not-empty ~ label, .mui-textfield > input:invalid:not(:focus):required[value]:not([value=""]):not(.mui--is-empty):not(.mui--is-not-empty) ~ label, .mui-textfield > input:invalid:not(:focus):required:not(:empty):not(.mui--is-empty):not(.mui--is-not-empty) ~ label,
+.mui-textfield > textarea:invalid:not(:focus):not(:required) ~ label,
+.mui-textfield > textarea:invalid:not(:focus):required.mui--is-not-empty ~ label,
+.mui-textfield > textarea:invalid:not(:focus):required[value]:not([value=""]):not(.mui--is-empty):not(.mui--is-not-empty) ~ label,
+.mui-textfield > textarea:invalid:not(:focus):required:not(:empty):not(.mui--is-empty):not(.mui--is-not-empty) ~ label,
+.mui-textfield > input:not(:focus).mui--is-invalid:not(:required) ~ label,
+.mui-textfield > input:not(:focus).mui--is-invalid:required.mui--is-not-empty ~ label,
+.mui-textfield > input:not(:focus).mui--is-invalid:required[value]:not([value=""]):not(.mui--is-empty):not(.mui--is-not-empty) ~ label,
+.mui-textfield > input:not(:focus).mui--is-invalid:required:not(:empty):not(.mui--is-empty):not(.mui--is-not-empty) ~ label,
+.mui-textfield > textarea:not(:focus).mui--is-invalid:not(:required) ~ label,
+.mui-textfield > textarea:not(:focus).mui--is-invalid:required.mui--is-not-empty ~ label,
+.mui-textfield > textarea:not(:focus).mui--is-invalid:required[value]:not([value=""]):not(.mui--is-empty):not(.mui--is-not-empty) ~ label,
+.mui-textfield > textarea:not(:focus).mui--is-invalid:required:not(:empty):not(.mui--is-empty):not(.mui--is-not-empty) ~ label {
+ color: #F44336; }
+
+.mui-textfield:not(.mui-textfield--float-label) > input:invalid:not(:focus):required.mui--is-empty.mui--is-dirty ~ label,
+.mui-textfield:not(.mui-textfield--float-label) > textarea:invalid:not(:focus):required.mui--is-empty.mui--is-dirty ~ label,
+.mui-textfield:not(.mui-textfield--float-label) > input:not(:focus).mui--is-invalid:required.mui--is-empty.mui--is-dirty ~ label,
+.mui-textfield:not(.mui-textfield--float-label) > textarea:not(:focus).mui--is-invalid:required.mui--is-empty.mui--is-dirty ~ label {
+ color: #F44336; }
+
+/**
+ * MUI Helpers module
+ */
+@keyframes mui-node-inserted {
+ from {
+ opacity: 0.99; }
+ to {
+ opacity: 1; } }
+
+.mui--no-transition {
+ transition: none !important; }
+
+.mui--no-user-select {
+ user-select: none; }
+
+.mui-caret {
+ display: inline-block;
+ width: 0;
+ height: 0;
+ margin-left: 2px;
+ vertical-align: middle;
+ border-top: 4px solid;
+ border-right: 4px solid transparent;
+ border-left: 4px solid transparent; }
+
+.mui--text-left {
+ text-align: left !important; }
+
+.mui--text-right {
+ text-align: right !important; }
+
+.mui--text-center {
+ text-align: center !important; }
+
+.mui--text-justify {
+ text-align: justify !important; }
+
+.mui--text-nowrap {
+ white-space: nowrap !important; }
+
+.mui--align-baseline {
+ vertical-align: baseline !important; }
+
+.mui--align-top {
+ vertical-align: top !important; }
+
+.mui--align-middle {
+ vertical-align: middle !important; }
+
+.mui--align-bottom {
+ vertical-align: bottom !important; }
+
+.mui--text-dark {
+ color: rgba(0, 0, 0, 0.87); }
+
+.mui--text-dark-secondary {
+ color: rgba(0, 0, 0, 0.54); }
+
+.mui--text-dark-hint {
+ color: rgba(0, 0, 0, 0.38); }
+
+.mui--text-light {
+ color: #FFF; }
+
+.mui--text-light-secondary {
+ color: rgba(255, 255, 255, 0.7); }
+
+.mui--text-light-hint {
+ color: rgba(255, 255, 255, 0.3); }
+
+.mui--text-accent {
+ color: rgba(49, 27, 146, 0.87); }
+
+.mui--text-accent-secondary {
+ color: rgba(49, 27, 146, 0.54); }
+
+.mui--text-accent-hint {
+ color: rgba(49, 27, 146, 0.38); }
+
+.mui--text-black {
+ color: #000; }
+
+.mui--text-white {
+ color: #FFF; }
+
+.mui--text-danger {
+ color: #F44336; }
+
+.mui-list--unstyled {
+ padding-left: 0;
+ list-style: none; }
+
+.mui-list--inline {
+ padding-left: 0;
+ list-style: none;
+ margin-left: -5px; }
+.mui-list--inline > li {
+ display: inline-block;
+ padding-left: 5px;
+ padding-right: 5px; }
+
+.mui--z1, .mui-dropdown__menu, .mui-select__menu {
+ box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24); }
+
+.mui--z2 {
+ box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16), 0 3px 6px rgba(0, 0, 0, 0.23); }
+
+.mui--z3 {
+ box-shadow: 0 10px 20px rgba(0, 0, 0, 0.19), 0 6px 6px rgba(0, 0, 0, 0.23); }
+
+.mui--z4 {
+ box-shadow: 0 14px 28px rgba(0, 0, 0, 0.25), 0 10px 10px rgba(0, 0, 0, 0.22); }
+
+.mui--z5 {
+ box-shadow: 0 19px 38px rgba(0, 0, 0, 0.3), 0 15px 12px rgba(0, 0, 0, 0.22); }
+
+.mui--clearfix:before, .mui--clearfix:after {
+ content: " ";
+ display: table; }
+
+.mui--clearfix:after {
+ clear: both; }
+
+.mui--pull-right {
+ float: right !important; }
+
+.mui--pull-left {
+ float: left !important; }
+
+.mui--hide {
+ display: none !important; }
+
+.mui--show {
+ display: block !important; }
+
+.mui--invisible {
+ visibility: hidden; }
+
+.mui--overflow-hidden {
+ overflow: hidden !important; }
+
+.mui--overflow-hidden-x {
+ overflow-x: hidden !important; }
+
+.mui--overflow-hidden-y {
+ overflow-y: hidden !important; }
+
+.mui--visible-xs-block,
+.mui--visible-xs-inline,
+.mui--visible-xs-inline-block,
+.mui--visible-sm-block,
+.mui--visible-sm-inline,
+.mui--visible-sm-inline-block,
+.mui--visible-md-block,
+.mui--visible-md-inline,
+.mui--visible-md-inline-block,
+.mui--visible-lg-block,
+.mui--visible-lg-inline,
+.mui--visible-lg-inline-block,
+.mui--visible-xl-block,
+.mui--visible-xl-inline,
+.mui--visible-xl-inline-block {
+ display: none !important; }
+
+@media (max-width: 543px) {
+ .mui-visible-xs {
+ display: block !important; }
+ table.mui-visible-xs {
+ display: table; }
+ tr.mui-visible-xs {
+ display: table-row !important; }
+ th.mui-visible-xs,
+ td.mui-visible-xs {
+ display: table-cell !important; }
+ .mui--visible-xs-block {
+ display: block !important; }
+ .mui--visible-xs-inline {
+ display: inline !important; }
+ .mui--visible-xs-inline-block {
+ display: inline-block !important; } }
+
+@media (min-width: 544px) and (max-width: 767px) {
+ .mui-visible-sm {
+ display: block !important; }
+ table.mui-visible-sm {
+ display: table; }
+ tr.mui-visible-sm {
+ display: table-row !important; }
+ th.mui-visible-sm,
+ td.mui-visible-sm {
+ display: table-cell !important; }
+ .mui--visible-sm-block {
+ display: block !important; }
+ .mui--visible-sm-inline {
+ display: inline !important; }
+ .mui--visible-sm-inline-block {
+ display: inline-block !important; } }
+
+@media (min-width: 768px) and (max-width: 991px) {
+ .mui-visible-md {
+ display: block !important; }
+ table.mui-visible-md {
+ display: table; }
+ tr.mui-visible-md {
+ display: table-row !important; }
+ th.mui-visible-md,
+ td.mui-visible-md {
+ display: table-cell !important; }
+ .mui--visible-md-block {
+ display: block !important; }
+ .mui--visible-md-inline {
+ display: inline !important; }
+ .mui--visible-md-inline-block {
+ display: inline-block !important; } }
+
+@media (min-width: 992px) and (max-width: 1199px) {
+ .mui-visible-lg {
+ display: block !important; }
+ table.mui-visible-lg {
+ display: table; }
+ tr.mui-visible-lg {
+ display: table-row !important; }
+ th.mui-visible-lg,
+ td.mui-visible-lg {
+ display: table-cell !important; }
+ .mui--visible-lg-block {
+ display: block !important; }
+ .mui--visible-lg-inline {
+ display: inline !important; }
+ .mui--visible-lg-inline-block {
+ display: inline-block !important; } }
+
+@media (min-width: 1200px) {
+ .mui-visible-xl {
+ display: block !important; }
+ table.mui-visible-xl {
+ display: table; }
+ tr.mui-visible-xl {
+ display: table-row !important; }
+ th.mui-visible-xl,
+ td.mui-visible-xl {
+ display: table-cell !important; }
+ .mui--visible-xl-block {
+ display: block !important; }
+ .mui--visible-xl-inline {
+ display: inline !important; }
+ .mui--visible-xl-inline-block {
+ display: inline-block !important; } }
+
+@media (max-width: 543px) {
+ .mui--hidden-xs {
+ display: none !important; } }
+
+@media (min-width: 544px) and (max-width: 767px) {
+ .mui--hidden-sm {
+ display: none !important; } }
+
+@media (min-width: 768px) and (max-width: 991px) {
+ .mui--hidden-md {
+ display: none !important; } }
+
+@media (min-width: 992px) and (max-width: 1199px) {
+ .mui--hidden-lg {
+ display: none !important; } }
+
+@media (min-width: 1200px) {
+ .mui--hidden-xl {
+ display: none !important; } }
+
+body.mui-body--scroll-lock {
+ overflow: hidden !important; }
+
+/**
+ * MUI Overlay module
+ */
+#mui-overlay {
+ position: fixed;
+ top: 0;
+ right: 0;
+ bottom: 0;
+ left: 0;
+ z-index: 99999999;
+ background-color: rgba(0, 0, 0, 0.2);
+ overflow: auto; }
+
+/**
+ * MUI Ripple module
+ */
+.mui-ripple-effect {
+ position: absolute;
+ border-radius: 50%;
+ pointer-events: none;
+ opacity: 0;
+ animation: mui-ripple-animation 2s; }
+
+@keyframes mui-ripple-animation {
+ from {
+ transform: scale(1);
+ opacity: 0.4; }
+ to {
+ transform: scale(100);
+ opacity: 0; } }
+
+.mui-btn > .mui-ripple-effect {
+ background-color: #a6a6a6; }
+
+.mui-btn--primary > .mui-ripple-effect {
+ background-color: #FFF; }
+
+.mui-btn--dark > .mui-ripple-effect {
+ background-color: #FFF; }
+
+.mui-btn--danger > .mui-ripple-effect {
+ background-color: #FFF; }
+
+.mui-btn--accent > .mui-ripple-effect {
+ background-color: #FFF; }
+
+.mui-btn--flat > .mui-ripple-effect {
+ background-color: #a6a6a6; }
+
+/**
+ * MUI Typography module
+ */
+.mui--text-display4 {
+ font-weight: 300;
+ font-size: 112px;
+ line-height: 112px; }
+
+.mui--text-display3 {
+ font-weight: 400;
+ font-size: 56px;
+ line-height: 56px; }
+
+.mui--text-display2 {
+ font-weight: 400;
+ font-size: 45px;
+ line-height: 48px; }
+
+.mui--text-display1, h1 {
+ font-weight: 400;
+ font-size: 34px;
+ line-height: 40px; }
+
+.mui--text-headline, h2 {
+ font-weight: 400;
+ font-size: 24px;
+ line-height: 32px; }
+
+.mui--text-title, h3 {
+ font-weight: 400;
+ font-size: 20px;
+ line-height: 28px; }
+
+.mui--text-subhead, h4 {
+ font-weight: 400;
+ font-size: 16px;
+ line-height: 24px; }
+
+.mui--text-body2, h5 {
+ font-weight: 500;
+ font-size: 14px;
+ line-height: 24px; }
+
+.mui--text-body1 {
+ font-weight: 400;
+ font-size: 14px;
+ line-height: 20px; }
+
+.mui--text-caption {
+ font-weight: 400;
+ font-size: 12px;
+ line-height: 16px; }
+
+.mui--text-menu {
+ font-weight: 500;
+ font-size: 13px;
+ line-height: 17px; }
+
+.mui--text-button {
+ font-weight: 500;
+ font-size: 14px;
+ line-height: 18px;
+ text-transform: uppercase; }
+
+#header {
+ position: fixed;
+ top: 0;
+ right: 0;
+ left: 0;
+ z-index: 2;
+ transition: left 0.2s; }
+
+ul {
+ margin: 0;
+ padding: 0; }
+
+li {
+ display: inline;
+ margin: 0;
+ padding: 0 4px 0 0; }
+
+.dates {
+ padding: 2px;
+ border: solid 1px #80007e;
+ background-color: #ffffff; }
+
+#btc, #fx, #trend {
+ font-size: 85%;
+}
+
+.up, .ontime, .trendUp {
+ color: green !important;
+}
+
+.down, .delayed, .trendDown {
+ color: red !important;
+}
+
+.nochange {
+ color: #000000; }
+
+.password {
+ border: 1px solid #BDBDBD;
+ background-color: #EEEEEE;
+ font-family: monospace;
+ white-space: pre; }
+
+
+.trendUp:before {
+ content: "▲";
+}
+
+.trendDown:before{content:'▼'}
diff --git a/dist/stuff/bell.mp3 b/dist/stuff/bell.mp3
new file mode 100644
index 0000000..eddcd2c
Binary files /dev/null and b/dist/stuff/bell.mp3 differ
diff --git a/views/index.html b/views/index.html
new file mode 100644
index 0000000..a7d03f1
--- /dev/null
+++ b/views/index.html
@@ -0,0 +1,21 @@
+
+
+
+
+
+
+ Svelte app
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/views/pages/cleaner.ejs b/views/pages/cleaner.ejs
index 1ac2581..44ad3c2 100644
--- a/views/pages/cleaner.ejs
+++ b/views/pages/cleaner.ejs
@@ -35,6 +35,7 @@
+
@@ -45,6 +46,24 @@