apeman-react-mixins
Version:
React mixin set of apeman.
248 lines (208 loc) • 17.3 kB
JavaScript
/**
* Mixin for page components
* @module ApPageMixin
*
*/
;
Object.defineProperty(exports, "__esModule", {
value: true
});
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _assert = require('assert');
var _assert2 = _interopRequireDefault(_assert);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/** @lends ApPageMixin */
var ApPageMixin = {
// --------------------
// Custom
// --------------------
$apPageMixed: true,
/**
* Register page view resolver.
* @param {object} resolver - A resolver instance
*/
registerPageViewResolver: function registerPageViewResolver(resolver) {
var s = this;
s._pageViewResolver = resolver;
},
/**
* Register page stack.
* @param {string} name - Name of stack
* @param {object} stacker - A stacker instance
*/
registerPageViewStacker: function registerPageViewStacker(name, stacker) {
var s = this;
s._pageStacks = s._pageStacks || {};
var resolver = s._pageViewResolver;
if (!resolver) {
throw new Error('Resolver not found call `.registerPageViewResolver()` before this.');
}
stacker.stackName = name;
stacker.addListener('push', s.pageStackViewDidPush);
stacker.addListener('pop', s.pageStackViewDidPop);
s._pageStacks[name] = stacker;
},
/**
* De register page stack
* @param name
*/
deregisterPageStack: function deregisterPageStack(name) {
var s = this;
var stacker = s._pageStacks[name];
stacker.removeListener('push', s.pageStackViewDidPush);
stacker.removeListener('pop', s.pageStackViewDidPop);
delete s._pageStacks[name];
},
/**
* Get page main stack.
* @param {string} name - Name of stack
* @returns {ApViewStack.Stacker}
*/
getPageStack: function getPageStack(name) {
var s = this;
var stack = s._pageStacks[name];
if (!stack) {
throw new Error('Stack not found. Call `.registerPageStack()` on componentWillMount.');
}
return stack;
},
/**
* Create page url from stacker
* @param {object} stacker - View stacker.
* @returns {string} - Page url
*/
pageURLWithStacker: function pageURLWithStacker(stacker) {
var s = this;
return '/' + s.pageName + '/' + stacker.stackName + '/' + stacker.toURL();
},
/**
* Reset page stacks.
*/
resetPageStacks: function resetPageStacks() {
var s = this;
var stacks = s._pageStacks || {};
var _iteratorNormalCompletion = true;
var _didIteratorError = false;
var _iteratorError = undefined;
try {
for (var _iterator = Object.keys(stacks)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
var name = _step.value;
var stack = stacks[name];
stack.reset();
}
} catch (err) {
_didIteratorError = true;
_iteratorError = err;
} finally {
try {
if (!_iteratorNormalCompletion && _iterator.return) {
_iterator.return();
}
} finally {
if (_didIteratorError) {
throw _iteratorError;
}
}
}
},
/**
* Restore page url
* @param {string} url
*/
restorePageURL: function restorePageURL(url) {
var s = this;
if (!url) {
return;
}
var names = url.replace(/^\//, '').split(/\//g);
if (names[0] === s.pageName) {
names.shift();
}
if (names.length === 0) {
s.resetPageStacks();
return;
}
var stackName = names.shift(),
stackerURL = names.join('/');
if (!stackName) {
return;
}
try {
var stacker = s.getPageStack(stackName);
stacker.fromURL(stackerURL);
stacker.reload();
} catch (e) {
console.warn('[' + s.pageName + '] Failed to restore url: ' + url);
}
},
/**
* Get layout for page.
* @returns {object}
*/
getPageLayouts: function getPageLayouts() {
var s = this;
return s._pageLayouts || {};
},
/**
* Update page layout.
* @param {string} name - Name of layout.
* @param {object} layout - Layout data.
*/
updatePageLayout: function updatePageLayout(name, layout) {
var s = this;
var _pageLayouts = Object.assign({}, s.getPageLayouts());
_pageLayouts[name] = Object.assign({}, _pageLayouts[name] || {}, layout);
s._pageLayouts = _pageLayouts;
s.layout(true);
},
// --------------------
// Specs
// --------------------
getInitialState: function getInitialState() {
return {};
},
// --------------------
// Lifecycle
// --------------------
componentWillMount: function componentWillMount() {
var s = this;
s.pageName = s.pageName || s.getPageName && s.getPageName();
_assert2.default.ok(s.$apLocaleMixed, "ApLocaleMixin is required.");
_assert2.default.ok(s.pageName, 'pageName is required.');
},
componentWillUnmount: function componentWillUnmount() {
var s = this;
// Cleanup stacks.
var _iteratorNormalCompletion2 = true;
var _didIteratorError2 = false;
var _iteratorError2 = undefined;
try {
for (var _iterator2 = Object.keys(s._pageStacks || {})[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) {
var name = _step2.value;
s.deregisterPageStack(name);
}
} catch (err) {
_didIteratorError2 = true;
_iteratorError2 = err;
} finally {
try {
if (!_iteratorNormalCompletion2 && _iterator2.return) {
_iterator2.return();
}
} finally {
if (_didIteratorError2) {
throw _iteratorError2;
}
}
}
},
// ------------------
// Private
// ------------------
_pageLayouts: null,
_pageStacks: null,
_pageViewResolver: null
};
exports.default = Object.freeze(ApPageMixin);
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["ap_page_mixin.jsx"],"names":[],"mappings":";;;;;AAKA;;;;;;AAEA;;;;AACA;;;;;;;AAGA,IAAI,cAAc;;;;;AAKd,kBAAc,IALA;;;;;;AAYd,4BAZc,oCAYW,QAZX,EAYqB;AAC/B,YAAM,IAAI,IAAV;AACA,UAAE,iBAAF,GAAsB,QAAtB;AACH,KAfa;;;;;;;;AAsBd,2BAtBc,mCAsBU,IAtBV,EAsBgB,OAtBhB,EAsByB;AACnC,YAAM,IAAI,IAAV;AACA,UAAE,WAAF,GAAgB,EAAE,WAAF,IAAiB,EAAjC;AACA,YAAI,WAAW,EAAE,iBAAjB;AACA,YAAI,CAAC,QAAL,EAAe;AACX,kBAAM,IAAI,KAAJ,CAAU,oEAAV,CAAN;AACH;AACD,gBAAQ,SAAR,GAAoB,IAApB;AACA,gBAAQ,WAAR,CAAoB,MAApB,EAA4B,EAAE,oBAA9B;AACA,gBAAQ,WAAR,CAAoB,KAApB,EAA2B,EAAE,mBAA7B;AACA,UAAE,WAAF,CAAc,IAAd,IAAsB,OAAtB;AACH,KAjCa;;;;;;;AAuCd,uBAvCc,+BAuCM,IAvCN,EAuCY;AACtB,YAAM,IAAI,IAAV;AACA,YAAI,UAAU,EAAE,WAAF,CAAc,IAAd,CAAd;AACA,gBAAQ,cAAR,CAAuB,MAAvB,EAA+B,EAAE,oBAAjC;AACA,gBAAQ,cAAR,CAAuB,KAAvB,EAA8B,EAAE,mBAAhC;AACA,eAAO,EAAE,WAAF,CAAc,IAAd,CAAP;AACH,KA7Ca;;;;;;;;AAoDd,gBApDc,wBAoDD,IApDC,EAoDK;AACf,YAAM,IAAI,IAAV;AACA,YAAI,QAAQ,EAAE,WAAF,CAAc,IAAd,CAAZ;AACA,YAAI,CAAC,KAAL,EAAY;AACR,kBAAM,IAAI,KAAJ,CAAU,qEAAV,CAAN;AACH;AACD,eAAO,KAAP;AACH,KA3Da;;;;;;;;AAkEd,sBAlEc,8BAkEK,OAlEL,EAkEc;AACxB,YAAM,IAAI,IAAV;AACA,qBAAW,EAAE,QAAb,SAAyB,QAAQ,SAAjC,SAA8C,QAAQ,KAAR,EAA9C;AACH,KArEa;;;;;;AA0Ed,mBA1Ec,6BA0EI;AACd,YAAM,IAAI,IAAV;AACA,YAAI,SAAS,EAAE,WAAF,IAAiB,EAA9B;AAFc;AAAA;AAAA;;AAAA;AAGd,iCAAiB,OAAO,IAAP,CAAY,MAAZ,CAAjB,8HAAsC;AAAA,oBAA7B,IAA6B;;AAClC,oBAAI,QAAQ,OAAO,IAAP,CAAZ;AACA,sBAAM,KAAN;AACH;AANa;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOjB,KAjFa;;;;;;;AAwFd,kBAxFc,0BAwFC,GAxFD,EAwFM;AAChB,YAAM,IAAI,IAAV;AACA,YAAI,CAAC,GAAL,EAAU;AACN;AACH;AACD,YAAI,QAAQ,IAAI,OAAJ,CAAY,KAAZ,EAAmB,EAAnB,EAAuB,KAAvB,CAA6B,KAA7B,CAAZ;AACA,YAAI,MAAM,CAAN,MAAa,EAAE,QAAnB,EAA6B;AACzB,kBAAM,KAAN;AACH;AACD,YAAI,MAAM,MAAN,KAAiB,CAArB,EAAwB;AACpB,cAAE,eAAF;AACA;AACH;AACD,YAAI,YAAY,MAAM,KAAN,EAAhB;YACI,aAAa,MAAM,IAAN,CAAW,GAAX,CADjB;AAEA,YAAI,CAAC,SAAL,EAAgB;AACZ;AACH;AACD,YAAI;AACA,gBAAI,UAAU,EAAE,YAAF,CAAe,SAAf,CAAd;AACA,oBAAQ,OAAR,CAAgB,UAAhB;AACA,oBAAQ,MAAR;AACH,SAJD,CAIE,OAAO,CAAP,EAAU;AACR,oBAAQ,IAAR,OAAiB,EAAE,QAAnB,iCAAuD,GAAvD;AACH;AACJ,KAjHa;;;;;;;AAuHd,kBAvHc,4BAuHG;AACb,YAAM,IAAI,IAAV;AACA,eAAO,EAAE,YAAF,IAAkB,EAAzB;AACH,KA1Ha;;;;;;;;AAiId,oBAjIc,4BAiIG,IAjIH,EAiIS,MAjIT,EAiIiB;AAC3B,YAAM,IAAI,IAAV;AACA,YAAI,eAAe,OAAO,MAAP,CAAc,EAAd,EAAkB,EAAE,cAAF,EAAlB,CAAnB;AACA,qBAAa,IAAb,IAAqB,OAAO,MAAP,CACjB,EADiB,EACb,aAAa,IAAb,KAAsB,EADT,EACa,MADb,CAArB;AAGA,UAAE,YAAF,GAAiB,YAAjB;AACA,UAAE,MAAF,CAAS,IAAT;AACH,KAzIa;;;;;;AA8Id,mBA9Ic,6BA8II;AACd,eAAO,EAAP;AACH,KAhJa;;;;;;AAqJd,sBArJc,gCAqJQ;AAClB,YAAM,IAAI,IAAV;;AAEA,UAAE,QAAF,GAAa,EAAE,QAAF,IAAe,EAAE,WAAF,IAAiB,EAAE,WAAF,EAA7C;AACA,yBAAO,EAAP,CAAU,EAAE,cAAZ,EAA4B,4BAA5B;AACA,yBAAO,EAAP,CAAU,EAAE,QAAZ,EAAsB,uBAAtB;AAEH,KA5Ja;AA6Jd,wBA7Jc,kCA6JU;AACpB,YAAM,IAAI,IAAV;;;AADoB;AAAA;AAAA;;AAAA;AAIpB,kCAAiB,OAAO,IAAP,CAAY,EAAE,WAAF,IAAiB,EAA7B,CAAjB,mIAAmD;AAAA,oBAA1C,IAA0C;;AAC/C,kBAAE,mBAAF,CAAsB,IAAtB;AACH;AANmB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOvB,KApKa;;;;;;;AA0Kd,kBAAc,IA1KA;AA2Kd,iBAAa,IA3KC;AA4Kd,uBAAmB;;AA5KL,CAAlB;;kBAgLe,OAAO,MAAP,CAAc,WAAd,C","file":"ap_page_mixin.js","sourceRoot":"/Users/okunishinishi/Projects/apeman-projects/apeman-react-mixins/lib","sourcesContent":["/**\n * Mixin for page components\n * @module ApPageMixin\n *\n */\n'use strict'\n\nimport React from 'react'\nimport assert from 'assert'\n\n/** @lends ApPageMixin */\nlet ApPageMixin = {\n\n    // --------------------\n    // Custom\n    // --------------------\n    $apPageMixed: true,\n\n\n    /**\n     * Register page view resolver.\n     * @param {object} resolver - A resolver instance\n     */\n    registerPageViewResolver(resolver) {\n        const s = this\n        s._pageViewResolver = resolver;\n    },\n\n    /**\n     * Register page stack.\n     * @param {string} name - Name of stack\n     * @param {object} stacker - A stacker instance\n     */\n    registerPageViewStacker(name, stacker) {\n        const s = this\n        s._pageStacks = s._pageStacks || {}\n        let resolver = s._pageViewResolver;\n        if (!resolver) {\n            throw new Error('Resolver not found call `.registerPageViewResolver()` before this.')\n        }\n        stacker.stackName = name;\n        stacker.addListener('push', s.pageStackViewDidPush)\n        stacker.addListener('pop', s.pageStackViewDidPop)\n        s._pageStacks[name] = stacker;\n    },\n\n    /**\n     * De register page stack\n     * @param name\n     */\n    deregisterPageStack(name) {\n        const s = this\n        let stacker = s._pageStacks[name];\n        stacker.removeListener('push', s.pageStackViewDidPush)\n        stacker.removeListener('pop', s.pageStackViewDidPop)\n        delete s._pageStacks[name];\n    },\n\n    /**\n     * Get page main stack.\n     * @param {string} name - Name of stack\n     * @returns {ApViewStack.Stacker}\n     */\n    getPageStack(name) {\n        const s = this\n        let stack = s._pageStacks[name];\n        if (!stack) {\n            throw new Error('Stack not found. Call `.registerPageStack()` on componentWillMount.')\n        }\n        return stack;\n    },\n\n    /**\n     * Create page url from stacker\n     * @param {object} stacker - View stacker.\n     * @returns {string} - Page url\n     */\n    pageURLWithStacker(stacker) {\n        const s = this\n        return `/${s.pageName}/${stacker.stackName}/${stacker.toURL()}`;\n    },\n\n    /**\n     * Reset page stacks.\n     */\n    resetPageStacks() {\n        const s = this\n        let stacks = s._pageStacks || {}\n        for (let name of Object.keys(stacks)) {\n            let stack = stacks[name];\n            stack.reset()\n        }\n    },\n\n\n    /**\n     * Restore page url\n     * @param {string} url\n     */\n    restorePageURL(url) {\n        const s = this\n        if (!url) {\n            return;\n        }\n        let names = url.replace(/^\\//, '').split(/\\//g)\n        if (names[0] === s.pageName) {\n            names.shift()\n        }\n        if (names.length === 0) {\n            s.resetPageStacks()\n            return;\n        }\n        let stackName = names.shift(),\n            stackerURL = names.join('/')\n        if (!stackName) {\n            return;\n        }\n        try {\n            let stacker = s.getPageStack(stackName)\n            stacker.fromURL(stackerURL)\n            stacker.reload()\n        } catch (e) {\n            console.warn(`[${s.pageName}] Failed to restore url: ${url}`)\n        }\n    },\n\n    /**\n     * Get layout for page.\n     * @returns {object}\n     */\n    getPageLayouts() {\n        const s = this\n        return s._pageLayouts || {}\n    },\n\n    /**\n     * Update page layout.\n     * @param {string} name - Name of layout.\n     * @param {object} layout - Layout data.\n     */\n    updatePageLayout(name, layout) {\n        const s = this\n        let _pageLayouts = Object.assign({}, s.getPageLayouts())\n        _pageLayouts[name] = Object.assign(\n            {}, _pageLayouts[name] || {}, layout\n        )\n        s._pageLayouts = _pageLayouts;\n        s.layout(true)\n    },\n\n    // --------------------\n    // Specs\n    // --------------------\n    getInitialState() {\n        return {}\n    },\n\n    // --------------------\n    // Lifecycle\n    // --------------------\n    componentWillMount () {\n        const s = this\n\n        s.pageName = s.pageName || (s.getPageName && s.getPageName())\n        assert.ok(s.$apLocaleMixed, \"ApLocaleMixin is required.\")\n        assert.ok(s.pageName, 'pageName is required.')\n\n    },\n    componentWillUnmount () {\n        const s = this\n\n        // Cleanup stacks.\n        for (let name of Object.keys(s._pageStacks || {})) {\n            s.deregisterPageStack(name)\n        }\n    },\n\n    // ------------------\n    // Private\n    // ------------------\n\n    _pageLayouts: null,\n    _pageStacks: null,\n    _pageViewResolver: null\n\n}\n\nexport default Object.freeze(ApPageMixin)"]}