UNPKG

@patternplate/client

Version:

Universal javascript client application for patternplate

382 lines (328 loc) 9.78 kB
Function.prototype.$asyncbind = function $asyncbind(self, catcher) { "use strict"; if (!Function.prototype.$asyncbind) { Object.defineProperty(Function.prototype, "$asyncbind", { value: $asyncbind, enumerable: false, configurable: true, writable: true }); } if (!$asyncbind.trampoline) { $asyncbind.trampoline = function trampoline(t, x, s, e, u) { return function b(q) { while (q) { if (q.then) { q = q.then(b, e); return u ? undefined : q; } try { if (q.pop) { if (q.length) return q.pop() ? x.call(t) : q; q = s; } else q = q.call(t); } catch (r) { return e(r); } } }; }; } if (!$asyncbind.LazyThenable) { $asyncbind.LazyThenable = function () { function isThenable(obj) { return obj && obj instanceof Object && typeof obj.then === "function"; } function resolution(p, r, how) { try { var x = how ? how(r) : r; if (p === x) return p.reject(new TypeError("Promise resolution loop")); if (isThenable(x)) { x.then(function (y) { resolution(p, y); }, function (e) { p.reject(e); }); } else { p.resolve(x); } } catch (ex) { p.reject(ex); } } function Chained() {} ; Chained.prototype = { resolve: _unchained, reject: _unchained, then: thenChain }; function _unchained(v) {} function thenChain(res, rej) { this.resolve = res; this.reject = rej; } function then(res, rej) { var chain = new Chained(); try { this._resolver(function (value) { return isThenable(value) ? value.then(res, rej) : resolution(chain, value, res); }, function (ex) { resolution(chain, ex, rej); }); } catch (ex) { resolution(chain, ex, rej); } return chain; } function Thenable(resolver) { this._resolver = resolver; this.then = then; } ; Thenable.resolve = function (v) { return Thenable.isThenable(v) ? v : { then: function then(resolve) { return resolve(v); } }; }; Thenable.isThenable = isThenable; return Thenable; }(); $asyncbind.EagerThenable = $asyncbind.Thenable = ($asyncbind.EagerThenableFactory = function (tick) { tick = tick || typeof process === "object" && process.nextTick || typeof setImmediate === "function" && setImmediate || function (f) { setTimeout(f, 0); }; var soon = function () { var fq = [], fqStart = 0, bufferSize = 1024; function callQueue() { while (fq.length - fqStart) { try { fq[fqStart](); } catch (ex) {} fq[fqStart++] = undefined; if (fqStart === bufferSize) { fq.splice(0, bufferSize); fqStart = 0; } } } return function (fn) { fq.push(fn); if (fq.length - fqStart === 1) tick(callQueue); }; }(); function Zousan(func) { if (func) { var me = this; func(function (arg) { me.resolve(arg); }, function (arg) { me.reject(arg); }); } } Zousan.prototype = { resolve: function resolve(value) { if (this.state !== undefined) return; if (value === this) return this.reject(new TypeError("Attempt to resolve promise with self")); var me = this; if (value && (typeof value === "function" || typeof value === "object")) { try { var first = 0; var then = value.then; if (typeof then === "function") { then.call(value, function (ra) { if (!first++) { me.resolve(ra); } }, function (rr) { if (!first++) { me.reject(rr); } }); return; } } catch (e) { if (!first) this.reject(e); return; } } this.state = STATE_FULFILLED; this.v = value; if (me.c) soon(function () { for (var n = 0, l = me.c.length; n < l; n++) STATE_FULFILLED(me.c[n], value); }); }, reject: function reject(reason) { if (this.state !== undefined) return; this.state = STATE_REJECTED; this.v = reason; var clients = this.c; if (clients) soon(function () { for (var n = 0, l = clients.length; n < l; n++) STATE_REJECTED(clients[n], reason); }); }, then: function then(onF, onR) { var p = new Zousan(); var client = { y: onF, n: onR, p: p }; if (this.state === undefined) { if (this.c) this.c.push(client);else this.c = [client]; } else { var s = this.state, a = this.v; soon(function () { s(client, a); }); } return p; } }; function STATE_FULFILLED(c, arg) { if (typeof c.y === "function") { try { var yret = c.y.call(undefined, arg); c.p.resolve(yret); } catch (err) { c.p.reject(err); } } else c.p.resolve(arg); } function STATE_REJECTED(c, reason) { if (typeof c.n === "function") { try { var yret = c.n.call(undefined, reason); c.p.resolve(yret); } catch (err) { c.p.reject(err); } } else c.p.reject(reason); } Zousan.resolve = function (val) { if (val && val instanceof Zousan) return val; var z = new Zousan(); z.resolve(val); return z; }; Zousan.reject = function (err) { if (err && err instanceof Zousan) return err; var z = new Zousan(); z.reject(err); return z; }; Zousan.version = "2.3.3-nodent"; return Zousan; })(); } var resolver = this; switch (catcher) { case true: return new $asyncbind.Thenable(boundThen); case 0: return new $asyncbind.LazyThenable(boundThen); case undefined: boundThen.then = boundThen; return boundThen; default: return function () { try { return resolver.apply(self, arguments); } catch (ex) { return catcher(ex); } }; } function boundThen() { return resolver.apply(self, arguments); } }; const ARSON = require("arson"); const url = require("url"); const fetch = require("isomorphic-fetch"); const platform = require("platform"); const router = require("./app/client").default; const _require = require("lodash"), merge = _require.merge; const _global = global, document = _global.document; main().catch(err => { console.error(err); }); function main() { return new Promise(function ($return, $error) { var slot, vault, data, beforeMount, afterMount, ctx; slot = document.querySelector('[data-application-el="patternplate"]'); vault = document.querySelector('[data-application-state="patternplate"]'); return getData(vault).then(function ($await_1) { data = $await_1; beforeMount = data.isStatic ? () => { const scrollTop = document.querySelector('[data-scrolling]').scrollTop; slot.innerHTML = ''; return { scrollTop }; } : () => ({}); afterMount = data.isStatic ? ctx => { const scrollElAfter = document.querySelector('[data-scrolling]'); scrollElAfter.scrollTop = ctx.scrollTop; document.body.setAttribute("data-mounted", true); } : () => { document.body.setAttribute("data-mounted", true); return {}; }; ctx = beforeMount(); router(data, slot); afterMount(ctx); return $return(); }.$asyncbind(this, $error), $error); }.$asyncbind(this)); } function getData(vault) { return new Promise(function ($return, $error) { var data, schema; data = ARSON.parse(decodeURIComponent(vault.textContent)); return getStateData(data.base).then(function ($await_2) { schema = $await_2; return $return(merge(data, getPlatformData(), getWindowData(), { schema, navigation: schema.meta })); }.$asyncbind(this, $error), $error); }.$asyncbind(this)); } function getStateData(base) { return new Promise(function ($return, $error) { return fetch(`${prefix(base)}/api/state.json`, { credentials: "include" }).then(function ($await_3) { return $return($await_3.json()); }.$asyncbind(this, $error), $error); }.$asyncbind(this)); } function prefix(base) { return base.charAt(base.length - 1) === "/" ? base.slice(0, base.length - 1) : base; } function getPlatformData() { return { clientRuntimeName: platform.name, clientRuntimeVersion: platform.version, clientOsName: platform.os.name, clientOsVersion: platform.os.version }; } function getWindowData() { return { window: { width: global.innerWidth, height: global.innerHeight } }; } //# sourceMappingURL=client.js.map