UNPKG

42.8 kBJavaScriptView Raw
1(function webpackUniversalModuleDefinition(root, factory) {
2 if(typeof exports === 'object' && typeof module === 'object')
3 module.exports = factory();
4 else if(typeof define === 'function' && define.amd)
5 define("redux-app", [], factory);
6 else if(typeof exports === 'object')
7 exports["redux-app"] = factory();
8 else
9 root["redux-app"] = factory();
10})(this, function() {
11return /******/ (function(modules) { // webpackBootstrap
12/******/ // The module cache
13/******/ var installedModules = {};
14/******/
15/******/ // The require function
16/******/ function __webpack_require__(moduleId) {
17/******/
18/******/ // Check if module is in cache
19/******/ if(installedModules[moduleId]) {
20/******/ return installedModules[moduleId].exports;
21/******/ }
22/******/ // Create a new module (and put it into the cache)
23/******/ var module = installedModules[moduleId] = {
24/******/ i: moduleId,
25/******/ l: false,
26/******/ exports: {}
27/******/ };
28/******/
29/******/ // Execute the module function
30/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
31/******/
32/******/ // Flag the module as loaded
33/******/ module.l = true;
34/******/
35/******/ // Return the exports of the module
36/******/ return module.exports;
37/******/ }
38/******/
39/******/
40/******/ // expose the modules object (__webpack_modules__)
41/******/ __webpack_require__.m = modules;
42/******/
43/******/ // expose the module cache
44/******/ __webpack_require__.c = installedModules;
45/******/
46/******/ // define getter function for harmony exports
47/******/ __webpack_require__.d = function(exports, name, getter) {
48/******/ if(!__webpack_require__.o(exports, name)) {
49/******/ Object.defineProperty(exports, name, {
50/******/ configurable: false,
51/******/ enumerable: true,
52/******/ get: getter
53/******/ });
54/******/ }
55/******/ };
56/******/
57/******/ // getDefaultExport function for compatibility with non-harmony modules
58/******/ __webpack_require__.n = function(module) {
59/******/ var getter = module && module.__esModule ?
60/******/ function getDefault() { return module['default']; } :
61/******/ function getModuleExports() { return module; };
62/******/ __webpack_require__.d(getter, 'a', getter);
63/******/ return getter;
64/******/ };
65/******/
66/******/ // Object.prototype.hasOwnProperty.call
67/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
68/******/
69/******/ // __webpack_public_path__
70/******/ __webpack_require__.p = "";
71/******/
72/******/ // Load entry module and return exports
73/******/ return __webpack_require__(__webpack_require__.s = 8);
74/******/ })
75/************************************************************************/
76/******/ ([
77/* 0 */
78/***/ (function(module, exports, __webpack_require__) {
79
80"use strict";
81
82function __export(m) {
83 for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
84}
85Object.defineProperty(exports, "__esModule", { value: true });
86__export(__webpack_require__(10));
87__export(__webpack_require__(5));
88__export(__webpack_require__(7));
89__export(__webpack_require__(23));
90
91
92/***/ }),
93/* 1 */
94/***/ (function(module, exports, __webpack_require__) {
95
96"use strict";
97
98function __export(m) {
99 for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
100}
101Object.defineProperty(exports, "__esModule", { value: true });
102__export(__webpack_require__(14));
103__export(__webpack_require__(15));
104__export(__webpack_require__(16));
105__export(__webpack_require__(17));
106
107
108/***/ }),
109/* 2 */
110/***/ (function(module, exports, __webpack_require__) {
111
112"use strict";
113
114Object.defineProperty(exports, "__esModule", { value: true });
115var snakecase = __webpack_require__(12);
116var SchemaOptions = (function () {
117 function SchemaOptions() {
118 this.actionNamespace = true;
119 this.uppercaseActions = true;
120 }
121 return SchemaOptions;
122}());
123exports.SchemaOptions = SchemaOptions;
124function getActionName(creator, methodName, options) {
125 var actionName = methodName;
126 var actionNamespace = creator.constructor.name;
127 if (options.uppercaseActions) {
128 actionName = snakecase(actionName).toUpperCase();
129 actionNamespace = snakecase(actionNamespace).toUpperCase();
130 }
131 if (options.actionNamespace) {
132 actionName = actionNamespace + '.' + actionName;
133 }
134 return actionName;
135}
136exports.getActionName = getActionName;
137var AppOptions = (function () {
138 function AppOptions() {
139 this.updateState = true;
140 }
141 return AppOptions;
142}());
143exports.AppOptions = AppOptions;
144var LogLevel;
145(function (LogLevel) {
146 LogLevel[LogLevel["None"] = 0] = "None";
147 LogLevel[LogLevel["Verbose"] = 1] = "Verbose";
148 LogLevel[LogLevel["Debug"] = 2] = "Debug";
149 LogLevel[LogLevel["Warn"] = 5] = "Warn";
150 LogLevel[LogLevel["Silent"] = 10] = "Silent";
151})(LogLevel = exports.LogLevel || (exports.LogLevel = {}));
152var GlobalOptions = (function () {
153 function GlobalOptions() {
154 this.logLevel = LogLevel.Warn;
155 this.emitClassNames = false;
156 this.schema = new SchemaOptions();
157 }
158 return GlobalOptions;
159}());
160exports.GlobalOptions = GlobalOptions;
161exports.globalOptions = new GlobalOptions();
162
163
164/***/ }),
165/* 3 */
166/***/ (function(module, exports, __webpack_require__) {
167
168"use strict";
169
170Object.defineProperty(exports, "__esModule", { value: true });
171var redux_1 = __webpack_require__(20);
172var components_1 = __webpack_require__(0);
173var options_1 = __webpack_require__(2);
174var utils_1 = __webpack_require__(1);
175exports.DEFAULT_APP_NAME = 'default';
176exports.appsRepository = {};
177var appsCount = 0;
178var ReduxApp = (function () {
179 function ReduxApp(appCreator) {
180 var params = [];
181 for (var _i = 1; _i < arguments.length; _i++) {
182 params[_i - 1] = arguments[_i];
183 }
184 var _this = this;
185 this.warehouse = new Map();
186 var _a = this.resolveParameters(params), options = _a.options, preLoadedState = _a.preLoadedState, enhancer = _a.enhancer;
187 this.name = this.getAppName(options.name);
188 if (exports.appsRepository[this.name])
189 throw new Error("An app with name '" + this.name + "' already exists.");
190 exports.appsRepository[this.name] = this;
191 var initialReducer = function (state) { return state; };
192 this.store = redux_1.createStore(initialReducer, preLoadedState, enhancer);
193 var rootComponent = components_1.Component.create(this.store, appCreator, null, [this.name]);
194 this.root = rootComponent;
195 if (options.updateState) {
196 this.subscriptionDisposer = this.store.subscribe(function () { return _this.updateState(); });
197 }
198 var actualReducer = components_1.Component.getReducerFromTree(rootComponent);
199 this.store.replaceReducer(actualReducer);
200 }
201 ReduxApp.createApp = function (appCreator) {
202 var params = [];
203 for (var _i = 1; _i < arguments.length; _i++) {
204 params[_i - 1] = arguments[_i];
205 }
206 return new (ReduxApp.bind.apply(ReduxApp, [void 0, appCreator].concat(params)))();
207 };
208 ReduxApp.prototype.dispose = function () {
209 if (this.subscriptionDisposer) {
210 this.subscriptionDisposer();
211 this.subscriptionDisposer = null;
212 }
213 if (exports.appsRepository[this.name]) {
214 delete exports.appsRepository[this.name];
215 }
216 };
217 ReduxApp.prototype.getTypeWarehouse = function (type) {
218 if (!this.warehouse.has(type))
219 this.warehouse.set(type, new Map());
220 return this.warehouse.get(type);
221 };
222 ReduxApp.prototype.getAppName = function (name) {
223 if (name)
224 return name;
225 if (!Object.keys(exports.appsRepository).length) {
226 return exports.DEFAULT_APP_NAME;
227 }
228 else {
229 return exports.DEFAULT_APP_NAME + '_' + (++appsCount);
230 }
231 };
232 ReduxApp.prototype.updateState = function () {
233 var newState = this.store.getState();
234 utils_1.log.verbose('[updateState] Store before: ', newState);
235 var visited = new Set();
236 this.updateStateRecursion(this.root, newState, [], visited);
237 utils_1.log.verbose('[updateState] Store after: ', newState);
238 };
239 ReduxApp.prototype.updateStateRecursion = function (obj, newState, path, visited) {
240 if (obj === newState)
241 return newState;
242 if (utils_1.isPrimitive(obj) || utils_1.isPrimitive(newState))
243 return newState;
244 if (visited.has(obj))
245 return obj;
246 visited.add(obj);
247 var targetType = obj.constructor;
248 var newStateType = newState.constructor;
249 if ((targetType === newStateType) || newStateType === Object) {
250 var changeMessage;
251 if (Array.isArray(obj) && Array.isArray(newState)) {
252 changeMessage = this.updateArray(obj, newState, path, visited);
253 }
254 else {
255 changeMessage = this.updateObject(obj, newState, path, visited);
256 }
257 }
258 else {
259 return newState;
260 }
261 if (changeMessage && changeMessage.length) {
262 utils_1.log.debug("[updateState] App state in path '" + utils_1.pathString(path) + "' changed.");
263 utils_1.log.debug("[updateState] " + changeMessage);
264 utils_1.log.verbose("[updateState] New state: ", obj);
265 }
266 else {
267 utils_1.log.verbose("[updateState] No change in path '" + utils_1.pathString(path) + "'.");
268 }
269 return obj;
270 };
271 ReduxApp.prototype.updateObject = function (obj, newState, path, visited) {
272 var _this = this;
273 var propsDeleted = [];
274 Object.keys(obj).forEach(function (key) {
275 if (!newState.hasOwnProperty(key)) {
276 delete obj[key];
277 propsDeleted.push(key);
278 }
279 });
280 var propsAssigned = [];
281 Object.keys(newState).forEach(function (key) {
282 var subState = newState[key];
283 var subObj = obj[key];
284 var newSubObj = _this.updateStateRecursion(subObj, subState, path.concat(key), visited);
285 if (newSubObj !== subObj) {
286 obj[key] = newSubObj;
287 propsAssigned.push(key);
288 }
289 });
290 if (propsDeleted.length || propsAssigned.length) {
291 var propsDeleteMessage = "Props deleted: " + (propsDeleted.length ? propsDeleted.join(', ') : '<none>') + ".";
292 var propsAssignedMessage = "Props assigned: " + (propsAssigned.length ? propsAssigned.join(', ') : '<none>') + ".";
293 return propsAssignedMessage + ' ' + propsDeleteMessage;
294 }
295 else {
296 return null;
297 }
298 };
299 ReduxApp.prototype.updateArray = function (arr, newState, path, visited) {
300 var changeMessage = [];
301 var prevLength = arr.length;
302 var newLength = newState.length;
303 var itemsAssigned = [];
304 for (var i = 0; i < Math.min(prevLength, newLength); i++) {
305 var subState = newState[i];
306 var subObj = arr[i];
307 var newSubObj = this.updateStateRecursion(subObj, subState, path.concat(i.toString()), visited);
308 if (newSubObj !== subObj) {
309 arr[i] = newSubObj;
310 itemsAssigned.push(i);
311 }
312 }
313 if (itemsAssigned.length)
314 changeMessage.push("Assigned item(s) at indexes " + itemsAssigned.join(', ') + ".");
315 if (newLength > prevLength) {
316 var newItems = newState.slice(prevLength);
317 Array.prototype.push.apply(arr, newItems);
318 changeMessage.push("Added " + (newLength - prevLength) + " item(s) at index " + prevLength + ".");
319 }
320 else if (prevLength > newLength) {
321 arr.splice(newLength);
322 changeMessage.push("Removed " + (prevLength - newLength) + " item(s) at index " + newLength + ".");
323 }
324 return changeMessage.join(' ');
325 };
326 ReduxApp.prototype.resolveParameters = function (params) {
327 var result = {};
328 if (params.length === 0) {
329 result.options = new options_1.AppOptions();
330 }
331 else if (params.length === 1) {
332 if (typeof params[0] === 'function') {
333 result.options = new options_1.AppOptions();
334 result.enhancer = params[0];
335 }
336 else {
337 result.options = Object.assign(new options_1.AppOptions(), params[0]);
338 }
339 }
340 else if (params.length === 2) {
341 result.options = Object.assign(new options_1.AppOptions(), params[0]);
342 result.preLoadedState = JSON.parse(JSON.stringify(params[1]));
343 }
344 else {
345 result.options = Object.assign(new options_1.AppOptions(), params[0]);
346 result.preLoadedState = JSON.parse(JSON.stringify(params[1]));
347 result.enhancer = params[2];
348 }
349 return result;
350 };
351 ReduxApp.options = options_1.globalOptions;
352 return ReduxApp;
353}());
354exports.ReduxApp = ReduxApp;
355
356
357/***/ }),
358/* 4 */
359/***/ (function(module, exports, __webpack_require__) {
360
361"use strict";
362
363Object.defineProperty(exports, "__esModule", { value: true });
364function setSymbol(obj, symbol, value) {
365 return obj[symbol] = value;
366}
367exports.setSymbol = setSymbol;
368function getSymbol(obj, symbol) {
369 return obj[symbol];
370}
371exports.getSymbol = getSymbol;
372exports.COMPONENT_META = Symbol('REDUX-APP.COMPONENT_METADATA');
373exports.COMPONENT_SCHEMA = Symbol('REDUX-APP.COMPONENT_SCHEMA');
374exports.AUTO_ID = Symbol('REDUX-APP.AUTO_ID');
375
376
377/***/ }),
378/* 5 */
379/***/ (function(module, exports, __webpack_require__) {
380
381"use strict";
382
383Object.defineProperty(exports, "__esModule", { value: true });
384var symbols_1 = __webpack_require__(4);
385var Metadata = (function () {
386 function Metadata() {
387 this.disposables = [];
388 this.computedGetters = {};
389 }
390 Metadata.getMeta = function (component) {
391 return symbols_1.getSymbol(component, symbols_1.COMPONENT_META);
392 };
393 Metadata.createMeta = function (component) {
394 return symbols_1.setSymbol(component, symbols_1.COMPONENT_META, new Metadata());
395 };
396 return Metadata;
397}());
398exports.Metadata = Metadata;
399
400
401/***/ }),
402/* 6 */
403/***/ (function(module, exports, __webpack_require__) {
404
405"use strict";
406
407function __export(m) {
408 for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
409}
410Object.defineProperty(exports, "__esModule", { value: true });
411__export(__webpack_require__(11));
412__export(__webpack_require__(13));
413__export(__webpack_require__(18));
414__export(__webpack_require__(21));
415__export(__webpack_require__(22));
416
417
418/***/ }),
419/* 7 */
420/***/ (function(module, exports, __webpack_require__) {
421
422"use strict";
423
424Object.defineProperty(exports, "__esModule", { value: true });
425var symbols_1 = __webpack_require__(4);
426var utils_1 = __webpack_require__(1);
427var Schema = (function () {
428 function Schema() {
429 this.computedGetters = {};
430 this.connectedProps = {};
431 this.noDispatch = {};
432 this.childIds = {};
433 }
434 Schema.getSchema = function (obj) {
435 if (!obj)
436 return undefined;
437 if (typeof obj === 'object') {
438 return utils_1.getConstructorProp(obj, symbols_1.COMPONENT_SCHEMA);
439 }
440 else {
441 return symbols_1.getSymbol(obj, symbols_1.COMPONENT_SCHEMA);
442 }
443 };
444 Schema.getOrCreateSchema = function (obj) {
445 var schema = Schema.getSchema(obj);
446 if (!schema) {
447 var isConstructor = (typeof obj === 'function' ? true : false);
448 var target = (isConstructor ? obj : obj.constructor);
449 schema = symbols_1.setSymbol(target, symbols_1.COMPONENT_SCHEMA, new Schema());
450 }
451 return schema;
452 };
453 Schema.assertSchema = function (obj, msg) {
454 if (!Schema.getSchema(obj))
455 throw new Error(msg || 'Invalid argument. Decorated component expected.');
456 };
457 return Schema;
458}());
459exports.Schema = Schema;
460
461
462/***/ }),
463/* 8 */
464/***/ (function(module, exports, __webpack_require__) {
465
466module.exports = __webpack_require__(9);
467
468
469/***/ }),
470/* 9 */
471/***/ (function(module, exports, __webpack_require__) {
472
473"use strict";
474
475Object.defineProperty(exports, "__esModule", { value: true });
476var components_1 = __webpack_require__(0);
477exports.isInstanceOf = components_1.isInstanceOf;
478var decorators_1 = __webpack_require__(6);
479exports.component = decorators_1.component;
480exports.connect = decorators_1.connect;
481exports.computed = decorators_1.computed;
482exports.noDispatch = decorators_1.noDispatch;
483exports.sequence = decorators_1.sequence;
484exports.withId = decorators_1.withId;
485var options_1 = __webpack_require__(2);
486exports.SchemaOptions = options_1.SchemaOptions;
487exports.AppOptions = options_1.AppOptions;
488exports.GlobalOptions = options_1.GlobalOptions;
489exports.LogLevel = options_1.LogLevel;
490var reduxApp_1 = __webpack_require__(3);
491exports.ReduxApp = reduxApp_1.ReduxApp;
492
493
494/***/ }),
495/* 10 */
496/***/ (function(module, exports, __webpack_require__) {
497
498"use strict";
499
500var __extends = (this && this.__extends) || (function () {
501 var extendStatics = Object.setPrototypeOf ||
502 ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
503 function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
504 return function (d, b) {
505 extendStatics(d, b);
506 function __() { this.constructor = d; }
507 d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
508 };
509})();
510var __assign = (this && this.__assign) || Object.assign || function(t) {
511 for (var s, i = 1, n = arguments.length; i < n; i++) {
512 s = arguments[i];
513 for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
514 t[p] = s[p];
515 }
516 return t;
517};
518Object.defineProperty(exports, "__esModule", { value: true });
519var decorators_1 = __webpack_require__(6);
520var options_1 = __webpack_require__(2);
521var reduxApp_1 = __webpack_require__(3);
522var utils_1 = __webpack_require__(1);
523var metadata_1 = __webpack_require__(5);
524var schema_1 = __webpack_require__(7);
525var Component = (function () {
526 function Component(store, creator, parentCreator, path, visited) {
527 if (path === void 0) { path = []; }
528 if (visited === void 0) { visited = new Set(); }
529 if (!schema_1.Schema.getSchema(creator))
530 throw new Error("Argument '" + "creator" + "' is not a component creator. Did you forget to use the decorator?");
531 Component.createSelf(this, store, creator, parentCreator, path);
532 Component.createSubComponents(this, store, creator, path, visited);
533 utils_1.log.debug("[Component] New " + creator.constructor.name + " component created. path: " + utils_1.pathString(path));
534 }
535 Component.create = function (store, creator, parentCreator, path, visited) {
536 if (path === void 0) { path = []; }
537 if (visited === void 0) { visited = new Set(); }
538 var ComponentClass = Component.getComponentClass(creator);
539 var component = new ComponentClass(store, creator, parentCreator, path, visited);
540 var appName = path[0] || reduxApp_1.DEFAULT_APP_NAME;
541 var app = reduxApp_1.appsRepository[appName];
542 var selfPropName = path[path.length - 1];
543 var isConnected = schema_1.Schema.getSchema(creator).connectedProps[selfPropName];
544 if (app && !isConnected) {
545 var warehouse = app.getTypeWarehouse(creator.constructor);
546 var key = metadata_1.Metadata.getMeta(component).id || warehouse.size;
547 warehouse.set(key, component);
548 }
549 return component;
550 };
551 Component.getReducerFromTree = function (obj, visited) {
552 if (visited === void 0) { visited = new Set(); }
553 if (utils_1.isPrimitive(obj))
554 return undefined;
555 if (visited.has(obj))
556 return undefined;
557 visited.add(obj);
558 var rootReducer;
559 var meta = metadata_1.Metadata.getMeta(obj);
560 if (meta) {
561 rootReducer = meta.reducer;
562 }
563 else {
564 rootReducer = Component.identityReducer;
565 }
566 var subReducers = {};
567 for (var _i = 0, _a = Object.keys(obj); _i < _a.length; _i++) {
568 var key = _a[_i];
569 var newSubReducer = Component.getReducerFromTree(obj[key], visited);
570 if (typeof newSubReducer === 'function')
571 subReducers[key] = newSubReducer;
572 }
573 var resultReducer = rootReducer;
574 if (Object.keys(subReducers).length) {
575 var combinedSubReducer = utils_1.simpleCombineReducers(subReducers);
576 resultReducer = function (state, action) {
577 var thisState = rootReducer(state, action);
578 var subStates = combinedSubReducer(thisState, action);
579 var combinedState = __assign({}, thisState, subStates);
580 return combinedState;
581 };
582 }
583 return decorators_1.Computed.wrapReducer(resultReducer, obj);
584 };
585 Component.getComponentClass = function (creator) {
586 var schema = schema_1.Schema.getSchema(creator);
587 if (!schema.componentClass) {
588 schema.componentClass = Component.createComponentClass(creator);
589 schema.originalClass = creator.constructor;
590 }
591 return schema.componentClass;
592 };
593 Component.createComponentClass = function (creator) {
594 var ComponentClass = (function (_super) {
595 __extends(ComponentClass, _super);
596 function ComponentClass(store, creatorArg) {
597 var params = [];
598 for (var _i = 2; _i < arguments.length; _i++) {
599 params[_i - 2] = arguments[_i];
600 }
601 var _this = _super.apply(this, [store, creatorArg].concat(params)) || this;
602 _this.__originalClassName__ = creator.constructor.name;
603 if (!options_1.globalOptions.emitClassNames)
604 delete _this.__originalClassName__;
605 return _this;
606 }
607 return ComponentClass;
608 }(Component));
609 var actions = Component.createActions(creator);
610 Object.assign(ComponentClass.prototype, actions);
611 return ComponentClass;
612 };
613 Component.createActions = function (creator) {
614 var methods = utils_1.getMethods(creator);
615 if (!methods)
616 return undefined;
617 var schema = schema_1.Schema.getSchema(creator);
618 var componentActions = {};
619 Object.keys(methods).forEach(function (key) {
620 componentActions[key] = function () {
621 var payload = [];
622 for (var _i = 0; _i < arguments.length; _i++) {
623 payload[_i] = arguments[_i];
624 }
625 if (!(this instanceof Component))
626 throw new Error("Component method invoked with non-Component as 'this'. Bound 'this' argument is: " + this);
627 var oldMethod = methods[key];
628 if (schema.noDispatch[key]) {
629 oldMethod.call.apply(oldMethod, [this].concat(payload));
630 }
631 else {
632 var meta = metadata_1.Metadata.getMeta(this);
633 meta.dispatch({
634 type: options_1.getActionName(creator, key, schema.options),
635 id: (meta ? meta.id : undefined),
636 payload: payload
637 });
638 }
639 };
640 });
641 return componentActions;
642 };
643 Component.createSelf = function (component, store, creator, parentCreator, path) {
644 for (var _i = 0, _a = Object.getOwnPropertyNames(creator); _i < _a.length; _i++) {
645 var key = _a[_i];
646 var desc = Object.getOwnPropertyDescriptor(creator, key);
647 Object.defineProperty(component, key, desc);
648 }
649 var meta = metadata_1.Metadata.createMeta(component);
650 var schema = schema_1.Schema.getSchema(creator);
651 meta.id = decorators_1.ComponentId.getComponentId(parentCreator, path);
652 meta.originalClass = schema.originalClass;
653 decorators_1.Computed.setupComputedProps(component, schema, meta);
654 meta.dispatch = store.dispatch;
655 meta.reducer = Component.createReducer(component, creator);
656 };
657 Component.createSubComponents = function (obj, store, creator, path, visited) {
658 if (utils_1.isPrimitive(obj))
659 return;
660 if (visited.has(obj))
661 return;
662 visited.add(obj);
663 var searchIn = creator || obj;
664 for (var _i = 0, _a = Object.keys(searchIn); _i < _a.length; _i++) {
665 var key = _a[_i];
666 var subPath = path.concat([key]);
667 var subCreator = searchIn[key];
668 if (schema_1.Schema.getSchema(subCreator)) {
669 obj[key] = Component.create(store, subCreator, creator, subPath, visited);
670 }
671 else {
672 Component.createSubComponents(obj[key], store, null, subPath, visited);
673 }
674 }
675 };
676 Component.createReducer = function (component, creator) {
677 var methods = utils_1.getMethods(creator);
678 var options = schema_1.Schema.getSchema(creator).options;
679 var methodNames = {};
680 Object.keys(methods).forEach(function (methName) {
681 var actionName = options_1.getActionName(creator, methName, options);
682 methodNames[actionName] = methName;
683 });
684 var componentId = metadata_1.Metadata.getMeta(component).id;
685 return function (state, action) {
686 utils_1.log.verbose("[reducer] Reducer of: " + creator.constructor.name + ", action: " + action.type);
687 if (state === undefined) {
688 utils_1.log.verbose('[reducer] State is undefined, returning initial value');
689 return component;
690 }
691 if (componentId !== action.id) {
692 utils_1.log.verbose("[reducer] Component id and action.id don't match (" + componentId + " !== " + action.id + ")");
693 return state;
694 }
695 var methodName = methodNames[action.type];
696 var actionReducer = methods[methodName];
697 if (!actionReducer) {
698 utils_1.log.verbose('[reducer] No matching action in this reducer, returning previous state');
699 return state;
700 }
701 var newState = Object.assign({}, state);
702 actionReducer.call.apply(actionReducer, [newState].concat(action.payload));
703 utils_1.log.verbose('[reducer] Reducer invoked, returning new state');
704 return newState;
705 };
706 };
707 Component.identityReducer = function (state) { return state; };
708 return Component;
709}());
710exports.Component = Component;
711
712
713/***/ }),
714/* 11 */
715/***/ (function(module, exports, __webpack_require__) {
716
717"use strict";
718
719Object.defineProperty(exports, "__esModule", { value: true });
720var options_1 = __webpack_require__(2);
721var components_1 = __webpack_require__(0);
722function component(ctorOrOptions) {
723 if (typeof ctorOrOptions === 'function') {
724 componentDecorator.call(undefined, ctorOrOptions);
725 }
726 else {
727 return function (ctor) { return componentDecorator(ctor, ctorOrOptions); };
728 }
729}
730exports.component = component;
731function componentDecorator(ctor, options) {
732 var schema = components_1.Schema.getOrCreateSchema(ctor);
733 schema.options = Object.assign({}, options, new options_1.SchemaOptions(), options_1.globalOptions.schema);
734}
735
736
737/***/ }),
738/* 12 */
739/***/ (function(module, exports) {
740
741module.exports = require("lodash.snakecase");
742
743/***/ }),
744/* 13 */
745/***/ (function(module, exports, __webpack_require__) {
746
747"use strict";
748
749Object.defineProperty(exports, "__esModule", { value: true });
750var components_1 = __webpack_require__(0);
751var utils_1 = __webpack_require__(1);
752function computed(target, propertyKey) {
753 var descriptor = Object.getOwnPropertyDescriptor(target, propertyKey);
754 if (typeof descriptor.get !== 'function')
755 throw new Error("Failed to decorate '" + propertyKey + "'. The 'computed' decorator should only be used on getters.");
756 if (descriptor.set)
757 throw new Error("Failed to decorate '" + propertyKey + "'. Decorated property should not have a setter.");
758 delete target[propertyKey];
759 Object.defineProperty(target, propertyKey, utils_1.dataDescriptor);
760 var schema = components_1.Schema.getOrCreateSchema(target);
761 schema.computedGetters[propertyKey] = descriptor.get;
762}
763exports.computed = computed;
764var Computed = (function () {
765 function Computed() {
766 }
767 Computed.wrapReducer = function (reducer, obj) {
768 return function (state, action) {
769 var newState = reducer(state, action);
770 Computed.computeProps(obj, newState);
771 return newState;
772 };
773 };
774 Computed.setupComputedProps = function (component, schema, meta) {
775 for (var _i = 0, _a = Object.keys(schema.computedGetters); _i < _a.length; _i++) {
776 var propKey = _a[_i];
777 delete component[propKey];
778 }
779 meta.computedGetters = schema.computedGetters;
780 };
781 Computed.computeProps = function (obj, state) {
782 var meta = components_1.Metadata.getMeta(obj);
783 if (!meta)
784 return;
785 for (var _i = 0, _a = Object.keys(meta.computedGetters); _i < _a.length; _i++) {
786 var propKey = _a[_i];
787 var getter = meta.computedGetters[propKey];
788 utils_1.log.verbose("[computeProps] computing new value of '" + propKey + "'");
789 var newValue = getter.call(state);
790 var oldValue = state[propKey];
791 if (newValue !== oldValue) {
792 utils_1.log.verbose("[computeProps] updating the state of '" + propKey + "'. New value: '" + newValue + "', Old value: '" + oldValue + "'.");
793 delete state[propKey];
794 state[propKey] = newValue;
795 }
796 }
797 };
798 return Computed;
799}());
800exports.Computed = Computed;
801
802
803/***/ }),
804/* 14 */
805/***/ (function(module, exports, __webpack_require__) {
806
807"use strict";
808
809Object.defineProperty(exports, "__esModule", { value: true });
810exports.dataDescriptor = {
811 writable: true,
812 configurable: true,
813 enumerable: true
814};
815exports.accessorDescriptor = {
816 configurable: true,
817 enumerable: true
818};
819function deferredDefineProperty(target, propertyKey, descriptor) {
820 var init = function (isGet) { return function (newVal) {
821 Object.defineProperty(this, propertyKey, descriptor);
822 if (isGet) {
823 return this[propertyKey];
824 }
825 else {
826 this[propertyKey] = newVal;
827 }
828 }; };
829 return Object.defineProperty(target, propertyKey, {
830 get: init(true),
831 set: init(false),
832 enumerable: true,
833 configurable: true
834 });
835}
836exports.deferredDefineProperty = deferredDefineProperty;
837
838
839/***/ }),
840/* 15 */
841/***/ (function(module, exports, __webpack_require__) {
842
843"use strict";
844
845Object.defineProperty(exports, "__esModule", { value: true });
846var options_1 = __webpack_require__(2);
847var Log = (function () {
848 function Log() {
849 }
850 Log.prototype.verbose = function (message) {
851 var optionalParams = [];
852 for (var _i = 1; _i < arguments.length; _i++) {
853 optionalParams[_i - 1] = arguments[_i];
854 }
855 if (!this.shouldLog(options_1.LogLevel.Verbose))
856 return;
857 console.debug.apply(console, ['VERBOSE [redux-app] ' + message].concat(optionalParams));
858 };
859 Log.prototype.debug = function (message) {
860 var optionalParams = [];
861 for (var _i = 1; _i < arguments.length; _i++) {
862 optionalParams[_i - 1] = arguments[_i];
863 }
864 if (!this.shouldLog(options_1.LogLevel.Debug))
865 return;
866 console.log.apply(console, ['DEBUG [redux-app] ' + message].concat(optionalParams));
867 };
868 Log.prototype.warn = function (message) {
869 var optionalParams = [];
870 for (var _i = 1; _i < arguments.length; _i++) {
871 optionalParams[_i - 1] = arguments[_i];
872 }
873 if (!this.shouldLog(options_1.LogLevel.Warn))
874 return;
875 console.warn.apply(console, ['WARN [redux-app] ' + message].concat(optionalParams));
876 };
877 Log.prototype.shouldLog = function (level) {
878 if (options_1.globalOptions.logLevel === options_1.LogLevel.None)
879 return false;
880 if (options_1.globalOptions.logLevel > level)
881 return false;
882 return true;
883 };
884 return Log;
885}());
886exports.log = new Log();
887
888
889/***/ }),
890/* 16 */
891/***/ (function(module, exports, __webpack_require__) {
892
893"use strict";
894
895Object.defineProperty(exports, "__esModule", { value: true });
896function simpleCombineReducers(reducers) {
897 var reducerKeys = Object.keys(reducers);
898 return function combination(state, action) {
899 if (state === void 0) { state = {}; }
900 var hasChanged = false;
901 var nextState = {};
902 for (var _i = 0, reducerKeys_1 = reducerKeys; _i < reducerKeys_1.length; _i++) {
903 var key = reducerKeys_1[_i];
904 var reducer = reducers[key];
905 var previousStateForKey = state[key];
906 var nextStateForKey = reducer(previousStateForKey, action);
907 nextState[key] = nextStateForKey;
908 hasChanged = hasChanged || nextStateForKey !== previousStateForKey;
909 }
910 return hasChanged ? nextState : state;
911 };
912}
913exports.simpleCombineReducers = simpleCombineReducers;
914
915
916/***/ }),
917/* 17 */
918/***/ (function(module, exports, __webpack_require__) {
919
920"use strict";
921
922Object.defineProperty(exports, "__esModule", { value: true });
923function isPrimitive(val) {
924 if (!val)
925 return true;
926 var type = typeof val;
927 return type !== 'object' && type !== 'function';
928}
929exports.isPrimitive = isPrimitive;
930function getMethods(obj) {
931 if (!obj)
932 return undefined;
933 var proto = Object.getPrototypeOf(obj);
934 if (!proto)
935 return undefined;
936 var methods = {};
937 for (var _i = 0, _a = Object.keys(proto); _i < _a.length; _i++) {
938 var key = _a[_i];
939 var desc = Object.getOwnPropertyDescriptor(proto, key);
940 var hasGetter = desc && typeof desc.get === 'function';
941 if (!hasGetter && typeof proto[key] === 'function')
942 methods[key] = proto[key];
943 }
944 return methods;
945}
946exports.getMethods = getMethods;
947function getProp(obj, path) {
948 if (typeof path === 'string') {
949 path = path.replace(/\[|\]/g, '.').split('.').filter(function (token) { return typeof token === 'string' && token.trim() !== ''; });
950 }
951 return path.reduce(function (result, key) {
952 if (typeof result === 'object' && key) {
953 return result[key.toString()];
954 }
955 return undefined;
956 }, obj);
957}
958exports.getProp = getProp;
959function getConstructorProp(obj, key) {
960 return obj && obj.constructor && obj.constructor[key];
961}
962exports.getConstructorProp = getConstructorProp;
963function pathString(path) {
964 if (path.length) {
965 return "root." + path.join('.');
966 }
967 else {
968 return 'root';
969 }
970}
971exports.pathString = pathString;
972
973
974/***/ }),
975/* 18 */
976/***/ (function(module, exports, __webpack_require__) {
977
978"use strict";
979
980Object.defineProperty(exports, "__esModule", { value: true });
981__webpack_require__(19);
982var reduxApp_1 = __webpack_require__(3);
983var utils_1 = __webpack_require__(1);
984var ConnectOptions = (function () {
985 function ConnectOptions() {
986 this.app = reduxApp_1.DEFAULT_APP_NAME;
987 this.live = false;
988 }
989 return ConnectOptions;
990}());
991exports.ConnectOptions = ConnectOptions;
992function connect(targetOrOptions, propertyKeyOrNothing) {
993 if (propertyKeyOrNothing) {
994 connectDecorator.call(undefined, targetOrOptions, propertyKeyOrNothing);
995 }
996 else {
997 return function (target, propertyKey) { return connectDecorator(target, propertyKey, targetOrOptions); };
998 }
999}
1000exports.connect = connect;
1001function connectDecorator(target, propertyKey, options) {
1002 options = Object.assign(new ConnectOptions(), options);
1003 var value = target[propertyKey];
1004 var type = Reflect.getMetadata("design:type", target, propertyKey);
1005 if (!type) {
1006 var reflectErrMsg = "[connect] Failed to reflect type of property '" + propertyKey + "'. " +
1007 "Make sure you're using TypeScript and that the 'emitDecoratorMetadata' compiler " +
1008 "option in your tsconfig.json file is turned on. " +
1009 "Note that even if TypeScript is configured correctly it may fail to reflect " +
1010 "property types due to the loading order of your classes. " +
1011 ("In that case, make sure that the type of '" + propertyKey + "' is loaded prior to the ") +
1012 ("type of it's containing class (" + target.constructor.name + ").");
1013 throw new Error(reflectErrMsg);
1014 }
1015 var oldDescriptor = Object.getOwnPropertyDescriptor(target, propertyKey);
1016 var newDescriptor = {
1017 get: function () {
1018 var app = reduxApp_1.appsRepository[options.app];
1019 if (!app) {
1020 utils_1.log.debug("[connect] Application '" + options.app + "' does not exist. Property " + propertyKey + " is not connected.");
1021 if (oldDescriptor && oldDescriptor.get) {
1022 return oldDescriptor.get();
1023 }
1024 else {
1025 return value;
1026 }
1027 }
1028 var warehouse = app.getTypeWarehouse(type);
1029 var result;
1030 if (options.id) {
1031 result = warehouse.get(options.id);
1032 }
1033 else {
1034 result = warehouse.values().next().value;
1035 }
1036 if (result && !options.live) {
1037 Object.defineProperty(this, propertyKey, utils_1.dataDescriptor);
1038 value = this[propertyKey] = result;
1039 utils_1.log.debug("[connect] Property '" + propertyKey + "' connected. Type: " + type.name + ".");
1040 }
1041 return result;
1042 },
1043 set: function (newValue) {
1044 var app = reduxApp_1.appsRepository[options.app];
1045 if (app) {
1046 utils_1.log.warn("[connect] Connected component '" + propertyKey + "' value assigned. Component disconnected.");
1047 }
1048 if (oldDescriptor && oldDescriptor.set) {
1049 return oldDescriptor.set(newValue);
1050 }
1051 else if (!oldDescriptor || oldDescriptor && oldDescriptor.writable) {
1052 return value = newValue;
1053 }
1054 }
1055 };
1056 return utils_1.deferredDefineProperty(target, propertyKey, Object.assign({}, utils_1.accessorDescriptor, newDescriptor));
1057}
1058
1059
1060/***/ }),
1061/* 19 */
1062/***/ (function(module, exports) {
1063
1064module.exports = require("reflect-metadata");
1065
1066/***/ }),
1067/* 20 */
1068/***/ (function(module, exports) {
1069
1070module.exports = require("redux");
1071
1072/***/ }),
1073/* 21 */
1074/***/ (function(module, exports, __webpack_require__) {
1075
1076"use strict";
1077
1078Object.defineProperty(exports, "__esModule", { value: true });
1079var components_1 = __webpack_require__(0);
1080function noDispatch(target, propertyKey) {
1081 noDispatchDecorator(target, propertyKey);
1082}
1083exports.noDispatch = noDispatch;
1084function sequence(target, propertyKey) {
1085 noDispatchDecorator(target, propertyKey);
1086}
1087exports.sequence = sequence;
1088function noDispatchDecorator(target, propertyKey) {
1089 var schema = components_1.Schema.getOrCreateSchema(target);
1090 schema.noDispatch[propertyKey] = true;
1091}
1092
1093
1094/***/ }),
1095/* 22 */
1096/***/ (function(module, exports, __webpack_require__) {
1097
1098"use strict";
1099
1100Object.defineProperty(exports, "__esModule", { value: true });
1101var components_1 = __webpack_require__(0);
1102var symbols_1 = __webpack_require__(4);
1103var utils_1 = __webpack_require__(1);
1104function withId(targetOrId, propertyKeyOrNothing) {
1105 if (propertyKeyOrNothing) {
1106 withIdDecorator.call(undefined, targetOrId, propertyKeyOrNothing);
1107 }
1108 else {
1109 return function (target, propertyKey) { return withIdDecorator(target, propertyKey, targetOrId); };
1110 }
1111}
1112exports.withId = withId;
1113function withIdDecorator(target, propertyKey, id) {
1114 var schema = components_1.Schema.getOrCreateSchema(target);
1115 schema.childIds[propertyKey] = id || symbols_1.AUTO_ID;
1116}
1117var ComponentId = (function () {
1118 function ComponentId() {
1119 }
1120 ComponentId.getComponentId = function (parentCreator, path) {
1121 var schema = components_1.Schema.getSchema(parentCreator);
1122 if (!parentCreator || !path.length)
1123 return undefined;
1124 var selfKey = path[path.length - 1];
1125 var id = schema.childIds[selfKey];
1126 if (!id)
1127 return undefined;
1128 if (id === symbols_1.AUTO_ID) {
1129 var generatedId = --ComponentId.autoComponentId;
1130 utils_1.log.verbose('[getComponentId] new component id generated: ' + generatedId);
1131 schema.childIds[selfKey] = generatedId;
1132 return generatedId;
1133 }
1134 return id;
1135 };
1136 ComponentId.autoComponentId = 0;
1137 return ComponentId;
1138}());
1139exports.ComponentId = ComponentId;
1140
1141
1142/***/ }),
1143/* 23 */
1144/***/ (function(module, exports, __webpack_require__) {
1145
1146"use strict";
1147
1148Object.defineProperty(exports, "__esModule", { value: true });
1149var metadata_1 = __webpack_require__(5);
1150function isInstanceOf(obj, type) {
1151 if (obj instanceof type)
1152 return true;
1153 var meta = metadata_1.Metadata.getMeta(obj);
1154 return !!(meta && meta.originalClass === type);
1155}
1156exports.isInstanceOf = isInstanceOf;
1157
1158
1159/***/ })
1160/******/ ]);
1161});
1162//# sourceMappingURL=redux-app.js.map
\No newline at end of file