@genialis/resolwe
Advanced tools
Comparing version 11.1.0 to 12.0.0
@@ -24,2 +24,1 @@ import * as Rx from 'rx'; | ||
} | ||
//# sourceMappingURL=auth.d.ts.map |
@@ -18,2 +18,1 @@ import * as Rx from 'rx'; | ||
} | ||
//# sourceMappingURL=base.d.ts.map |
@@ -220,2 +220,1 @@ import * as Rx from 'rx'; | ||
} | ||
//# sourceMappingURL=connection.d.ts.map |
@@ -48,2 +48,1 @@ import { GenError } from '../core/errors/error'; | ||
} | ||
//# sourceMappingURL=errors.d.ts.map |
@@ -38,2 +38,1 @@ import { Connection } from './connection'; | ||
} | ||
//# sourceMappingURL=index.d.ts.map |
@@ -5,3 +5,3 @@ import * as Rx from 'rx'; | ||
import { APIError } from './errors'; | ||
import { Query, Sample, Collection, Data } from './types/rest'; | ||
import { Query, Collection, Data } from './types/rest'; | ||
import { ResolweApi } from './index'; | ||
@@ -349,9 +349,4 @@ /** | ||
/** | ||
* Helper function for supporting filtering by descriptor_completed, which can be used as a [[MockQueryEvaluator]]. | ||
*/ | ||
export declare function annotatedQuery<T extends Sample>(query: any, items: T[]): T[]; | ||
/** | ||
* Helper function for supporting filtering by slug, which can be used as a [[MockQueryEvaluator]]. | ||
*/ | ||
export declare function slugQuery<T extends Collection | Data>(query: any, items: T[]): T[]; | ||
//# sourceMappingURL=mock.d.ts.map |
@@ -166,2 +166,1 @@ import * as Rx from 'rx'; | ||
} | ||
//# sourceMappingURL=queryobserver.d.ts.map |
@@ -325,2 +325,2 @@ "use strict"; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/api/queryobserver.ts"],"names":[],"mappings":";;AAAA,0BAA4B;AAC5B,uBAAyB;AACzB,qCAAuC;AAGvC,qDAAsD;AACtD,mCAA6C;AAE7C,0BAA0B;AACb,QAAA,aAAa,GAAG,OAAO,CAAC;AACxB,QAAA,eAAe,GAAG,SAAS,CAAC;AAC5B,QAAA,eAAe,GAAG,SAAS,CAAC;AAEzC;;GAEG;AACH,IAAY,mBAMX;AAND,WAAY,mBAAmB;IAC3B,2DAAG,CAAA;IACH,6EAAY,CAAA;IACZ,2EAAW,CAAA;IACX,iFAAc,CAAA;IACd,mEAAO,CAAA;AACX,CAAC,EANW,mBAAmB,GAAnB,2BAAmB,KAAnB,2BAAmB,QAM9B;AAMD;;;GAGG;AACH;IAUI;;;;;OAKG;IACH,uBAAmB,EAAU,EAAU,qBAA2C;QAAlF,iBASC;QATkB,OAAE,GAAF,EAAE,CAAQ;QAAU,0BAAqB,GAArB,qBAAqB,CAAsB;QAC9E,IAAI,CAAC,MAAM,GAAG,mBAAmB,CAAC,GAAG,CAAC;QACtC,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAChB,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC,IAAI,EAAE,CAAC;QAC/B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,UAAC,QAAQ;YACpD,KAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC;YACjC,OAAO,KAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAI,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAED;;;OAGG;IACI,4BAAI,GAAX;QACI,IAAI,CAAC,MAAM,GAAG,mBAAmB,CAAC,OAAO,CAAC;QAC1C,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC/C,CAAC;IAED;;;;;;OAMG;IACI,8CAAsB,GAA7B,UAA8B,OAA4B;QACtD,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC;IACjC,CAAC;IAED;;;;OAIG;IACI,oCAAY,GAAnB;QAAA,iBAsBC;QArBG,IAAI,IAAI,CAAC,MAAM,KAAK,mBAAmB,CAAC,WAAW,EAAE;YACjD,OAAO;SACV;QAED,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACrB,IAAM,KAAK,GAAG,IAAI,4BAAmB,CAAC,8EAA8E,CAAC,CAAC;YACtH,IAAI,CAAC,qBAAqB,CAAC,aAAa,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACvD,OAAO;SACV;QAED,IAAI,CAAC,MAAM,GAAG,mBAAmB,CAAC,cAAc,CAAC;QACjD,IAAI,CAAC,aAAa,EAAE,CAAC,SAAS,CAAC,UAAC,QAA+B;YAC3D,uEAAuE;YACvE,IAAM,KAAK,GAAG,KAAI,CAAC,EAAE,CAAC;YACtB,KAAI,CAAC,EAAE,GAAG,QAAQ,CAAC,QAAQ,CAAC;YAC5B,KAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,KAAK,EAAE,KAAI,CAAC,CAAC;YAE7C,4BAA4B;YAC5B,KAAI,CAAC,MAAM,GAAG,mBAAmB,CAAC,GAAG,CAAC;YACtC,KAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;;OAKG;IACI,gCAAQ,GAAf,UAAgB,QAAuB;QACnC,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAC1C,QAAQ,CAAC,YAAY,GAAG,IAAI,CAAC;IACjC,CAAC;IAED;;;;OAIG;IACI,kCAAU,GAAjB,UAAkB,KAAY;QAC1B,IAAI,IAAI,CAAC,MAAM,KAAK,mBAAmB,CAAC,GAAG,EAAE;YACzC,OAAO;SACV;QAED,IAAI,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE;YACtB,IAAM,KAAK,GAAG,IAAI,4BAAmB,CAAC,qEAAqE,CAAC,CAAC;YAC7G,IAAI,CAAC,qBAAqB,CAAC,aAAa,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAEvD,KAAK,GAAG,EAAE,CAAC;SACd;QAED,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACtC,IAAI,CAAC,MAAM,GAAG,mBAAmB,CAAC,YAAY,CAAC;QAE/C,+BAA+B;QAC/B,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACrD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QAEzB,IAAI,CAAC,MAAM,GAAG,mBAAmB,CAAC,WAAW,CAAC;QAC9C,IAAI,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC;IAED;;;;OAIG;IACI,8BAAM,GAAb,UAAc,OAAgB;QAC1B,IAAI,IAAI,CAAC,MAAM,KAAK,mBAAmB,CAAC,OAAO,IAAI,IAAI,CAAC,MAAM,KAAK,mBAAmB,CAAC,cAAc,EAAE;YACnG,OAAO;SACV;aAAM,IAAI,IAAI,CAAC,MAAM,KAAK,mBAAmB,CAAC,GAAG,EAAE;YAChD,sEAAsE;YACtE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAChC,OAAO;SACV;QAED,IAAI,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;QACxB,IAAI,IAAI,GAAG,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC1C,QAAQ,OAAO,CAAC,GAAG,EAAE;YACjB,KAAK,qBAAa,CAAC,CAAC;gBAChB,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;gBAC1C,MAAM;aACT;YACD,KAAK,uBAAe,CAAC,CAAC;gBAClB,KAAK,GAAG,KAAK,CAAC,SAAS,CACnB,UAAC,KAAK,IAAK,OAAA,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,KAAK,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,EAAhE,CAAgE,CAC9E,CAAC,MAAM,EAAE,CAAC;gBACX,MAAM;aACT;YACD,KAAK,uBAAe,CAAC,CAAC;gBAClB,IAAI,KAAK,GAAG,KAAK,CAAC,SAAS,CACvB,UAAC,KAAK,IAAK,OAAA,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,KAAK,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,EAAhE,CAAgE,CAC9E,CAAC;gBACF,IAAI,KAAK,IAAI,CAAC,EAAE;oBACZ,IAAI,KAAK,KAAK,OAAO,CAAC,KAAK,EAAE;wBACzB,yCAAyC;wBACzC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;qBAC3D;yBAAM;wBACH,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;qBAClC;iBACJ;gBACD,MAAM;aACT;YACD,OAAO,CAAC,CAAC;gBACL,IAAM,KAAK,GAAG,IAAI,4BAAmB,CAAC,0BAAwB,OAAO,CAAC,GAAK,CAAC,CAAC;gBAC7E,IAAI,CAAC,qBAAqB,CAAC,aAAa,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;aAC1D;SACJ;QAED,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QAEpB,mCAAmC;QACnC,IAAI,IAAI,CAAC,MAAM,KAAK,mBAAmB,CAAC,WAAW,EAAE;YACjD,IAAI,CAAC,OAAO,EAAE,CAAC;SAClB;IACL,CAAC;IAED;;OAEG;IACK,+BAAO,GAAf;QACI,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QAChC,yBAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE1B,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC;IAED;;;OAGG;IACI,kCAAU,GAAjB;QACI,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACnC,CAAC;IACL,oBAAC;AAAD,CA3LA,AA2LC,IAAA;AA3LY,sCAAa;AAoM1B;;GAEG;AACH;IAII;;OAEG;IACH,8BAAoB,WAAuB,EAAU,OAAyC;QAA1E,gBAAW,GAAX,WAAW,CAAY;QAAU,YAAO,GAAP,OAAO,CAAkC;QALtF,sBAAiB,GAAG,OAAO,CAAC,OAAO,CAAM,EAAE,CAAC,CAAC;QAMjD,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACzB,CAAC;IAKD,sBAAW,+CAAa;QAHxB;;WAEG;aACH;YACI,OAAO,IAAI,CAAC,OAAO,CAAC;QACxB,CAAC;;;OAAA;IAED;;;;;;OAMG;IACI,kCAAG,GAAV,UAAW,UAAkB,EAAE,MAAsB;QAAtB,uBAAA,EAAA,aAAsB;QACjD,mEAAmE;QACnE,IAAI,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;QAC3C,IAAI,CAAC,QAAQ,IAAI,MAAM,EAAE;YACrB,QAAQ,GAAG,IAAI,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;YAC/C,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,GAAG,QAAQ,CAAC;SAC1C;QAED,OAAO,QAAQ,CAAC;IACpB,CAAC;IAED;;;;OAIG;IACO,8CAAe,GAAzB,UAA0B,UAAkB;QACxC,OAAO,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;IACvC,CAAC;IAED;;;;OAIG;IACO,2CAAY,GAAtB,UAA0B,UAAkB;QACxC,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAI,gCAAgC,EAAE,EAAE,EAAE;YAClE,QAAQ,EAAE,UAAU;YACpB,UAAU,EAAE,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE;SAC3C,CAAC,CAAC;IACP,CAAC;IAED;;;;;;;OAOG;IACI,qCAAM,GAAb,UAAc,UAAkB;QAAhC,iBAQC;QAPG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QAEjC,gFAAgF;QAChF,qEAAqE;QACrE,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;YACjD,OAAO,KAAI,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,SAAS,EAAE,CAAC;QACrD,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;OAEG;IACI,oDAAqB,GAA5B,UAAgC,cAAsC;QAClE,OAAO,EAAE,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC;YAC7D,OAAO,cAAc,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;;OAKG;IACI,mCAAI,GAAX,UAAY,aAAqB,EAAE,QAAuB;QACtD,IAAI,aAAa,KAAK,QAAQ,CAAC,EAAE,EAAE;YAC/B,OAAO;SACV;QAED,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;QAE3B,gFAAgF;QAChF,sEAAsE;QACtE,IAAI,gBAAgB,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QACpD,IAAI,gBAAgB,EAAE;YAClB,QAAQ,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAC;SACvC;QAED,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC;IAC5C,CAAC;IAED;;;;OAIG;IACI,qCAAM,GAAb,UAAc,OAAgB;QAC1B,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAC/C,CAAC;IAED;;;;;OAKG;IACI,yCAAU,GAAjB,UAAkB,UAAkB;QAChC,OAAO,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,UAAU,EAAE,CAAC;IAC7C,CAAC;IAED;;;;;OAKG;IACI,2CAAY,GAAnB;QACI,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,UAAC,QAAQ;YAC/B,QAAQ,CAAC,YAAY,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;IACP,CAAC;IACL,2BAAC;AAAD,CAzIA,AAyIC,IAAA;AAzIY,oDAAoB","file":"api/queryobserver.js","sourcesContent":["import * as _ from 'lodash';\nimport * as Rx from 'rx';\nimport * as immutable from 'immutable';\n\nimport {Message, Connection, QueryObserverResponse} from './connection';\nimport {makeImmutable} from '../core/utils/immutable';\nimport {QueryObserversError} from './errors';\n\n// Possible message types.\nexport const MESSAGE_ADDED = 'added';\nexport const MESSAGE_CHANGED = 'changed';\nexport const MESSAGE_REMOVED = 'removed';\n\n/**\n * Valid query observer statuses.\n */\nexport enum QueryObserverStatus {\n    NEW,\n    INITIALIZING,\n    INITIALIZED,\n    REINITIALIZING,\n    STOPPED\n}\n\nexport interface ReinitializeHandler {\n    (): Rx.Observable<Object>;\n}\n\n/**\n * A local copy of the query observer that is synchronized with the remote\n * instance on the genesis platform server.\n */\nexport class QueryObserver {\n    public status: QueryObserverStatus;\n    public items: any[];\n    private _items: immutable.List<any>;\n\n    private _updateQueue: Message[];\n    private _updatesObservable: Rx.Observable<any>;\n    private _updatesObserver: Rx.Observer<any>;\n    private _reinitialize: ReinitializeHandler;\n\n    /**\n     * Constructs a new query observer.\n     *\n     * @param {string} id Unique query observer identifier\n     * @param {QueryObserverManager} queryObserverManager Query observer manager\n     */\n    constructor(public id: string, private _queryObserverManager: QueryObserverManager) {\n        this.status = QueryObserverStatus.NEW;\n        this.items = [];\n        this._items = immutable.List();\n        this._updateQueue = [];\n        this._updatesObservable = Rx.Observable.create((observer) => {\n            this._updatesObserver = observer;\n            return this.stop.bind(this);\n        }).publish().refCount();\n    }\n\n    /**\n     * Stops the query observer. There should be no need to call this method\n     * manually.\n     */\n    public stop() {\n        this.status = QueryObserverStatus.STOPPED;\n        this._queryObserverManager.remove(this.id);\n    }\n\n    /**\n     * Sets up a reinitialization handler for this query observer. The handler will be\n     * called when the query observer needs to be reinitialized and it should return\n     * an Rx.Observable, which produces the initial QueryObserverResponse.\n     *\n     * @param {ReinitializeHandler} handler Reinitialization handler\n     */\n    public setReinitializeHandler(handler: ReinitializeHandler) {\n        this._reinitialize = handler;\n    }\n\n    /**\n     * Starts query observer reinitialization. This method should be called when some\n     * internal connection state changes (for example, when user authentication state\n     * is changed).\n     */\n    public reinitialize() {\n        if (this.status !== QueryObserverStatus.INITIALIZED) {\n            return;\n        }\n\n        if (!this._reinitialize) {\n            const error = new QueryObserversError('Attempted to reinitialize a QueryObserver without a reinitialization handler');\n            this._queryObserverManager.errorObserver.onNext(error);\n            return;\n        }\n\n        this.status = QueryObserverStatus.REINITIALIZING;\n        this._reinitialize().subscribe((response: QueryObserverResponse) => {\n            // Observer identifier might have changed, update observer and manager.\n            const oldId = this.id;\n            this.id = response.observer;\n            this._queryObserverManager.move(oldId, this);\n\n            // Perform reinitialization.\n            this.status = QueryObserverStatus.NEW;\n            this.initialize(response.items);\n        });\n    }\n\n    /**\n     * Moves an existing query observer into this query observer. The source query observer\n     * should be considered invalid after this operation.\n     *\n     * @param {QueryObserver} observer Source query observer\n     */\n    public moveFrom(observer: QueryObserver) {\n        this._updateQueue = observer._updateQueue;\n        observer._updateQueue = null;\n    }\n\n    /**\n     * Initializes the query observer.\n     *\n     * @param {any[]} items An initial list of items\n     */\n    public initialize(items: any[]) {\n        if (this.status !== QueryObserverStatus.NEW) {\n            return;\n        }\n\n        if (_.isUndefined(items)) {\n            const error = new QueryObserversError('Invalid response received from backend, is the resource observable?');\n            this._queryObserverManager.errorObserver.onNext(error);\n\n            items = [];\n        }\n\n        this._items = immutable.fromJS(items);\n        this.status = QueryObserverStatus.INITIALIZING;\n\n        // Process all queued messages.\n        _.forEach(this._updateQueue, this.update.bind(this));\n        this._updateQueue = null;\n\n        this.status = QueryObserverStatus.INITIALIZED;\n        this._notify();\n    }\n\n    /**\n     * Updates the item cache based on an incoming message.\n     *\n     * @param {Message} message Message instance\n     */\n    public update(message: Message) {\n        if (this.status === QueryObserverStatus.STOPPED || this.status === QueryObserverStatus.REINITIALIZING) {\n            return;\n        } else if (this.status === QueryObserverStatus.NEW) {\n            // Just queue the update for later as we haven't yet been initialized.\n            this._updateQueue.push(message);\n            return;\n        }\n\n        let items = this._items;\n        let item = immutable.fromJS(message.item);\n        switch (message.msg) {\n            case MESSAGE_ADDED: {\n                items = items.insert(message.order, item);\n                break;\n            }\n            case MESSAGE_REMOVED: {\n                items = items.filterNot(\n                    (other) => item.get(message.primary_key) === other.get(message.primary_key)\n                ).toList();\n                break;\n            }\n            case MESSAGE_CHANGED: {\n                let index = items.findIndex(\n                    (other) => item.get(message.primary_key) === other.get(message.primary_key)\n                );\n                if (index >= 0) {\n                    if (index !== message.order) {\n                        // Item order has changed, move the item.\n                        items = items.remove(index).insert(message.order, item);\n                    } else {\n                        items = items.set(index, item);\n                    }\n                }\n                break;\n            }\n            default: {\n                const error = new QueryObserversError(`Unknown message type ${message.msg}`);\n                this._queryObserverManager.errorObserver.onNext(error);\n            }\n        }\n\n        this._items = items;\n\n        // Push updates to all subscribers.\n        if (this.status === QueryObserverStatus.INITIALIZED) {\n            this._notify();\n        }\n    }\n\n    /**\n     * Notifies subscribers of new items.\n     */\n    private _notify(): void {\n        this.items = this._items.toJS();\n        makeImmutable(this.items);\n\n        this._updatesObserver.onNext(this.items);\n    }\n\n    /**\n     * Returns an observable that will emit a list of items when any changes\n     * happen to the observed query.\n     */\n    public observable(): Rx.Observable<any> {\n        return this._updatesObservable;\n    }\n}\n\n/**\n * A dictionary containing the query observers, indexed by their identifier.\n */\ninterface QueryObserverMap {\n    [index: string]: QueryObserver;\n}\n\n/**\n * Manages all active query observers.\n */\nexport class QueryObserverManager {\n    private _observers: QueryObserverMap;\n    private _unsubscribeChain = Promise.resolve<any>({});\n\n    /**\n     * Constructs a new query observer manager.\n     */\n    constructor(private _connection: Connection, private _errors: Rx.Observer<QueryObserversError>) {\n        this._observers = {};\n    }\n\n    /**\n     * Error observer getter for notifying about query observer errors.\n     */\n    public get errorObserver(): Rx.Observer<QueryObserversError> {\n        return this._errors;\n    }\n\n    /**\n     * Returns a query observer with a specific identifier.\n     *\n     * @param {string} observerId Query observer identifier\n     * @param {boolean} create Should a new query observer be created if one with the specified identifier does not yet exist\n     * @return {QueryObserver} Query observer instance\n     */\n    public get(observerId: string, create: boolean = true): QueryObserver {\n        // If the specific observer does not yet exist, create a new entry.\n        let observer = this._observers[observerId];\n        if (!observer && create) {\n            observer = new QueryObserver(observerId, this);\n            this._observers[observerId] = observer;\n        }\n\n        return observer;\n    }\n\n    /**\n     * Deletes a query observer with the specified identifier.\n     *\n     * @param observerId Query observer identifier\n     */\n    protected _deleteObserver(observerId: string) {\n        delete this._observers[observerId];\n    }\n\n    /**\n     * Requests the backend to unsubscribe us from this observer.\n     *\n     * @param observerId Query observer identifier\n     */\n    protected _unsubscribe<T>(observerId: string): Rx.Observable<T> {\n        return this._connection.post<T>('/api/queryobserver/unsubscribe', {}, {\n            observer: observerId,\n            subscriber: this._connection.sessionId(),\n        });\n    }\n\n    /**\n     * Removes a query observer with a specific identifier.\n     *\n     * Rx has no way of waiting for dispose to finish, that's why\n     * we defer reactive queries after unsubscribe is finished.\n     *\n     * @param {string} observerId Query observer identifier\n     */\n    public remove(observerId: string) {\n        this._deleteObserver(observerId);\n\n        // Using promises, because we couldn't get observables to unsubscribe only once.\n        // Even using .take(1) didn't seem to correctly limit number of emits\n        this._unsubscribeChain = this._unsubscribeChain.then(() => {\n            return this._unsubscribe(observerId).toPromise();\n        });\n    }\n\n    /**\n     * Calls a function that creates an observable, after previous unsubscribe request finishes.\n     */\n    public chainAfterUnsubscribe<T>(makeObservable: () => Rx.Observable<T>): Rx.Observable<T> {\n        return Rx.Observable.fromPromise(this._unsubscribeChain).flatMap(() => {\n            return makeObservable();\n        });\n    }\n\n    /**\n     * Changes a query observer's identifier.\n     *\n     * @param {string} oldObserverId Old query observer identifier\n     * @param {QueryObserver} observer New query observer\n     */\n    public move(oldObserverId: string, observer: QueryObserver) {\n        if (oldObserverId === observer.id) {\n            return;\n        }\n\n        this.remove(oldObserverId);\n\n        // The observer we are moving into might have already received some messages. In\n        // this case, we need to move the queued messages to the old observer.\n        let existingObserver = this._observers[observer.id];\n        if (existingObserver) {\n            observer.moveFrom(existingObserver);\n        }\n\n        this._observers[observer.id] = observer;\n    }\n\n    /**\n     * Updates the query observers based on an incoming message.\n     *\n     * @param {Message} message Message instance\n     */\n    public update(message: Message) {\n        this.get(message.observer).update(message);\n    }\n\n    /**\n     * Returns an observable that will emit a list of items when any changes\n     * happen to the observed query.\n     *\n     * @param {string} observerId Query observer identifier\n     */\n    public observable(observerId: string): Rx.Observable<Object> {\n        return this.get(observerId).observable();\n    }\n\n    /**\n     * Requests all query observers to start reinitialization.\n     *\n     * This method should be called when some internal connection state changes\n     * (for example, when user authentication state is changed).\n     */\n    public reinitialize() {\n        _.forOwn(this._observers, (observer) => {\n            observer.reinitialize();\n        });\n    }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/api/queryobserver.ts"],"names":[],"mappings":"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","file":"api/queryobserver.js","sourcesContent":["import * as _ from 'lodash';\nimport * as Rx from 'rx';\nimport * as immutable from 'immutable';\n\nimport {Message, Connection, QueryObserverResponse} from './connection';\nimport {makeImmutable} from '../core/utils/immutable';\nimport {QueryObserversError} from './errors';\n\n// Possible message types.\nexport const MESSAGE_ADDED = 'added';\nexport const MESSAGE_CHANGED = 'changed';\nexport const MESSAGE_REMOVED = 'removed';\n\n/**\n * Valid query observer statuses.\n */\nexport enum QueryObserverStatus {\n    NEW,\n    INITIALIZING,\n    INITIALIZED,\n    REINITIALIZING,\n    STOPPED,\n}\n\nexport interface ReinitializeHandler {\n    (): Rx.Observable<Object>;\n}\n\n/**\n * A local copy of the query observer that is synchronized with the remote\n * instance on the genesis platform server.\n */\nexport class QueryObserver {\n    public status: QueryObserverStatus;\n    public items: any[];\n    private _items: immutable.List<any>;\n\n    private _updateQueue: Message[];\n    private _updatesObservable: Rx.Observable<any>;\n    private _updatesObserver: Rx.Observer<any>;\n    private _reinitialize: ReinitializeHandler;\n\n    /**\n     * Constructs a new query observer.\n     *\n     * @param {string} id Unique query observer identifier\n     * @param {QueryObserverManager} queryObserverManager Query observer manager\n     */\n    constructor(public id: string, private _queryObserverManager: QueryObserverManager) {\n        this.status = QueryObserverStatus.NEW;\n        this.items = [];\n        this._items = immutable.List();\n        this._updateQueue = [];\n        this._updatesObservable = Rx.Observable.create((observer) => {\n            this._updatesObserver = observer;\n            return this.stop.bind(this);\n        }).publish().refCount();\n    }\n\n    /**\n     * Stops the query observer. There should be no need to call this method\n     * manually.\n     */\n    public stop() {\n        this.status = QueryObserverStatus.STOPPED;\n        this._queryObserverManager.remove(this.id);\n    }\n\n    /**\n     * Sets up a reinitialization handler for this query observer. The handler will be\n     * called when the query observer needs to be reinitialized and it should return\n     * an Rx.Observable, which produces the initial QueryObserverResponse.\n     *\n     * @param {ReinitializeHandler} handler Reinitialization handler\n     */\n    public setReinitializeHandler(handler: ReinitializeHandler) {\n        this._reinitialize = handler;\n    }\n\n    /**\n     * Starts query observer reinitialization. This method should be called when some\n     * internal connection state changes (for example, when user authentication state\n     * is changed).\n     */\n    public reinitialize() {\n        if (this.status !== QueryObserverStatus.INITIALIZED) {\n            return;\n        }\n\n        if (!this._reinitialize) {\n            const error = new QueryObserversError('Attempted to reinitialize a QueryObserver without a reinitialization handler');\n            this._queryObserverManager.errorObserver.onNext(error);\n            return;\n        }\n\n        this.status = QueryObserverStatus.REINITIALIZING;\n        this._reinitialize().subscribe((response: QueryObserverResponse) => {\n            // Observer identifier might have changed, update observer and manager.\n            const oldId = this.id;\n            this.id = response.observer;\n            this._queryObserverManager.move(oldId, this);\n\n            // Perform reinitialization.\n            this.status = QueryObserverStatus.NEW;\n            this.initialize(response.items);\n        });\n    }\n\n    /**\n     * Moves an existing query observer into this query observer. The source query observer\n     * should be considered invalid after this operation.\n     *\n     * @param {QueryObserver} observer Source query observer\n     */\n    public moveFrom(observer: QueryObserver) {\n        this._updateQueue = observer._updateQueue;\n        observer._updateQueue = null;\n    }\n\n    /**\n     * Initializes the query observer.\n     *\n     * @param {any[]} items An initial list of items\n     */\n    public initialize(items: any[]) {\n        if (this.status !== QueryObserverStatus.NEW) {\n            return;\n        }\n\n        if (_.isUndefined(items)) {\n            const error = new QueryObserversError('Invalid response received from backend, is the resource observable?');\n            this._queryObserverManager.errorObserver.onNext(error);\n\n            items = [];\n        }\n\n        this._items = immutable.fromJS(items);\n        this.status = QueryObserverStatus.INITIALIZING;\n\n        // Process all queued messages.\n        _.forEach(this._updateQueue, this.update.bind(this));\n        this._updateQueue = null;\n\n        this.status = QueryObserverStatus.INITIALIZED;\n        this._notify();\n    }\n\n    /**\n     * Updates the item cache based on an incoming message.\n     *\n     * @param {Message} message Message instance\n     */\n    public update(message: Message) {\n        if (this.status === QueryObserverStatus.STOPPED || this.status === QueryObserverStatus.REINITIALIZING) {\n            return;\n        } else if (this.status === QueryObserverStatus.NEW) {\n            // Just queue the update for later as we haven't yet been initialized.\n            this._updateQueue.push(message);\n            return;\n        }\n\n        let items = this._items;\n        let item = immutable.fromJS(message.item);\n        switch (message.msg) {\n            case MESSAGE_ADDED: {\n                items = items.insert(message.order, item);\n                break;\n            }\n            case MESSAGE_REMOVED: {\n                items = items.filterNot(\n                    (other) => item.get(message.primary_key) === other.get(message.primary_key)\n                ).toList();\n                break;\n            }\n            case MESSAGE_CHANGED: {\n                let index = items.findIndex(\n                    (other) => item.get(message.primary_key) === other.get(message.primary_key)\n                );\n                if (index >= 0) {\n                    if (index !== message.order) {\n                        // Item order has changed, move the item.\n                        items = items.remove(index).insert(message.order, item);\n                    } else {\n                        items = items.set(index, item);\n                    }\n                }\n                break;\n            }\n            default: {\n                const error = new QueryObserversError(`Unknown message type ${message.msg}`);\n                this._queryObserverManager.errorObserver.onNext(error);\n            }\n        }\n\n        this._items = items;\n\n        // Push updates to all subscribers.\n        if (this.status === QueryObserverStatus.INITIALIZED) {\n            this._notify();\n        }\n    }\n\n    /**\n     * Notifies subscribers of new items.\n     */\n    private _notify(): void {\n        this.items = this._items.toJS();\n        makeImmutable(this.items);\n\n        this._updatesObserver.onNext(this.items);\n    }\n\n    /**\n     * Returns an observable that will emit a list of items when any changes\n     * happen to the observed query.\n     */\n    public observable(): Rx.Observable<any> {\n        return this._updatesObservable;\n    }\n}\n\n/**\n * A dictionary containing the query observers, indexed by their identifier.\n */\ninterface QueryObserverMap {\n    [index: string]: QueryObserver;\n}\n\n/**\n * Manages all active query observers.\n */\nexport class QueryObserverManager {\n    private _observers: QueryObserverMap;\n    private _unsubscribeChain = Promise.resolve<any>({});\n\n    /**\n     * Constructs a new query observer manager.\n     */\n    constructor(private _connection: Connection, private _errors: Rx.Observer<QueryObserversError>) {\n        this._observers = {};\n    }\n\n    /**\n     * Error observer getter for notifying about query observer errors.\n     */\n    public get errorObserver(): Rx.Observer<QueryObserversError> {\n        return this._errors;\n    }\n\n    /**\n     * Returns a query observer with a specific identifier.\n     *\n     * @param {string} observerId Query observer identifier\n     * @param {boolean} create Should a new query observer be created if one with the specified identifier does not yet exist\n     * @return {QueryObserver} Query observer instance\n     */\n    public get(observerId: string, create: boolean = true): QueryObserver {\n        // If the specific observer does not yet exist, create a new entry.\n        let observer = this._observers[observerId];\n        if (!observer && create) {\n            observer = new QueryObserver(observerId, this);\n            this._observers[observerId] = observer;\n        }\n\n        return observer;\n    }\n\n    /**\n     * Deletes a query observer with the specified identifier.\n     *\n     * @param observerId Query observer identifier\n     */\n    protected _deleteObserver(observerId: string) {\n        delete this._observers[observerId];\n    }\n\n    /**\n     * Requests the backend to unsubscribe us from this observer.\n     *\n     * @param observerId Query observer identifier\n     */\n    protected _unsubscribe<T>(observerId: string): Rx.Observable<T> {\n        return this._connection.post<T>('/api/queryobserver/unsubscribe', {}, {\n            observer: observerId,\n            subscriber: this._connection.sessionId(),\n        });\n    }\n\n    /**\n     * Removes a query observer with a specific identifier.\n     *\n     * Rx has no way of waiting for dispose to finish, that's why\n     * we defer reactive queries after unsubscribe is finished.\n     *\n     * @param {string} observerId Query observer identifier\n     */\n    public remove(observerId: string) {\n        this._deleteObserver(observerId);\n\n        // Using promises, because we couldn't get observables to unsubscribe only once.\n        // Even using .take(1) didn't seem to correctly limit number of emits\n        this._unsubscribeChain = this._unsubscribeChain.then(() => {\n            return this._unsubscribe(observerId).toPromise();\n        });\n    }\n\n    /**\n     * Calls a function that creates an observable, after previous unsubscribe request finishes.\n     */\n    public chainAfterUnsubscribe<T>(makeObservable: () => Rx.Observable<T>): Rx.Observable<T> {\n        return Rx.Observable.fromPromise(this._unsubscribeChain).flatMap(() => {\n            return makeObservable();\n        });\n    }\n\n    /**\n     * Changes a query observer's identifier.\n     *\n     * @param {string} oldObserverId Old query observer identifier\n     * @param {QueryObserver} observer New query observer\n     */\n    public move(oldObserverId: string, observer: QueryObserver) {\n        if (oldObserverId === observer.id) {\n            return;\n        }\n\n        this.remove(oldObserverId);\n\n        // The observer we are moving into might have already received some messages. In\n        // this case, we need to move the queued messages to the old observer.\n        let existingObserver = this._observers[observer.id];\n        if (existingObserver) {\n            observer.moveFrom(existingObserver);\n        }\n\n        this._observers[observer.id] = observer;\n    }\n\n    /**\n     * Updates the query observers based on an incoming message.\n     *\n     * @param {Message} message Message instance\n     */\n    public update(message: Message) {\n        this.get(message.observer).update(message);\n    }\n\n    /**\n     * Returns an observable that will emit a list of items when any changes\n     * happen to the observed query.\n     *\n     * @param {string} observerId Query observer identifier\n     */\n    public observable(observerId: string): Rx.Observable<Object> {\n        return this.get(observerId).observable();\n    }\n\n    /**\n     * Requests all query observers to start reinitialization.\n     *\n     * This method should be called when some internal connection state changes\n     * (for example, when user authentication state is changed).\n     */\n    public reinitialize() {\n        _.forOwn(this._observers, (observer) => {\n            observer.reinitialize();\n        });\n    }\n}\n"]} |
@@ -49,2 +49,1 @@ import * as Rx from 'rx'; | ||
} | ||
//# sourceMappingURL=resource.d.ts.map |
@@ -6,2 +6,3 @@ "use strict"; | ||
var queryobserver_1 = require("./queryobserver"); | ||
var error_1 = require("../core/errors/error"); | ||
/** | ||
@@ -65,3 +66,3 @@ * An abstract resource class. | ||
if (hasEmptyInArray) | ||
console.error('Invalid parameter *__in=empty in query', query); | ||
throw new error_1.GenError('Invalid parameter *__in=empty in query'); | ||
}; | ||
@@ -172,2 +173,2 @@ /** | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/api/resource.ts"],"names":[],"mappings":"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","file":"api/resource.js","sourcesContent":["import * as _ from 'lodash';\nimport * as Rx from 'rx';\n\nimport {Connection, QueryObserverResponse} from './connection';\nimport {QueryObserverStatus} from './queryobserver';\nimport * as types from './types/rest';\n\n/**\n * A mapping of queries to their query observer identifiers, so that we don't\n * need to hit the server in case the identifier is already known.\n */\ninterface QueryObserverIdCache {\n    [index: string]: string;\n}\n\ninterface PendingQueries {\n    [index: string]: {\n        subscriptions: Rx.Disposable[];\n        observer: Rx.Observer<any>;\n    }[];\n}\n\n/**\n * Per-query configuration options.\n */\nexport interface QueryOptions {\n    reactive?: boolean;\n}\n\n/**\n * An abstract resource class.\n */\nexport abstract class Resource {\n    // Cache query observer identifiers.\n    private _queryObserverIdCache: QueryObserverIdCache = {};\n    private _pendingQueries: PendingQueries = {};\n\n    /**\n     * Constructs a new resource.\n     *\n     * @param connection Connection with the genesis platform server\n     */\n    constructor(private _connection: Connection) {\n    }\n\n    /**\n     * Connection to the genesis-platform server.\n     */\n    public get connection(): Connection {\n        return this._connection;\n    }\n\n    /**\n     * Returns base path that resource path is based upon.\n     */\n    protected getBasePath(): string {\n        return `/api`;\n    }\n\n    /**\n     * Performs any query transformations needed for this resource. The\n     * original query object is not modified.\n     *\n     * @param query Query\n     * @return Transformed query\n     */\n    protected transformQuery(query: types.Query): types.Query {\n        this._validateParameters(query);\n        return _.cloneDeep(this._fixQueryForElasticSearch(query));\n    }\n\n    private _fixQueryForElasticSearch(query: types.Query): types.Query {\n        // Move `__in` query keys to the end.\n        // TODO: remove this workaround when elastic search is fixed and these both return results\n        // /api/data?entity__in=2726&collection=246&tags=community%3Aexpressions\n        // /api/data?collection=246&tags=community%3Aexpressions&entity__in=2726\n        return _.zipObject(_.sortBy(_.pairs(query), ([key]) => {\n            return _.endsWith(key, '__in') ? Infinity : -1;\n        }));\n    }\n\n    /**\n     * Warn about invalid query parameters, like ?id__in=&...\n     */\n    private _validateParameters(query: types.Query): void {\n        const hasEmptyInArray = _.any(query, (value, key) => _.endsWith(key, '__in') && !value);\n        if (hasEmptyInArray) console.error('Invalid parameter *__in=empty in query', query);\n    }\n\n    /**\n     * Performs a query against this resource and subscribes to subsequent updates.\n     */\n    protected reactiveRequest<T>(query: types.Query, path: string, options?: QueryOptions): Rx.Observable<T[]> {\n        // We assume that the same query object on the same resource will always result in the same\n        // underlying queryset (and therefore query observer).\n        let serializedQuery = JSON.stringify([path, query]);\n        options = _.defaults({}, options || {}, {\n            reactive: false,\n        });\n        query = this.transformQuery(query);\n\n        return Rx.Observable.create<T[]>((observer) => {\n            if (!options.reactive) {\n                // Reactivity is disabled for this query.\n                const subscription = this.connection.get(path, query).map((response: any) => {\n                    // Correctly handle paginated results.\n                    if (_.has(response, 'results')) return response.results;\n                    return response;\n                }).subscribe(observer);\n\n                return () => subscription.dispose();\n            }\n\n            // Reactivity is enabled.\n            let queryObserverId = this._queryObserverIdCache[serializedQuery];\n            let pendingQueries = this._pendingQueries[serializedQuery];\n\n            // Perform a REST query to get the observer identifier and to subscribe to new updates.\n            let subscriptions: Rx.Disposable[] = [];\n\n            if (queryObserverId) {\n                // This query observer identifier has already been cached. Check if it exists and in this\n                // case just subscribe to all items.\n                let queryObserver = this.connection.queryObserverManager().get(queryObserverId, false);\n                if (queryObserver) {\n                    if (queryObserver.status === QueryObserverStatus.INITIALIZED ||\n                        queryObserver.status === QueryObserverStatus.REINITIALIZING) {\n                        subscriptions.push(queryObserver.observable().subscribe(observer));\n                    }\n\n                    if (queryObserver.status === QueryObserverStatus.INITIALIZED) {\n                        observer.onNext(queryObserver.items);\n                    }\n                }\n            }\n\n            if (_.isEmpty(subscriptions)) {\n                if (pendingQueries) {\n                    // A request for the same query is already in progress.\n                    pendingQueries.push({observer, subscriptions});\n                } else {\n                    this._pendingQueries[serializedQuery] = [{observer, subscriptions}];\n\n                    query = _.assign(query, {observe: this.connection.sessionId()});\n                    this.connection.queryObserverManager().chainAfterUnsubscribe(() => this.connection.get(path, query)).subscribe(\n                        (response: QueryObserverResponse) => {\n                            // Populate messages from this request.\n                            let queryObserver = this.connection.queryObserverManager().get(response.observer);\n                            this._queryObserverIdCache[serializedQuery] = response.observer;\n\n                            // Setup a reinitialization handler for this observer. It may be used in case the parameters\n                            // of a connection change and the observer needs to be re-created on the server without losing\n                            // any of the client-side subscriptions.\n                            queryObserver.setReinitializeHandler(() => {\n                                return this.connection.get(path, query);\n                            });\n\n                            if (_.isEmpty(this._pendingQueries[serializedQuery])) {\n                                // Send /api/queryobserver/unsubscribe, same as we would if subscribers got disposed after\n                                // pendingQueries resolve, instead of before.\n                                queryObserver.observable().subscribe().dispose();\n                            } else {\n                                for (const pending of this._pendingQueries[serializedQuery]) {\n                                    pending.subscriptions.push(queryObserver.observable().subscribe(pending.observer));\n\n                                    if (queryObserver.status === QueryObserverStatus.INITIALIZED) {\n                                        // If the query observer is already initialized, emit the current items immediately.\n                                        pending.observer.onNext(queryObserver.items);\n                                    }\n                                }\n                            }\n\n                            delete this._pendingQueries[serializedQuery];\n\n                            if (queryObserver.status !== QueryObserverStatus.INITIALIZED) {\n                                queryObserver.initialize(response.items);\n                            }\n                        },\n                        (error) => {\n                            observer.onError(error);\n                        }\n                    );\n                }\n            }\n\n            return () => {\n                // Dispose of the query observer subscription when all subscriptions to this query are stopped.\n                for (const subscription of subscriptions) {\n                    subscription.dispose();\n                }\n\n                // If query is still just pending, remove observer before it even becomes disposable.\n                if (this._pendingQueries[serializedQuery]) {\n                    this._pendingQueries[serializedQuery] = _.reject(this._pendingQueries[serializedQuery], (pending) => {\n                        // Check for same reference, not content!\n                        return pending.subscriptions === subscriptions;\n                    });\n                }\n            };\n        }).publish().refCount();\n    }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/api/resource.ts"],"names":[],"mappings":";;AAAA,0BAA4B;AAC5B,uBAAyB;AAGzB,iDAAoD;AACpD,8CAA8C;AAyB9C;;GAEG;AACH;IAKI;;;;OAIG;IACH,kBAAoB,WAAuB;QAAvB,gBAAW,GAAX,WAAW,CAAY;QAT3C,oCAAoC;QAC5B,0BAAqB,GAAyB,EAAE,CAAC;QACjD,oBAAe,GAAmB,EAAE,CAAC;IAQ7C,CAAC;IAKD,sBAAW,gCAAU;QAHrB;;WAEG;aACH;YACI,OAAO,IAAI,CAAC,WAAW,CAAC;QAC5B,CAAC;;;OAAA;IAED;;OAEG;IACO,8BAAW,GAArB;QACI,OAAO,MAAM,CAAC;IAClB,CAAC;IAED;;;;;;OAMG;IACO,iCAAc,GAAxB,UAAyB,KAAkB;QACvC,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;QAChC,OAAO,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,yBAAyB,CAAC,KAAK,CAAC,CAAC,CAAC;IAC9D,CAAC;IAEO,4CAAyB,GAAjC,UAAkC,KAAkB;QAChD,qCAAqC;QACrC,0FAA0F;QAC1F,wEAAwE;QACxE,wEAAwE;QACxE,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,UAAC,EAAK;gBAAJ,WAAG;YAC7C,OAAO,CAAC,CAAC,QAAQ,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACnD,CAAC,CAAC,CAAC,CAAC;IACR,CAAC;IAED;;OAEG;IACK,sCAAmB,GAA3B,UAA4B,KAAkB;QAC1C,IAAM,eAAe,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,UAAC,KAAK,EAAE,GAAG,IAAK,OAAA,CAAC,CAAC,QAAQ,CAAC,GAAG,EAAE,MAAM,CAAC,IAAI,CAAC,KAAK,EAAjC,CAAiC,CAAC,CAAC;QACxF,IAAI,eAAe;YAAE,MAAM,IAAI,gBAAQ,CAAC,wCAAwC,CAAC,CAAC;IACtF,CAAC;IAED;;OAEG;IACO,kCAAe,GAAzB,UAA6B,KAAkB,EAAE,IAAY,EAAE,OAAsB;QAArF,iBA4GC;QA3GG,2FAA2F;QAC3F,sDAAsD;QACtD,IAAI,eAAe,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC;QACpD,OAAO,GAAG,CAAC,CAAC,QAAQ,CAAC,EAAE,EAAE,OAAO,IAAI,EAAE,EAAE;YACpC,QAAQ,EAAE,KAAK;SAClB,CAAC,CAAC;QACH,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAEnC,OAAO,EAAE,CAAC,UAAU,CAAC,MAAM,CAAM,UAAC,QAAQ;YACtC,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE;gBACnB,yCAAyC;gBACzC,IAAM,cAAY,GAAG,KAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,GAAG,CAAC,UAAC,QAAa;oBACpE,sCAAsC;oBACtC,IAAI,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,SAAS,CAAC;wBAAE,OAAO,QAAQ,CAAC,OAAO,CAAC;oBACxD,OAAO,QAAQ,CAAC;gBACpB,CAAC,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;gBAEvB,OAAO,cAAM,OAAA,cAAY,CAAC,OAAO,EAAE,EAAtB,CAAsB,CAAC;aACvC;YAED,yBAAyB;YACzB,IAAI,eAAe,GAAG,KAAI,CAAC,qBAAqB,CAAC,eAAe,CAAC,CAAC;YAClE,IAAI,cAAc,GAAG,KAAI,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC;YAE3D,uFAAuF;YACvF,IAAI,aAAa,GAAoB,EAAE,CAAC;YAExC,IAAI,eAAe,EAAE;gBACjB,yFAAyF;gBACzF,oCAAoC;gBACpC,IAAI,aAAa,GAAG,KAAI,CAAC,UAAU,CAAC,oBAAoB,EAAE,CAAC,GAAG,CAAC,eAAe,EAAE,KAAK,CAAC,CAAC;gBACvF,IAAI,aAAa,EAAE;oBACf,IAAI,aAAa,CAAC,MAAM,KAAK,mCAAmB,CAAC,WAAW;wBACxD,aAAa,CAAC,MAAM,KAAK,mCAAmB,CAAC,cAAc,EAAE;wBAC7D,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;qBACtE;oBAED,IAAI,aAAa,CAAC,MAAM,KAAK,mCAAmB,CAAC,WAAW,EAAE;wBAC1D,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;qBACxC;iBACJ;aACJ;YAED,IAAI,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,EAAE;gBAC1B,IAAI,cAAc,EAAE;oBAChB,uDAAuD;oBACvD,cAAc,CAAC,IAAI,CAAC,EAAC,QAAQ,UAAA,EAAE,aAAa,eAAA,EAAC,CAAC,CAAC;iBAClD;qBAAM;oBACH,KAAI,CAAC,eAAe,CAAC,eAAe,CAAC,GAAG,CAAC,EAAC,QAAQ,UAAA,EAAE,aAAa,eAAA,EAAC,CAAC,CAAC;oBAEpE,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,EAAC,OAAO,EAAE,KAAI,CAAC,UAAU,CAAC,SAAS,EAAE,EAAC,CAAC,CAAC;oBAChE,KAAI,CAAC,UAAU,CAAC,oBAAoB,EAAE,CAAC,qBAAqB,CAAC,cAAM,OAAA,KAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,EAAhC,CAAgC,CAAC,CAAC,SAAS,CAC1G,UAAC,QAA+B;wBAC5B,uCAAuC;wBACvC,IAAI,aAAa,GAAG,KAAI,CAAC,UAAU,CAAC,oBAAoB,EAAE,CAAC,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;wBAClF,KAAI,CAAC,qBAAqB,CAAC,eAAe,CAAC,GAAG,QAAQ,CAAC,QAAQ,CAAC;wBAEhE,4FAA4F;wBAC5F,8FAA8F;wBAC9F,wCAAwC;wBACxC,aAAa,CAAC,sBAAsB,CAAC;4BACjC,OAAO,KAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;wBAC5C,CAAC,CAAC,CAAC;wBAEH,IAAI,CAAC,CAAC,OAAO,CAAC,KAAI,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,EAAE;4BAClD,0FAA0F;4BAC1F,6CAA6C;4BAC7C,aAAa,CAAC,UAAU,EAAE,CAAC,SAAS,EAAE,CAAC,OAAO,EAAE,CAAC;yBACpD;6BAAM;4BACH,KAAsB,UAAqC,EAArC,KAAA,KAAI,CAAC,eAAe,CAAC,eAAe,CAAC,EAArC,cAAqC,EAArC,IAAqC,EAAE;gCAAxD,IAAM,SAAO,SAAA;gCACd,SAAO,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,CAAC,SAAS,CAAC,SAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;gCAEnF,IAAI,aAAa,CAAC,MAAM,KAAK,mCAAmB,CAAC,WAAW,EAAE;oCAC1D,oFAAoF;oCACpF,SAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;iCAChD;6BACJ;yBACJ;wBAED,OAAO,KAAI,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC;wBAE7C,IAAI,aAAa,CAAC,MAAM,KAAK,mCAAmB,CAAC,WAAW,EAAE;4BAC1D,aAAa,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;yBAC5C;oBACL,CAAC,EACD,UAAC,KAAK;wBACF,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;oBAC5B,CAAC,CACJ,CAAC;iBACL;aACJ;YAED,OAAO;gBACH,+FAA+F;gBAC/F,KAA2B,UAAa,EAAb,+BAAa,EAAb,2BAAa,EAAb,IAAa,EAAE;oBAArC,IAAM,YAAY,sBAAA;oBACnB,YAAY,CAAC,OAAO,EAAE,CAAC;iBAC1B;gBAED,qFAAqF;gBACrF,IAAI,KAAI,CAAC,eAAe,CAAC,eAAe,CAAC,EAAE;oBACvC,KAAI,CAAC,eAAe,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,KAAI,CAAC,eAAe,CAAC,eAAe,CAAC,EAAE,UAAC,OAAO;wBAC5F,yCAAyC;wBACzC,OAAO,OAAO,CAAC,aAAa,KAAK,aAAa,CAAC;oBACnD,CAAC,CAAC,CAAC;iBACN;YACL,CAAC,CAAC;QACN,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IACL,eAAC;AAAD,CAzKA,AAyKC,IAAA;AAzKqB,4BAAQ","file":"api/resource.js","sourcesContent":["import * as _ from 'lodash';\nimport * as Rx from 'rx';\n\nimport {Connection, QueryObserverResponse} from './connection';\nimport {QueryObserverStatus} from './queryobserver';\nimport {GenError} from '../core/errors/error';\nimport * as types from './types/rest';\n\n/**\n * A mapping of queries to their query observer identifiers, so that we don't\n * need to hit the server in case the identifier is already known.\n */\ninterface QueryObserverIdCache {\n    [index: string]: string;\n}\n\ninterface PendingQueries {\n    [index: string]: {\n        subscriptions: Rx.Disposable[];\n        observer: Rx.Observer<any>;\n    }[];\n}\n\n/**\n * Per-query configuration options.\n */\nexport interface QueryOptions {\n    reactive?: boolean;\n}\n\n/**\n * An abstract resource class.\n */\nexport abstract class Resource {\n    // Cache query observer identifiers.\n    private _queryObserverIdCache: QueryObserverIdCache = {};\n    private _pendingQueries: PendingQueries = {};\n\n    /**\n     * Constructs a new resource.\n     *\n     * @param connection Connection with the genesis platform server\n     */\n    constructor(private _connection: Connection) {\n    }\n\n    /**\n     * Connection to the genesis-platform server.\n     */\n    public get connection(): Connection {\n        return this._connection;\n    }\n\n    /**\n     * Returns base path that resource path is based upon.\n     */\n    protected getBasePath(): string {\n        return `/api`;\n    }\n\n    /**\n     * Performs any query transformations needed for this resource. The\n     * original query object is not modified.\n     *\n     * @param query Query\n     * @return Transformed query\n     */\n    protected transformQuery(query: types.Query): types.Query {\n        this._validateParameters(query);\n        return _.cloneDeep(this._fixQueryForElasticSearch(query));\n    }\n\n    private _fixQueryForElasticSearch(query: types.Query): types.Query {\n        // Move `__in` query keys to the end.\n        // TODO: remove this workaround when elastic search is fixed and these both return results\n        // /api/data?entity__in=2726&collection=246&tags=community%3Aexpressions\n        // /api/data?collection=246&tags=community%3Aexpressions&entity__in=2726\n        return _.zipObject(_.sortBy(_.pairs(query), ([key]) => {\n            return _.endsWith(key, '__in') ? Infinity : -1;\n        }));\n    }\n\n    /**\n     * Warn about invalid query parameters, like ?id__in=&...\n     */\n    private _validateParameters(query: types.Query): void {\n        const hasEmptyInArray = _.any(query, (value, key) => _.endsWith(key, '__in') && !value);\n        if (hasEmptyInArray) throw new GenError('Invalid parameter *__in=empty in query');\n    }\n\n    /**\n     * Performs a query against this resource and subscribes to subsequent updates.\n     */\n    protected reactiveRequest<T>(query: types.Query, path: string, options?: QueryOptions): Rx.Observable<T[]> {\n        // We assume that the same query object on the same resource will always result in the same\n        // underlying queryset (and therefore query observer).\n        let serializedQuery = JSON.stringify([path, query]);\n        options = _.defaults({}, options || {}, {\n            reactive: false,\n        });\n        query = this.transformQuery(query);\n\n        return Rx.Observable.create<T[]>((observer) => {\n            if (!options.reactive) {\n                // Reactivity is disabled for this query.\n                const subscription = this.connection.get(path, query).map((response: any) => {\n                    // Correctly handle paginated results.\n                    if (_.has(response, 'results')) return response.results;\n                    return response;\n                }).subscribe(observer);\n\n                return () => subscription.dispose();\n            }\n\n            // Reactivity is enabled.\n            let queryObserverId = this._queryObserverIdCache[serializedQuery];\n            let pendingQueries = this._pendingQueries[serializedQuery];\n\n            // Perform a REST query to get the observer identifier and to subscribe to new updates.\n            let subscriptions: Rx.Disposable[] = [];\n\n            if (queryObserverId) {\n                // This query observer identifier has already been cached. Check if it exists and in this\n                // case just subscribe to all items.\n                let queryObserver = this.connection.queryObserverManager().get(queryObserverId, false);\n                if (queryObserver) {\n                    if (queryObserver.status === QueryObserverStatus.INITIALIZED ||\n                        queryObserver.status === QueryObserverStatus.REINITIALIZING) {\n                        subscriptions.push(queryObserver.observable().subscribe(observer));\n                    }\n\n                    if (queryObserver.status === QueryObserverStatus.INITIALIZED) {\n                        observer.onNext(queryObserver.items);\n                    }\n                }\n            }\n\n            if (_.isEmpty(subscriptions)) {\n                if (pendingQueries) {\n                    // A request for the same query is already in progress.\n                    pendingQueries.push({observer, subscriptions});\n                } else {\n                    this._pendingQueries[serializedQuery] = [{observer, subscriptions}];\n\n                    query = _.assign(query, {observe: this.connection.sessionId()});\n                    this.connection.queryObserverManager().chainAfterUnsubscribe(() => this.connection.get(path, query)).subscribe(\n                        (response: QueryObserverResponse) => {\n                            // Populate messages from this request.\n                            let queryObserver = this.connection.queryObserverManager().get(response.observer);\n                            this._queryObserverIdCache[serializedQuery] = response.observer;\n\n                            // Setup a reinitialization handler for this observer. It may be used in case the parameters\n                            // of a connection change and the observer needs to be re-created on the server without losing\n                            // any of the client-side subscriptions.\n                            queryObserver.setReinitializeHandler(() => {\n                                return this.connection.get(path, query);\n                            });\n\n                            if (_.isEmpty(this._pendingQueries[serializedQuery])) {\n                                // Send /api/queryobserver/unsubscribe, same as we would if subscribers got disposed after\n                                // pendingQueries resolve, instead of before.\n                                queryObserver.observable().subscribe().dispose();\n                            } else {\n                                for (const pending of this._pendingQueries[serializedQuery]) {\n                                    pending.subscriptions.push(queryObserver.observable().subscribe(pending.observer));\n\n                                    if (queryObserver.status === QueryObserverStatus.INITIALIZED) {\n                                        // If the query observer is already initialized, emit the current items immediately.\n                                        pending.observer.onNext(queryObserver.items);\n                                    }\n                                }\n                            }\n\n                            delete this._pendingQueries[serializedQuery];\n\n                            if (queryObserver.status !== QueryObserverStatus.INITIALIZED) {\n                                queryObserver.initialize(response.items);\n                            }\n                        },\n                        (error) => {\n                            observer.onError(error);\n                        }\n                    );\n                }\n            }\n\n            return () => {\n                // Dispose of the query observer subscription when all subscriptions to this query are stopped.\n                for (const subscription of subscriptions) {\n                    subscription.dispose();\n                }\n\n                // If query is still just pending, remove observer before it even becomes disposable.\n                if (this._pendingQueries[serializedQuery]) {\n                    this._pendingQueries[serializedQuery] = _.reject(this._pendingQueries[serializedQuery], (pending) => {\n                        // Check for same reference, not content!\n                        return pending.subscriptions === subscriptions;\n                    });\n                }\n            };\n        }).publish().refCount();\n    }\n}\n"]} |
export {}; | ||
//# sourceMappingURL=resource.spec.d.ts.map |
@@ -28,2 +28,1 @@ import * as Rx from 'rx'; | ||
export declare function setPermissions(resource: RESTResource<any>, id: number, permissions: types.SetPermissionsRequest): Rx.Observable<types.ItemPermissions[]>; | ||
//# sourceMappingURL=permissions.d.ts.map |
@@ -53,2 +53,1 @@ import * as Rx from 'rx'; | ||
} | ||
//# sourceMappingURL=knowledge_base.d.ts.map |
@@ -38,2 +38,1 @@ import { Connection } from '../../connection'; | ||
} | ||
//# sourceMappingURL=module_resource.d.ts.map |
import * as Rx from 'rx'; | ||
import { QueryOptions } from '../../resource'; | ||
import { RESTResource } from './rest_resource'; | ||
@@ -24,4 +23,2 @@ import { Connection } from '../../connection'; | ||
slugExists(slug: string): Rx.Observable<boolean>; | ||
query(query?: types.QueryObject, options?: QueryOptions): Rx.Observable<types.Collection[]>; | ||
queryOne(query?: types.QueryObject, options?: QueryOptions): Rx.Observable<types.Collection>; | ||
/** | ||
@@ -37,2 +34,1 @@ * Makes a copy of collections. | ||
} | ||
//# sourceMappingURL=collection.d.ts.map |
@@ -41,10 +41,2 @@ "use strict"; | ||
}; | ||
CollectionResource.prototype.query = function (query, options) { | ||
if (query === void 0) { query = {}; } | ||
return _super.prototype.query.call(this, query, options); | ||
}; | ||
CollectionResource.prototype.queryOne = function (query, options) { | ||
if (query === void 0) { query = {}; } | ||
return _super.prototype.queryOne.call(this, query, options); | ||
}; | ||
/** | ||
@@ -69,2 +61,2 @@ * Makes a copy of collections. | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9hcGkvcmVzb3VyY2VzL3Jlc3QvY29sbGVjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7QUFHQSxpREFBNkM7QUFFN0MscURBQXFGO0FBR3JGOztHQUVHO0FBQ0g7SUFBd0Msc0NBQThCO0lBUWxFLDRCQUFZLFVBQXNCO1FBQWxDLFlBQ0ksa0JBQU0sWUFBWSxFQUFFLFVBQVUsQ0FBQyxTQUNsQztRQVREOzs7O1dBSUc7UUFDYSwyQkFBcUIsR0FBRyxFQUFFLENBQUM7O0lBSTNDLENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksdUNBQVUsR0FBakIsVUFBa0IsSUFBWTtRQUMxQixPQUFnQyxJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsYUFBYSxDQUFDLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUMvRyxDQUFDO0lBRU0sa0NBQUssR0FBWixVQUFhLEtBQTZCLEVBQUUsT0FBc0I7UUFBckQsc0JBQUEsRUFBQSxVQUE2QjtRQUN0QyxPQUFPLGlCQUFNLEtBQUssWUFBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVNLHFDQUFRLEdBQWYsVUFBZ0IsS0FBNkIsRUFBRSxPQUFzQjtRQUFyRCxzQkFBQSxFQUFBLFVBQTZCO1FBQ3pDLE9BQU8saUJBQU0sUUFBUSxZQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSxzQ0FBUyxHQUFoQixVQUFpQixhQUF1QjtRQUNwQyxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFxQixJQUFJLENBQUMsaUJBQWlCLENBQUMsV0FBVyxDQUFDLEVBQUUsRUFBRSxHQUFHLEVBQUUsYUFBYSxFQUFFLENBQUMsQ0FBQztJQUNqSCxDQUFDO0lBRU0sMkNBQWMsR0FBckIsVUFBc0IsRUFBVTtRQUM1QixPQUFPLDRCQUFjLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFTSwyQ0FBYyxHQUFyQixVQUFzQixFQUFVLEVBQUUsV0FBd0M7UUFDdEUsT0FBTyw0QkFBYyxDQUFDLElBQUksRUFBRSxFQUFFLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDakQsQ0FBQztJQUNMLHlCQUFDO0FBQUQsQ0E5Q0EsQUE4Q0MsQ0E5Q3VDLDRCQUFZLEdBOENuRDtBQTlDWSxnREFBa0IiLCJmaWxlIjoiYXBpL3Jlc291cmNlcy9yZXN0L2NvbGxlY3Rpb24uanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSeCBmcm9tICdyeCc7XG5cbmltcG9ydCB7UXVlcnlPcHRpb25zfSBmcm9tICcuLi8uLi9yZXNvdXJjZSc7XG5pbXBvcnQge1JFU1RSZXNvdXJjZX0gZnJvbSAnLi9yZXN0X3Jlc291cmNlJztcbmltcG9ydCB7Q29ubmVjdGlvbn0gZnJvbSAnLi4vLi4vY29ubmVjdGlvbic7XG5pbXBvcnQge1Blcm1pc3Npb25hYmxlLCBnZXRQZXJtaXNzaW9ucywgc2V0UGVybWlzc2lvbnN9IGZyb20gJy4uL2FkZG9ucy9wZXJtaXNzaW9ucyc7XG5pbXBvcnQgKiBhcyB0eXBlcyBmcm9tICcuLi8uLi90eXBlcy9yZXN0JztcblxuLyoqXG4gKiBDb2xsZWN0aW9uIHJlc291cmNlIGNsYXNzIGZvciBkZWFsaW5nIHdpdGggY29sbGVjdGlvbiBlbmRwb2ludC5cbiAqL1xuZXhwb3J0IGNsYXNzIENvbGxlY3Rpb25SZXNvdXJjZSBleHRlbmRzIFJFU1RSZXNvdXJjZTx0eXBlcy5Db2xsZWN0aW9uPiBpbXBsZW1lbnRzIFBlcm1pc3Npb25hYmxlIHtcbiAgICAvKipcbiAgICAgKiBPcmRlcmluZyBieSByZWxldmFuY2UgY29uc3RhbnQuIEFwcGx5IHRoaXMgdmFsdWUgdG8gYG9yZGVyaW5nYCBxdWVyeSBwYXJhbWV0ZXIgdG9cbiAgICAgKiBvcmRlciBieSByZWxldmFuY2UuXG4gICAgICogVGhpcyB3b3JrcyBieSBvdmVycmlkaW5nIGFueSBkZWZhdWx0IG9yZGVyaW5nIG9uIGJhY2tlbmQsIHNvIGl0IGtlZXBzIG9yZGVyIG9mIEVTIHJlc3VsdHNcbiAgICAgKi9cbiAgICBwdWJsaWMgcmVhZG9ubHkgT1JERVJJTkdfQllfUkVMRVZBTkNFID0gJyc7XG5cbiAgICBjb25zdHJ1Y3Rvcihjb25uZWN0aW9uOiBDb25uZWN0aW9uKSB7XG4gICAgICAgIHN1cGVyKCdjb2xsZWN0aW9uJywgY29ubmVjdGlvbik7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQ2hlY2tzIGlmIGNvbGxlY3Rpb24gc2x1ZyBhbHJlYWR5IGV4aXN0cy5cbiAgICAgKlxuICAgICAqIEBwYXJhbSBTbHVnIHRvIGNoZWNrXG4gICAgICovXG4gICAgcHVibGljIHNsdWdFeGlzdHMoc2x1Zzogc3RyaW5nKTogUnguT2JzZXJ2YWJsZTxib29sZWFuPiB7XG4gICAgICAgIHJldHVybiA8UnguT2JzZXJ2YWJsZTxib29sZWFuPj4gdGhpcy5jb25uZWN0aW9uLmdldCh0aGlzLmdldExpc3RNZXRob2RQYXRoKCdzbHVnX2V4aXN0cycpLCB7IG5hbWU6IHNsdWcgfSk7XG4gICAgfVxuXG4gICAgcHVibGljIHF1ZXJ5KHF1ZXJ5OiB0eXBlcy5RdWVyeU9iamVjdCA9IHt9LCBvcHRpb25zPzogUXVlcnlPcHRpb25zKTogUnguT2JzZXJ2YWJsZTx0eXBlcy5Db2xsZWN0aW9uW10+IHtcbiAgICAgICAgcmV0dXJuIHN1cGVyLnF1ZXJ5KHF1ZXJ5LCBvcHRpb25zKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgcXVlcnlPbmUocXVlcnk6IHR5cGVzLlF1ZXJ5T2JqZWN0ID0ge30sIG9wdGlvbnM/OiBRdWVyeU9wdGlvbnMpOiBSeC5PYnNlcnZhYmxlPHR5cGVzLkNvbGxlY3Rpb24+IHtcbiAgICAgICAgcmV0dXJuIHN1cGVyLnF1ZXJ5T25lKHF1ZXJ5LCBvcHRpb25zKTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBNYWtlcyBhIGNvcHkgb2YgY29sbGVjdGlvbnMuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gY29sbGVjdGlvbklkcyBBIGxpc3Qgb2YgY29sbGVjdGlvbiBpZHMgdG8gZHVwbGljYXRlXG4gICAgICogQHJldHVybiBEdXBsaWNhdGVkIGNvbGxlY3Rpb25zLlxuICAgICAqL1xuICAgIHB1YmxpYyBkdXBsaWNhdGUoY29sbGVjdGlvbklkczogbnVtYmVyW10pOiBSeC5PYnNlcnZhYmxlPHR5cGVzLkNvbGxlY3Rpb25bXT4ge1xuICAgICAgICByZXR1cm4gdGhpcy5jb25uZWN0aW9uLnBvc3Q8dHlwZXMuQ29sbGVjdGlvbltdPih0aGlzLmdldExpc3RNZXRob2RQYXRoKCdkdXBsaWNhdGUnKSwgeyBpZHM6IGNvbGxlY3Rpb25JZHMgfSk7XG4gICAgfVxuXG4gICAgcHVibGljIGdldFBlcm1pc3Npb25zKGlkOiBudW1iZXIpOiBSeC5PYnNlcnZhYmxlPHR5cGVzLkl0ZW1QZXJtaXNzaW9uc1tdPiB7XG4gICAgICAgIHJldHVybiBnZXRQZXJtaXNzaW9ucyh0aGlzLCBpZCk7XG4gICAgfVxuXG4gICAgcHVibGljIHNldFBlcm1pc3Npb25zKGlkOiBudW1iZXIsIHBlcm1pc3Npb25zOiB0eXBlcy5TZXRQZXJtaXNzaW9uc1JlcXVlc3QpOiBSeC5PYnNlcnZhYmxlPHR5cGVzLkl0ZW1QZXJtaXNzaW9uc1tdPiB7XG4gICAgICAgIHJldHVybiBzZXRQZXJtaXNzaW9ucyh0aGlzLCBpZCwgcGVybWlzc2lvbnMpO1xuICAgIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9hcGkvcmVzb3VyY2VzL3Jlc3QvY29sbGVjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7QUFFQSxpREFBNkM7QUFFN0MscURBQXFGO0FBR3JGOztHQUVHO0FBQ0g7SUFBd0Msc0NBQThCO0lBUWxFLDRCQUFZLFVBQXNCO1FBQWxDLFlBQ0ksa0JBQU0sWUFBWSxFQUFFLFVBQVUsQ0FBQyxTQUNsQztRQVREOzs7O1dBSUc7UUFDYSwyQkFBcUIsR0FBRyxFQUFFLENBQUM7O0lBSTNDLENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksdUNBQVUsR0FBakIsVUFBa0IsSUFBWTtRQUMxQixPQUFnQyxJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsYUFBYSxDQUFDLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUMvRyxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSxzQ0FBUyxHQUFoQixVQUFpQixhQUF1QjtRQUNwQyxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFxQixJQUFJLENBQUMsaUJBQWlCLENBQUMsV0FBVyxDQUFDLEVBQUUsRUFBRSxHQUFHLEVBQUUsYUFBYSxFQUFFLENBQUMsQ0FBQztJQUNqSCxDQUFDO0lBRU0sMkNBQWMsR0FBckIsVUFBc0IsRUFBVTtRQUM1QixPQUFPLDRCQUFjLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFTSwyQ0FBYyxHQUFyQixVQUFzQixFQUFVLEVBQUUsV0FBd0M7UUFDdEUsT0FBTyw0QkFBYyxDQUFDLElBQUksRUFBRSxFQUFFLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDakQsQ0FBQztJQUNMLHlCQUFDO0FBQUQsQ0F0Q0EsQUFzQ0MsQ0F0Q3VDLDRCQUFZLEdBc0NuRDtBQXRDWSxnREFBa0IiLCJmaWxlIjoiYXBpL3Jlc291cmNlcy9yZXN0L2NvbGxlY3Rpb24uanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSeCBmcm9tICdyeCc7XG5cbmltcG9ydCB7UkVTVFJlc291cmNlfSBmcm9tICcuL3Jlc3RfcmVzb3VyY2UnO1xuaW1wb3J0IHtDb25uZWN0aW9ufSBmcm9tICcuLi8uLi9jb25uZWN0aW9uJztcbmltcG9ydCB7UGVybWlzc2lvbmFibGUsIGdldFBlcm1pc3Npb25zLCBzZXRQZXJtaXNzaW9uc30gZnJvbSAnLi4vYWRkb25zL3Blcm1pc3Npb25zJztcbmltcG9ydCAqIGFzIHR5cGVzIGZyb20gJy4uLy4uL3R5cGVzL3Jlc3QnO1xuXG4vKipcbiAqIENvbGxlY3Rpb24gcmVzb3VyY2UgY2xhc3MgZm9yIGRlYWxpbmcgd2l0aCBjb2xsZWN0aW9uIGVuZHBvaW50LlxuICovXG5leHBvcnQgY2xhc3MgQ29sbGVjdGlvblJlc291cmNlIGV4dGVuZHMgUkVTVFJlc291cmNlPHR5cGVzLkNvbGxlY3Rpb24+IGltcGxlbWVudHMgUGVybWlzc2lvbmFibGUge1xuICAgIC8qKlxuICAgICAqIE9yZGVyaW5nIGJ5IHJlbGV2YW5jZSBjb25zdGFudC4gQXBwbHkgdGhpcyB2YWx1ZSB0byBgb3JkZXJpbmdgIHF1ZXJ5IHBhcmFtZXRlciB0b1xuICAgICAqIG9yZGVyIGJ5IHJlbGV2YW5jZS5cbiAgICAgKiBUaGlzIHdvcmtzIGJ5IG92ZXJyaWRpbmcgYW55IGRlZmF1bHQgb3JkZXJpbmcgb24gYmFja2VuZCwgc28gaXQga2VlcHMgb3JkZXIgb2YgRVMgcmVzdWx0c1xuICAgICAqL1xuICAgIHB1YmxpYyByZWFkb25seSBPUkRFUklOR19CWV9SRUxFVkFOQ0UgPSAnJztcblxuICAgIGNvbnN0cnVjdG9yKGNvbm5lY3Rpb246IENvbm5lY3Rpb24pIHtcbiAgICAgICAgc3VwZXIoJ2NvbGxlY3Rpb24nLCBjb25uZWN0aW9uKTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBDaGVja3MgaWYgY29sbGVjdGlvbiBzbHVnIGFscmVhZHkgZXhpc3RzLlxuICAgICAqXG4gICAgICogQHBhcmFtIFNsdWcgdG8gY2hlY2tcbiAgICAgKi9cbiAgICBwdWJsaWMgc2x1Z0V4aXN0cyhzbHVnOiBzdHJpbmcpOiBSeC5PYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICAgICAgcmV0dXJuIDxSeC5PYnNlcnZhYmxlPGJvb2xlYW4+PiB0aGlzLmNvbm5lY3Rpb24uZ2V0KHRoaXMuZ2V0TGlzdE1ldGhvZFBhdGgoJ3NsdWdfZXhpc3RzJyksIHsgbmFtZTogc2x1ZyB9KTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBNYWtlcyBhIGNvcHkgb2YgY29sbGVjdGlvbnMuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gY29sbGVjdGlvbklkcyBBIGxpc3Qgb2YgY29sbGVjdGlvbiBpZHMgdG8gZHVwbGljYXRlXG4gICAgICogQHJldHVybiBEdXBsaWNhdGVkIGNvbGxlY3Rpb25zLlxuICAgICAqL1xuICAgIHB1YmxpYyBkdXBsaWNhdGUoY29sbGVjdGlvbklkczogbnVtYmVyW10pOiBSeC5PYnNlcnZhYmxlPHR5cGVzLkNvbGxlY3Rpb25bXT4ge1xuICAgICAgICByZXR1cm4gdGhpcy5jb25uZWN0aW9uLnBvc3Q8dHlwZXMuQ29sbGVjdGlvbltdPih0aGlzLmdldExpc3RNZXRob2RQYXRoKCdkdXBsaWNhdGUnKSwgeyBpZHM6IGNvbGxlY3Rpb25JZHMgfSk7XG4gICAgfVxuXG4gICAgcHVibGljIGdldFBlcm1pc3Npb25zKGlkOiBudW1iZXIpOiBSeC5PYnNlcnZhYmxlPHR5cGVzLkl0ZW1QZXJtaXNzaW9uc1tdPiB7XG4gICAgICAgIHJldHVybiBnZXRQZXJtaXNzaW9ucyh0aGlzLCBpZCk7XG4gICAgfVxuXG4gICAgcHVibGljIHNldFBlcm1pc3Npb25zKGlkOiBudW1iZXIsIHBlcm1pc3Npb25zOiB0eXBlcy5TZXRQZXJtaXNzaW9uc1JlcXVlc3QpOiBSeC5PYnNlcnZhYmxlPHR5cGVzLkl0ZW1QZXJtaXNzaW9uc1tdPiB7XG4gICAgICAgIHJldHVybiBzZXRQZXJtaXNzaW9ucyh0aGlzLCBpZCwgcGVybWlzc2lvbnMpO1xuICAgIH1cbn1cbiJdfQ== |
import * as Rx from 'rx'; | ||
import { QueryOptions } from '../../resource'; | ||
import { RESTResource } from './rest_resource'; | ||
@@ -20,11 +19,2 @@ import { Connection } from '../../connection'; | ||
slugExists(slug: string): Rx.Observable<boolean>; | ||
/** | ||
* Explicitly re-defined with return type Data, because this differs from `create` and `get`. | ||
*/ | ||
query(query?: types.Query, options?: QueryOptions): Rx.Observable<types.Data[]>; | ||
/** | ||
* Explicitly re-defined with return type Data, because this differs from `create` and `get`. | ||
*/ | ||
queryOne(query?: types.Query, options?: QueryOptions): Rx.Observable<types.Data>; | ||
get(primaryKey: number | string, opts?: types.Query): Rx.Observable<types.Data>; | ||
getParents(id: number): Rx.Observable<types.Data[]>; | ||
@@ -56,2 +46,1 @@ getChildren(id: number): Rx.Observable<types.Data[]>; | ||
} | ||
//# sourceMappingURL=data.d.ts.map |
@@ -55,19 +55,2 @@ "use strict"; | ||
}; | ||
/** | ||
* Explicitly re-defined with return type Data, because this differs from `create` and `get`. | ||
*/ | ||
DataResource.prototype.query = function (query, options) { | ||
if (query === void 0) { query = {}; } | ||
return _super.prototype.query.call(this, query, options); | ||
}; | ||
/** | ||
* Explicitly re-defined with return type Data, because this differs from `create` and `get`. | ||
*/ | ||
DataResource.prototype.queryOne = function (query, options) { | ||
if (query === void 0) { query = {}; } | ||
return _super.prototype.queryOne.call(this, query, options); | ||
}; | ||
DataResource.prototype.get = function (primaryKey, opts) { | ||
return this.connection.get(this.getDetailPath(primaryKey), opts); | ||
}; | ||
DataResource.prototype.getParents = function (id) { | ||
@@ -99,3 +82,3 @@ return this.connection.get(this.getDetailMethodPath(id, 'parents')); | ||
]); | ||
return this.get(id, LimitedData.limitQuery).map(function (data) { | ||
return this.connection.get(this.getDetailPath(id), LimitedData.limitQuery).map(function (data) { | ||
if (!data.entity) { | ||
@@ -137,2 +120,2 @@ console.error('Expected data to belong to a sample', data); | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/api/resources/rest/data.ts"],"names":[],"mappings":"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","file":"api/resources/rest/data.js","sourcesContent":["import * as Rx from 'rx';\nimport * as _ from 'lodash';\n\nimport {QueryOptions} from '../../resource';\nimport {RESTResource} from './rest_resource';\nimport {Connection} from '../../connection';\nimport {Permissionable, getPermissions, setPermissions} from '../addons/permissions';\nimport {uniteDeepPicks, deepPickType} from '../../types/utils';\nimport * as types from '../../types/rest';\n\n/**\n * Data resource class for dealing with data endpoint.\n */\nexport class DataResource extends RESTResource<types.Data> implements Permissionable {\n\n    constructor(connection: Connection) {\n        super('data', connection);\n    }\n\n    protected transformQuery(query: types.Query): types.Query {\n        // Rename `sample` query field to `entity`.\n        const transformedQuery = _.mapKeys(query, (value, field) => {\n            return field\n                .replace(/^sample$/g, 'entity')\n                .replace(/^sample__/g, 'entity__');\n        });\n\n        // Rename `sample` in limit fields to `entity`.\n        if (transformedQuery.fields) {\n            transformedQuery.fields = transformedQuery.fields.split(',').map((field) => {\n                return field\n                    .replace(/^sample$/g, 'entity')\n                    .replace(/^sample__/g, 'entity__');\n            }).join(',');\n        }\n\n        return super.transformQuery(transformedQuery);\n    }\n\n    /**\n     * Checks if data slug already exists.\n     *\n     * @param {string} Slug to check\n     * @return {Rx.Observable<boolean>} An observable that emits the response\n     */\n    public slugExists(slug: string): Rx.Observable<boolean> {\n        return <Rx.Observable<boolean>> this.connection.get(this.getListMethodPath('slug_exists'), { name: slug });\n    }\n\n    /**\n     * Explicitly re-defined with return type Data, because this differs from `create` and `get`.\n     */\n    public query(query: types.Query = {}, options?: QueryOptions): Rx.Observable<types.Data[]> {\n        return super.query(query, options);\n    }\n\n    /**\n     * Explicitly re-defined with return type Data, because this differs from `create` and `get`.\n     */\n    public queryOne(query: types.Query = {}, options?: QueryOptions): Rx.Observable<types.Data> {\n        return super.queryOne(query, options);\n    }\n\n    public get(primaryKey: number | string, opts?: types.Query): Rx.Observable<types.Data> {\n        return this.connection.get(this.getDetailPath(primaryKey), opts);\n    }\n\n    public getParents(id: number): Rx.Observable<types.Data[]> {\n        return this.connection.get(this.getDetailMethodPath(id, 'parents'));\n    }\n\n    public getChildren(id: number): Rx.Observable<types.Data[]> {\n        return this.connection.get(this.getDetailMethodPath(id, 'children'));\n    }\n\n    public addToSample(dataIds: number[], sampleId: number): Rx.Observable<unknown> {\n        return Rx.Observable.fromArray(dataIds).concatMap((id) => {\n            return this.update(id, { sample: { id: sampleId } });\n        }).toArray();\n    }\n\n    public addToCollection(dataIds: number[], collectionId: number): Rx.Observable<unknown> {\n        return Rx.Observable.fromArray(dataIds).concatMap((id) => {\n            return this.update(id, { collection: { id: collectionId } });\n        }).toArray();\n    }\n\n    /**\n     * Get a sample by data id.\n     */\n    public getSampleFromDataId(id: number): Rx.Observable<Omit<types.Sample, 'current_user_permissions'>> {\n        const LimitedData = uniteDeepPicks([\n            deepPickType(<types.Data> null, 'id'),\n            deepPickType(<types.Data> null, 'entity'),\n        ]);\n        type LimitedData = typeof LimitedData.type;\n\n        return this.get(id, LimitedData.limitQuery).map((data: LimitedData) => {\n            if (!data.entity) {\n                console.error('Expected data to belong to a sample', data);\n                return null;\n            }\n\n            return data.entity;\n        });\n    }\n\n    /**\n     * Get Data object with the same inputs if it already exists, otherwise\n     * create it.\n     *\n     * Note: Consider sorting arrays in the inputs, to prevent needlessly\n     * creating the same Data objects.\n     */\n    public getOrCreate(data: Object): Rx.Observable<types.Data> {\n        return this.connection.post<types.Data>(this.getListMethodPath('get_or_create'), data);\n    }\n\n    /**\n     * Makes a copy of data objects.\n     *\n     * @param dataIds A list of data object ids to duplicate\n     * @return Duplicated data objects.\n     */\n    public duplicate(dataIds: number[]): Rx.Observable<types.Data[]> {\n        return this.connection.post<types.Data[]>(this.getListMethodPath('duplicate'), { ids: dataIds });\n    }\n\n    public getPermissions(id: number): Rx.Observable<types.ItemPermissions[]> {\n        return getPermissions(this, id);\n    }\n\n    public setPermissions(id: number, permissions: types.SetPermissionsRequest): Rx.Observable<types.ItemPermissions[]> {\n        return setPermissions(this, id, permissions);\n    }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/api/resources/rest/data.ts"],"names":[],"mappings":"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","file":"api/resources/rest/data.js","sourcesContent":["import * as Rx from 'rx';\nimport * as _ from 'lodash';\n\nimport {RESTResource} from './rest_resource';\nimport {Connection} from '../../connection';\nimport {Permissionable, getPermissions, setPermissions} from '../addons/permissions';\nimport {uniteDeepPicks, deepPickType} from '../../types/utils';\nimport * as types from '../../types/rest';\n\n/**\n * Data resource class for dealing with data endpoint.\n */\nexport class DataResource extends RESTResource<types.Data> implements Permissionable {\n\n    constructor(connection: Connection) {\n        super('data', connection);\n    }\n\n    protected transformQuery(query: types.Query): types.Query {\n        // Rename `sample` query field to `entity`.\n        const transformedQuery = _.mapKeys(query, (value, field) => {\n            return field\n                .replace(/^sample$/g, 'entity')\n                .replace(/^sample__/g, 'entity__');\n        });\n\n        // Rename `sample` in limit fields to `entity`.\n        if (transformedQuery.fields) {\n            transformedQuery.fields = transformedQuery.fields.split(',').map((field) => {\n                return field\n                    .replace(/^sample$/g, 'entity')\n                    .replace(/^sample__/g, 'entity__');\n            }).join(',');\n        }\n\n        return super.transformQuery(transformedQuery);\n    }\n\n    /**\n     * Checks if data slug already exists.\n     *\n     * @param {string} Slug to check\n     * @return {Rx.Observable<boolean>} An observable that emits the response\n     */\n    public slugExists(slug: string): Rx.Observable<boolean> {\n        return <Rx.Observable<boolean>> this.connection.get(this.getListMethodPath('slug_exists'), { name: slug });\n    }\n\n    public getParents(id: number): Rx.Observable<types.Data[]> {\n        return this.connection.get(this.getDetailMethodPath(id, 'parents'));\n    }\n\n    public getChildren(id: number): Rx.Observable<types.Data[]> {\n        return this.connection.get(this.getDetailMethodPath(id, 'children'));\n    }\n\n    public addToSample(dataIds: number[], sampleId: number): Rx.Observable<unknown> {\n        return Rx.Observable.fromArray(dataIds).concatMap((id) => {\n            return this.update(id, { sample: { id: sampleId } });\n        }).toArray();\n    }\n\n    public addToCollection(dataIds: number[], collectionId: number): Rx.Observable<unknown> {\n        return Rx.Observable.fromArray(dataIds).concatMap((id) => {\n            return this.update(id, { collection: { id: collectionId } });\n        }).toArray();\n    }\n\n    /**\n     * Get a sample by data id.\n     */\n    public getSampleFromDataId(id: number): Rx.Observable<Omit<types.Sample, 'current_user_permissions'>> {\n        const LimitedData = uniteDeepPicks([\n            deepPickType(<types.Data> null, 'id'),\n            deepPickType(<types.Data> null, 'entity'),\n        ]);\n        type LimitedData = typeof LimitedData.type;\n\n        return this.connection.get(this.getDetailPath(id), LimitedData.limitQuery).map((data: LimitedData) => {\n            if (!data.entity) {\n                console.error('Expected data to belong to a sample', data);\n                return null;\n            }\n\n            return data.entity;\n        });\n    }\n\n    /**\n     * Get Data object with the same inputs if it already exists, otherwise\n     * create it.\n     *\n     * Note: Consider sorting arrays in the inputs, to prevent needlessly\n     * creating the same Data objects.\n     */\n    public getOrCreate(data: Object): Rx.Observable<types.Data> {\n        return this.connection.post<types.Data>(this.getListMethodPath('get_or_create'), data);\n    }\n\n    /**\n     * Makes a copy of data objects.\n     *\n     * @param dataIds A list of data object ids to duplicate\n     * @return Duplicated data objects.\n     */\n    public duplicate(dataIds: number[]): Rx.Observable<types.Data[]> {\n        return this.connection.post<types.Data[]>(this.getListMethodPath('duplicate'), { ids: dataIds });\n    }\n\n    public getPermissions(id: number): Rx.Observable<types.ItemPermissions[]> {\n        return getPermissions(this, id);\n    }\n\n    public setPermissions(id: number, permissions: types.SetPermissionsRequest): Rx.Observable<types.ItemPermissions[]> {\n        return setPermissions(this, id, permissions);\n    }\n}\n"]} |
@@ -13,2 +13,1 @@ import { RESTResource } from './rest_resource'; | ||
} | ||
//# sourceMappingURL=descriptor_schema.d.ts.map |
@@ -23,2 +23,1 @@ import * as Rx from 'rx'; | ||
} | ||
//# sourceMappingURL=file.d.ts.map |
@@ -123,2 +123,1 @@ import * as Rx from 'rx'; | ||
} | ||
//# sourceMappingURL=rest_resource.d.ts.map |
import * as Rx from 'rx'; | ||
import { RESTResource } from './rest_resource'; | ||
import { QueryOptions } from '../../resource'; | ||
import { Connection } from '../../connection'; | ||
import { Permissionable } from '../addons/permissions'; | ||
import * as types from '../../types/rest'; | ||
export declare type AnnotationQuery = { | ||
annotation: 'annotated' | 'unannotated' | 'annotatedAndUnannotated'; | ||
}; | ||
/** | ||
@@ -29,7 +25,2 @@ * Sample resource class for dealing with sample endpoint. | ||
/** | ||
* Use this method carefully. Check to make sure you need unannotated and annotated samples. | ||
*/ | ||
query(query: types.QueryObject & AnnotationQuery, options?: QueryOptions): Rx.Observable<types.Sample[]>; | ||
queryOne(query: types.QueryObject, options?: QueryOptions): Rx.Observable<types.Sample>; | ||
/** | ||
* Adds sample to collections. | ||
@@ -62,2 +53,1 @@ * | ||
} | ||
//# sourceMappingURL=sample.d.ts.map |
@@ -15,24 +15,2 @@ "use strict"; | ||
})(); | ||
var __assign = (this && this.__assign) || function () { | ||
__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; | ||
}; | ||
return __assign.apply(this, arguments); | ||
}; | ||
var __rest = (this && this.__rest) || function (s, e) { | ||
var t = {}; | ||
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) | ||
t[p] = s[p]; | ||
if (s != null && typeof Object.getOwnPropertySymbols === "function") | ||
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { | ||
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) | ||
t[p[i]] = s[p[i]]; | ||
} | ||
return t; | ||
}; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
@@ -67,15 +45,2 @@ var rest_resource_1 = require("./rest_resource"); | ||
/** | ||
* Use this method carefully. Check to make sure you need unannotated and annotated samples. | ||
*/ | ||
SampleResource.prototype.query = function (query, options) { | ||
var annotation = query.annotation, remainingQuery = __rest(query, ["annotation"]); | ||
var annotationQuery = annotation === 'annotated' ? { descriptor_completed: true } : | ||
annotation === 'unannotated' ? { descriptor_completed: false } | ||
: {}; | ||
return _super.prototype.query.call(this, __assign({}, remainingQuery, annotationQuery), options); | ||
}; | ||
SampleResource.prototype.queryOne = function (query, options) { | ||
return _super.prototype.queryOne.call(this, query, options); | ||
}; | ||
/** | ||
* Adds sample to collections. | ||
@@ -134,2 +99,2 @@ * | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/api/resources/rest/sample.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,iDAA6C;AAG7C,oDAAoD;AACpD,qDAAqF;AAOrF;;GAEG;AACH;IAAoC,kCAA0B;IAQ1D,wBAAY,UAAsB;QAAlC,YACI,kBAAM,QAAQ,EAAE,UAAU,CAAC,SAC9B;QATD;;;;WAIG;QACa,2BAAqB,GAAG,EAAE,CAAC;;IAI3C,CAAC;IAED;;;;;OAKG;IACI,mCAAU,GAAjB,UAAkB,IAAY;QAC1B,OAAO,IAAI,CAAC,UAAU,CAAC,GAAG,CAAU,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;IAC/F,CAAC;IAED;;OAEG;IACI,8BAAK,GAAZ,UAAa,KAA0C,EAAE,OAAsB;QACpE,IAAA,6BAAU,EAAE,8CAAiB,CAAU;QAC9C,IAAM,eAAe,GAAG,UAAU,KAAK,WAAW,CAAC,CAAC,CAAC,EAAE,oBAAoB,EAAE,IAAI,EAAE,CAAC,CAAC;YAC/D,UAAU,KAAK,aAAa,CAAC,CAAC,CAAC,EAAE,oBAAoB,EAAE,KAAK,EAAE;gBACjC,CAAC,CAAC,EAAE,CAAC;QAExD,OAAO,iBAAM,KAAK,yBAAM,cAAc,EAAK,eAAe,GAAI,OAAO,CAAC,CAAC;IAC3E,CAAC;IAEM,iCAAQ,GAAf,UAAgB,KAAwB,EAAE,OAAsB;QAC5D,OAAO,iBAAM,QAAQ,YAAC,KAAK,EAAE,OAAO,CAAC,CAAC;IAC1C,CAAC;IAED;;;;;OAKG;IACI,wCAAe,GAAtB,UAAuB,QAAgB,EAAE,YAAoB;QACzD,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;YACzB,UAAU,EAAE;gBACR,EAAE,EAAE,YAAY;aACnB;SACJ,CAAC,CAAC;IACP,CAAC;IAED;;;;;OAKG;IACI,yCAAgB,GAAvB,UAAwB,SAAmB,EAAE,kBAA0B,EAAE,uBAA+B;QACpG,OAAO,IAAI,CAAC,cAAc,CAAO,oBAAoB,EAAE;YACnD,GAAG,EAAE,SAAS;YACd,iBAAiB,EAAE,kBAAkB;YACrC,sBAAsB,EAAE,uBAAuB;SACjD,CAAC,CAAC;IACR,CAAC;IAEM,+BAAM,GAAb,UAAc,IAAY;QACtB,MAAM,IAAI,gBAAQ,CAAC,6BAA6B,CAAC,CAAC;IACtD,CAAC;IAEM,gCAAO,GAAd,UAAe,UAA2B,EAAE,IAAY;QACpD,MAAM,IAAI,gBAAQ,CAAC,8BAA8B,CAAC,CAAC;IACvD,CAAC;IAED;;;;;OAKG;IACI,kCAAS,GAAhB,UAAiB,SAAmB,EACnB,IAAoC;QACjD,OAAO,IAAI,CAAC,cAAc,CAAiB,WAAW,EAAE;YACpD,GAAG,EAAE,SAAS;YACd,kBAAkB,EAAE,IAAI,CAAC,iBAAiB;SAC7C,CAAC,CAAC;IACP,CAAC;IAEM,uCAAc,GAArB,UAAsB,EAAU;QAC5B,OAAO,4BAAc,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;IACpC,CAAC;IAEM,uCAAc,GAArB,UAAsB,EAAU,EAAE,WAAwC;QACtE,OAAO,4BAAc,CAAC,IAAI,EAAE,EAAE,EAAE,WAAW,CAAC,CAAC;IACjD,CAAC;IACL,qBAAC;AAAD,CA/FA,AA+FC,CA/FmC,4BAAY,GA+F/C;AA/FY,wCAAc","file":"api/resources/rest/sample.js","sourcesContent":["import * as Rx from 'rx';\nimport {RESTResource} from './rest_resource';\nimport {QueryOptions} from '../../resource';\nimport {Connection} from '../../connection';\nimport {GenError} from '../../../core/errors/error';\nimport {Permissionable, getPermissions, setPermissions} from '../addons/permissions';\nimport * as types from '../../types/rest';\n\nexport type AnnotationQuery = {\n    annotation: 'annotated' | 'unannotated' | 'annotatedAndUnannotated';\n};\n\n/**\n * Sample resource class for dealing with sample endpoint.\n */\nexport class SampleResource extends RESTResource<types.Sample> implements Permissionable {\n    /**\n     * Ordering by relevance constant. Apply this value to `ordering` query parameter to\n     * order by relevance.\n     * This works by overriding any default ordering on backend, so it keeps order of ES results\n     */\n    public readonly ORDERING_BY_RELEVANCE = '';\n\n    constructor(connection: Connection) {\n        super('sample', connection);\n    }\n\n    /**\n     * Checks if sample slug already exists.\n     *\n     * @param Slug to check\n     * @return An observable that emits the response\n     */\n    public slugExists(slug: string): Rx.Observable<boolean> {\n        return this.connection.get<boolean>(this.getListMethodPath('slug_exists'), { name: slug });\n    }\n\n    /**\n     * Use this method carefully. Check to make sure you need unannotated and annotated samples.\n     */\n    public query(query: types.QueryObject & AnnotationQuery, options?: QueryOptions): Rx.Observable<types.Sample[]> {\n        const {annotation, ...remainingQuery} = query;\n        const annotationQuery = annotation === 'annotated' ? { descriptor_completed: true } :\n                              annotation === 'unannotated' ? { descriptor_completed: false }\n                                                           : {};\n\n        return super.query({ ...remainingQuery, ...annotationQuery }, options);\n    }\n\n    public queryOne(query: types.QueryObject, options?: QueryOptions): Rx.Observable<types.Sample> {\n        return super.queryOne(query, options);\n    }\n\n    /**\n     * Adds sample to collections.\n     *\n     * @param sampleId Sample id\n     * @param collectionIds Array of collection ids\n     */\n    public addToCollection(sampleId: number, collectionId: number): Rx.Observable<unknown> {\n        return this.update(sampleId, {\n            collection: {\n                id: collectionId,\n            },\n        });\n    }\n\n    /**\n     * Move samples to collection.\n     *\n     * @param sampleId Sample id\n     * @param collectionIds Array of collection ids\n     */\n    public moveToCollection(sampleIds: number[], sourceCollectionId: number, destinationCollectionId: number): Rx.Observable<void> {\n        return this.callListMethod<void>('move_to_collection', {\n            ids: sampleIds,\n            source_collection: sourceCollectionId,\n            destination_collection: destinationCollectionId,\n         });\n    }\n\n    public create(data: Object): Rx.Observable<any> {\n        throw new GenError(\"Create method not supported\");\n    }\n\n    public replace(primaryKey: number | string, data: Object): Rx.Observable<any> {\n        throw new GenError(\"Replace method not supported\");\n    }\n\n    /**\n     * Makes a copy of samples.\n     *\n     * @param sampleIds A list of sample ids to duplicate\n     * @return Duplicated samples.\n     */\n    public duplicate(sampleIds: number[],\n                     opts: { inheritCollection: boolean }): Rx.Observable<types.Sample[]> {\n        return this.callListMethod<types.Sample[]>('duplicate', {\n            ids: sampleIds,\n            inherit_collection: opts.inheritCollection,\n        });\n    }\n\n    public getPermissions(id: number): Rx.Observable<types.ItemPermissions[]> {\n        return getPermissions(this, id);\n    }\n\n    public setPermissions(id: number, permissions: types.SetPermissionsRequest): Rx.Observable<types.ItemPermissions[]> {\n        return setPermissions(this, id, permissions);\n    }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9hcGkvcmVzb3VyY2VzL3Jlc3Qvc2FtcGxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7OztBQUNBLGlEQUE2QztBQUU3QyxvREFBb0Q7QUFDcEQscURBQXFGO0FBR3JGOztHQUVHO0FBQ0g7SUFBb0Msa0NBQTBCO0lBUTFELHdCQUFZLFVBQXNCO1FBQWxDLFlBQ0ksa0JBQU0sUUFBUSxFQUFFLFVBQVUsQ0FBQyxTQUM5QjtRQVREOzs7O1dBSUc7UUFDYSwyQkFBcUIsR0FBRyxFQUFFLENBQUM7O0lBSTNDLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNJLG1DQUFVLEdBQWpCLFVBQWtCLElBQVk7UUFDMUIsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBVSxJQUFJLENBQUMsaUJBQWlCLENBQUMsYUFBYSxDQUFDLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUMvRixDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSx3Q0FBZSxHQUF0QixVQUF1QixRQUFnQixFQUFFLFlBQW9CO1FBQ3pELE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUU7WUFDekIsVUFBVSxFQUFFO2dCQUNSLEVBQUUsRUFBRSxZQUFZO2FBQ25CO1NBQ0osQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0kseUNBQWdCLEdBQXZCLFVBQXdCLFNBQW1CLEVBQUUsa0JBQTBCLEVBQUUsdUJBQStCO1FBQ3BHLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBTyxvQkFBb0IsRUFBRTtZQUNuRCxHQUFHLEVBQUUsU0FBUztZQUNkLGlCQUFpQixFQUFFLGtCQUFrQjtZQUNyQyxzQkFBc0IsRUFBRSx1QkFBdUI7U0FDakQsQ0FBQyxDQUFDO0lBQ1IsQ0FBQztJQUVNLCtCQUFNLEdBQWIsVUFBYyxJQUFZO1FBQ3RCLE1BQU0sSUFBSSxnQkFBUSxDQUFDLDZCQUE2QixDQUFDLENBQUM7SUFDdEQsQ0FBQztJQUVNLGdDQUFPLEdBQWQsVUFBZSxVQUEyQixFQUFFLElBQVk7UUFDcEQsTUFBTSxJQUFJLGdCQUFRLENBQUMsOEJBQThCLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSxrQ0FBUyxHQUFoQixVQUFpQixTQUFtQixFQUNuQixJQUFvQztRQUNqRCxPQUFPLElBQUksQ0FBQyxjQUFjLENBQWlCLFdBQVcsRUFBRTtZQUNwRCxHQUFHLEVBQUUsU0FBUztZQUNkLGtCQUFrQixFQUFFLElBQUksQ0FBQyxpQkFBaUI7U0FDN0MsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVNLHVDQUFjLEdBQXJCLFVBQXNCLEVBQVU7UUFDNUIsT0FBTyw0QkFBYyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRU0sdUNBQWMsR0FBckIsVUFBc0IsRUFBVSxFQUFFLFdBQXdDO1FBQ3RFLE9BQU8sNEJBQWMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBQ2pELENBQUM7SUFDTCxxQkFBQztBQUFELENBL0VBLEFBK0VDLENBL0VtQyw0QkFBWSxHQStFL0M7QUEvRVksd0NBQWMiLCJmaWxlIjoiYXBpL3Jlc291cmNlcy9yZXN0L3NhbXBsZS5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJ4IGZyb20gJ3J4JztcbmltcG9ydCB7UkVTVFJlc291cmNlfSBmcm9tICcuL3Jlc3RfcmVzb3VyY2UnO1xuaW1wb3J0IHtDb25uZWN0aW9ufSBmcm9tICcuLi8uLi9jb25uZWN0aW9uJztcbmltcG9ydCB7R2VuRXJyb3J9IGZyb20gJy4uLy4uLy4uL2NvcmUvZXJyb3JzL2Vycm9yJztcbmltcG9ydCB7UGVybWlzc2lvbmFibGUsIGdldFBlcm1pc3Npb25zLCBzZXRQZXJtaXNzaW9uc30gZnJvbSAnLi4vYWRkb25zL3Blcm1pc3Npb25zJztcbmltcG9ydCAqIGFzIHR5cGVzIGZyb20gJy4uLy4uL3R5cGVzL3Jlc3QnO1xuXG4vKipcbiAqIFNhbXBsZSByZXNvdXJjZSBjbGFzcyBmb3IgZGVhbGluZyB3aXRoIHNhbXBsZSBlbmRwb2ludC5cbiAqL1xuZXhwb3J0IGNsYXNzIFNhbXBsZVJlc291cmNlIGV4dGVuZHMgUkVTVFJlc291cmNlPHR5cGVzLlNhbXBsZT4gaW1wbGVtZW50cyBQZXJtaXNzaW9uYWJsZSB7XG4gICAgLyoqXG4gICAgICogT3JkZXJpbmcgYnkgcmVsZXZhbmNlIGNvbnN0YW50LiBBcHBseSB0aGlzIHZhbHVlIHRvIGBvcmRlcmluZ2AgcXVlcnkgcGFyYW1ldGVyIHRvXG4gICAgICogb3JkZXIgYnkgcmVsZXZhbmNlLlxuICAgICAqIFRoaXMgd29ya3MgYnkgb3ZlcnJpZGluZyBhbnkgZGVmYXVsdCBvcmRlcmluZyBvbiBiYWNrZW5kLCBzbyBpdCBrZWVwcyBvcmRlciBvZiBFUyByZXN1bHRzXG4gICAgICovXG4gICAgcHVibGljIHJlYWRvbmx5IE9SREVSSU5HX0JZX1JFTEVWQU5DRSA9ICcnO1xuXG4gICAgY29uc3RydWN0b3IoY29ubmVjdGlvbjogQ29ubmVjdGlvbikge1xuICAgICAgICBzdXBlcignc2FtcGxlJywgY29ubmVjdGlvbik7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQ2hlY2tzIGlmIHNhbXBsZSBzbHVnIGFscmVhZHkgZXhpc3RzLlxuICAgICAqXG4gICAgICogQHBhcmFtIFNsdWcgdG8gY2hlY2tcbiAgICAgKiBAcmV0dXJuIEFuIG9ic2VydmFibGUgdGhhdCBlbWl0cyB0aGUgcmVzcG9uc2VcbiAgICAgKi9cbiAgICBwdWJsaWMgc2x1Z0V4aXN0cyhzbHVnOiBzdHJpbmcpOiBSeC5PYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY29ubmVjdGlvbi5nZXQ8Ym9vbGVhbj4odGhpcy5nZXRMaXN0TWV0aG9kUGF0aCgnc2x1Z19leGlzdHMnKSwgeyBuYW1lOiBzbHVnIH0pO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEFkZHMgc2FtcGxlIHRvIGNvbGxlY3Rpb25zLlxuICAgICAqXG4gICAgICogQHBhcmFtIHNhbXBsZUlkIFNhbXBsZSBpZFxuICAgICAqIEBwYXJhbSBjb2xsZWN0aW9uSWRzIEFycmF5IG9mIGNvbGxlY3Rpb24gaWRzXG4gICAgICovXG4gICAgcHVibGljIGFkZFRvQ29sbGVjdGlvbihzYW1wbGVJZDogbnVtYmVyLCBjb2xsZWN0aW9uSWQ6IG51bWJlcik6IFJ4Lk9ic2VydmFibGU8dW5rbm93bj4ge1xuICAgICAgICByZXR1cm4gdGhpcy51cGRhdGUoc2FtcGxlSWQsIHtcbiAgICAgICAgICAgIGNvbGxlY3Rpb246IHtcbiAgICAgICAgICAgICAgICBpZDogY29sbGVjdGlvbklkLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogTW92ZSBzYW1wbGVzIHRvIGNvbGxlY3Rpb24uXG4gICAgICpcbiAgICAgKiBAcGFyYW0gc2FtcGxlSWQgU2FtcGxlIGlkXG4gICAgICogQHBhcmFtIGNvbGxlY3Rpb25JZHMgQXJyYXkgb2YgY29sbGVjdGlvbiBpZHNcbiAgICAgKi9cbiAgICBwdWJsaWMgbW92ZVRvQ29sbGVjdGlvbihzYW1wbGVJZHM6IG51bWJlcltdLCBzb3VyY2VDb2xsZWN0aW9uSWQ6IG51bWJlciwgZGVzdGluYXRpb25Db2xsZWN0aW9uSWQ6IG51bWJlcik6IFJ4Lk9ic2VydmFibGU8dm9pZD4ge1xuICAgICAgICByZXR1cm4gdGhpcy5jYWxsTGlzdE1ldGhvZDx2b2lkPignbW92ZV90b19jb2xsZWN0aW9uJywge1xuICAgICAgICAgICAgaWRzOiBzYW1wbGVJZHMsXG4gICAgICAgICAgICBzb3VyY2VfY29sbGVjdGlvbjogc291cmNlQ29sbGVjdGlvbklkLFxuICAgICAgICAgICAgZGVzdGluYXRpb25fY29sbGVjdGlvbjogZGVzdGluYXRpb25Db2xsZWN0aW9uSWQsXG4gICAgICAgICB9KTtcbiAgICB9XG5cbiAgICBwdWJsaWMgY3JlYXRlKGRhdGE6IE9iamVjdCk6IFJ4Lk9ic2VydmFibGU8YW55PiB7XG4gICAgICAgIHRocm93IG5ldyBHZW5FcnJvcihcIkNyZWF0ZSBtZXRob2Qgbm90IHN1cHBvcnRlZFwiKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgcmVwbGFjZShwcmltYXJ5S2V5OiBudW1iZXIgfCBzdHJpbmcsIGRhdGE6IE9iamVjdCk6IFJ4Lk9ic2VydmFibGU8YW55PiB7XG4gICAgICAgIHRocm93IG5ldyBHZW5FcnJvcihcIlJlcGxhY2UgbWV0aG9kIG5vdCBzdXBwb3J0ZWRcIik7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogTWFrZXMgYSBjb3B5IG9mIHNhbXBsZXMuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gc2FtcGxlSWRzIEEgbGlzdCBvZiBzYW1wbGUgaWRzIHRvIGR1cGxpY2F0ZVxuICAgICAqIEByZXR1cm4gRHVwbGljYXRlZCBzYW1wbGVzLlxuICAgICAqL1xuICAgIHB1YmxpYyBkdXBsaWNhdGUoc2FtcGxlSWRzOiBudW1iZXJbXSxcbiAgICAgICAgICAgICAgICAgICAgIG9wdHM6IHsgaW5oZXJpdENvbGxlY3Rpb246IGJvb2xlYW4gfSk6IFJ4Lk9ic2VydmFibGU8dHlwZXMuU2FtcGxlW10+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY2FsbExpc3RNZXRob2Q8dHlwZXMuU2FtcGxlW10+KCdkdXBsaWNhdGUnLCB7XG4gICAgICAgICAgICBpZHM6IHNhbXBsZUlkcyxcbiAgICAgICAgICAgIGluaGVyaXRfY29sbGVjdGlvbjogb3B0cy5pbmhlcml0Q29sbGVjdGlvbixcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcHVibGljIGdldFBlcm1pc3Npb25zKGlkOiBudW1iZXIpOiBSeC5PYnNlcnZhYmxlPHR5cGVzLkl0ZW1QZXJtaXNzaW9uc1tdPiB7XG4gICAgICAgIHJldHVybiBnZXRQZXJtaXNzaW9ucyh0aGlzLCBpZCk7XG4gICAgfVxuXG4gICAgcHVibGljIHNldFBlcm1pc3Npb25zKGlkOiBudW1iZXIsIHBlcm1pc3Npb25zOiB0eXBlcy5TZXRQZXJtaXNzaW9uc1JlcXVlc3QpOiBSeC5PYnNlcnZhYmxlPHR5cGVzLkl0ZW1QZXJtaXNzaW9uc1tdPiB7XG4gICAgICAgIHJldHVybiBzZXRQZXJtaXNzaW9ucyh0aGlzLCBpZCwgcGVybWlzc2lvbnMpO1xuICAgIH1cbn1cbiJdfQ== |
@@ -18,2 +18,1 @@ import * as Rx from 'rx'; | ||
} | ||
//# sourceMappingURL=storage.d.ts.map |
@@ -58,2 +58,1 @@ import * as Rx from 'rx'; | ||
} | ||
//# sourceMappingURL=user.d.ts.map |
@@ -49,2 +49,1 @@ import { Query } from './rest'; | ||
} | ||
//# sourceMappingURL=modules.d.ts.map |
@@ -21,4 +21,2 @@ import * as Rx from 'rx'; | ||
[propertyName: string]: any; | ||
} | ||
export interface QueryObject extends Query { | ||
data?: "Disallow deprecated api.Sample.queryOne({ data: data.id }). Use api.Data.getSampleFromDataId(data.id) instead."; | ||
@@ -430,3 +428,2 @@ parents?: "Disallow deprecated api.Data.query({ parents: data.id }). Use api.Data.getChildren(data.id) instead."; | ||
collection: void | Omit<Collection, 'current_user_permissions'>; | ||
descriptor_completed: boolean; | ||
type: 'sample'; | ||
@@ -524,2 +521,1 @@ } | ||
} | ||
//# sourceMappingURL=rest.d.ts.map |
@@ -33,2 +33,2 @@ "use strict"; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/api/types/rest.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;AAwCH,SAAgB,mBAAmB,CAAI,QAA2B;IAC9D,OAAO,QAAQ,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;AAC9C,CAAC;AAFD,kDAEC;AAsBY,QAAA,gBAAgB,GAAoB,OAAO,CAAC;AAC5C,QAAA,gBAAgB,GAAoB,OAAO,CAAC;AAC5C,QAAA,eAAe,GAAmB,MAAM,CAAC;AACzC,QAAA,iBAAiB,GAAqB,MAAM,CAAC;AAC7C,QAAA,cAAc,GAAkB,KAAK,CAAC;AACtC,QAAA,mBAAmB,GAAuB,UAAU,CAAC;AACrD,QAAA,eAAe,GAAmB,MAAM,CAAC;AAUzC,QAAA,sBAAsB,GAAyB,QAAQ,CAAC;AACxD,QAAA,qBAAqB,GAAwB,OAAO,CAAC;AACrD,QAAA,oBAAoB,GAAuB,MAAM,CAAC;AAkDlD,QAAA,uBAAuB,GAA0B,KAAK,CAAC;AACvD,QAAA,0BAA0B,GAA6B,KAAK,CAAC;AAC7D,QAAA,wBAAwB,GAA2B,KAAK,CAAC;AAuKzD,QAAA,qBAAqB,GAAwB,IAAI,CAAC;AAClD,QAAA,qBAAqB,GAAwB,IAAI,CAAC;AAClD,QAAA,mBAAmB,GAAsB,IAAI,CAAC;AAC9C,QAAA,sBAAsB,GAAyB,IAAI,CAAC;AACpD,QAAA,gBAAgB,GAAmB,IAAI,CAAC;AACxC,QAAA,iBAAiB,GAAoB,IAAI,CAAC;AAC1C,QAAA,iBAAiB,GAAoB,IAAI,CAAC","file":"api/types/rest.js","sourcesContent":["/*\n * Type definitions\n *\n * Here is defined everything the API returns.\n */\n\nimport * as Rx from 'rx';\nimport * as _ from 'lodash';\n\nimport Dictionary = _.Dictionary;\nimport NumericDictionary = _.NumericDictionary;\n\n\n// ------------------------------------------------------------------\n// Query\n\nexport interface StrictQuery {\n    limit?: number;\n    offset?: number;\n    ordering?: string; // '-field1,-field2,field3'\n    fields?: string; // 'id,slug,input__reads__file'\n    id?: number;\n    slug?: string;\n    id__in?: string; // '13,24,35'\n    slug__in?: string; // 'reads1,reads-paired-2'\n    name__icontains?: string;\n    status__in?: string; // 'UP,WT,RE,PR'\n    text?: string; // Elastic search\n    tags?: string; // 'community:universe,community:expressions'\n}\n\nexport interface Query extends StrictQuery {\n    [propertyName: string]: any;\n}\n\nexport interface QueryObject extends Query {\n    data?: \"Disallow deprecated api.Sample.queryOne({ data: data.id }). Use api.Data.getSampleFromDataId(data.id) instead.\";\n    parents?: \"Disallow deprecated api.Data.query({ parents: data.id }). Use api.Data.getChildren(data.id) instead.\";\n    children?: \"Disallow deprecated api.Data.query({ children: data.id }). Use api.Data.getParents(data.id) instead.\";\n    hydrate_data?: \"Disallow deprecated hydrate_data.\";\n    hydrate_collections?: \"Disallow deprecated hydrate_collections.\";\n    hydrate_entities?: \"Disallow deprecated hydrate_entities.\";\n}\n\nexport function isResponsePaginated<T>(response: T | { results: T}): response is { results: T } {\n    return response.hasOwnProperty('results');\n}\n\n// LimitOffsetPagination\nexport interface PaginatedResponse<T> {\n    count: number;\n    next: string;\n    previous: string;\n    results: T[];\n}\n\n\n// ------------------------------------------------------------------\n// Permissions\n\nexport type OwnerPermission = 'owner';\nexport type SharePermission = 'share';\nexport type EditPermission = 'edit';\nexport type DeletePermission = 'edit'; // not a typo (API doesn't support delete permission)\nexport type AddPermission = 'add';\nexport type DownloadPermission = 'download';\nexport type ViewPermission = 'view';\n\nexport const OWNER_PERMISSION: OwnerPermission = 'owner';\nexport const SHARE_PERMISSION: SharePermission = 'share';\nexport const EDIT_PERMISSION: EditPermission = 'edit';\nexport const DELETE_PERMISSION: DeletePermission = 'edit';\nexport const ADD_PERMISSION: AddPermission = 'add';\nexport const DOWNLOAD_PERMISSION: DownloadPermission = 'download';\nexport const VIEW_PERMISSION: ViewPermission = 'view';\n\nexport type Permission = OwnerPermission | SharePermission | EditPermission | DeletePermission | AddPermission |\n    DownloadPermission | ViewPermission;\n\n\nexport type PublicPermissionType = 'public';\nexport type GroupPermissionType = 'group';\nexport type UserPermissionType = 'user';\n\nexport const PUBLIC_PERMISSION_TYPE: PublicPermissionType = 'public';\nexport const GROUP_PERMISSION_TYPE: GroupPermissionType = 'group';\nexport const USER_PERMISSION_TYPE: UserPermissionType = 'user';\n\nexport type PermissionType = PublicPermissionType | GroupPermissionType | UserPermissionType;\n\nexport interface ItemPermissionsOf<T> {\n    type: PermissionType;\n    permissions: T[];\n    id?: number;\n    name?: string;\n}\n\nexport type ItemPermissions = ItemPermissionsOf<Permission>;\n\nexport interface SetPermissionsRequest {\n    public?: {\n        add?: Permission[],\n        remove?: Permission[]\n    };\n    groups?: {\n        add?: NumericDictionary<Permission[]> | Dictionary<Permission[]>\n        remove?: NumericDictionary<Permission[]> | Dictionary<Permission[]>\n    };\n    users?: {\n        add?: NumericDictionary<Permission[]> | Dictionary<Permission[]>\n        remove?: NumericDictionary<Permission[]> | Dictionary<Permission[]>\n    };\n    share_content?: '0' | '1';\n}\n\n\n// ------------------------------------------------------------------\n// Contributor\n\nexport interface Contributor {\n    id: number;\n    username: string;\n    first_name: string;\n    last_name: string;\n}\n\n\n// ------------------------------------------------------------------\n// Process\n\nexport type ProcessPermissions = ViewPermission | SharePermission;\n\nexport type RawProcessPersistence = 'RAW';\nexport type CachedProcessPersistence = 'CAC';\nexport type TempProcessPersistence = 'TMP';\n\nexport const RAW_PROCESS_PERSISTENCE: RawProcessPersistence = 'RAW';\nexport const CACHED_PROCESS_PERSISTENCE: CachedProcessPersistence = 'CAC';\nexport const TEMP_PROCESS_PERSISTENCE: TempProcessPersistence = 'TMP';\n\nexport type ProcessPersistence = RawProcessPersistence | CachedProcessPersistence | TempProcessPersistence;\n\nexport interface Process {\n    id: number;\n    slug: string;\n    name: string;\n    created: string;\n    modified: string;\n    version: string;\n    type: string;\n    category: string;\n    requirements?: {\n        relations?: Array<{\n            type: 'compare' | 'group' | 'background' | 'series';\n            category?: string;\n            labels?: string[];\n            required?: boolean;\n        }>;\n    };\n    persistence: ProcessPersistence;\n    description: string;\n    input_schema: any;\n    output_schema: any;\n    run: any;\n    contributor: Contributor;\n    current_user_permissions: ItemPermissionsOf<ProcessPermissions>[];\n    is_active: boolean;\n    data_name: string;\n    entity_descriptor_schema: void | string;\n    entity_input: any;\n    entity_type: void | string;\n    scheduling_class: string;\n}\n\n// ------------------------------------------------------------------\n// Relation\n\nexport interface RelationPartition {\n    id: number;\n    entity: number;\n    position: number | null;\n    label: string | null;\n}\n\nexport interface Relation {\n    id: number;\n    created: string;\n    modified: string;\n    type: string;\n    collection: number;\n    partitions: RelationPartition[];\n    category: string;\n    unit: 's' | 'min' | 'hr' | 'd' | 'wk' | null;\n    contributor: Contributor;\n}\n\n// ------------------------------------------------------------------\n// DescriptorSchema\n\n// Schema\nexport interface ChoiceMap {\n    value: string;\n    label: string;\n}\n\nexport interface FieldSchema {\n    disabled?: boolean | string;\n    required?: boolean;\n    collapsed?: boolean;\n    hidden?: boolean | string;\n    default?: any;\n    choices?: ChoiceMap[];\n    allow_custom_choice?: boolean;\n    validate_regex?: string;\n    slug?: {\n        source?: string;\n        uniqueValidator?: (slug: string) => Rx.Observable<boolean>;\n    };\n    type: string;\n    name: string;\n    label: string;\n    group?: Schema;\n    range?: [number, number]; // Min, max\n}\n\nexport type Schema = FieldSchema[];\n\n\n// DescriptorSchema\nexport type DescriptorSchemaPermissions = ViewPermission | EditPermission | SharePermission;\n\nexport interface DescriptorSchemaBase {\n    id: number;\n    created: string;\n    modified: string;\n    slug: string;\n    name: string;\n    version: string;\n    schema: Schema;\n    contributor: Contributor;\n}\n\nexport interface DescriptorSchema extends DescriptorSchemaBase {\n    current_user_permissions: ItemPermissionsOf<DescriptorSchemaPermissions>[];\n}\n\n\n// ------------------------------------------------------------------\n// Scatter Plot Json\n\n// ScatterPlotJson.RootObject is a type of process output. Processes (i.e. Rose2)\n// save it to data.output.scatter_plot.\nexport namespace ScatterPlotJson {\n\n    export interface RootObject { // This is the actual type of the json output\n        points: Points;\n        meta?: Meta;\n        annotations?: Annotation[];\n    }\n\n    export interface Points {\n        x_axis: number[];\n        y_axis: number[];\n        items?: any[];\n    }\n\n    export interface Meta {\n        x_label?: string;\n        y_label?: string;\n        text?: string;\n        chr_pos?: string[];\n    }\n\n    export type Annotation = AnnotationLineGeneral | AnnotationLineVertical | AnnotationLineHorizontal;\n\n    export interface AnnotationLineGeneral {\n        type: 'line';\n        x1: number;\n        x2: number;\n        y1: number;\n        y2: number;\n    }\n    export interface AnnotationLineVertical {\n        type: 'line_vertical';\n        x: number;\n    }\n    export interface AnnotationLineHorizontal {\n        type: 'line_horizontal';\n        y: number;\n    }\n}\n\n// ------------------------------------------------------------------\n// Data\n\nexport type DataPermissions = ViewPermission | EditPermission | SharePermission | DownloadPermission;\n\nexport type UploadingDataStatus = 'UP';\nexport type ResolvingDataStatus = 'RE';\nexport type WaitingDataStatus = 'WT';\nexport type ProcessingDataStatus = 'PR';\nexport type DoneDataStatus = 'OK';\nexport type ErrorDataStatus = 'ER';\nexport type DirtyDataStatus = 'DR';\n\nexport const UPLOADING_DATA_STATUS: UploadingDataStatus = 'UP';\nexport const RESOLVING_DATA_STATUS: ResolvingDataStatus = 'RE';\nexport const WAITING_DATA_STATUS: WaitingDataStatus = 'WT';\nexport const PROCESSING_DATA_STATUS: ProcessingDataStatus = 'PR';\nexport const DONE_DATA_STATUS: DoneDataStatus = 'OK';\nexport const ERROR_DATA_STATUS: ErrorDataStatus = 'ER';\nexport const DIRTY_DATA_STATUS: DirtyDataStatus = 'DR';\n\nexport type DataStatus = UploadingDataStatus | ResolvingDataStatus | WaitingDataStatus | ProcessingDataStatus |\n    DoneDataStatus | ErrorDataStatus | DirtyDataStatus;\n\nexport interface Data {\n    id: number;\n    created: string;\n    modified: string;\n    scheduled: string;\n    started: string;\n    finished: string;\n    duplicated: void | string;\n\n    checksum: string;\n    size: number;\n    status: DataStatus;\n    process_progress: number;\n    process_rc: number;\n    process_cores: number;\n    process_memory: number;\n    process_info: string[];\n    process_warning: string[];\n    process_error: string[];\n    slug: string;\n    name: string;\n    input: any;\n    output: any;\n    descriptor_schema: DescriptorSchemaBase;\n    descriptor: any;\n    contributor: Contributor;\n    process: Omit<Process, 'current_user_permissions'>;\n    tags: string[];\n\n    entity: void | Omit<Sample, 'current_user_permissions'>;\n    collection: void | Omit<Collection, 'current_user_permissions'>;\n    current_user_permissions: ItemPermissionsOf<DataPermissions>[];\n}\n\n\n// ------------------------------------------------------------------\n// data:differentialexpression:\n\nexport interface DataDifferentialExpression extends Data {\n    output: {\n        de_file: { file: string, size: number };\n        raw: { file: string, size: number };\n        de_json: number;\n        source: string;\n        species: string;\n    };\n}\n\n// ------------------------------------------------------------------\n// data:geneset:\n\nexport interface DataGenesetOutput {\n    geneset: { file: string, size: number };\n    geneset_json: number; // => DataGenesetStorage\n    source: string;\n    species: string;\n}\n\nexport interface DataGeneset extends Data {\n    output: DataGenesetOutput;\n}\n\nexport interface DataGenesetStorage extends Storage {\n    json: {\n        genes: string[];\n    };\n}\n\n// ------------------------------------------------------------------\n// data:geneset:venn:\n\nexport interface DataGenesetVennOutput extends DataGenesetOutput {\n    venn: number; // => DataGenesetVennStorage\n}\n\nexport interface DataGenesetVenn extends DataGeneset {\n    output: DataGenesetVennOutput;\n}\n\nexport interface DataGenesetVennStorage extends Storage {\n    json: {\n        parents: Array<{\n            id: number;\n            name: string;\n            genes: string[]; // geneset_json . genes\n        }>;\n    };\n}\n\n// ------------------------------------------------------------------\n// data:goea: Gene Ontology\n\nexport interface DataGOEnrichmentAnalysis extends Data {\n    output: {\n        terms: number; // => DataGOEnrichmentAnalysisStorage\n        source: string;\n        species: string;\n    };\n}\n\nexport type GOEnrichmentAspect = GOEnrichmentNode[];\nexport interface GOEnrichmentJson {\n    total_genes: number;\n    gene_associations: {\n        [goTermId: string]: string[]; // term_id => gene_ids\n    };\n    tree: {\n        [aspectSlug: string]: GOEnrichmentAspect, // \"BP\" | \"CC\" | \"MF\"\n    };\n}\n\nexport interface GOEnrichmentNode {\n    gene_ids: string[]; // selected_gene_associations\n    term_name: string;\n    term_id: string;\n    pval: number;\n    score: number;\n    matched: number; // Number of found elements in a single node.\n    total: number; // Total number of elements (including children nodes) in a single node.\n    children?: GOEnrichmentNode[];\n\n    // Added by frontend:\n    depth?: number; // Numerical representation of the level of depth. Used for offsetting the term column.\n    source?: string;\n    species?: string;\n    score_percentage?: number; // Percentage of max score within GOEnrichmentAspect.\n    gene_associations?: string[]; // all_gene_associations - Plucked from GOEnrichmentJson.gene_associations.\n    collapsed?: boolean; // Boolean representation if the selected item is hidden.\n}\n\nexport interface DataGOEnrichmentAnalysisStorage extends Storage {\n    json: GOEnrichmentJson;\n}\n\nexport interface DataGOEnrichmentAnalysisInput {\n    pval_threshold: number;\n    genes: string[];\n    source: string;\n    species: string;\n    ontology: number;\n    gaf: number;\n}\n\n// ------------------------------------------------------------------\n// data:gaf: GAF annotation\n\nexport interface DataGafAnnotation extends Data {\n    output: {\n        source: string;\n        species: string;\n        gaf: { file: string, size: number };\n        gaf_obj: { file: string, size: number };\n    };\n}\n\n// ------------------------------------------------------------------\n// data:varianttable:\n\nexport interface DataVariantAmpliconTable extends Data {\n    input: {\n        master_file: number; // data ID\n        coverage: number; // data ID\n        annot_vars: number[]; // data IDs\n        all_amplicons: boolean;\n        table_name: string;\n    };\n    output: {\n        variant_table: number; // => DataVariantTableStorage\n    };\n}\n\nexport interface DataVariantTLATable extends Data {\n    input: {\n        tla_results: number; // data ID\n    };\n    output: {\n        variant_table: number; // => DataVariantTableStorage\n        species: string;\n        build: string;\n    };\n}\n\nexport type DataVariantTable = DataVariantAmpliconTable | DataVariantTLATable;\n\nexport type DataVariantTableJsonValueColumn = string; // Example: MSH6_exon5_F1/2\nexport type DataVariantTableJsonDelimitedColumn = string; // Example: DP4=46,41,11,16;SB=4\nexport type DataVariantTableJsonUrlsColumn = [string, string][]; // Example: [['Gene', 'http://www.ncbi.nlm.nih.gov/gene/?term=gene']]\nexport type DataVariantTableJsonColumn = DataVariantTableJsonValueColumn |\n                                         DataVariantTableJsonDelimitedColumn |\n                                         DataVariantTableJsonUrlsColumn;\nexport interface DataVariantTableRow {\n    columns: DataVariantTableJsonColumn[];\n    pos: string;\n}\n\nexport interface DataVariantTableJson { // api-typecheck:amplicon_table_output.json.gz\n    column_types: Array<'value' | 'delimited' | 'urls'>;\n    headers: string[];\n    labels: string[];\n    data: DataVariantTableRow[];\n}\n\nexport interface DataVariantTableStorage extends Storage {\n    json: DataVariantTableJson;\n}\n\n// ------------------------------------------------------------------\n// Collection\n\nexport type CollectionPermissions = ViewPermission | EditPermission | SharePermission |\n    DownloadPermission | AddPermission;\n\nexport interface Collection {\n    id: number;\n    created: string;\n    modified: string;\n    duplicated: void | string;\n    slug: string;\n    name: string;\n    description: string;\n    descriptor_schema: DescriptorSchemaBase;\n    descriptor: any;\n    contributor: Contributor;\n    current_user_permissions: ItemPermissionsOf<CollectionPermissions>[];\n    tags: string[];\n    settings: any;\n}\n\nexport interface Sample extends Collection {\n    collection: void | Omit<Collection, 'current_user_permissions'>;\n    descriptor_completed: boolean;\n    type: 'sample';\n}\n\nexport interface CollectionHydrateData extends Collection {\n    data: Data[];\n}\n\nexport interface SampleHydrateData extends Sample {\n    data: Data[];\n}\n\n\n// ------------------------------------------------------------------\n// Storage\n\nexport interface Storage {\n    id: number;\n    slug: string;\n    name: string;\n    data: number;\n    json: any;\n    contributor: Contributor;\n    created: string;\n    modified: string;\n}\n\nexport interface SampleClustering { // api-typecheck:sample_cluster_data.json.gz\n    order: number[];\n    linkage: number[][]; // [[node1, node2, distance, number of samples]]\n    sample_ids: _.Dictionary<{ id: number }>;\n}\n\nexport interface GeneClustering { // api-typecheck:gene_cluster_data.json.gz\n    order: number[];\n    linkage: number[][]; // [[node1, node2, distance, number of genes]]\n    gene_symbols: _.Dictionary<{ gene: string }>;\n}\n\nexport interface PCA { // api-typecheck:pca_plot_ncbi.json.gz\n    explained_variance_ratios: number[];\n    all_explained_variance_ratios: number[];\n    all_components: [string, number][][];\n    components: [string, number][][];\n    zero_gene_symbols: string[]; // gene ids with no expressions\n    flot: {\n        xlabel: string;\n        ylabel: string;\n        data: number[][];\n        sample_ids: string[];\n    };\n}\n\nexport interface QCStorage extends Storage {\n    json: {\n        status: 'PASS' | 'FAIL' | 'WARNING',\n        message: string,\n    };\n}\n\n\n// ------------------------------------------------------------------\n// User\n\nexport interface User {\n    id: number;\n    username: string;\n    email: string;\n    first_name: string;\n    last_name: string;\n    job_title: string;\n    company: string;\n    department: string;\n    location: string;\n    lab: string;\n    phone_number: string;\n    last_login: string;\n    date_joined: string;\n}\n\nexport interface LoginResponse {\n    key: string;\n}\n\nexport interface LogoutResponse {\n}\n\nexport interface CreateAccountInformation {\n    username: string;\n    password: string;\n    email: string;\n    first_name: string;\n    last_name: string;\n    job_title?: string;\n    company?: string;\n    department?: string;\n    location?: string;\n    lab?: string;\n    phone_number?: string;\n    newsletter?: boolean;\n    community?: string;\n}\n\nexport interface ActivateAccountResponse {\n    username: string;\n}\n\n\n// ------------------------------------------------------------------\n// File\n\nexport interface Download {\n    data: string;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/api/types/rest.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;AAqCH,SAAgB,mBAAmB,CAAI,QAA2B;IAC9D,OAAO,QAAQ,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;AAC9C,CAAC;AAFD,kDAEC;AAsBY,QAAA,gBAAgB,GAAoB,OAAO,CAAC;AAC5C,QAAA,gBAAgB,GAAoB,OAAO,CAAC;AAC5C,QAAA,eAAe,GAAmB,MAAM,CAAC;AACzC,QAAA,iBAAiB,GAAqB,MAAM,CAAC;AAC7C,QAAA,cAAc,GAAkB,KAAK,CAAC;AACtC,QAAA,mBAAmB,GAAuB,UAAU,CAAC;AACrD,QAAA,eAAe,GAAmB,MAAM,CAAC;AAUzC,QAAA,sBAAsB,GAAyB,QAAQ,CAAC;AACxD,QAAA,qBAAqB,GAAwB,OAAO,CAAC;AACrD,QAAA,oBAAoB,GAAuB,MAAM,CAAC;AAkDlD,QAAA,uBAAuB,GAA0B,KAAK,CAAC;AACvD,QAAA,0BAA0B,GAA6B,KAAK,CAAC;AAC7D,QAAA,wBAAwB,GAA2B,KAAK,CAAC;AAuKzD,QAAA,qBAAqB,GAAwB,IAAI,CAAC;AAClD,QAAA,qBAAqB,GAAwB,IAAI,CAAC;AAClD,QAAA,mBAAmB,GAAsB,IAAI,CAAC;AAC9C,QAAA,sBAAsB,GAAyB,IAAI,CAAC;AACpD,QAAA,gBAAgB,GAAmB,IAAI,CAAC;AACxC,QAAA,iBAAiB,GAAoB,IAAI,CAAC;AAC1C,QAAA,iBAAiB,GAAoB,IAAI,CAAC","file":"api/types/rest.js","sourcesContent":["/*\n * Type definitions\n *\n * Here is defined everything the API returns.\n */\n\nimport * as Rx from 'rx';\nimport * as _ from 'lodash';\n\nimport Dictionary = _.Dictionary;\nimport NumericDictionary = _.NumericDictionary;\n\n\n// ------------------------------------------------------------------\n// Query\n\nexport interface StrictQuery {\n    limit?: number;\n    offset?: number;\n    ordering?: string; // '-field1,-field2,field3'\n    fields?: string; // 'id,slug,input__reads__file'\n    id?: number;\n    slug?: string;\n    id__in?: string; // '13,24,35'\n    slug__in?: string; // 'reads1,reads-paired-2'\n    name__icontains?: string;\n    status__in?: string; // 'UP,WT,RE,PR'\n    text?: string; // Elastic search\n    tags?: string; // 'community:universe,community:expressions'\n}\n\nexport interface Query extends StrictQuery {\n    [propertyName: string]: any;\n    data?: \"Disallow deprecated api.Sample.queryOne({ data: data.id }). Use api.Data.getSampleFromDataId(data.id) instead.\";\n    parents?: \"Disallow deprecated api.Data.query({ parents: data.id }). Use api.Data.getChildren(data.id) instead.\";\n    children?: \"Disallow deprecated api.Data.query({ children: data.id }). Use api.Data.getParents(data.id) instead.\";\n    hydrate_data?: \"Disallow deprecated hydrate_data.\";\n    hydrate_collections?: \"Disallow deprecated hydrate_collections.\";\n    hydrate_entities?: \"Disallow deprecated hydrate_entities.\";\n}\n\nexport function isResponsePaginated<T>(response: T | { results: T}): response is { results: T } {\n    return response.hasOwnProperty('results');\n}\n\n// LimitOffsetPagination\nexport interface PaginatedResponse<T> {\n    count: number;\n    next: string;\n    previous: string;\n    results: T[];\n}\n\n\n// ------------------------------------------------------------------\n// Permissions\n\nexport type OwnerPermission = 'owner';\nexport type SharePermission = 'share';\nexport type EditPermission = 'edit';\nexport type DeletePermission = 'edit'; // not a typo (API doesn't support delete permission)\nexport type AddPermission = 'add';\nexport type DownloadPermission = 'download';\nexport type ViewPermission = 'view';\n\nexport const OWNER_PERMISSION: OwnerPermission = 'owner';\nexport const SHARE_PERMISSION: SharePermission = 'share';\nexport const EDIT_PERMISSION: EditPermission = 'edit';\nexport const DELETE_PERMISSION: DeletePermission = 'edit';\nexport const ADD_PERMISSION: AddPermission = 'add';\nexport const DOWNLOAD_PERMISSION: DownloadPermission = 'download';\nexport const VIEW_PERMISSION: ViewPermission = 'view';\n\nexport type Permission = OwnerPermission | SharePermission | EditPermission | DeletePermission | AddPermission |\n    DownloadPermission | ViewPermission;\n\n\nexport type PublicPermissionType = 'public';\nexport type GroupPermissionType = 'group';\nexport type UserPermissionType = 'user';\n\nexport const PUBLIC_PERMISSION_TYPE: PublicPermissionType = 'public';\nexport const GROUP_PERMISSION_TYPE: GroupPermissionType = 'group';\nexport const USER_PERMISSION_TYPE: UserPermissionType = 'user';\n\nexport type PermissionType = PublicPermissionType | GroupPermissionType | UserPermissionType;\n\nexport interface ItemPermissionsOf<T> {\n    type: PermissionType;\n    permissions: T[];\n    id?: number;\n    name?: string;\n}\n\nexport type ItemPermissions = ItemPermissionsOf<Permission>;\n\nexport interface SetPermissionsRequest {\n    public?: {\n        add?: Permission[],\n        remove?: Permission[],\n    };\n    groups?: {\n        add?: NumericDictionary<Permission[]> | Dictionary<Permission[]>,\n        remove?: NumericDictionary<Permission[]> | Dictionary<Permission[]>,\n    };\n    users?: {\n        add?: NumericDictionary<Permission[]> | Dictionary<Permission[]>,\n        remove?: NumericDictionary<Permission[]> | Dictionary<Permission[]>,\n    };\n    share_content?: '0' | '1';\n}\n\n\n// ------------------------------------------------------------------\n// Contributor\n\nexport interface Contributor {\n    id: number;\n    username: string;\n    first_name: string;\n    last_name: string;\n}\n\n\n// ------------------------------------------------------------------\n// Process\n\nexport type ProcessPermissions = ViewPermission | SharePermission;\n\nexport type RawProcessPersistence = 'RAW';\nexport type CachedProcessPersistence = 'CAC';\nexport type TempProcessPersistence = 'TMP';\n\nexport const RAW_PROCESS_PERSISTENCE: RawProcessPersistence = 'RAW';\nexport const CACHED_PROCESS_PERSISTENCE: CachedProcessPersistence = 'CAC';\nexport const TEMP_PROCESS_PERSISTENCE: TempProcessPersistence = 'TMP';\n\nexport type ProcessPersistence = RawProcessPersistence | CachedProcessPersistence | TempProcessPersistence;\n\nexport interface Process {\n    id: number;\n    slug: string;\n    name: string;\n    created: string;\n    modified: string;\n    version: string;\n    type: string;\n    category: string;\n    requirements?: {\n        relations?: Array<{\n            type: 'compare' | 'group' | 'background' | 'series';\n            category?: string;\n            labels?: string[];\n            required?: boolean;\n        }>;\n    };\n    persistence: ProcessPersistence;\n    description: string;\n    input_schema: any;\n    output_schema: any;\n    run: any;\n    contributor: Contributor;\n    current_user_permissions: ItemPermissionsOf<ProcessPermissions>[];\n    is_active: boolean;\n    data_name: string;\n    entity_descriptor_schema: void | string;\n    entity_input: any;\n    entity_type: void | string;\n    scheduling_class: string;\n}\n\n// ------------------------------------------------------------------\n// Relation\n\nexport interface RelationPartition {\n    id: number;\n    entity: number;\n    position: number | null;\n    label: string | null;\n}\n\nexport interface Relation {\n    id: number;\n    created: string;\n    modified: string;\n    type: string;\n    collection: number;\n    partitions: RelationPartition[];\n    category: string;\n    unit: 's' | 'min' | 'hr' | 'd' | 'wk' | null;\n    contributor: Contributor;\n}\n\n// ------------------------------------------------------------------\n// DescriptorSchema\n\n// Schema\nexport interface ChoiceMap {\n    value: string;\n    label: string;\n}\n\nexport interface FieldSchema {\n    disabled?: boolean | string;\n    required?: boolean;\n    collapsed?: boolean;\n    hidden?: boolean | string;\n    default?: any;\n    choices?: ChoiceMap[];\n    allow_custom_choice?: boolean;\n    validate_regex?: string;\n    slug?: {\n        source?: string;\n        uniqueValidator?: (slug: string) => Rx.Observable<boolean>;\n    };\n    type: string;\n    name: string;\n    label: string;\n    group?: Schema;\n    range?: [number, number]; // Min, max\n}\n\nexport type Schema = FieldSchema[];\n\n\n// DescriptorSchema\nexport type DescriptorSchemaPermissions = ViewPermission | EditPermission | SharePermission;\n\nexport interface DescriptorSchemaBase {\n    id: number;\n    created: string;\n    modified: string;\n    slug: string;\n    name: string;\n    version: string;\n    schema: Schema;\n    contributor: Contributor;\n}\n\nexport interface DescriptorSchema extends DescriptorSchemaBase {\n    current_user_permissions: ItemPermissionsOf<DescriptorSchemaPermissions>[];\n}\n\n\n// ------------------------------------------------------------------\n// Scatter Plot Json\n\n// ScatterPlotJson.RootObject is a type of process output. Processes (i.e. Rose2)\n// save it to data.output.scatter_plot.\nexport namespace ScatterPlotJson {\n\n    export interface RootObject { // This is the actual type of the json output\n        points: Points;\n        meta?: Meta;\n        annotations?: Annotation[];\n    }\n\n    export interface Points {\n        x_axis: number[];\n        y_axis: number[];\n        items?: any[];\n    }\n\n    export interface Meta {\n        x_label?: string;\n        y_label?: string;\n        text?: string;\n        chr_pos?: string[];\n    }\n\n    export type Annotation = AnnotationLineGeneral | AnnotationLineVertical | AnnotationLineHorizontal;\n\n    export interface AnnotationLineGeneral {\n        type: 'line';\n        x1: number;\n        x2: number;\n        y1: number;\n        y2: number;\n    }\n    export interface AnnotationLineVertical {\n        type: 'line_vertical';\n        x: number;\n    }\n    export interface AnnotationLineHorizontal {\n        type: 'line_horizontal';\n        y: number;\n    }\n}\n\n// ------------------------------------------------------------------\n// Data\n\nexport type DataPermissions = ViewPermission | EditPermission | SharePermission | DownloadPermission;\n\nexport type UploadingDataStatus = 'UP';\nexport type ResolvingDataStatus = 'RE';\nexport type WaitingDataStatus = 'WT';\nexport type ProcessingDataStatus = 'PR';\nexport type DoneDataStatus = 'OK';\nexport type ErrorDataStatus = 'ER';\nexport type DirtyDataStatus = 'DR';\n\nexport const UPLOADING_DATA_STATUS: UploadingDataStatus = 'UP';\nexport const RESOLVING_DATA_STATUS: ResolvingDataStatus = 'RE';\nexport const WAITING_DATA_STATUS: WaitingDataStatus = 'WT';\nexport const PROCESSING_DATA_STATUS: ProcessingDataStatus = 'PR';\nexport const DONE_DATA_STATUS: DoneDataStatus = 'OK';\nexport const ERROR_DATA_STATUS: ErrorDataStatus = 'ER';\nexport const DIRTY_DATA_STATUS: DirtyDataStatus = 'DR';\n\nexport type DataStatus = UploadingDataStatus | ResolvingDataStatus | WaitingDataStatus | ProcessingDataStatus |\n    DoneDataStatus | ErrorDataStatus | DirtyDataStatus;\n\nexport interface Data {\n    id: number;\n    created: string;\n    modified: string;\n    scheduled: string;\n    started: string;\n    finished: string;\n    duplicated: void | string;\n\n    checksum: string;\n    size: number;\n    status: DataStatus;\n    process_progress: number;\n    process_rc: number;\n    process_cores: number;\n    process_memory: number;\n    process_info: string[];\n    process_warning: string[];\n    process_error: string[];\n    slug: string;\n    name: string;\n    input: any;\n    output: any;\n    descriptor_schema: DescriptorSchemaBase;\n    descriptor: any;\n    contributor: Contributor;\n    process: Omit<Process, 'current_user_permissions'>;\n    tags: string[];\n\n    entity: void | Omit<Sample, 'current_user_permissions'>;\n    collection: void | Omit<Collection, 'current_user_permissions'>;\n    current_user_permissions: ItemPermissionsOf<DataPermissions>[];\n}\n\n\n// ------------------------------------------------------------------\n// data:differentialexpression:\n\nexport interface DataDifferentialExpression extends Data {\n    output: {\n        de_file: { file: string, size: number };\n        raw: { file: string, size: number };\n        de_json: number;\n        source: string;\n        species: string;\n    };\n}\n\n// ------------------------------------------------------------------\n// data:geneset:\n\nexport interface DataGenesetOutput {\n    geneset: { file: string, size: number };\n    geneset_json: number; // => DataGenesetStorage\n    source: string;\n    species: string;\n}\n\nexport interface DataGeneset extends Data {\n    output: DataGenesetOutput;\n}\n\nexport interface DataGenesetStorage extends Storage {\n    json: {\n        genes: string[];\n    };\n}\n\n// ------------------------------------------------------------------\n// data:geneset:venn:\n\nexport interface DataGenesetVennOutput extends DataGenesetOutput {\n    venn: number; // => DataGenesetVennStorage\n}\n\nexport interface DataGenesetVenn extends DataGeneset {\n    output: DataGenesetVennOutput;\n}\n\nexport interface DataGenesetVennStorage extends Storage {\n    json: {\n        parents: Array<{\n            id: number;\n            name: string;\n            genes: string[]; // geneset_json . genes\n        }>;\n    };\n}\n\n// ------------------------------------------------------------------\n// data:goea: Gene Ontology\n\nexport interface DataGOEnrichmentAnalysis extends Data {\n    output: {\n        terms: number; // => DataGOEnrichmentAnalysisStorage\n        source: string;\n        species: string;\n    };\n}\n\nexport type GOEnrichmentAspect = GOEnrichmentNode[];\nexport interface GOEnrichmentJson {\n    total_genes: number;\n    gene_associations: {\n        [goTermId: string]: string[]; // term_id => gene_ids\n    };\n    tree: {\n        [aspectSlug: string]: GOEnrichmentAspect, // \"BP\" | \"CC\" | \"MF\"\n    };\n}\n\nexport interface GOEnrichmentNode {\n    gene_ids: string[]; // selected_gene_associations\n    term_name: string;\n    term_id: string;\n    pval: number;\n    score: number;\n    matched: number; // Number of found elements in a single node.\n    total: number; // Total number of elements (including children nodes) in a single node.\n    children?: GOEnrichmentNode[];\n\n    // Added by frontend:\n    depth?: number; // Numerical representation of the level of depth. Used for offsetting the term column.\n    source?: string;\n    species?: string;\n    score_percentage?: number; // Percentage of max score within GOEnrichmentAspect.\n    gene_associations?: string[]; // all_gene_associations - Plucked from GOEnrichmentJson.gene_associations.\n    collapsed?: boolean; // Boolean representation if the selected item is hidden.\n}\n\nexport interface DataGOEnrichmentAnalysisStorage extends Storage {\n    json: GOEnrichmentJson;\n}\n\nexport interface DataGOEnrichmentAnalysisInput {\n    pval_threshold: number;\n    genes: string[];\n    source: string;\n    species: string;\n    ontology: number;\n    gaf: number;\n}\n\n// ------------------------------------------------------------------\n// data:gaf: GAF annotation\n\nexport interface DataGafAnnotation extends Data {\n    output: {\n        source: string;\n        species: string;\n        gaf: { file: string, size: number };\n        gaf_obj: { file: string, size: number };\n    };\n}\n\n// ------------------------------------------------------------------\n// data:varianttable:\n\nexport interface DataVariantAmpliconTable extends Data {\n    input: {\n        master_file: number; // data ID\n        coverage: number; // data ID\n        annot_vars: number[]; // data IDs\n        all_amplicons: boolean;\n        table_name: string;\n    };\n    output: {\n        variant_table: number; // => DataVariantTableStorage\n    };\n}\n\nexport interface DataVariantTLATable extends Data {\n    input: {\n        tla_results: number; // data ID\n    };\n    output: {\n        variant_table: number; // => DataVariantTableStorage\n        species: string;\n        build: string;\n    };\n}\n\nexport type DataVariantTable = DataVariantAmpliconTable | DataVariantTLATable;\n\nexport type DataVariantTableJsonValueColumn = string; // Example: MSH6_exon5_F1/2\nexport type DataVariantTableJsonDelimitedColumn = string; // Example: DP4=46,41,11,16;SB=4\nexport type DataVariantTableJsonUrlsColumn = [string, string][]; // Example: [['Gene', 'http://www.ncbi.nlm.nih.gov/gene/?term=gene']]\nexport type DataVariantTableJsonColumn = DataVariantTableJsonValueColumn |\n                                         DataVariantTableJsonDelimitedColumn |\n                                         DataVariantTableJsonUrlsColumn;\nexport interface DataVariantTableRow {\n    columns: DataVariantTableJsonColumn[];\n    pos: string;\n}\n\nexport interface DataVariantTableJson { // api-typecheck:amplicon_table_output.json.gz\n    column_types: Array<'value' | 'delimited' | 'urls'>;\n    headers: string[];\n    labels: string[];\n    data: DataVariantTableRow[];\n}\n\nexport interface DataVariantTableStorage extends Storage {\n    json: DataVariantTableJson;\n}\n\n// ------------------------------------------------------------------\n// Collection\n\nexport type CollectionPermissions = ViewPermission | EditPermission | SharePermission |\n    DownloadPermission | AddPermission;\n\nexport interface Collection {\n    id: number;\n    created: string;\n    modified: string;\n    duplicated: void | string;\n    slug: string;\n    name: string;\n    description: string;\n    descriptor_schema: DescriptorSchemaBase;\n    descriptor: any;\n    contributor: Contributor;\n    current_user_permissions: ItemPermissionsOf<CollectionPermissions>[];\n    tags: string[];\n    settings: any;\n}\n\nexport interface Sample extends Collection {\n    collection: void | Omit<Collection, 'current_user_permissions'>;\n    type: 'sample';\n}\n\nexport interface CollectionHydrateData extends Collection {\n    data: Data[];\n}\n\nexport interface SampleHydrateData extends Sample {\n    data: Data[];\n}\n\n\n// ------------------------------------------------------------------\n// Storage\n\nexport interface Storage {\n    id: number;\n    slug: string;\n    name: string;\n    data: number;\n    json: any;\n    contributor: Contributor;\n    created: string;\n    modified: string;\n}\n\nexport interface SampleClustering { // api-typecheck:sample_cluster_data.json.gz\n    order: number[];\n    linkage: number[][]; // [[node1, node2, distance, number of samples]]\n    sample_ids: _.Dictionary<{ id: number }>;\n}\n\nexport interface GeneClustering { // api-typecheck:gene_cluster_data.json.gz\n    order: number[];\n    linkage: number[][]; // [[node1, node2, distance, number of genes]]\n    gene_symbols: _.Dictionary<{ gene: string }>;\n}\n\nexport interface PCA { // api-typecheck:pca_plot_ncbi.json.gz\n    explained_variance_ratios: number[];\n    all_explained_variance_ratios: number[];\n    all_components: [string, number][][];\n    components: [string, number][][];\n    zero_gene_symbols: string[]; // gene ids with no expressions\n    flot: {\n        xlabel: string;\n        ylabel: string;\n        data: number[][];\n        sample_ids: string[];\n    };\n}\n\nexport interface QCStorage extends Storage {\n    json: {\n        status: 'PASS' | 'FAIL' | 'WARNING',\n        message: string,\n    };\n}\n\n\n// ------------------------------------------------------------------\n// User\n\nexport interface User {\n    id: number;\n    username: string;\n    email: string;\n    first_name: string;\n    last_name: string;\n    job_title: string;\n    company: string;\n    department: string;\n    location: string;\n    lab: string;\n    phone_number: string;\n    last_login: string;\n    date_joined: string;\n}\n\nexport interface LoginResponse {\n    key: string;\n}\n\nexport interface LogoutResponse {\n}\n\nexport interface CreateAccountInformation {\n    username: string;\n    password: string;\n    email: string;\n    first_name: string;\n    last_name: string;\n    job_title?: string;\n    company?: string;\n    department?: string;\n    location?: string;\n    lab?: string;\n    phone_number?: string;\n    newsletter?: boolean;\n    community?: string;\n}\n\nexport interface ActivateAccountResponse {\n    username: string;\n}\n\n\n// ------------------------------------------------------------------\n// File\n\nexport interface Download {\n    data: string;\n}\n"]} |
@@ -214,2 +214,1 @@ import * as Rx from 'rx'; | ||
export {}; | ||
//# sourceMappingURL=utils.d.ts.map |
export {}; | ||
//# sourceMappingURL=utils.spec.d.ts.map |
@@ -276,2 +276,1 @@ import * as angular from 'angular'; | ||
export declare function directive(config: ComponentConfiguration): ClassDecorator; | ||
//# sourceMappingURL=base.d.ts.map |
export {}; | ||
//# sourceMappingURL=base.spec.d.ts.map |
@@ -46,9 +46,9 @@ "use strict"; | ||
it('should reactively update on shallow component changes', function () { | ||
var component = tester.createComponent(DummyComponent.asView().template); | ||
var dummyComponent = tester.createComponent(DummyComponent.asView().template); | ||
// Test this.str | ||
var strSpy = jasmine.createSpy('strSpy'); | ||
component.ctrl.strObservable | ||
dummyComponent.ctrl.strObservable | ||
.distinctUntilChanged() | ||
.subscribe(function (value) { return strSpy(_.cloneDeep(value)); }); | ||
component.ctrl.str = 'some value'; | ||
dummyComponent.ctrl.str = 'some value'; | ||
tester.digest(); | ||
@@ -60,11 +60,11 @@ expect(strSpy.calls.count()).toBe(2); | ||
it('should reactively update on deep component changes', function () { | ||
var component = tester.createComponent(DummyComponent.asView().template); | ||
var dummyComponent = tester.createComponent(DummyComponent.asView().template); | ||
// Test this.array | ||
var arraySpy = jasmine.createSpy('arraySpy'); | ||
component.ctrl.arrayObservable | ||
dummyComponent.ctrl.arrayObservable | ||
.filter(function (value) { return !_.isEmpty(value); }) | ||
.subscribe(function (value) { return arraySpy(_.cloneDeep(value)); }); | ||
component.ctrl.array.push('some value'); | ||
dummyComponent.ctrl.array.push('some value'); | ||
tester.digest(); | ||
component.ctrl.array.push('some other value'); | ||
dummyComponent.ctrl.array.push('some other value'); | ||
tester.digest(); | ||
@@ -75,7 +75,7 @@ expect(arraySpy.calls.all()[0].args[0]).toEqual(['some value']); | ||
it('should support watch', function () { | ||
var component = tester.createComponent(DummyComponent.asView().template); | ||
var dummyComponent = tester.createComponent(DummyComponent.asView().template); | ||
// No watch should be created if computation is immediately unsubscribed. | ||
var expression = 0; | ||
var executed = 0; | ||
var watchComputation = component.ctrl.watch(function () { return expression; }, function (computation) { | ||
var watchComputation = dummyComponent.ctrl.watch(function () { return expression; }, function (computation) { | ||
executed++; | ||
@@ -92,3 +92,3 @@ expect(computation.isDone()).toBeFalsy(); | ||
executed = 0; | ||
watchComputation = component.ctrl.watch(function () { return expression; }, function (computation) { | ||
watchComputation = dummyComponent.ctrl.watch(function () { return expression; }, function (computation) { | ||
executed++; | ||
@@ -114,2 +114,2 @@ if (executed > 2) | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/core/components/base.spec.ts"],"names":[],"mappings":"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","file":"core/components/base.spec.js","sourcesContent":["import * as _ from 'lodash';\nimport * as Rx from 'rx';\nimport * as angular from 'angular';\n\nimport {ComponentBase, component} from './base';\nimport {describeComponent} from '../../tests/component';\n\ndescribeComponent('base component', [], (tester) => {\n    @component({\n        module: tester.module,\n        directive: 'gen-watch-observable',\n    })\n    class DummyComponent extends ComponentBase {\n        public str: string;\n        public strObservable: Rx.Observable<string>;\n\n        public array: string[] = [];\n        public arrayObservable: Rx.Observable<string[]>;\n\n        // @ngInject\n        constructor($scope: angular.IScope) {\n            super($scope);\n\n            this.strObservable = this.createWatchObservable(() => this.str);\n            this.arrayObservable = this.createWatchObservable(() => this.array, true);\n        }\n    }\n\n    it('should reactively update on shallow component changes', () => {\n        const component = tester.createComponent<DummyComponent>(\n            DummyComponent.asView().template\n        );\n\n        // Test this.str\n        const strSpy = jasmine.createSpy('strSpy');\n        component.ctrl.strObservable\n            .distinctUntilChanged()\n            .subscribe((value) => strSpy(_.cloneDeep(value)));\n\n        component.ctrl.str = 'some value';\n        tester.digest();\n\n        expect(strSpy.calls.count()).toBe(2);\n        expect(strSpy.calls.first().args[0]).toBeUndefined();\n        expect(strSpy.calls.mostRecent().args[0]).toBe('some value');\n    });\n\n    it('should reactively update on deep component changes', () => {\n        const component = tester.createComponent<DummyComponent>(\n            DummyComponent.asView().template\n        );\n\n        // Test this.array\n        const arraySpy = jasmine.createSpy('arraySpy');\n        component.ctrl.arrayObservable\n            .filter((value) => !_.isEmpty(value))\n            .subscribe((value) => arraySpy(_.cloneDeep(value)));\n\n        component.ctrl.array.push('some value');\n        tester.digest();\n        component.ctrl.array.push('some other value');\n        tester.digest();\n\n        expect(arraySpy.calls.all()[0].args[0]).toEqual(['some value']);\n        expect(arraySpy.calls.all()[1].args[0]).toEqual(['some value', 'some other value']);\n    });\n\n    it('should support watch', () => {\n        const component = tester.createComponent<DummyComponent>(\n            DummyComponent.asView().template\n        );\n\n        // No watch should be created if computation is immediately unsubscribed.\n        let expression = 0;\n        let executed = 0;\n        let watchComputation = component.ctrl.watch(() => expression, (computation) => {\n            executed++;\n            expect(computation.isDone()).toBeFalsy();\n            computation.unsubscribe();\n        });\n        expect(watchComputation.isDone()).toBeTruthy();\n\n        expression = 1;\n        tester.digest();\n        expect(executed).toBe(1);\n\n        // Check that watching works correctly.\n        expression = 0;\n        executed = 0;\n        watchComputation = component.ctrl.watch(() => expression, (computation) => {\n            executed++;\n            if (executed > 2) computation.unsubscribe();\n        });\n        expect(watchComputation.isDone()).toBeFalsy();\n\n        expression = 1;\n        tester.digest();\n        // Just to check that watch is only evaluated when the expression changes.\n        tester.digest();\n        expect(executed).toBe(2);\n\n        expression = 2;\n        tester.digest();\n        expect(executed).toBe(3);\n\n        // Check that unsubscribe actually stops the watch.\n        expression = 3;\n        tester.digest();\n        expect(executed).toBe(3);\n    });\n});\n\n\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/core/components/base.spec.ts"],"names":[],"mappings":"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","file":"core/components/base.spec.js","sourcesContent":["import * as _ from 'lodash';\nimport * as Rx from 'rx';\nimport * as angular from 'angular';\n\nimport {ComponentBase, component} from './base';\nimport {describeComponent} from '../../tests/component';\n\ndescribeComponent('base component', [], (tester) => {\n    @component({\n        module: tester.module,\n        directive: 'gen-watch-observable',\n    })\n    class DummyComponent extends ComponentBase {\n        public str: string;\n        public strObservable: Rx.Observable<string>;\n\n        public array: string[] = [];\n        public arrayObservable: Rx.Observable<string[]>;\n\n        // @ngInject\n        constructor($scope: angular.IScope) {\n            super($scope);\n\n            this.strObservable = this.createWatchObservable(() => this.str);\n            this.arrayObservable = this.createWatchObservable(() => this.array, true);\n        }\n    }\n\n    it('should reactively update on shallow component changes', () => {\n        const dummyComponent = tester.createComponent<DummyComponent>(\n            DummyComponent.asView().template\n        );\n\n        // Test this.str\n        const strSpy = jasmine.createSpy('strSpy');\n        dummyComponent.ctrl.strObservable\n            .distinctUntilChanged()\n            .subscribe((value) => strSpy(_.cloneDeep(value)));\n\n        dummyComponent.ctrl.str = 'some value';\n        tester.digest();\n\n        expect(strSpy.calls.count()).toBe(2);\n        expect(strSpy.calls.first().args[0]).toBeUndefined();\n        expect(strSpy.calls.mostRecent().args[0]).toBe('some value');\n    });\n\n    it('should reactively update on deep component changes', () => {\n        const dummyComponent = tester.createComponent<DummyComponent>(\n            DummyComponent.asView().template\n        );\n\n        // Test this.array\n        const arraySpy = jasmine.createSpy('arraySpy');\n        dummyComponent.ctrl.arrayObservable\n            .filter((value) => !_.isEmpty(value))\n            .subscribe((value) => arraySpy(_.cloneDeep(value)));\n\n        dummyComponent.ctrl.array.push('some value');\n        tester.digest();\n        dummyComponent.ctrl.array.push('some other value');\n        tester.digest();\n\n        expect(arraySpy.calls.all()[0].args[0]).toEqual(['some value']);\n        expect(arraySpy.calls.all()[1].args[0]).toEqual(['some value', 'some other value']);\n    });\n\n    it('should support watch', () => {\n        const dummyComponent = tester.createComponent<DummyComponent>(\n            DummyComponent.asView().template\n        );\n\n        // No watch should be created if computation is immediately unsubscribed.\n        let expression = 0;\n        let executed = 0;\n        let watchComputation = dummyComponent.ctrl.watch(() => expression, (computation) => {\n            executed++;\n            expect(computation.isDone()).toBeFalsy();\n            computation.unsubscribe();\n        });\n        expect(watchComputation.isDone()).toBeTruthy();\n\n        expression = 1;\n        tester.digest();\n        expect(executed).toBe(1);\n\n        // Check that watching works correctly.\n        expression = 0;\n        executed = 0;\n        watchComputation = dummyComponent.ctrl.watch(() => expression, (computation) => {\n            executed++;\n            if (executed > 2) computation.unsubscribe();\n        });\n        expect(watchComputation.isDone()).toBeFalsy();\n\n        expression = 1;\n        tester.digest();\n        // Just to check that watch is only evaluated when the expression changes.\n        tester.digest();\n        expect(executed).toBe(2);\n\n        expression = 2;\n        tester.digest();\n        expect(executed).toBe(3);\n\n        // Check that unsubscribe actually stops the watch.\n        expression = 3;\n        tester.digest();\n        expect(executed).toBe(3);\n    });\n});\n\n\n"]} |
@@ -78,2 +78,1 @@ import { StatefulComponentBase } from './stateful'; | ||
} | ||
//# sourceMappingURL=manager.d.ts.map |
@@ -196,2 +196,1 @@ import * as angular from 'angular'; | ||
export declare function sharedState(name?: string): (target: StatefulComponentBase, propertyKey: string) => void; | ||
//# sourceMappingURL=stateful.d.ts.map |
@@ -274,2 +274,3 @@ "use strict"; | ||
if (!store) { | ||
throw new error_1.GenError("Ignored missing store: " + storeMetadata.propertyName + " " + _this.globalStateId); | ||
} | ||
@@ -310,3 +311,3 @@ if (!store) | ||
var result = {}; | ||
var state = result[this.globalStateId] = {}; | ||
var state = result[this.globalStateId] = {}; // tslint:disable-line:no-shadowed-variable | ||
_.forOwn(this.__stateMetadata, function (metadata, key) { | ||
@@ -337,2 +338,3 @@ var value = _this[metadata.propertyName]; | ||
if (loadChildren === void 0) { loadChildren = true; } | ||
// tslint:disable-next-line:no-shadowed-variable | ||
var state = globalState[this.globalStateId]; | ||
@@ -446,2 +448,2 @@ var sharedStateChanged = false; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/core/components/stateful.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA,0BAA4B;AAC5B,iCAAmC;AAEnC,yCAAyC;AAGzC,+BAAsF;AAGtF;IACI,2BAAmB,YAAoB,EAAS,MAAe;QAA5C,iBAAY,GAAZ,YAAY,CAAQ;QAAS,WAAM,GAAN,MAAM,CAAS;IAC/D,CAAC;IAEM,sDAA0B,GAAjC;QACI,OAAO,mBAAmB,GAAG,IAAI,CAAC,YAAY,CAAC;IACnD,CAAC;IACL,wBAAC;AAAD,CAPA,AAOC,IAAA;AAPY,8CAAiB;AAiB9B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuDG;AAOH;IAAoD,yCAAa;IAoB7D,YAAY;IACZ,+BAAY,MAAsB,EAAE,YAA0B;QAA9D,YACI,kBAAM,MAAM,CAAC,SAIhB;QAnBD,8BAA8B;QACtB,aAAO,GAA0B,IAAI,CAAC;QAC9C,wCAAwC;QAChC,eAAS,GAA4B,EAAE,CAAC;QAKhD,4CAA4C;QACpC,mCAA6B,GAAkC,EAAE,CAAC;QAC1E,mCAAmC;QAC3B,+BAAyB,GAAmB,EAAE,CAAC;QAMnD,KAAI,CAAC,aAAa,GAAG,YAAY,CAAC;QAClC,KAAI,CAAC,mBAAmB,GAAG,YAAY,CAAC,kBAAkB,CAAC;;IAC/D,CAAC;8BA1BiB,qBAAqB;IA4BhC,+CAAe,GAAtB;QAAA,iBAkCC;QAjCG,iBAAM,eAAe,WAAE,CAAC;QAExB,mEAAmE;QACnE,IAAI,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YACzB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,SAAS,CAAC;SAC7C;QAED,uDAAuD;QACvD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC3C,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YAClC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,GAAG,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC;SACxE;aAAM;YACH,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;YAC9C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC;SACrC;QAED,8CAA8C;QAC9C,IAAI,CAAC,aAAa,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC;QAEnD,kDAAkD;QAClD,IAAM,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC;QAC3C,CAAC,CAAC,MAAM,CAAC,aAAa,EAAE,UAAC,QAAQ;YAC7B,IAAI,QAAQ,CAAC,MAAM,EAAE;gBACjB,IAAM,eAAe,GAAG,KAAI,CAAC,QAAQ,CAAC,0BAA0B,EAAE,CAAC,CAAC;gBACpE,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC,EAAE;oBAC7B,IAAM,KAAK,GAAG,KAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC;oBACjE,KAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,KAAK,CAAC;iBACvC;gBAED,KAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;aACjD;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;;OAKG;IACO,iDAAiB,GAA3B,UAA4B,KAAa;QACrC,kFAAkF;QAClF,iCAAiC;QACjC,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC;IAC7C,CAAC;IAKD,sBAAW,+CAAY;QAHvB;;WAEG;aACH;YACI,OAAO,IAAI,CAAC,aAAa,CAAC;QAC9B,CAAC;;;OAAA;IAKD,sBAAc,qDAAkB;QAHhC;;WAEG;aACH;YACI,OAAO,IAAI,CAAC,mBAAmB,CAAC;QACpC,CAAC;;;OAAA;IAEM,oDAAoB,GAA3B;QACI,4EAA4E;QAC5E,yBAAyB;QACzB,IAAI,CAAC,aAAa,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC;QAEnD,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;SACvC;aAAM;YACH,IAAI,CAAC,aAAa,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC;SACpD;QAED,iBAAM,oBAAoB,WAAE,CAAC;IACjC,CAAC;IAED;;OAEG;IACI,yDAAyB,GAAhC;QACI,yBAAyB;IAC7B,CAAC;IAED;;OAEG;IACI,uDAAuB,GAA9B;QACI,yBAAyB;IAC7B,CAAC;IAED;;OAEG;IACK,oDAAoB,GAA5B;QACI,IAAI,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;QAChC,OAAO,KAAK,EAAE;YACV,IAAI,KAAK,CAAC,MAAM,CAAC,YAAY,uBAAqB,EAAE;gBAChD,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC;aACxB;YAED,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC;SACzB;QAED,OAAO,IAAI,CAAC;IAChB,CAAC;IAED;;;;OAIG;IACK,8CAAc,GAAtB,UAAuB,KAA4B;QAC/C,+CAA+C;QAC/C,IAAI,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,EAAE,UAAC,CAAC,IAAK,OAAA,CAAC,CAAC,OAAO,KAAK,KAAK,CAAC,OAAO,EAA3B,CAA2B,CAAC,EAAE;YAC3D,MAAM,IAAI,gBAAQ,CAAC,iDAAiD,GAAG,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,CAAC;SAChG;QAED,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED;;;;OAIG;IACK,gDAAgB,GAAxB,UAAyB,KAA4B;QACjD,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;IACtD,CAAC;IAED;;OAEG;IACI,+CAAe,GAAtB;QACI,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED;;OAEG;IACI,+CAAe,GAAtB;QACI,OAAO,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACnC,CAAC;IAED;;;;;OAKG;IACI,iDAAiB,GAAxB,UAA0D,OAAe;QACrE,OAAW,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,UAAC,KAAK,IAAK,OAAA,KAAK,CAAC,OAAO,KAAK,OAAO,EAAzB,CAAyB,CAAC,CAAC;IAC5E,CAAC;IAED;;;;;;;;;;;OAWG;IACI,oDAAoB,GAA3B,UAA4B,IAAY,EAAE,QAA8B;QAAxE,iBAgBC;QAfG,IAAM,aAAa,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QACnD,IAAI,CAAC,aAAa,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE;YACzC,MAAM,IAAI,gBAAQ,CAAC,gBAAgB,GAAG,IAAI,GAAG,cAAc,CAAC,CAAC;SAChE;QAED,IAAM,UAAU,GAAG;YACf,IAAM,KAAK,GAA0B,KAAI,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC;YACtE,IAAI,CAAC,KAAK,EAAE;aACX;YACD,IAAI,CAAC,KAAK;gBAAE,OAAO;YACnB,KAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,KAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,KAAK,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;QACtF,CAAC,CAAC;QAEF,IAAI,CAAC,6BAA6B,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACpD,UAAU,EAAE,CAAC;IACjB,CAAC;IAED;;;;;;OAMG;IACI,2DAA2B,GAAlC,UAAsC,IAAY,EAAE,QAA4B;QAC5E,IAAI,CAAC,oBAAoB,CAAC,IAAI,EAAE,UAAC,KAAK,IAAK,OAAA,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAA7B,CAA6B,CAAC,CAAC;IAC9E,CAAC;IAED;;;;;OAKG;IACK,iDAAiB,GAAzB,UAA0B,IAAY;QAClC,OAAO,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC;IAED;;OAEG;IACI,yCAAS,GAAhB,UAAiB,YAA4B;QAA7C,iBAwBC;QAxBgB,6BAAA,EAAA,mBAA4B;QACzC,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAE/B,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,IAAI,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,EAAE,CAAC;QAC5C,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,EAAE,UAAC,QAAQ,EAAE,GAAG;YACzC,IAAI,KAAK,GAAG,KAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;YAExC,IAAI,QAAQ,CAAC,MAAM,EAAE;gBACjB,oEAAoE;gBACpE,KAAK,GAA4B,KAAM,CAAC,OAAO,CAAC;aACnD;YAED,KAAK,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QACvB,CAAC,CAAC,CAAC;QAEH,oBAAoB;QACpB,IAAI,YAAY,EAAE;YACd,KAAoB,UAAc,EAAd,KAAA,IAAI,CAAC,SAAS,EAAd,cAAc,EAAd,IAAc,EAAE;gBAA/B,IAAM,KAAK,SAAA;gBACZ,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC;aACvC;SACJ;QAED,OAAO,MAAM,CAAC;IAClB,CAAC;IAED;;;;OAIG;IACI,yCAAS,GAAhB,UAAiB,WAAgB,EAAE,YAA4B;QAA/D,iBA2CC;QA3CkC,6BAAA,EAAA,mBAA4B;QAC3D,IAAM,KAAK,GAAG,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAC9C,IAAI,kBAAkB,GAAG,KAAK,CAAC;QAC/B,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,EAAE,UAAC,QAAQ,EAAE,GAAG;YACzC,IAAI,CAAC,KAAK;gBAAE,OAAO;YACnB,IAAI,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC;gBAAE,OAAO;YAE5B,IAAM,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC;YACzB,IAAI,QAAQ,CAAC,MAAM,EAAE;gBACjB,sDAAsD;gBACtD,IAAM,aAAa,GAA0B,KAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;gBACzE,IAAI,aAAa,CAAC,OAAO,KAAK,KAAK,EAAE;oBACjC,KAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,KAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAM,KAAK,CAAC,CAAC;oBAC5E,kBAAkB,GAAG,IAAI,CAAC;iBAC7B;aACJ;iBAAM;gBACH,KAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,KAAK,CAAC;aACvC;QACL,CAAC,CAAC,CAAC;QAEH,oBAAoB;QACpB,IAAI,YAAY,EAAE;YACd,KAAoB,UAAc,EAAd,KAAA,IAAI,CAAC,SAAS,EAAd,cAAc,EAAd,IAAc,EAAE;gBAA/B,IAAM,KAAK,SAAA;gBACZ,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;aAChC;SACJ;QAED,IAAI,kBAAkB,EAAE;YACpB,sDAAsD;YACtD,KAA2B,UAA8B,EAA9B,KAAA,IAAI,CAAC,yBAAyB,EAA9B,cAA8B,EAA9B,IAA8B,EAAE;gBAAtD,IAAM,YAAY,SAAA;gBACnB,YAAY,CAAC,WAAW,EAAE,CAAC;aAC9B;YAED,qCAAqC;YACrC,KAAsB,UAAkC,EAAlC,KAAA,IAAI,CAAC,6BAA6B,EAAlC,cAAkC,EAAlC,IAAkC,EAAE;gBAArD,IAAM,OAAO,SAAA;gBACd,OAAO,EAAE,CAAC;aACb;SACJ;QAED,IAAI,CAAC,yBAAyB,EAAE,CAAC;QAEjC,uCAAuC;QACvC,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;IAC9B,CAAC;IAED;;;OAGG;IACI,yEAAyC,GAAhD,UAAuE,QAAW;QAC9E,OAAO,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;IACzC,CAAC;IAEa,wCAAkB,GAAhC,UAAiC,MAA8B;QAC3D,IAAM,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC;QACrD,IAAI,CAAC,MAAM,CAAC,QAAQ;YAAE,MAAM,CAAC,QAAQ,GAAG,EAAE,CAAC;QAE3C,CAAC,CAAC,MAAM,CAAC,aAAa,EAAE,UAAC,QAAQ,EAAE,GAAG;YAClC,IAAI,QAAQ,CAAC,MAAM,EAAE;gBACjB,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,0BAA0B,EAAE,CAAC,GAAG,QAAQ,GAAG,CAAC,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;aACzF;QACL,CAAC,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAClB,CAAC;;IAzUiB,qBAAqB;QAN1C,gBAAS,CAAC;YACP,QAAQ,EAAE,IAAI;YACd,QAAQ,EAAE;gBACN,OAAO,EAAE,UAAU;aACtB;SACJ,CAAC;OACoB,qBAAqB,CA0U1C;IAAD,4BAAC;CA1UD,AA0UC,CA1UmD,oBAAa,GA0UhE;AA1UqB,sDAAqB;AA4U3C;;;;;GAKG;AACH,SAAgB,KAAK,CAAC,IAAa,EAAE,MAAuB;IAAvB,uBAAA,EAAA,cAAuB;IACxD,OAAO,UAAC,MAA6B,EAAE,WAAmB;QACtD,IAAI,CAAC,IAAI;YAAE,IAAI,GAAG,WAAW,CAAC;QAE9B,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE;YACjB,MAAM,IAAI,gBAAQ,CAAC,6DAA6D,CAAC,CAAC;SACrF;QAED,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE;YACzB,MAAM,CAAC,eAAe,GAAG,EAAE,CAAC;SAC/B;QAED,IAAI,MAAM,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE;YAC9B,MAAM,IAAI,gBAAQ,CAAC,8BAA8B,GAAG,IAAI,GAAG,2BAA2B,GAAG,MAAM,GAAG,IAAI,CAAC,CAAC;SAC3G;QACD,MAAM,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,IAAI,iBAAiB,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;IAC9E,CAAC,CAAC;AACN,CAAC;AAjBD,sBAiBC;AAED;;;;;GAKG;AACH,SAAgB,WAAW,CAAC,IAAa;IACrC,OAAO,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AAC7B,CAAC;AAFD,kCAEC","file":"core/components/stateful.js","sourcesContent":["import * as _ from 'lodash';\nimport * as angular from 'angular';\n\nimport {GenError} from '../errors/error';\nimport {SharedStore, SharedStoreManager} from '../shared_store/index';\n\nimport {ComponentBase, component, ComponentConfiguration, Subscription} from './base';\nimport {StateManager} from './manager';\n\nexport class StateItemMetadata {\n    constructor(public propertyName: string, public shared: boolean) {\n    }\n\n    public getSharedStoreNameProperty(): string {\n        return '_sharedStoreName_' + this.propertyName;\n    }\n}\n\nexport interface StateMetadata {\n    [index: string]: StateItemMetadata;\n}\n\ninterface SharedStoreSubscribeRequest {\n    (): void;\n}\n\n/**\n * A component which contains state that may be saved and reloaded later. Such\n * stateful components are automatically organized into a hierarchy, so that\n * parents also store state for all their children. Calling `saveState` on the\n * top-level component will therefore save the state of the complete application.\n *\n * Component state is defined by using property decorators as follows:\n * ```\n * export class ProcessGroups extends ViewComponent {\n *     @state() public selectedGroup: number;\n *\n *     // ...\n * }\n * ```\n *\n * It may be then referenced and watched from the controller or templates and\n * will automatically be saved when calling [[StatefulComponentBase.saveState]]\n * and reloaded when calling [[StatefulComponentBase.loadState]].\n *\n * A related decorator may be used to declare state, which is shared between\n * multiple components:\n * ```\n * export class WidgetRose2 extends WidgetBase {\n *     @sharedState() public selectedValue: SharedStore<types.Data>;\n *\n *     // ...\n * }\n * ```\n *\n * See [[SharedStoreManager]] and [[SharedStore]] for more documentation on\n * defining shared state using shared stores.\n *\n * For example, if a stateful component defines a shared state property called\n * `selectedValue` (as shown above) and you want to link it with the shared store\n * named `rose2-selected-data-item`, you can do the following in your template:\n * ```html\n * <gen-widget-rose2 store-selected-value=\"rose2-selected-data-item\"></gen-widget-rose2>\n * ```\n *\n * Note that the template attribute name is prefixed with `store` even when the\n * property is called just `selectedValue`. This is done because what you pass\n * in the template is just a name of the store, which must be resolved using the\n * shared store manager.\n *\n * Inside the components you can then dispatch and subscribe to the underlying\n * store:\n * ```\n * // Publish something by dispatching an action to the shared store.\n * this.selectedValue.dispatch({type: Actions.SET, value: 42});\n *\n * // Subscribe to updates of the shared store.\n * this.subscribeSharedState('selectedValue', (data) => {\n *     console.log(\"Shared state 'selectedValue' is now\", data);\n * });\n * ```\n */\n@component({\n    abstract: true,\n    bindings: {\n        stateId: '@stateId',\n    },\n})\nexport abstract class StatefulComponentBase extends ComponentBase {\n    /// Metadata about the state defined on the component.\n    public __stateMetadata: StateMetadata;\n    /// This component's local state identifier.\n    public stateId: string;\n    /// This component's global state identifier.\n    public globalStateId: string;\n    /// Parent stateful component.\n    private _parent: StatefulComponentBase = null;\n    /// A list of child stateful components.\n    private _children: StatefulComponentBase[] = [];\n    /// State manager.\n    private _stateManager: StateManager;\n    /// Shared store manager.\n    private _sharedStoreManager: SharedStoreManager;\n    /// Subscription requests for shared stores.\n    private _sharedStoreSubscribeRequests: SharedStoreSubscribeRequest[] = [];\n    /// Subscriptions to shared stores.\n    private _sharedStoreSubscriptions: Subscription[] = [];\n\n    // @ngInject\n    constructor($scope: angular.IScope, stateManager: StateManager) {\n        super($scope);\n\n        this._stateManager = stateManager;\n        this._sharedStoreManager = stateManager.sharedStoreManager;\n    }\n\n    public onComponentInit() {\n        super.onComponentInit();\n\n        // When state identifier is not defined, default to directive name.\n        if (_.isEmpty(this.stateId)) {\n            this.stateId = this.getConfig().directive;\n        }\n\n        // Determine our parent and register ourselves with it.\n        this._parent = this._findParentComponent();\n        if (this._parent) {\n            this._parent._registerChild(this);\n            this.globalStateId = this._parent.globalStateId + '-' + this.stateId;\n        } else {\n            this._stateManager.addTopLevelComponent(this);\n            this.globalStateId = this.stateId;\n        }\n\n        // Check if there is any pending state for us.\n        this._stateManager.loadPendingComponentState(this);\n\n        // Automatically load any configured shared state.\n        const stateMetadata = this.__stateMetadata;\n        _.forOwn(stateMetadata, (metadata) => {\n            if (metadata.shared) {\n                const sharedStoreName = this[metadata.getSharedStoreNameProperty()];\n                if (!_.isEmpty(sharedStoreName)) {\n                    const store = this._sharedStoreManager.getStore(sharedStoreName);\n                    this[metadata.propertyName] = store;\n                }\n\n                this._setupSharedStore(metadata.propertyName);\n            }\n        });\n    }\n\n    /**\n     * Sets up the shared store. This method may be overriden by subclasses when something\n     * different should be done here.\n     *\n     * @param {store} Shared state\n     */\n    protected _setupSharedStore(store: string): void {\n        // Subscribe to shared store, so that this component's scope gets updated when the\n        // value in the store is updated.\n        this.subscribeSharedState(store, _.noop);\n    }\n\n    /**\n     * Returns the state manager.\n     */\n    public get stateManager(): StateManager {\n        return this._stateManager;\n    }\n\n    /**\n     * Returns the shared store manager.\n     */\n    protected get sharedStoreManager(): SharedStoreManager {\n        return this._sharedStoreManager;\n    }\n\n    public onComponentDestroyed(): void {\n        // Save current component state, so it will be available when this component\n        // is instantiated again.\n        this._stateManager.savePendingComponentState(this);\n\n        if (this._parent) {\n            this._parent._unregisterChild(this);\n        } else {\n            this._stateManager.removeTopLevelComponent(this);\n        }\n\n        super.onComponentDestroyed();\n    }\n\n    /**\n     * This method will be called after the component's state has been loaded.\n     */\n    public onComponentStateAfterLoad(): void {\n        // Do nothing by default.\n    }\n\n    /**\n     * This method will be called before the component's state has been saved.\n     */\n    public onComponentStatePreSave(): void {\n        // Do nothing by default.\n    }\n\n    /**\n     * Discovers the parent stateful component.\n     */\n    private _findParentComponent(): StatefulComponentBase {\n        let scope = this.$scope.$parent;\n        while (scope) {\n            if (scope['ctrl'] instanceof StatefulComponentBase) {\n                return scope['ctrl'];\n            }\n\n            scope = scope.$parent;\n        }\n\n        return null;\n    }\n\n    /**\n     * Registers a new child of this stateful component.\n     *\n     * @param {StatefulComponentBase} child Child component instance\n     */\n    private _registerChild(child: StatefulComponentBase) {\n        // Ensure the child's local state id is unique.\n        if (_.any(this._children, (c) => c.stateId === child.stateId)) {\n            throw new GenError(\"Duplicate stateful component state identifier '\" + child.stateId + \"'.\");\n        }\n\n        this._children.push(child);\n    }\n\n    /**\n     * Unregisters an existing child of this stateful component.\n     *\n     * @param {StatefulComponentBase} child Child component instance\n     */\n    private _unregisterChild(child: StatefulComponentBase) {\n        this._children = _.without(this._children, child);\n    }\n\n    /**\n     * Returns the parent stateful component.\n     */\n    public parentComponent(): StatefulComponentBase {\n        return this._parent;\n    }\n\n    /**\n     * Returns a list of child stateful components.\n     */\n    public childComponents(): StatefulComponentBase[] {\n        return _.clone(this._children);\n    }\n\n    /**\n     * Finds a child component by its state identifier.\n     *\n     * @param {string} stateId Child's state identifier\n     * @return {StatefulComponentBase} Child component instance\n     */\n    public getChildComponent<T extends StatefulComponentBase>(stateId: string): T {\n        return <T> _.find(this._children, (child) => child.stateId === stateId);\n    }\n\n    /**\n     * Subscribes to shared state. This is the same as a normal subscribe, but in\n     * addition it also properly handles underlying data store changes when\n     * component state is reloaded.\n     *\n     * The value observed from the shared store MUST NOT be mutated in any way as\n     * doing so may cause undefined behavior. If you need to mutate the observed\n     * value, use [[subscribeSharedStateMutable]] instead.\n     *\n     * @param {string} name Name of shared state\n     * @param callback Callback to be invoked on subscription\n     */\n    public subscribeSharedState(name: string, callback: (value: any) => void): void {\n        const storeMetadata = this._getStateMetadata(name);\n        if (!storeMetadata || !storeMetadata.shared) {\n            throw new GenError(\"Shared state '\" + name + \"' not found.\");\n        }\n\n        const subscriber = () => {\n            const store: SharedStore<any, any> = this[storeMetadata.propertyName];\n            if (!store) {\n                // @ifndef GENJS_PRODUCTION\n                    throw new GenError(`Ignored missing store: ${storeMetadata.propertyName} ${this.globalStateId}`);\n                // @endif\n            }\n            if (!store) return;\n            this._sharedStoreSubscriptions.push(this.subscribe(callback, store.observable()));\n        };\n\n        this._sharedStoreSubscribeRequests.push(subscriber);\n        subscriber();\n    }\n\n    /**\n     * A version of [[subscribeSharedState]], which ensures that the observed shared\n     * store value is copied and can thus be safely mutated afterwards.\n     *\n     * @param {string} name Name of shared state\n     * @param callback Callback to be invoked on subscription\n     */\n    public subscribeSharedStateMutable<T>(name: string, callback: (value: T) => void): void {\n        this.subscribeSharedState(name, (value) => callback(angular.copy(value)));\n    }\n\n    /**\n     * Returns metadata for specific component state.\n     *\n     * @param {string} name Name of shared state (not property name)\n     * @return {StateItemMetadata} State metadata\n     */\n    private _getStateMetadata(name: string): StateItemMetadata {\n        return this.__stateMetadata[name];\n    }\n\n    /**\n     * Saves this component's current state and returns it.\n     */\n    public saveState(saveChildren: boolean = true): any {\n        this.onComponentStatePreSave();\n\n        let result = {};\n        let state = result[this.globalStateId] = {};\n        _.forOwn(this.__stateMetadata, (metadata, key) => {\n            let value = this[metadata.propertyName];\n\n            if (metadata.shared) {\n                // In case of shared state, save the identifier of the shared store.\n                value = (<SharedStore<any, any>> value).storeId;\n            }\n\n            state[key] = value;\n        });\n\n        // Save child state.\n        if (saveChildren) {\n            for (const child of this._children) {\n                _.extend(result, child.saveState());\n            }\n        }\n\n        return result;\n    }\n\n    /**\n     * Loads this component's current state.\n     *\n     * @param {any} globalState Global state\n     */\n    public loadState(globalState: any, loadChildren: boolean = true): void {\n        const state = globalState[this.globalStateId];\n        let sharedStateChanged = false;\n        _.forOwn(this.__stateMetadata, (metadata, key) => {\n            if (!state) return;\n            if (!(key in state)) return;\n\n            const value = state[key];\n            if (metadata.shared) {\n                // Get the shared store from the shared store manager.\n                const existingValue: SharedStore<any, any> = this[metadata.propertyName];\n                if (existingValue.storeId !== value) {\n                    this[metadata.propertyName] = this._sharedStoreManager.getStore<any>(value);\n                    sharedStateChanged = true;\n                }\n            } else {\n                this[metadata.propertyName] = value;\n            }\n        });\n\n        // Load child state.\n        if (loadChildren) {\n            for (const child of this._children) {\n                child.loadState(globalState);\n            }\n        }\n\n        if (sharedStateChanged) {\n            // Cancel any previous subscriptions to shared stores.\n            for (const subscription of this._sharedStoreSubscriptions) {\n                subscription.unsubscribe();\n            }\n\n            // Resubscribe, using the new stores.\n            for (const request of this._sharedStoreSubscribeRequests) {\n                request();\n            }\n        }\n\n        this.onComponentStateAfterLoad();\n\n        // Propagate state updates to the view.\n        this.$scope.$applyAsync();\n    }\n\n    /**\n     * Check if property has not been loaded from state, or isn't defined. Usually used\n     * before setting a deferred default value.\n     */\n    public isPropertyNotLoadedFromStateOrIsUndefined<P extends keyof this>(property: P) {\n        return _.isUndefined(this[property]);\n    }\n\n    public static configureComponent(config: ComponentConfiguration): ComponentConfiguration {\n        const stateMetadata = this.prototype.__stateMetadata;\n        if (!config.bindings) config.bindings = {};\n\n        _.forOwn(stateMetadata, (metadata, key) => {\n            if (metadata.shared) {\n                config.bindings[metadata.getSharedStoreNameProperty()] = '@store' + _.capitalize(key);\n            }\n        });\n        return config;\n    }\n}\n\n/**\n * Marks a property as being part of the component's state.\n *\n * @param {string} name Optional state name\n * @param {boolean} shared Does this state reference a shared store\n */\nexport function state(name?: string, shared: boolean = false) {\n    return (target: StatefulComponentBase, propertyKey: string) => {\n        if (!name) name = propertyKey;\n\n        if (name[0] === '_') {\n            throw new GenError(\"State identifiers starting with an underscore are reserved.\");\n        }\n\n        if (!target.__stateMetadata) {\n            target.__stateMetadata = {};\n        }\n\n        if (target.__stateMetadata[name]) {\n            throw new GenError(\"Duplicate state identifier '\" + name + \"' on stateful component '\" + target + \"'.\");\n        }\n        target.__stateMetadata[name] = new StateItemMetadata(propertyKey, shared);\n    };\n}\n\n/**\n * Marks a property as being part of the component's state, which references\n * a shared store.\n *\n * @param {string} name Optional state name\n */\nexport function sharedState(name?: string) {\n    return state(name, true);\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/core/components/stateful.ts"],"names":[],"mappings":"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","file":"core/components/stateful.js","sourcesContent":["import * as _ from 'lodash';\nimport * as angular from 'angular';\n\nimport {GenError} from '../errors/error';\nimport {SharedStore, SharedStoreManager} from '../shared_store/index';\n\nimport {ComponentBase, component, ComponentConfiguration, Subscription} from './base';\nimport {StateManager} from './manager';\n\nexport class StateItemMetadata {\n    constructor(public propertyName: string, public shared: boolean) {\n    }\n\n    public getSharedStoreNameProperty(): string {\n        return '_sharedStoreName_' + this.propertyName;\n    }\n}\n\nexport interface StateMetadata {\n    [index: string]: StateItemMetadata;\n}\n\ninterface SharedStoreSubscribeRequest {\n    (): void;\n}\n\n/**\n * A component which contains state that may be saved and reloaded later. Such\n * stateful components are automatically organized into a hierarchy, so that\n * parents also store state for all their children. Calling `saveState` on the\n * top-level component will therefore save the state of the complete application.\n *\n * Component state is defined by using property decorators as follows:\n * ```\n * export class ProcessGroups extends ViewComponent {\n *     @state() public selectedGroup: number;\n *\n *     // ...\n * }\n * ```\n *\n * It may be then referenced and watched from the controller or templates and\n * will automatically be saved when calling [[StatefulComponentBase.saveState]]\n * and reloaded when calling [[StatefulComponentBase.loadState]].\n *\n * A related decorator may be used to declare state, which is shared between\n * multiple components:\n * ```\n * export class WidgetRose2 extends WidgetBase {\n *     @sharedState() public selectedValue: SharedStore<types.Data>;\n *\n *     // ...\n * }\n * ```\n *\n * See [[SharedStoreManager]] and [[SharedStore]] for more documentation on\n * defining shared state using shared stores.\n *\n * For example, if a stateful component defines a shared state property called\n * `selectedValue` (as shown above) and you want to link it with the shared store\n * named `rose2-selected-data-item`, you can do the following in your template:\n * ```html\n * <gen-widget-rose2 store-selected-value=\"rose2-selected-data-item\"></gen-widget-rose2>\n * ```\n *\n * Note that the template attribute name is prefixed with `store` even when the\n * property is called just `selectedValue`. This is done because what you pass\n * in the template is just a name of the store, which must be resolved using the\n * shared store manager.\n *\n * Inside the components you can then dispatch and subscribe to the underlying\n * store:\n * ```\n * // Publish something by dispatching an action to the shared store.\n * this.selectedValue.dispatch({type: Actions.SET, value: 42});\n *\n * // Subscribe to updates of the shared store.\n * this.subscribeSharedState('selectedValue', (data) => {\n *     console.log(\"Shared state 'selectedValue' is now\", data);\n * });\n * ```\n */\n@component({\n    abstract: true,\n    bindings: {\n        stateId: '@stateId',\n    },\n})\nexport abstract class StatefulComponentBase extends ComponentBase {\n    /// Metadata about the state defined on the component.\n    public __stateMetadata: StateMetadata;\n    /// This component's local state identifier.\n    public stateId: string;\n    /// This component's global state identifier.\n    public globalStateId: string;\n    /// Parent stateful component.\n    private _parent: StatefulComponentBase = null;\n    /// A list of child stateful components.\n    private _children: StatefulComponentBase[] = [];\n    /// State manager.\n    private _stateManager: StateManager;\n    /// Shared store manager.\n    private _sharedStoreManager: SharedStoreManager;\n    /// Subscription requests for shared stores.\n    private _sharedStoreSubscribeRequests: SharedStoreSubscribeRequest[] = [];\n    /// Subscriptions to shared stores.\n    private _sharedStoreSubscriptions: Subscription[] = [];\n\n    // @ngInject\n    constructor($scope: angular.IScope, stateManager: StateManager) {\n        super($scope);\n\n        this._stateManager = stateManager;\n        this._sharedStoreManager = stateManager.sharedStoreManager;\n    }\n\n    public onComponentInit() {\n        super.onComponentInit();\n\n        // When state identifier is not defined, default to directive name.\n        if (_.isEmpty(this.stateId)) {\n            this.stateId = this.getConfig().directive;\n        }\n\n        // Determine our parent and register ourselves with it.\n        this._parent = this._findParentComponent();\n        if (this._parent) {\n            this._parent._registerChild(this);\n            this.globalStateId = this._parent.globalStateId + '-' + this.stateId;\n        } else {\n            this._stateManager.addTopLevelComponent(this);\n            this.globalStateId = this.stateId;\n        }\n\n        // Check if there is any pending state for us.\n        this._stateManager.loadPendingComponentState(this);\n\n        // Automatically load any configured shared state.\n        const stateMetadata = this.__stateMetadata;\n        _.forOwn(stateMetadata, (metadata) => {\n            if (metadata.shared) {\n                const sharedStoreName = this[metadata.getSharedStoreNameProperty()];\n                if (!_.isEmpty(sharedStoreName)) {\n                    const store = this._sharedStoreManager.getStore(sharedStoreName);\n                    this[metadata.propertyName] = store;\n                }\n\n                this._setupSharedStore(metadata.propertyName);\n            }\n        });\n    }\n\n    /**\n     * Sets up the shared store. This method may be overriden by subclasses when something\n     * different should be done here.\n     *\n     * @param {store} Shared state\n     */\n    protected _setupSharedStore(store: string): void {\n        // Subscribe to shared store, so that this component's scope gets updated when the\n        // value in the store is updated.\n        this.subscribeSharedState(store, _.noop);\n    }\n\n    /**\n     * Returns the state manager.\n     */\n    public get stateManager(): StateManager {\n        return this._stateManager;\n    }\n\n    /**\n     * Returns the shared store manager.\n     */\n    protected get sharedStoreManager(): SharedStoreManager {\n        return this._sharedStoreManager;\n    }\n\n    public onComponentDestroyed(): void {\n        // Save current component state, so it will be available when this component\n        // is instantiated again.\n        this._stateManager.savePendingComponentState(this);\n\n        if (this._parent) {\n            this._parent._unregisterChild(this);\n        } else {\n            this._stateManager.removeTopLevelComponent(this);\n        }\n\n        super.onComponentDestroyed();\n    }\n\n    /**\n     * This method will be called after the component's state has been loaded.\n     */\n    public onComponentStateAfterLoad(): void {\n        // Do nothing by default.\n    }\n\n    /**\n     * This method will be called before the component's state has been saved.\n     */\n    public onComponentStatePreSave(): void {\n        // Do nothing by default.\n    }\n\n    /**\n     * Discovers the parent stateful component.\n     */\n    private _findParentComponent(): StatefulComponentBase {\n        let scope = this.$scope.$parent;\n        while (scope) {\n            if (scope['ctrl'] instanceof StatefulComponentBase) {\n                return scope['ctrl'];\n            }\n\n            scope = scope.$parent;\n        }\n\n        return null;\n    }\n\n    /**\n     * Registers a new child of this stateful component.\n     *\n     * @param {StatefulComponentBase} child Child component instance\n     */\n    private _registerChild(child: StatefulComponentBase) {\n        // Ensure the child's local state id is unique.\n        if (_.any(this._children, (c) => c.stateId === child.stateId)) {\n            throw new GenError(\"Duplicate stateful component state identifier '\" + child.stateId + \"'.\");\n        }\n\n        this._children.push(child);\n    }\n\n    /**\n     * Unregisters an existing child of this stateful component.\n     *\n     * @param {StatefulComponentBase} child Child component instance\n     */\n    private _unregisterChild(child: StatefulComponentBase) {\n        this._children = _.without(this._children, child);\n    }\n\n    /**\n     * Returns the parent stateful component.\n     */\n    public parentComponent(): StatefulComponentBase {\n        return this._parent;\n    }\n\n    /**\n     * Returns a list of child stateful components.\n     */\n    public childComponents(): StatefulComponentBase[] {\n        return _.clone(this._children);\n    }\n\n    /**\n     * Finds a child component by its state identifier.\n     *\n     * @param {string} stateId Child's state identifier\n     * @return {StatefulComponentBase} Child component instance\n     */\n    public getChildComponent<T extends StatefulComponentBase>(stateId: string): T {\n        return <T> _.find(this._children, (child) => child.stateId === stateId);\n    }\n\n    /**\n     * Subscribes to shared state. This is the same as a normal subscribe, but in\n     * addition it also properly handles underlying data store changes when\n     * component state is reloaded.\n     *\n     * The value observed from the shared store MUST NOT be mutated in any way as\n     * doing so may cause undefined behavior. If you need to mutate the observed\n     * value, use [[subscribeSharedStateMutable]] instead.\n     *\n     * @param {string} name Name of shared state\n     * @param callback Callback to be invoked on subscription\n     */\n    public subscribeSharedState(name: string, callback: (value: any) => void): void {\n        const storeMetadata = this._getStateMetadata(name);\n        if (!storeMetadata || !storeMetadata.shared) {\n            throw new GenError(\"Shared state '\" + name + \"' not found.\");\n        }\n\n        const subscriber = () => {\n            const store: SharedStore<any, any> = this[storeMetadata.propertyName];\n            if (!store) {\n                // @ifndef GENJS_PRODUCTION\n                    throw new GenError(`Ignored missing store: ${storeMetadata.propertyName} ${this.globalStateId}`);\n                // @endif\n            }\n            if (!store) return;\n            this._sharedStoreSubscriptions.push(this.subscribe(callback, store.observable()));\n        };\n\n        this._sharedStoreSubscribeRequests.push(subscriber);\n        subscriber();\n    }\n\n    /**\n     * A version of [[subscribeSharedState]], which ensures that the observed shared\n     * store value is copied and can thus be safely mutated afterwards.\n     *\n     * @param {string} name Name of shared state\n     * @param callback Callback to be invoked on subscription\n     */\n    public subscribeSharedStateMutable<T>(name: string, callback: (value: T) => void): void {\n        this.subscribeSharedState(name, (value) => callback(angular.copy(value)));\n    }\n\n    /**\n     * Returns metadata for specific component state.\n     *\n     * @param {string} name Name of shared state (not property name)\n     * @return {StateItemMetadata} State metadata\n     */\n    private _getStateMetadata(name: string): StateItemMetadata {\n        return this.__stateMetadata[name];\n    }\n\n    /**\n     * Saves this component's current state and returns it.\n     */\n    public saveState(saveChildren: boolean = true): any {\n        this.onComponentStatePreSave();\n\n        let result = {};\n        let state = result[this.globalStateId] = {}; // tslint:disable-line:no-shadowed-variable\n        _.forOwn(this.__stateMetadata, (metadata, key) => {\n            let value = this[metadata.propertyName];\n\n            if (metadata.shared) {\n                // In case of shared state, save the identifier of the shared store.\n                value = (<SharedStore<any, any>> value).storeId;\n            }\n\n            state[key] = value;\n        });\n\n        // Save child state.\n        if (saveChildren) {\n            for (const child of this._children) {\n                _.extend(result, child.saveState());\n            }\n        }\n\n        return result;\n    }\n\n    /**\n     * Loads this component's current state.\n     *\n     * @param {any} globalState Global state\n     */\n    public loadState(globalState: any, loadChildren: boolean = true): void {\n        // tslint:disable-next-line:no-shadowed-variable\n        const state = globalState[this.globalStateId];\n        let sharedStateChanged = false;\n        _.forOwn(this.__stateMetadata, (metadata, key) => {\n            if (!state) return;\n            if (!(key in state)) return;\n\n            const value = state[key];\n            if (metadata.shared) {\n                // Get the shared store from the shared store manager.\n                const existingValue: SharedStore<any, any> = this[metadata.propertyName];\n                if (existingValue.storeId !== value) {\n                    this[metadata.propertyName] = this._sharedStoreManager.getStore<any>(value);\n                    sharedStateChanged = true;\n                }\n            } else {\n                this[metadata.propertyName] = value;\n            }\n        });\n\n        // Load child state.\n        if (loadChildren) {\n            for (const child of this._children) {\n                child.loadState(globalState);\n            }\n        }\n\n        if (sharedStateChanged) {\n            // Cancel any previous subscriptions to shared stores.\n            for (const subscription of this._sharedStoreSubscriptions) {\n                subscription.unsubscribe();\n            }\n\n            // Resubscribe, using the new stores.\n            for (const request of this._sharedStoreSubscribeRequests) {\n                request();\n            }\n        }\n\n        this.onComponentStateAfterLoad();\n\n        // Propagate state updates to the view.\n        this.$scope.$applyAsync();\n    }\n\n    /**\n     * Check if property has not been loaded from state, or isn't defined. Usually used\n     * before setting a deferred default value.\n     */\n    public isPropertyNotLoadedFromStateOrIsUndefined<P extends keyof this>(property: P) {\n        return _.isUndefined(this[property]);\n    }\n\n    public static configureComponent(config: ComponentConfiguration): ComponentConfiguration {\n        const stateMetadata = this.prototype.__stateMetadata;\n        if (!config.bindings) config.bindings = {};\n\n        _.forOwn(stateMetadata, (metadata, key) => {\n            if (metadata.shared) {\n                config.bindings[metadata.getSharedStoreNameProperty()] = '@store' + _.capitalize(key);\n            }\n        });\n        return config;\n    }\n}\n\n/**\n * Marks a property as being part of the component's state.\n *\n * @param {string} name Optional state name\n * @param {boolean} shared Does this state reference a shared store\n */\nexport function state(name?: string, shared: boolean = false) {\n    return (target: StatefulComponentBase, propertyKey: string) => {\n        if (!name) name = propertyKey;\n\n        if (name[0] === '_') {\n            throw new GenError(\"State identifiers starting with an underscore are reserved.\");\n        }\n\n        if (!target.__stateMetadata) {\n            target.__stateMetadata = {};\n        }\n\n        if (target.__stateMetadata[name]) {\n            throw new GenError(\"Duplicate state identifier '\" + name + \"' on stateful component '\" + target + \"'.\");\n        }\n        target.__stateMetadata[name] = new StateItemMetadata(propertyKey, shared);\n    };\n}\n\n/**\n * Marks a property as being part of the component's state, which references\n * a shared store.\n *\n * @param {string} name Optional state name\n */\nexport function sharedState(name?: string) {\n    return state(name, true);\n}\n"]} |
import 'angular-mocks'; | ||
//# sourceMappingURL=stateful.spec.d.ts.map |
@@ -25,2 +25,1 @@ import * as angular from 'angular'; | ||
} | ||
//# sourceMappingURL=view.d.ts.map |
@@ -9,2 +9,1 @@ /** | ||
} | ||
//# sourceMappingURL=error.d.ts.map |
@@ -101,2 +101,1 @@ import * as Rx from 'rx'; | ||
} | ||
//# sourceMappingURL=api.d.ts.map |
@@ -5,2 +5,1 @@ import { APIServiceBase } from './api'; | ||
} | ||
//# sourceMappingURL=api.spec.d.ts.map |
@@ -338,2 +338,1 @@ import * as Rx from 'rx'; | ||
export {}; | ||
//# sourceMappingURL=index.d.ts.map |
@@ -495,2 +495,2 @@ "use strict"; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/core/shared_store/index.ts"],"names":[],"mappings":"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","file":"core/shared_store/index.js","sourcesContent":["import * as _ from 'lodash';\nimport * as Rx from 'rx';\nimport * as angular from 'angular';\n\nimport {isJsonable} from '../utils/lang';\nimport * as immutable from '../utils/immutable';\n\n/**\n * A shared store action contains a `type` property and any number of other\n * custom properties. Action types starting with `@@internal/` are reserved\n * for internal use.\n */\nexport interface Action {\n    type: string;\n    [propertyName: string]: any;\n}\n\ntype MethodReturns<Actions> = Actions extends { [key in keyof Actions]: (() => infer Return) | infer Else } ? Return : never;\ntype FilterActions<Return> = Return extends { type: infer R } ? Return : never;\nexport type GetActions<Actions> = FilterActions<MethodReturns<Actions>> | { type: '...' };\n\n/**\n * A thunk is a function, which mediates the dispatch of an action. It may\n * be dispatched in the same way as an action.\n */\nexport interface Thunk {\n    (dispatcher: Dispatcher, getState: () => any): any;\n}\n\nexport interface SharedStoreQuery<T, U> {\n    (state: Rx.Observable<T>): Rx.Observable<U>;\n}\n\nexport class Actions {\n    /// Internal action for setting this store to a specific value.\n    public static SET = <'@@internal/SET'> '@@internal/SET';\n    public set(value: any) {\n        return { type: Actions.SET, value };\n    }\n}\n\n/**\n * A shared store represents state that is shared between multiple components in\n * a predictable way. Components update the store by dispatching actions to\n * it using the `dispatch` method.\n *\n * Each shared store also provides a way for the components to subscribe to any\n * changes in the store's state.\n *\n * Consider defining actions for use in a shared store separately from the store,\n * in the `actions` subdirectory. See [[SharedStoreManager]] for details.\n *\n * Don't forget to call constructor with actions as an argument when extending\n * this class.\n */\nexport abstract class SharedStore<T, U> {\n    private _subject: Rx.BehaviorSubject<T>;\n    private _dispatcher: Dispatcher;\n    private _queries: {[name: string]: Rx.Observable<any>} = {};\n    private _actions: U;\n    private _storeId: string;\n\n    constructor(actions?: U) {\n        this._subject = new Rx.BehaviorSubject(this.initialState());\n        this._actions = actions;\n\n        // Create a local dispatcher.\n        this._dispatcher = new Dispatcher();\n        this._dispatcher.setDispatcher(this._dispatch.bind(this), this.value.bind(this));\n    }\n\n    /**\n     * Returns a unique identifier for this shared store.\n     */\n    public get storeId(): string {\n        return this._storeId;\n    }\n\n    /**\n     * Returns store actions.\n     */\n    public get actions(): U {\n        return this._actions;\n    }\n\n    /**\n     * Internal dispatcher implementation.\n     *\n     * NOTE: This method is public because there is no way to define private\n     * but accessible to other classes within this module in TypeScript.\n     */\n    public _dispatch(action: Action): void {\n        const existingValue = this.value();\n        let reducer: (value: T, action: Action) => T;\n        if (_.startsWith(action.type, '@@internal/')) {\n            reducer = this._reduceInternal.bind(this);\n        } else {\n            reducer = this.reduce.bind(this);\n        }\n\n        let newValue = reducer(existingValue, action);\n        if (_.isUndefined(newValue)) return;\n\n        if (angular.equals(existingValue, newValue)) return;\n        this._subject.onNext(immutable.makeImmutable(newValue));\n    }\n\n    /**\n     * Dispatches an action to this shared store.\n     *\n     * @param action Action to dispatch\n     */\n    public dispatch(action: GetActions<U> | GetActions<Actions> | Thunk): any {\n        return this._dispatcher.dispatch(<Action | Thunk> action);\n    }\n\n    /**\n     * Performs internal reduce actions implemented for each shared store.\n     *\n     * @param state Existing shared store state\n     * @param action Action to perform\n     * @return New shared store state\n     */\n    private _reduceInternal(state: T, action: Action): T {\n        switch (action.type) {\n            case Actions.SET: {\n                const nextState = action['value'];\n                return this.onStateLoad(state, nextState);\n            }\n            default: {\n                // Do nothing.\n            }\n        }\n    }\n\n    /**\n     * Performs the given action on the underlying state.\n     *\n     * Subclasses may override this method to implement arbitrary complex\n     * actions on the data store. This method MUST NOT mutate the existing\n     * state. Instead, it MUST return an immutable copy.\n     *\n     * @param value Existing shared store state\n     * @param action Operation to perform\n     * @return New shared store state\n     */\n    protected abstract reduce(state: T, action: GetActions<U>): T;\n\n    /**\n     * Provides the initial state for this shared store. This state is\n     * used when the store is initialized.\n     */\n    protected abstract initialState(): T;\n\n    /**\n     * This method gets called when the data store's state is loaded from\n     * an external source (when the SET action is dispatched to the store).\n     *\n     * It is called before the new state has been set. The default implementation\n     * does nothing.\n     *\n     * @param state Old state\n     * @param nextState New state\n     * @return Possibly modified state that should be used instead\n     */\n    protected onStateLoad(state: T, nextState: T): T {\n        return nextState;\n    }\n\n    /**\n     * A helper method for defining shared store queries. If the query is already\n     * defined, the existing observable is returned.\n     *\n     * @param name Query name\n     * @param query Query function\n     * @return Resulting query observable\n     */\n    protected defineQuery<V>(name: string, query: SharedStoreQuery<T, V>): Rx.Observable<V> {\n        let observable: Rx.Observable<V> = this._queries[name];\n        if (observable) return observable;\n\n        observable = this._queries[name] = this.observable().let(query).distinctUntilChanged();\n        return observable;\n    }\n\n    /**\n     * Returns the current value stored in the store.\n     *\n     * You MUST ensure that the resulting object is NOT mutated in any way. Any\n     * mutation may cause undefined behavior.\n     */\n    public value(): T {\n        return this._subject.getValue();\n    }\n\n    /**\n     * Returns an observable of the store's value.\n     *\n     * You MUST ensure that the observed value is NOT mutated in any way. Any\n     * mutation may cause undefined behavior.\n     */\n    public observable(): Rx.Observable<T> {\n        return this._subject;\n    }\n\n    /**\n     * Returns a value that should be used when saving store state.\n     *\n     * By default, this will return the same as [[value]].\n     */\n    public saveValue(): T {\n        return this.value();\n    }\n}\n\n/**\n * [[SimpleSharedStore]] is a helper class intended to be used as a type in conjunction with\n * [[SharedStoreProvider]]'s `create` method where only SET action is used.\n *\n * In this case no subclassing of store and actions is needed because only SET action is used.\n * This is convenient for use cases where you only need to set a value that you can subscribe\n * to from other components.\n */\nexport abstract class SimpleSharedStore<T> extends SharedStore<T, typeof undefined> { }\n\n/**\n * Used to dispatch actions to shared stores.\n */\nexport class Dispatcher extends Rx.Subject<Action> {\n    private _getState: () => any = () => undefined;\n\n    /**\n     * Configures a dispatcher function for this dispatcher.\n     *\n     * @param dispatcher The dispatcher function\n     */\n    public setDispatcher(dispatcher: (action: Action) => void, getState?: () => any): void {\n        // The dispatcher is used to dispatch all actions using a queue, so actions\n        // may invoke the dispatch method without causing recursion. The currentThread\n        // scheduler puts all pending items inside a queue, which is dispatched after\n        // returning from active dispatch.\n        this.observeOn(Rx.Scheduler.currentThread).subscribe(dispatcher);\n        if (getState) this._getState = getState;\n    }\n\n    /**\n     * Dispatches an action via this dispatcher.\n     */\n    public dispatch(action: Action | Thunk): any {\n        if (_.isFunction(action)) {\n            // A thunk has been passed. Execute it with the dispatcher argument and\n            // return the result.\n            return action(this, this._getState);\n        } else {\n            this.onNext(action);\n        }\n    }\n}\n\ninterface SharedStoreMap {\n    [index: string]: SharedStore<any, any>;\n}\n\nexport interface SharedStoreFactory<T, U> {\n    new (...args): SharedStore<T, U>;\n}\n\nexport interface ActionFactory {\n    new (...args): any;\n}\n\n/**\n * Shared store provider, enabling registration of shared stores. All stores\n * must be registered in the application configuration phase.\n */\nexport class SharedStoreProvider {\n    /// A list of registered stores.\n    private _stores: string[] = [];\n    /// Provide service.\n    private _provide: angular.auto.IProvideService;\n\n    // @ngInject\n    constructor($provide: angular.auto.IProvideService) {\n        this._provide = $provide;\n    }\n\n    /**\n     * A list of registered stores.\n     */\n    public get stores(): string[] {\n        return this._stores;\n    }\n\n    /**\n     * Creates a new shared store.\n     *\n     * When choosing an identifier for the store, you should write it using\n     * kebab-case and not include the string 'store' either as a prefix or\n     * a suffix.\n     *\n     * This method may only be called in the application's configuration\n     * phase.\n     *\n     * @param storeId Identifier of the shared store (must be globally unique)\n     * @param initialState Optional initial state of the shared store\n     */\n    public create<T>(storeId: string, initialState: T = null): void {\n        class Extended extends SimpleSharedStore<T> {\n            protected initialState() { return initialState; }\n            protected reduce(state: T, action: Action): T { return undefined; }\n        }\n\n        this.register<T>(storeId, Extended);\n    }\n\n    /**\n     * Registers a new shared store. A store with the same name must not already\n     * be registered.\n     *\n     * This method may only be called in the application's configuration\n     * phase.\n     *\n     * @param storeId Identifier of the shared store (must be globally unique)\n     * @param Shared store class\n     */\n    public register<T>(storeId: string, storeType: SharedStoreFactory<T, any>): void {\n        // Register the store as an angular service. We use factory instead of service\n        // so we can set the `_storeId` on the instance.\n        this._provide.factory(\n            storeIdToServiceId(storeId),\n            // @ngInject\n            ($injector: angular.auto.IInjectorService) => {\n                const store: any = $injector.instantiate(storeType);\n                store._storeId = storeId;\n                return store;\n            }\n        );\n        this._stores.push(storeId);\n    }\n\n    /**\n     * Registers a new actions class.\n     *\n     * This method may only be called in the application's configuration\n     * phase.\n     *\n     * @param actionsId Identifier of the actions class (must be globally unique)\n     * @param Actions class\n     */\n    public registerActions(actionsId: string, actionsType: ActionFactory): void {\n        this._provide.service(actionsIdToServiceId(actionsId), actionsType);\n    }\n\n    // @ngInject\n    public $get($injector: angular.auto.IInjectorService,\n                dispatcher: Dispatcher): SharedStoreManager {\n        return new SharedStoreManager($injector, dispatcher, this);\n    }\n}\n\n/**\n * Manager of all shared stores (see [[SharedStore]]) in an application. Each store\n * requires a globally unique identifier, which is also used during state serialization.\n *\n * In order to use shared stores, you must first create them. The best way to do\n * this is inside your module's `config` function as follows:\n * ```\n * module.config((sharedStoreManagerProvider: SharedStoreProvider) => {\n *     // Create the selected ROSE2 data items shared store.\n *     sharedStoreManagerProvider.create('rose2-selected-data-item');\n * });\n * ```\n *\n * The store may then be used as input to shared state defined on stateful\n * components (see [[StatefulComponentBase]]) and can also be injected using\n * a specific token. If a store is named `my-nice-items`, it will be injectable\n * by using the token `myNiceItemsStore`.\n *\n * If you wish to define shared stores which support additional actions, you\n * should subclass [[SharedStore]] and register your store by using [[register]]\n * as follows:\n * ```\n * class ComplexActions {\n *     static ADD_ITEM = 'complex/add_item';\n *     public addItem(value: types.SampleData) {\n *         return { type: ComplexActions.ADD_ITEM, item: value };\n *     }\n * }\n *\n * class ComplexStore extends SharedStore<types.SampleData[], ComplexActions> {\n *     // @ngInject\n *     constructor(complexActions: ComplexActions) {\n *         super(complexActions);\n *     }\n *\n *     protected initialState(): types.SampleData[] {\n *         return [];\n *     }\n *\n *     protected reduce(state: types.SampleData[], action: any): void {\n *         switch (action.type) {\n *             case ADD_ITEM: {\n *                 return _.union(state, action.item);\n *             }\n *             // ...\n *         }\n *     }\n * }\n *\n * module.config((sharedStoreManagerProvider: SharedStoreProvider) => {\n *     sharedStoreManagerProvider.registerActions('complex', ComplexActions);\n *     sharedStoreManagerProvider.register('complex', ComplexStore);\n * });\n * ```\n *\n * When creating a new shared store, a good design practice is to separate\n * actions into the `actions` directory and implement actions as methods on\n * the actions class named after your store (eg. for store `FooStore` put\n * actions into `FooActions`).\n *\n * Stores themselves should only implement the state management functionality\n * and most business logic should be contained in the actions class. For\n * example, if actions require some asynchronous operations to be performed\n * on a remote backend all this functionality should be put into the actions\n * class and not into the store.\n *\n * All actions classes should be registered via the [[SharedStoreProvider]]\n * and support Angular dependency injection. Actions classes are injectable\n * under the token `idActions` where the `id` part is the value defined by\n * `actionsId`, formatted in camelCase. The constructor of an actions\n * class may also inject other dependencies.\n *\n * For convenience, you may inject your actions class in your shared store\n * class under the public attribute `actions`. This way one may get the\n * actions class simply by accessing `store.actions` when given a shared\n * store instance.\n */\nexport class SharedStoreManager {\n    /// Shared store provider.\n    private _provider: SharedStoreProvider;\n    /// Dispatcher.\n    private _dispatcher: Dispatcher;\n    /// Angular injector.\n    private _injector: angular.auto.IInjectorService;\n\n    // @ngInject\n    constructor($injector: angular.auto.IInjectorService,\n                dispatcher: Dispatcher,\n                sharedStoreManagerProvider: SharedStoreProvider) {\n        this._provider = sharedStoreManagerProvider;\n        this._injector = $injector;\n        this._dispatcher = dispatcher;\n        this._dispatcher.setDispatcher(this._dispatch.bind(this));\n    }\n\n    /**\n     * Returns a previously registered store. It is an error to request a store\n     * which doesn't exist.\n     *\n     * @param storeId Identifier of the shared store\n     * @return Shared store instance\n     */\n    public getStore<T>(storeId: string): SharedStore<T, any> {\n        return this._injector.get<SharedStore<T, any>>(storeIdToServiceId(storeId));\n    }\n\n    /**\n     * Dispatches an action to all shared stores.\n     *\n     * @param action Action to dispatch\n     */\n    public dispatch(action: Action | Thunk): any {\n        return this._dispatcher.dispatch(action);\n    }\n\n    /**\n     * Internal global dispatch implementation.\n     */\n    private _dispatch(action: Action): void {\n        for (const storeId of this._provider.stores) {\n            this.getStore(storeId)._dispatch(action);\n        }\n    }\n\n    /**\n     * Serializes the values of all shared stores.\n     */\n    public saveState(): any {\n        let result = {};\n        for (const storeId of this._provider.stores) {\n            let value = this.getStore(storeId).saveValue();\n            if (isJsonable(value)) {\n                result[storeId] = value.toJSON();\n            } else {\n                result[storeId] = angular.copy(value);\n            }\n        }\n\n        return result;\n    }\n\n    /**\n     * Loads serialized values of all shared stores. Existing values are overwritten.\n     */\n    public loadState(state: any): void {\n        for (const storeId of this._provider.stores) {\n            if (!(storeId in state)) continue;\n\n            const value = state[storeId];\n            this.getStore(storeId).dispatch({type: Actions.SET, value: value});\n        }\n    }\n}\n\n/**\n * Returns the Angular service identifier that can be used to inject a\n * store via dependency injection.\n *\n * @param storeId Store identifier\n */\nfunction storeIdToServiceId(storeId: string): string {\n    return _.camelCase(`${storeId}-store`);\n}\n\n/**\n * Returns the Angular service identifier that can be used to inject an\n * actions object via dependency injection.\n *\n * @param actionsId Actions object identifier\n */\nfunction actionsIdToServiceId(actionsId: string): string {\n    return _.camelCase(`${actionsId}-actions`);\n}\n\nconst angularModule: angular.IModule = angular.module('resolwe.services.shared_store', []);\n\n// Register injectable services.\nangularModule.provider('sharedStoreManager', SharedStoreProvider);\nangularModule.service('dispatcher', Dispatcher);\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/core/shared_store/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,0BAA4B;AAC5B,uBAAyB;AACzB,iCAAmC;AAEnC,sCAAyC;AACzC,8CAAgD;AA8BhD;IAAA;IAMA,CAAC;IAHU,qBAAG,GAAV,UAAW,KAAU;QACjB,OAAO,EAAE,IAAI,EAAE,OAAO,CAAC,GAAG,EAAE,KAAK,OAAA,EAAE,CAAC;IACxC,CAAC;IAJD,+DAA+D;IACjD,WAAG,GAAsB,gBAAgB,CAAC;IAI5D,cAAC;CAND,AAMC,IAAA;AANY,0BAAO;AAQpB;;;;;;;;;;;;;GAaG;AACH;IAOI,qBAAY,OAAW;QAJf,aAAQ,GAAyC,EAAE,CAAC;QAKxD,IAAI,CAAC,QAAQ,GAAG,IAAI,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;QAC5D,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QAExB,6BAA6B;QAC7B,IAAI,CAAC,WAAW,GAAG,IAAI,UAAU,EAAE,CAAC;QACpC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACrF,CAAC;IAKD,sBAAW,gCAAO;QAHlB;;WAEG;aACH;YACI,OAAO,IAAI,CAAC,QAAQ,CAAC;QACzB,CAAC;;;OAAA;IAKD,sBAAW,gCAAO;QAHlB;;WAEG;aACH;YACI,OAAO,IAAI,CAAC,QAAQ,CAAC;QACzB,CAAC;;;OAAA;IAED;;;;;OAKG;IACI,+BAAS,GAAhB,UAAiB,MAAc;QAC3B,IAAM,aAAa,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;QACnC,IAAI,OAAwC,CAAC;QAC7C,IAAI,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,EAAE,aAAa,CAAC,EAAE;YAC1C,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC7C;aAAM;YACH,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACpC;QAED,IAAI,QAAQ,GAAG,OAAO,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;QAC9C,IAAI,CAAC,CAAC,WAAW,CAAC,QAAQ,CAAC;YAAE,OAAO;QAEpC,IAAI,OAAO,CAAC,MAAM,CAAC,aAAa,EAAE,QAAQ,CAAC;YAAE,OAAO;QACpD,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC;IAC5D,CAAC;IAED;;;;OAIG;IACI,8BAAQ,GAAf,UAAgB,MAAmD;QAC/D,OAAO,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAkB,MAAM,CAAC,CAAC;IAC9D,CAAC;IAED;;;;;;OAMG;IACK,qCAAe,GAAvB,UAAwB,KAAQ,EAAE,MAAc;QAC5C,QAAQ,MAAM,CAAC,IAAI,EAAE;YACjB,KAAK,OAAO,CAAC,GAAG,CAAC,CAAC;gBACd,IAAM,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;gBAClC,OAAO,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;aAC7C;YACD,OAAO,CAAC,CAAC;gBACL,cAAc;aACjB;SACJ;IACL,CAAC;IAqBD;;;;;;;;;;OAUG;IACO,iCAAW,GAArB,UAAsB,KAAQ,EAAE,SAAY;QACxC,OAAO,SAAS,CAAC;IACrB,CAAC;IAED;;;;;;;OAOG;IACO,iCAAW,GAArB,UAAyB,IAAY,EAAE,KAA6B;QAChE,IAAI,UAAU,GAAqB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACvD,IAAI,UAAU;YAAE,OAAO,UAAU,CAAC;QAElC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,oBAAoB,EAAE,CAAC;QACvF,OAAO,UAAU,CAAC;IACtB,CAAC;IAED;;;;;OAKG;IACI,2BAAK,GAAZ;QACI,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;IAED;;;;;OAKG;IACI,gCAAU,GAAjB;QACI,OAAO,IAAI,CAAC,QAAQ,CAAC;IACzB,CAAC;IAED;;;;OAIG;IACI,+BAAS,GAAhB;QACI,OAAO,IAAI,CAAC,KAAK,EAAE,CAAC;IACxB,CAAC;IACL,kBAAC;AAAD,CA9JA,AA8JC,IAAA;AA9JqB,kCAAW;AAgKjC;;;;;;;GAOG;AACH;IAAmD,qCAAgC;IAAnF;;IAAsF,CAAC;IAAD,wBAAC;AAAD,CAAtF,AAAuF,CAApC,WAAW,GAAyB;AAAjE,8CAAiB;AAEvC;;GAEG;AACH;IAAgC,8BAAkB;IAAlD;QAAA,qEA6BC;QA5BW,eAAS,GAAc,cAAM,OAAA,SAAS,EAAT,CAAS,CAAC;;IA4BnD,CAAC;IA1BG;;;;OAIG;IACI,kCAAa,GAApB,UAAqB,UAAoC,EAAE,QAAoB;QAC3E,2EAA2E;QAC3E,8EAA8E;QAC9E,6EAA6E;QAC7E,kCAAkC;QAClC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QACjE,IAAI,QAAQ;YAAE,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;IAC5C,CAAC;IAED;;OAEG;IACI,6BAAQ,GAAf,UAAgB,MAAsB;QAClC,IAAI,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE;YACtB,uEAAuE;YACvE,qBAAqB;YACrB,OAAO,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;SACvC;aAAM;YACH,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;SACvB;IACL,CAAC;IACL,iBAAC;AAAD,CA7BA,AA6BC,CA7B+B,EAAE,CAAC,OAAO,GA6BzC;AA7BY,gCAAU;AAuCvB;;;GAGG;AACH;IAMI,YAAY;IACZ,6BAAY,QAAsC;QANlD,gCAAgC;QACxB,YAAO,GAAa,EAAE,CAAC;QAM3B,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC7B,CAAC;IAKD,sBAAW,uCAAM;QAHjB;;WAEG;aACH;YACI,OAAO,IAAI,CAAC,OAAO,CAAC;QACxB,CAAC;;;OAAA;IAED;;;;;;;;;;;;OAYG;IACI,oCAAM,GAAb,UAAiB,OAAe,EAAE,YAAsB;QAAtB,6BAAA,EAAA,mBAAsB;QACpD;YAAuB,4BAAoB;YAA3C;;YAGA,CAAC;YAFa,+BAAY,GAAtB,cAA2B,OAAO,YAAY,CAAC,CAAC,CAAC;YACvC,yBAAM,GAAhB,UAAiB,KAAQ,EAAE,MAAc,IAAO,OAAO,SAAS,CAAC,CAAC,CAAC;YACvE,eAAC;QAAD,CAHA,AAGC,CAHsB,iBAAiB,GAGvC;QAED,IAAI,CAAC,QAAQ,CAAI,OAAO,EAAE,QAAQ,CAAC,CAAC;IACxC,CAAC;IAED;;;;;;;;;OASG;IACI,sCAAQ,GAAf,UAAmB,OAAe,EAAE,SAAqC;QACrE,8EAA8E;QAC9E,gDAAgD;QAChD,IAAI,CAAC,QAAQ,CAAC,OAAO,CACjB,kBAAkB,CAAC,OAAO,CAAC;QAC3B,YAAY;QACZ,UAAC,SAAwC;YACrC,IAAM,KAAK,GAAQ,SAAS,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;YACpD,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;YACzB,OAAO,KAAK,CAAC;QACjB,CAAC,CACJ,CAAC;QACF,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC/B,CAAC;IAED;;;;;;;;OAQG;IACI,6CAAe,GAAtB,UAAuB,SAAiB,EAAE,WAA0B;QAChE,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,oBAAoB,CAAC,SAAS,CAAC,EAAE,WAAW,CAAC,CAAC;IACxE,CAAC;IAED,YAAY;IACL,kCAAI,GAAX,UAAY,SAAwC,EACxC,UAAsB;QAC9B,OAAO,IAAI,kBAAkB,CAAC,SAAS,EAAE,UAAU,EAAE,IAAI,CAAC,CAAC;IAC/D,CAAC;IACL,0BAAC;AAAD,CAnFA,AAmFC,IAAA;AAnFY,kDAAmB;AAqFhC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4EG;AACH;IAQI,YAAY;IACZ,4BAAY,SAAwC,EACxC,UAAsB,EACtB,0BAA+C;QACvD,IAAI,CAAC,SAAS,GAAG,0BAA0B,CAAC;QAC5C,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;QAC9B,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAC9D,CAAC;IAED;;;;;;OAMG;IACI,qCAAQ,GAAf,UAAmB,OAAe;QAC9B,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAsB,kBAAkB,CAAC,OAAO,CAAC,CAAC,CAAC;IAChF,CAAC;IAED;;;;OAIG;IACI,qCAAQ,GAAf,UAAgB,MAAsB;QAClC,OAAO,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IAC7C,CAAC;IAED;;OAEG;IACK,sCAAS,GAAjB,UAAkB,MAAc;QAC5B,KAAsB,UAAqB,EAArB,KAAA,IAAI,CAAC,SAAS,CAAC,MAAM,EAArB,cAAqB,EAArB,IAAqB,EAAE;YAAxC,IAAM,OAAO,SAAA;YACd,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;SAC5C;IACL,CAAC;IAED;;OAEG;IACI,sCAAS,GAAhB;QACI,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,KAAsB,UAAqB,EAArB,KAAA,IAAI,CAAC,SAAS,CAAC,MAAM,EAArB,cAAqB,EAArB,IAAqB,EAAE;YAAxC,IAAM,OAAO,SAAA;YACd,IAAI,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,CAAC;YAC/C,IAAI,iBAAU,CAAC,KAAK,CAAC,EAAE;gBACnB,MAAM,CAAC,OAAO,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC;aACpC;iBAAM;gBACH,MAAM,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACzC;SACJ;QAED,OAAO,MAAM,CAAC;IAClB,CAAC;IAED;;OAEG;IACI,sCAAS,GAAhB,UAAiB,KAAU;QACvB,KAAsB,UAAqB,EAArB,KAAA,IAAI,CAAC,SAAS,CAAC,MAAM,EAArB,cAAqB,EAArB,IAAqB,EAAE;YAAxC,IAAM,OAAO,SAAA;YACd,IAAI,CAAC,CAAC,OAAO,IAAI,KAAK,CAAC;gBAAE,SAAS;YAElC,IAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC;YAC7B,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,EAAC,IAAI,EAAE,OAAO,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,EAAC,CAAC,CAAC;SACtE;IACL,CAAC;IACL,yBAAC;AAAD,CA3EA,AA2EC,IAAA;AA3EY,gDAAkB;AA6E/B;;;;;GAKG;AACH,SAAS,kBAAkB,CAAC,OAAe;IACvC,OAAO,CAAC,CAAC,SAAS,CAAI,OAAO,WAAQ,CAAC,CAAC;AAC3C,CAAC;AAED;;;;;GAKG;AACH,SAAS,oBAAoB,CAAC,SAAiB;IAC3C,OAAO,CAAC,CAAC,SAAS,CAAI,SAAS,aAAU,CAAC,CAAC;AAC/C,CAAC;AAED,IAAM,aAAa,GAAoB,OAAO,CAAC,MAAM,CAAC,+BAA+B,EAAE,EAAE,CAAC,CAAC;AAE3F,gCAAgC;AAChC,aAAa,CAAC,QAAQ,CAAC,oBAAoB,EAAE,mBAAmB,CAAC,CAAC;AAClE,aAAa,CAAC,OAAO,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC","file":"core/shared_store/index.js","sourcesContent":["import * as _ from 'lodash';\nimport * as Rx from 'rx';\nimport * as angular from 'angular';\n\nimport {isJsonable} from '../utils/lang';\nimport * as immutable from '../utils/immutable';\n\n/**\n * A shared store action contains a `type` property and any number of other\n * custom properties. Action types starting with `@@internal/` are reserved\n * for internal use.\n */\nexport interface Action {\n    type: string;\n    [propertyName: string]: any;\n}\n\n// tslint:disable:no-shadowed-variable\ntype MethodReturns<Actions> = Actions extends { [key in keyof Actions]: (() => infer Return) | infer Else } ? Return : never;\ntype FilterActions<Return> = Return extends { type: infer R } ? Return : never;\nexport type GetActions<Actions> = FilterActions<MethodReturns<Actions>> | { type: '...' };\n// tslint:enable:no-shadowed-variable\n\n/**\n * A thunk is a function, which mediates the dispatch of an action. It may\n * be dispatched in the same way as an action.\n */\nexport interface Thunk {\n    (dispatcher: Dispatcher, getState: () => any): any;\n}\n\nexport interface SharedStoreQuery<T, U> {\n    (state: Rx.Observable<T>): Rx.Observable<U>;\n}\n\nexport class Actions {\n    /// Internal action for setting this store to a specific value.\n    public static SET = <'@@internal/SET'> '@@internal/SET';\n    public set(value: any) {\n        return { type: Actions.SET, value };\n    }\n}\n\n/**\n * A shared store represents state that is shared between multiple components in\n * a predictable way. Components update the store by dispatching actions to\n * it using the `dispatch` method.\n *\n * Each shared store also provides a way for the components to subscribe to any\n * changes in the store's state.\n *\n * Consider defining actions for use in a shared store separately from the store,\n * in the `actions` subdirectory. See [[SharedStoreManager]] for details.\n *\n * Don't forget to call constructor with actions as an argument when extending\n * this class.\n */\nexport abstract class SharedStore<T, U> {\n    private _subject: Rx.BehaviorSubject<T>;\n    private _dispatcher: Dispatcher;\n    private _queries: {[name: string]: Rx.Observable<any>} = {};\n    private _actions: U;\n    private _storeId: string;\n\n    constructor(actions?: U) {\n        this._subject = new Rx.BehaviorSubject(this.initialState());\n        this._actions = actions;\n\n        // Create a local dispatcher.\n        this._dispatcher = new Dispatcher();\n        this._dispatcher.setDispatcher(this._dispatch.bind(this), this.value.bind(this));\n    }\n\n    /**\n     * Returns a unique identifier for this shared store.\n     */\n    public get storeId(): string {\n        return this._storeId;\n    }\n\n    /**\n     * Returns store actions.\n     */\n    public get actions(): U {\n        return this._actions;\n    }\n\n    /**\n     * Internal dispatcher implementation.\n     *\n     * NOTE: This method is public because there is no way to define private\n     * but accessible to other classes within this module in TypeScript.\n     */\n    public _dispatch(action: Action): void {\n        const existingValue = this.value();\n        let reducer: (value: T, action: Action) => T;\n        if (_.startsWith(action.type, '@@internal/')) {\n            reducer = this._reduceInternal.bind(this);\n        } else {\n            reducer = this.reduce.bind(this);\n        }\n\n        let newValue = reducer(existingValue, action);\n        if (_.isUndefined(newValue)) return;\n\n        if (angular.equals(existingValue, newValue)) return;\n        this._subject.onNext(immutable.makeImmutable(newValue));\n    }\n\n    /**\n     * Dispatches an action to this shared store.\n     *\n     * @param action Action to dispatch\n     */\n    public dispatch(action: GetActions<U> | GetActions<Actions> | Thunk): any {\n        return this._dispatcher.dispatch(<Action | Thunk> action);\n    }\n\n    /**\n     * Performs internal reduce actions implemented for each shared store.\n     *\n     * @param state Existing shared store state\n     * @param action Action to perform\n     * @return New shared store state\n     */\n    private _reduceInternal(state: T, action: Action): T {\n        switch (action.type) {\n            case Actions.SET: {\n                const nextState = action['value'];\n                return this.onStateLoad(state, nextState);\n            }\n            default: {\n                // Do nothing.\n            }\n        }\n    }\n\n    /**\n     * Performs the given action on the underlying state.\n     *\n     * Subclasses may override this method to implement arbitrary complex\n     * actions on the data store. This method MUST NOT mutate the existing\n     * state. Instead, it MUST return an immutable copy.\n     *\n     * @param value Existing shared store state\n     * @param action Operation to perform\n     * @return New shared store state\n     */\n    protected abstract reduce(state: T, action: GetActions<U>): T;\n\n    /**\n     * Provides the initial state for this shared store. This state is\n     * used when the store is initialized.\n     */\n    protected abstract initialState(): T;\n\n    /**\n     * This method gets called when the data store's state is loaded from\n     * an external source (when the SET action is dispatched to the store).\n     *\n     * It is called before the new state has been set. The default implementation\n     * does nothing.\n     *\n     * @param state Old state\n     * @param nextState New state\n     * @return Possibly modified state that should be used instead\n     */\n    protected onStateLoad(state: T, nextState: T): T {\n        return nextState;\n    }\n\n    /**\n     * A helper method for defining shared store queries. If the query is already\n     * defined, the existing observable is returned.\n     *\n     * @param name Query name\n     * @param query Query function\n     * @return Resulting query observable\n     */\n    protected defineQuery<V>(name: string, query: SharedStoreQuery<T, V>): Rx.Observable<V> {\n        let observable: Rx.Observable<V> = this._queries[name];\n        if (observable) return observable;\n\n        observable = this._queries[name] = this.observable().let(query).distinctUntilChanged();\n        return observable;\n    }\n\n    /**\n     * Returns the current value stored in the store.\n     *\n     * You MUST ensure that the resulting object is NOT mutated in any way. Any\n     * mutation may cause undefined behavior.\n     */\n    public value(): T {\n        return this._subject.getValue();\n    }\n\n    /**\n     * Returns an observable of the store's value.\n     *\n     * You MUST ensure that the observed value is NOT mutated in any way. Any\n     * mutation may cause undefined behavior.\n     */\n    public observable(): Rx.Observable<T> {\n        return this._subject;\n    }\n\n    /**\n     * Returns a value that should be used when saving store state.\n     *\n     * By default, this will return the same as [[value]].\n     */\n    public saveValue(): T {\n        return this.value();\n    }\n}\n\n/**\n * [[SimpleSharedStore]] is a helper class intended to be used as a type in conjunction with\n * [[SharedStoreProvider]]'s `create` method where only SET action is used.\n *\n * In this case no subclassing of store and actions is needed because only SET action is used.\n * This is convenient for use cases where you only need to set a value that you can subscribe\n * to from other components.\n */\nexport abstract class SimpleSharedStore<T> extends SharedStore<T, typeof undefined> { }\n\n/**\n * Used to dispatch actions to shared stores.\n */\nexport class Dispatcher extends Rx.Subject<Action> {\n    private _getState: () => any = () => undefined;\n\n    /**\n     * Configures a dispatcher function for this dispatcher.\n     *\n     * @param dispatcher The dispatcher function\n     */\n    public setDispatcher(dispatcher: (action: Action) => void, getState?: () => any): void {\n        // The dispatcher is used to dispatch all actions using a queue, so actions\n        // may invoke the dispatch method without causing recursion. The currentThread\n        // scheduler puts all pending items inside a queue, which is dispatched after\n        // returning from active dispatch.\n        this.observeOn(Rx.Scheduler.currentThread).subscribe(dispatcher);\n        if (getState) this._getState = getState;\n    }\n\n    /**\n     * Dispatches an action via this dispatcher.\n     */\n    public dispatch(action: Action | Thunk): any {\n        if (_.isFunction(action)) {\n            // A thunk has been passed. Execute it with the dispatcher argument and\n            // return the result.\n            return action(this, this._getState);\n        } else {\n            this.onNext(action);\n        }\n    }\n}\n\nexport interface SharedStoreFactory<T, U> {\n    new (...args): SharedStore<T, U>;\n}\n\nexport interface ActionFactory {\n    new (...args): any;\n}\n\n/**\n * Shared store provider, enabling registration of shared stores. All stores\n * must be registered in the application configuration phase.\n */\nexport class SharedStoreProvider {\n    /// A list of registered stores.\n    private _stores: string[] = [];\n    /// Provide service.\n    private _provide: angular.auto.IProvideService;\n\n    // @ngInject\n    constructor($provide: angular.auto.IProvideService) {\n        this._provide = $provide;\n    }\n\n    /**\n     * A list of registered stores.\n     */\n    public get stores(): string[] {\n        return this._stores;\n    }\n\n    /**\n     * Creates a new shared store.\n     *\n     * When choosing an identifier for the store, you should write it using\n     * kebab-case and not include the string 'store' either as a prefix or\n     * a suffix.\n     *\n     * This method may only be called in the application's configuration\n     * phase.\n     *\n     * @param storeId Identifier of the shared store (must be globally unique)\n     * @param initialState Optional initial state of the shared store\n     */\n    public create<T>(storeId: string, initialState: T = null): void {\n        class Extended extends SimpleSharedStore<T> {\n            protected initialState() { return initialState; }\n            protected reduce(state: T, action: Action): T { return undefined; }\n        }\n\n        this.register<T>(storeId, Extended);\n    }\n\n    /**\n     * Registers a new shared store. A store with the same name must not already\n     * be registered.\n     *\n     * This method may only be called in the application's configuration\n     * phase.\n     *\n     * @param storeId Identifier of the shared store (must be globally unique)\n     * @param Shared store class\n     */\n    public register<T>(storeId: string, storeType: SharedStoreFactory<T, any>): void {\n        // Register the store as an angular service. We use factory instead of service\n        // so we can set the `_storeId` on the instance.\n        this._provide.factory(\n            storeIdToServiceId(storeId),\n            // @ngInject\n            ($injector: angular.auto.IInjectorService) => {\n                const store: any = $injector.instantiate(storeType);\n                store._storeId = storeId;\n                return store;\n            }\n        );\n        this._stores.push(storeId);\n    }\n\n    /**\n     * Registers a new actions class.\n     *\n     * This method may only be called in the application's configuration\n     * phase.\n     *\n     * @param actionsId Identifier of the actions class (must be globally unique)\n     * @param Actions class\n     */\n    public registerActions(actionsId: string, actionsType: ActionFactory): void {\n        this._provide.service(actionsIdToServiceId(actionsId), actionsType);\n    }\n\n    // @ngInject\n    public $get($injector: angular.auto.IInjectorService,\n                dispatcher: Dispatcher): SharedStoreManager {\n        return new SharedStoreManager($injector, dispatcher, this);\n    }\n}\n\n/**\n * Manager of all shared stores (see [[SharedStore]]) in an application. Each store\n * requires a globally unique identifier, which is also used during state serialization.\n *\n * In order to use shared stores, you must first create them. The best way to do\n * this is inside your module's `config` function as follows:\n * ```\n * module.config((sharedStoreManagerProvider: SharedStoreProvider) => {\n *     // Create the selected ROSE2 data items shared store.\n *     sharedStoreManagerProvider.create('rose2-selected-data-item');\n * });\n * ```\n *\n * The store may then be used as input to shared state defined on stateful\n * components (see [[StatefulComponentBase]]) and can also be injected using\n * a specific token. If a store is named `my-nice-items`, it will be injectable\n * by using the token `myNiceItemsStore`.\n *\n * If you wish to define shared stores which support additional actions, you\n * should subclass [[SharedStore]] and register your store by using [[register]]\n * as follows:\n * ```\n * class ComplexActions {\n *     static ADD_ITEM = 'complex/add_item';\n *     public addItem(value: types.SampleData) {\n *         return { type: ComplexActions.ADD_ITEM, item: value };\n *     }\n * }\n *\n * class ComplexStore extends SharedStore<types.SampleData[], ComplexActions> {\n *     // @ngInject\n *     constructor(complexActions: ComplexActions) {\n *         super(complexActions);\n *     }\n *\n *     protected initialState(): types.SampleData[] {\n *         return [];\n *     }\n *\n *     protected reduce(state: types.SampleData[], action: any): void {\n *         switch (action.type) {\n *             case ADD_ITEM: {\n *                 return _.union(state, action.item);\n *             }\n *             // ...\n *         }\n *     }\n * }\n *\n * module.config((sharedStoreManagerProvider: SharedStoreProvider) => {\n *     sharedStoreManagerProvider.registerActions('complex', ComplexActions);\n *     sharedStoreManagerProvider.register('complex', ComplexStore);\n * });\n * ```\n *\n * When creating a new shared store, a good design practice is to separate\n * actions into the `actions` directory and implement actions as methods on\n * the actions class named after your store (eg. for store `FooStore` put\n * actions into `FooActions`).\n *\n * Stores themselves should only implement the state management functionality\n * and most business logic should be contained in the actions class. For\n * example, if actions require some asynchronous operations to be performed\n * on a remote backend all this functionality should be put into the actions\n * class and not into the store.\n *\n * All actions classes should be registered via the [[SharedStoreProvider]]\n * and support Angular dependency injection. Actions classes are injectable\n * under the token `idActions` where the `id` part is the value defined by\n * `actionsId`, formatted in camelCase. The constructor of an actions\n * class may also inject other dependencies.\n *\n * For convenience, you may inject your actions class in your shared store\n * class under the public attribute `actions`. This way one may get the\n * actions class simply by accessing `store.actions` when given a shared\n * store instance.\n */\nexport class SharedStoreManager {\n    /// Shared store provider.\n    private _provider: SharedStoreProvider;\n    /// Dispatcher.\n    private _dispatcher: Dispatcher;\n    /// Angular injector.\n    private _injector: angular.auto.IInjectorService;\n\n    // @ngInject\n    constructor($injector: angular.auto.IInjectorService,\n                dispatcher: Dispatcher,\n                sharedStoreManagerProvider: SharedStoreProvider) {\n        this._provider = sharedStoreManagerProvider;\n        this._injector = $injector;\n        this._dispatcher = dispatcher;\n        this._dispatcher.setDispatcher(this._dispatch.bind(this));\n    }\n\n    /**\n     * Returns a previously registered store. It is an error to request a store\n     * which doesn't exist.\n     *\n     * @param storeId Identifier of the shared store\n     * @return Shared store instance\n     */\n    public getStore<T>(storeId: string): SharedStore<T, any> {\n        return this._injector.get<SharedStore<T, any>>(storeIdToServiceId(storeId));\n    }\n\n    /**\n     * Dispatches an action to all shared stores.\n     *\n     * @param action Action to dispatch\n     */\n    public dispatch(action: Action | Thunk): any {\n        return this._dispatcher.dispatch(action);\n    }\n\n    /**\n     * Internal global dispatch implementation.\n     */\n    private _dispatch(action: Action): void {\n        for (const storeId of this._provider.stores) {\n            this.getStore(storeId)._dispatch(action);\n        }\n    }\n\n    /**\n     * Serializes the values of all shared stores.\n     */\n    public saveState(): any {\n        let result = {};\n        for (const storeId of this._provider.stores) {\n            let value = this.getStore(storeId).saveValue();\n            if (isJsonable(value)) {\n                result[storeId] = value.toJSON();\n            } else {\n                result[storeId] = angular.copy(value);\n            }\n        }\n\n        return result;\n    }\n\n    /**\n     * Loads serialized values of all shared stores. Existing values are overwritten.\n     */\n    public loadState(state: any): void {\n        for (const storeId of this._provider.stores) {\n            if (!(storeId in state)) continue;\n\n            const value = state[storeId];\n            this.getStore(storeId).dispatch({type: Actions.SET, value: value});\n        }\n    }\n}\n\n/**\n * Returns the Angular service identifier that can be used to inject a\n * store via dependency injection.\n *\n * @param storeId Store identifier\n */\nfunction storeIdToServiceId(storeId: string): string {\n    return _.camelCase(`${storeId}-store`);\n}\n\n/**\n * Returns the Angular service identifier that can be used to inject an\n * actions object via dependency injection.\n *\n * @param actionsId Actions object identifier\n */\nfunction actionsIdToServiceId(actionsId: string): string {\n    return _.camelCase(`${actionsId}-actions`);\n}\n\nconst angularModule: angular.IModule = angular.module('resolwe.services.shared_store', []);\n\n// Register injectable services.\nangularModule.provider('sharedStoreManager', SharedStoreProvider);\nangularModule.service('dispatcher', Dispatcher);\n"]} |
export {}; | ||
//# sourceMappingURL=index.spec.d.ts.map |
@@ -10,2 +10,1 @@ /** | ||
export declare function makeImmutable<T>(object: T): T; | ||
//# sourceMappingURL=immutable.d.ts.map |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
var _ = require("lodash"); | ||
/** | ||
@@ -12,2 +13,6 @@ * Makes an object deeply immutable by using Object.freeze. The passed object | ||
function makeImmutable(object) { | ||
if (_.isObject(object)) { | ||
_.each(object, function (property) { return makeImmutable(property); }); | ||
return Object.freeze(object); | ||
} | ||
return object; | ||
@@ -17,2 +22,2 @@ } | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb3JlL3V0aWxzL2ltbXV0YWJsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUVBOzs7Ozs7O0dBT0c7QUFDSCxTQUFnQixhQUFhLENBQUksTUFBUztJQUV0QyxPQUFPLE1BQU0sQ0FBQztBQUNsQixDQUFDO0FBSEQsc0NBR0MiLCJmaWxlIjoiY29yZS91dGlscy9pbW11dGFibGUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBfIGZyb20gJ2xvZGFzaCc7XG5cbi8qKlxuICogTWFrZXMgYW4gb2JqZWN0IGRlZXBseSBpbW11dGFibGUgYnkgdXNpbmcgT2JqZWN0LmZyZWV6ZS4gVGhlIHBhc3NlZCBvYmplY3RcbiAqIHdpbGwgYmUgY2hhbmdlZCBzbyB0aGF0IGl0IHdpbGwgbm93IGJlIGltbXV0YWJsZSBhbmQgdGhlIHNhbWUgb2JqZWN0IHdpbGxcbiAqIGJlIHJldHVybmVkLlxuICpcbiAqIEBwYXJhbSB7VH0gb2JqZWN0IFRoZSBvYmplY3QgdG8gbWFrZSBpbW11dGFibGVcbiAqIEByZXR1cm4ge1R9IFRoZSBzYW1lIG9iamVjdCB0aGF0IHdhcyBwYXNzZWQgYXMgYW4gYXJndW1lbnRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIG1ha2VJbW11dGFibGU8VD4ob2JqZWN0OiBUKTogVCB7XG4gICAgLy8gQGlmbmRlZiBHRU5KU19QUk9EVUNUSU9OXG4gICAgaWYgKF8uaXNPYmplY3Qob2JqZWN0KSkge1xuICAgICAgICBfLmVhY2gob2JqZWN0LCAocHJvcGVydHkpID0+IG1ha2VJbW11dGFibGUocHJvcGVydHkpKTtcbiAgICAgICAgcmV0dXJuIE9iamVjdC5mcmVlemUob2JqZWN0KTtcbiAgICB9XG4gICAgLy8gQGVuZGlmXG5cbiAgICByZXR1cm4gb2JqZWN0O1xufVxuIl19 | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb3JlL3V0aWxzL2ltbXV0YWJsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDBCQUE0QjtBQUU1Qjs7Ozs7OztHQU9HO0FBQ0gsU0FBZ0IsYUFBYSxDQUFJLE1BQVM7SUFDdEMsSUFBSSxDQUFDLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxFQUFFO1FBQ3BCLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLFVBQUMsUUFBUSxJQUFLLE9BQUEsYUFBYSxDQUFDLFFBQVEsQ0FBQyxFQUF2QixDQUF1QixDQUFDLENBQUM7UUFDdEQsT0FBTyxNQUFNLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0tBQ2hDO0lBRUQsT0FBTyxNQUFNLENBQUM7QUFDbEIsQ0FBQztBQVBELHNDQU9DIiwiZmlsZSI6ImNvcmUvdXRpbHMvaW1tdXRhYmxlLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgXyBmcm9tICdsb2Rhc2gnO1xuXG4vKipcbiAqIE1ha2VzIGFuIG9iamVjdCBkZWVwbHkgaW1tdXRhYmxlIGJ5IHVzaW5nIE9iamVjdC5mcmVlemUuIFRoZSBwYXNzZWQgb2JqZWN0XG4gKiB3aWxsIGJlIGNoYW5nZWQgc28gdGhhdCBpdCB3aWxsIG5vdyBiZSBpbW11dGFibGUgYW5kIHRoZSBzYW1lIG9iamVjdCB3aWxsXG4gKiBiZSByZXR1cm5lZC5cbiAqXG4gKiBAcGFyYW0ge1R9IG9iamVjdCBUaGUgb2JqZWN0IHRvIG1ha2UgaW1tdXRhYmxlXG4gKiBAcmV0dXJuIHtUfSBUaGUgc2FtZSBvYmplY3QgdGhhdCB3YXMgcGFzc2VkIGFzIGFuIGFyZ3VtZW50XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBtYWtlSW1tdXRhYmxlPFQ+KG9iamVjdDogVCk6IFQge1xuICAgIC8vIEBpZm5kZWYgR0VOSlNfUFJPRFVDVElPTlxuICAgIGlmIChfLmlzT2JqZWN0KG9iamVjdCkpIHtcbiAgICAgICAgXy5lYWNoKG9iamVjdCwgKHByb3BlcnR5KSA9PiBtYWtlSW1tdXRhYmxlKHByb3BlcnR5KSk7XG4gICAgICAgIHJldHVybiBPYmplY3QuZnJlZXplKG9iamVjdCk7XG4gICAgfVxuICAgIC8vIEBlbmRpZlxuXG4gICAgcmV0dXJuIG9iamVjdDtcbn1cbiJdfQ== |
@@ -57,2 +57,1 @@ /// <reference types="angular" /> | ||
export {}; | ||
//# sourceMappingURL=lang.d.ts.map |
@@ -129,3 +129,2 @@ "use strict"; | ||
} | ||
; | ||
return class_1; | ||
@@ -160,2 +159,2 @@ }()); | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/core/utils/lang.ts"],"names":[],"mappings":"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","file":"core/utils/lang.js","sourcesContent":["import * as _ from 'lodash';\nimport * as immutable from 'immutable';\n\nexport interface Jsonable {\n    toJSON(): any;\n}\n\n/**\n * Returns true if the given value is a promise.\n *\n * @param value Value to check\n */\nexport function isPromiseLike(value: any): value is Promise<any> | angular.IPromise<any> {\n    const promise = <Promise<any>> value;\n    return !!promise.then && typeof promise.then === 'function';\n}\n\n/**\n * Returns true if the given value is an observable.\n *\n * @param value Value to check\n */\nexport function isObservable(value: any): value is Rx.Observable<any> {\n    return _.isObject(value) && value.subscribe;\n}\n\n/**\n * Returns true if the given value has a `toJSON` method.\n *\n * @param value Value to check\n */\nexport function isJsonable(value: any): value is Jsonable {\n    return _.isObject(value) && value.toJSON;\n}\n\n/**\n * Returns true if the given value is an Immutable.js collection.\n *\n * @param value Value to check\n */\nexport function isImmutableCollection(value: any): value is immutable.Collection<any, any> {\n    return _.isObject(value) && value.toJS;\n}\n\n/**\n * Copy properties of source object to target object excluding constructor.\n * If a property with the same exists on the target it is NOT overwritten.\n *\n * @param target\n * @param source\n */\nfunction extend(target: any, source: any) {\n    do {\n        Object.getOwnPropertyNames(source).forEach((name) => {\n            if (name !== 'constructor' && !target.hasOwnProperty(name)) {\n                Object.defineProperty(target, name, Object.getOwnPropertyDescriptor(source, name));\n            }\n        });\n\n        // Recurse upwards.\n        source = Object.getPrototypeOf(source);\n    } while (Object.getPrototypeOf(source) !== null);\n}\n\n\n/**\n * Create a constructor function for a class implementing the given mixins.\n *\n * @param mixins Array of classes to be mixed together\n * @param separateArguments Should the new construct accept separate arguments\n * @return A constructor function\n */\nexport function compose(mixins: any[], separateArguments: boolean = false) {\n    // Constructor function that will be called every time a new composed object is created.\n    let ctor = function (...args: any[]) {\n        if (separateArguments) {\n            // Call each construction function with respective arguments.\n            _.zip(mixins, args).forEach(([mixin, mixinArgs]) => {\n                mixin.apply(this, mixinArgs);\n            });\n        } else {\n            // Call the constructor function of all the mixins, in order.\n            mixins.forEach((mixin) => {\n                mixin.apply(this, args);\n            });\n        }\n    };\n\n    // Add all mixins properties and methods to the constructor prototype for all\n    // created objects to have them.\n    mixins.forEach((mixin) => {\n        extend(ctor.prototype, mixin.prototype);\n    });\n\n    return ctor;\n}\n\n\ninterface AngularConstructor {\n    new (...args: any[]): void;\n    $inject?: ReadonlyArray<string>;\n}\nfunction getInjects(mixin: AngularConstructor): ReadonlyArray<string> {\n    const numArguments = mixin.length;\n    // If no arguments and no inject, pretend that inject is [].\n    if (numArguments === 0 && !mixin.$inject) return [];\n    return mixin.$inject;\n}\n\n/**\n * Create a constructor function for a class implementing the given mixins. All mixins\n * must have annotated injections (// @ngInject) with $inject property, so that returned\n * constructor can be instantiated with $injector.instantiate\n */\nexport function ngCompose(mixins: AngularConstructor[]) {\n    if (!_.all(mixins, (mixin) => getInjects(mixin))) {\n        throw new Error('All mixins in ngCompose must have $inject property or no arguments');\n    }\n\n    const ctor = class {\n        constructor (...flattenedArgs: any[]) {\n            let mutableFlattenedArgs = _.clone(flattenedArgs);\n            _.each(mixins, (mixin) => {\n                // Take and remove it's part of flattened args.\n                const argsPart = mutableFlattenedArgs.splice(0, getInjects(mixin).length);\n                // Construct\n                mixin.apply(this, argsPart);\n            });\n        };\n    };\n\n    ctor.$inject = <string[]> _.flatten(_.map(mixins, (mixin) => getInjects(mixin)));\n\n    // Add all mixins properties and methods to the constructor prototype for all\n    // created objects to have them.\n    mixins.forEach((mixin) => {\n        extend(ctor.prototype, mixin.prototype);\n    });\n\n    return ctor;\n}\n\n\n/**\n * Traverse and transform objects by visiting every node on a recursive walk.\n * This is needed because `_.cloneDeep(value, replacer)` drops object keys when\n * replacer returns `undefined`.\n */\nexport function deepTraverse(tree: any, replacer: (value: any) => any): any {\n    const transformedTree = replacer(tree);\n\n    if (_.isArray(transformedTree)) {\n        return _.map(transformedTree, (element) => deepTraverse(element, replacer));\n    }\n    if (_.isObject(transformedTree) && !_.isFunction(transformedTree) && !_.isArray(transformedTree)) {\n        return _.mapValues(transformedTree, (element) => deepTraverse(element, replacer));\n    }\n    // Leaf node\n    return transformedTree;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["../src/core/utils/lang.ts"],"names":[],"mappings":"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","file":"core/utils/lang.js","sourcesContent":["import * as _ from 'lodash';\nimport * as immutable from 'immutable';\n\nexport interface Jsonable {\n    toJSON(): any;\n}\n\n/**\n * Returns true if the given value is a promise.\n *\n * @param value Value to check\n */\nexport function isPromiseLike(value: any): value is Promise<any> | angular.IPromise<any> {\n    const promise = <Promise<any>> value;\n    return !!promise.then && typeof promise.then === 'function';\n}\n\n/**\n * Returns true if the given value is an observable.\n *\n * @param value Value to check\n */\nexport function isObservable(value: any): value is Rx.Observable<any> {\n    return _.isObject(value) && value.subscribe;\n}\n\n/**\n * Returns true if the given value has a `toJSON` method.\n *\n * @param value Value to check\n */\nexport function isJsonable(value: any): value is Jsonable {\n    return _.isObject(value) && value.toJSON;\n}\n\n/**\n * Returns true if the given value is an Immutable.js collection.\n *\n * @param value Value to check\n */\nexport function isImmutableCollection(value: any): value is immutable.Collection<any, any> {\n    return _.isObject(value) && value.toJS;\n}\n\n/**\n * Copy properties of source object to target object excluding constructor.\n * If a property with the same exists on the target it is NOT overwritten.\n *\n * @param target\n * @param source\n */\nfunction extend(target: any, source: any) {\n    do {\n        Object.getOwnPropertyNames(source).forEach((name) => {\n            if (name !== 'constructor' && !target.hasOwnProperty(name)) {\n                Object.defineProperty(target, name, Object.getOwnPropertyDescriptor(source, name));\n            }\n        });\n\n        // Recurse upwards.\n        source = Object.getPrototypeOf(source);\n    } while (Object.getPrototypeOf(source) !== null);\n}\n\n\n/**\n * Create a constructor function for a class implementing the given mixins.\n *\n * @param mixins Array of classes to be mixed together\n * @param separateArguments Should the new construct accept separate arguments\n * @return A constructor function\n */\nexport function compose(mixins: any[], separateArguments: boolean = false) {\n    // Constructor function that will be called every time a new composed object is created.\n    let ctor = function (...args: any[]) {\n        if (separateArguments) {\n            // Call each construction function with respective arguments.\n            _.zip(mixins, args).forEach(([mixin, mixinArgs]) => {\n                mixin.apply(this, mixinArgs);\n            });\n        } else {\n            // Call the constructor function of all the mixins, in order.\n            mixins.forEach((mixin) => {\n                mixin.apply(this, args);\n            });\n        }\n    };\n\n    // Add all mixins properties and methods to the constructor prototype for all\n    // created objects to have them.\n    mixins.forEach((mixin) => {\n        extend(ctor.prototype, mixin.prototype);\n    });\n\n    return ctor;\n}\n\n\ninterface AngularConstructor {\n    new (...args: any[]): void;\n    $inject?: ReadonlyArray<string>;\n}\nfunction getInjects(mixin: AngularConstructor): ReadonlyArray<string> {\n    const numArguments = mixin.length;\n    // If no arguments and no inject, pretend that inject is [].\n    if (numArguments === 0 && !mixin.$inject) return [];\n    return mixin.$inject;\n}\n\n/**\n * Create a constructor function for a class implementing the given mixins. All mixins\n * must have annotated injections (// @ngInject) with $inject property, so that returned\n * constructor can be instantiated with $injector.instantiate\n */\nexport function ngCompose(mixins: AngularConstructor[]) {\n    if (!_.all(mixins, (mixin) => getInjects(mixin))) {\n        throw new Error('All mixins in ngCompose must have $inject property or no arguments');\n    }\n\n    const ctor = class {\n        constructor (...flattenedArgs: any[]) {\n            let mutableFlattenedArgs = _.clone(flattenedArgs);\n            _.each(mixins, (mixin) => {\n                // Take and remove it's part of flattened args.\n                const argsPart = mutableFlattenedArgs.splice(0, getInjects(mixin).length);\n                // Construct\n                mixin.apply(this, argsPart);\n            });\n        }\n    };\n\n    ctor.$inject = <string[]> _.flatten(_.map(mixins, (mixin) => getInjects(mixin)));\n\n    // Add all mixins properties and methods to the constructor prototype for all\n    // created objects to have them.\n    mixins.forEach((mixin) => {\n        extend(ctor.prototype, mixin.prototype);\n    });\n\n    return ctor;\n}\n\n\n/**\n * Traverse and transform objects by visiting every node on a recursive walk.\n * This is needed because `_.cloneDeep(value, replacer)` drops object keys when\n * replacer returns `undefined`.\n */\nexport function deepTraverse(tree: any, replacer: (value: any) => any): any {\n    const transformedTree = replacer(tree);\n\n    if (_.isArray(transformedTree)) {\n        return _.map(transformedTree, (element) => deepTraverse(element, replacer));\n    }\n    if (_.isObject(transformedTree) && !_.isFunction(transformedTree) && !_.isArray(transformedTree)) {\n        return _.mapValues(transformedTree, (element) => deepTraverse(element, replacer));\n    }\n    // Leaf node\n    return transformedTree;\n}\n"]} |
@@ -5,2 +5,1 @@ /** | ||
export declare function randomUuid(): string; | ||
//# sourceMappingURL=random.d.ts.map |
@@ -19,2 +19,1 @@ export declare class SerializationError extends Error { | ||
export declare function verboseSerialize(tree: any): any; | ||
//# sourceMappingURL=serialization.d.ts.map |
export {}; | ||
//# sourceMappingURL=serialization.spec.d.ts.map |
@@ -1,1 +0,1 @@ | ||
//# sourceMappingURL=index.d.ts.map | ||
@@ -97,2 +97,1 @@ import * as angular from 'angular'; | ||
export declare function describeComponent(description: string, modules: any[], tests: (tester: ComponentTester) => void, apiClass?: MockApiFactory, baseModules?: string[]): void; | ||
//# sourceMappingURL=component.d.ts.map |
import 'jquery'; | ||
//# sourceMappingURL=initialization.d.ts.map |
@@ -15,2 +15,1 @@ export declare const ngEqualMatcher: { | ||
} | ||
//# sourceMappingURL=matchers.d.ts.map |
@@ -30,2 +30,1 @@ import * as Rx from 'rx'; | ||
} | ||
//# sourceMappingURL=mock.d.ts.map |
{ | ||
"name": "@genialis/resolwe", | ||
"author": "Genialis Inc.", | ||
"version": "11.1.0", | ||
"version": "12.0.0", | ||
"description": "Resolwe frontend libraries", | ||
@@ -15,4 +15,3 @@ "license": "Apache-2.0", | ||
"scripts": { | ||
"build": "gulp build", | ||
"prepublishOnly": "gulp build" | ||
"build": "gulp build" | ||
}, | ||
@@ -19,0 +18,0 @@ "main": "dist/index.js", |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
1034677
104
12611