UNPKG

monadic_react

Version:

A monadic library for easily composing React-based libraries.

185 lines 18 kB
"use strict"; var __extends = (this && this.__extends) || (function () { var extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; return function (d, b) { extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); var __assign = (this && this.__assign) || Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; Object.defineProperty(exports, "__esModule", { value: true }); var React = require("react"); var Immutable = require("immutable"); var Option = require("./option"); var Slugify = require("slugify"); var core_1 = require("./core"); var html_1 = require("./html"); exports.parse_url = function (template) { return function (url) { var res = {}; var url_items = url.split("/"); if (url_items.length != template.length) return Option.none(); for (var i = 0; i < url_items.length; i++) { var x = Slugify(url_items[i]); var y = Slugify(template[i]); if (typeof y === "string") { if (x != y) return Option.none(); } else { var n = parseInt(x); if (isNaN(n)) return Option.none(); res[y.name] = n; } } return Option.some(res); }; }; exports.instantiate_url = function (template) { return function (t) { var url = ""; for (var i = 0; i < template.length; i++) { var el = Slugify(template[i]); if (typeof el === "string") { url = i == 0 ? el : url + "/" + el; } else { url = i == 0 ? "" + t[el.name] : url + "/" + t[el.name]; } } return url; }; }; exports.make_url = function (template) { return { in: exports.parse_url(template), out: exports.instantiate_url(template) }; }; exports.fallback_url = function () { return { in: function (_) { return Option.some({}); }, out: function (_) { return ""; } }; }; var Application = (function (_super) { __extends(Application, _super); function Application(props, context) { var _this = _super.call(this, props, context) || this; _this.state = { kind: "loading routes" }; return _this; } Application.prototype.load = function () { var _this = this; this.props.routes().then(function (raw_routes) { var routes = Immutable.List(raw_routes); var initial_page = undefined; routes.forEach(function (r) { var p = r.url.in(_this.props.slug).map(r.page); if (p.kind == "some") { initial_page = p.value; return false; } return true; }); _this.setState(__assign({}, _this.state, { kind: "running", context: _this.context_from_props(_this.props, initial_page), routes: routes })); }).catch(function () { return setTimeout(function () { return _this.load(); }, 250); }); }; Application.prototype.componentDidMount = function () { this.load(); }; Application.prototype.context_from_props = function (props, p) { var _this = this; var self = this; return { current_page: p, logic_frame: 0, force_reload: function (callback) { return core_1.make_C(function (ctxt) { return function (inner_callback) { if (_this.state.kind == "loading routes") return null; var old_context = _this.state.context; var new_state = __assign({}, _this.state, { context: __assign({}, old_context, { logic_frame: _this.state.context.logic_frame + 1 }) }); _this.setState(new_state, function () { return inner_callback(callback)(null); }); return null; }; }); }, set_page: function (x, new_page, callback) { var _this = this; window.history.pushState("", "", "" + self.props.base_url + new_page.url.out(x)); return core_1.make_C(function (ctxt) { return function (inner_callback) { if (self.state.kind == "loading routes") return undefined; var new_context = __assign({}, self.state.context, { current_page: new_page.page(x) }); var new_state = __assign({}, _this.state, { context: new_context }); self.setState(new_state, function () { return inner_callback(callback)(null); }); return null; }; }); }, set_url: function (x, new_url, callback) { // console.log(self.props.base_url, new_url.out(x)) window.history.pushState("", "", "" + self.props.base_url + new_url.out(x)); return core_1.unit(null); }, push_route: function (new_route, callback) { return core_1.make_C(function (ctxt) { return function (inner_callback) { if (_this.state.kind == "loading routes") return null; var old_context = _this.state.context; var new_state = __assign({}, _this.state, { routes: _this.state.routes.push(new_route) }); _this.setState(new_state, function () { return inner_callback(callback)(null); }); return null; }; }); }, set_routes: function (routes, callback) { return core_1.make_C(function (ctxt) { return function (inner_callback) { if (_this.state.kind == "loading routes") return null; var old_context = _this.state.context; var new_state = __assign({}, _this.state, { routes: Immutable.List(routes) }); _this.setState(new_state, function () { return inner_callback(callback)(null); }); return null; }; }); }, }; }; Application.prototype.render = function () { var _this = this; if (this.state.kind == "loading routes") return React.createElement("div", { className: "loading" }, "Loading..."); return React.createElement("div", { className: "monadic-application", key: "application@" + this.state.context.logic_frame }, this.state.context.current_page.comp(function () { return _this.state.kind != "loading routes" && _this.state.context; })(function (callback) { return function (_) { return callback && callback(); }; })); }; return Application; }(React.Component)); exports.Application = Application; exports.application = function (mode, base_url, slug, routes) { console.log("Calling application with", window.location.href, slug, base_url); return React.createElement(Application, { mode: mode, base_url: base_url, slug: slug, routes: routes }); }; exports.get_context = function (key, dbg) { return core_1.make_C(function (ctxt) { return function (cont) { return (core_1.unit(ctxt()).comp(ctxt)(cont)); }; }); }; exports.link_to_route = function (label, x, r, key, className) { return html_1.button(label)(null).then(key, function (_) { return exports.get_context().then(undefined, function (c) { return c.set_page(x, r); }, className).ignore(); }); }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router.js","sourceRoot":"","sources":["../../src/react_monad/router.tsx"],"names":[],"mappings":"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"}