monadic_react
Version:
A monadic library for easily composing React-based libraries.
185 lines • 18 kB
JavaScript
;
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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"}