@pebula/metap
Version:
meta-programming tools
173 lines • 13.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Mixin } from '@pebula/utils';
/** @type {?} */
var ModelClassCollectionMark = Symbol('ModelClassCollection instance mark');
/** @type {?} */
var NON_EXTENDABLE_PROPS = ['constructor'];
/** @type {?} */
var pCopyMap = new Map();
/**
* @param {?} proto
* @return {?}
*/
function buildAndCacheProperties(proto) {
/** @type {?} */
var propertiesToCopy = Object.getOwnPropertyNames(proto)
.concat((/** @type {?} */ (Object.getOwnPropertySymbols(proto))))
.filter((/**
* @param {?} v
* @return {?}
*/
function (v) { return NON_EXTENDABLE_PROPS.indexOf(v) === -1; }));
pCopyMap.set(proto, propertiesToCopy);
}
/**
* @param {?} proto
* @param {?} thisVar
* @return {?}
*/
function runtimeExtend(proto, thisVar) {
/** @type {?} */
var propertiesToCopy = pCopyMap.get(proto) || [];
thisVar[ModelClassCollectionMark] = true;
for (var i = 0, len = propertiesToCopy.length; i < len; i++) {
/** @type {?} */
var name_1 = propertiesToCopy[i];
/** @type {?} */
var propDesc = Object.getOwnPropertyDescriptor(proto, name_1);
if (propDesc) {
Object.defineProperty(thisVar, name_1, propDesc);
}
else {
thisVar[name_1] = proto[name_1];
}
}
}
// TODO: document the class and how to use it. explain about methods that return new instance (concat, reverse, etc)
// that return Array instance and not ActiveRecordCollection instance.
// TODO: override ref changing methods? throw on them? return ActiveRecordCollection on them?
/**
* @template T
*/
var
// TODO: document the class and how to use it. explain about methods that return new instance (concat, reverse, etc)
// that return Array instance and not ActiveRecordCollection instance.
// TODO: override ref changing methods? throw on them? return ActiveRecordCollection on them?
/**
* @template T
*/
ModelClassCollection = /** @class */ (function (_super) {
tslib_1.__extends(ModelClassCollection, _super);
function ModelClassCollection() {
var _this = _super.call(this) || this;
runtimeExtend(ModelClassCollection.prototype, _this);
return _this;
}
/**
* @param {?} type
* @return {?}
*/
ModelClassCollection.extend = /**
* @param {?} type
* @return {?}
*/
function (type) {
Mixin((/** @type {?} */ (ModelClassCollection)), type);
buildAndCacheProperties(ModelClassCollection.prototype);
};
/**
* @param {?} instance
* @return {?}
*/
ModelClassCollection.instanceOf = /**
* @param {?} instance
* @return {?}
*/
function (instance) {
return instance[ModelClassCollectionMark] === true;
};
/**
* @template T
* @param {?=} targetStore
* @param {?=} type
* @return {?}
*/
ModelClassCollection.create = /**
* @template T
* @param {?=} targetStore
* @param {?=} type
* @return {?}
*/
function (targetStore, type) {
if (!type) {
return new ModelClassCollection();
}
else {
return targetStore.getTargetMeta(type).createCollection();
}
};
/**
* Creates a new ModelClassCollection class mixed in with the proto object.
* @param proto An object literal used as a mixin to the ModelClassCollection prototype.
* @returns
*/
/**
* Creates a new ModelClassCollection class mixed in with the proto object.
* @template T
* @param {?} proto An object literal used as a mixin to the ModelClassCollection prototype.
* @return {?}
*/
ModelClassCollection.factory = /**
* Creates a new ModelClassCollection class mixed in with the proto object.
* @template T
* @param {?} proto An object literal used as a mixin to the ModelClassCollection prototype.
* @return {?}
*/
function (proto) {
/** @type {?} */
var clz = /** @class */ (function (_super) {
tslib_1.__extends(RuntimeTDMCollection, _super);
function RuntimeTDMCollection() {
var _this = _super.call(this) || this;
runtimeExtend(clz.prototype, _this);
return _this;
}
/**
* @param {?} type
* @return {?}
*/
RuntimeTDMCollection.extend = /**
* @param {?} type
* @return {?}
*/
function (type) {
Mixin((/** @type {?} */ (ModelClassCollection)), type);
buildAndCacheProperties(clz.prototype);
};
return RuntimeTDMCollection;
}(ModelClassCollection));
Object.defineProperty(clz, Symbol.hasInstance, {
value: clz.instanceOf
});
Object.assign(clz.prototype, proto);
buildAndCacheProperties(clz.prototype);
return clz;
};
return ModelClassCollection;
}(Array));
// TODO: document the class and how to use it. explain about methods that return new instance (concat, reverse, etc)
// that return Array instance and not ActiveRecordCollection instance.
// TODO: override ref changing methods? throw on them? return ActiveRecordCollection on them?
/**
* @template T
*/
export { ModelClassCollection };
Object.defineProperty(ModelClassCollection, Symbol.hasInstance, {
value: ModelClassCollection.instanceOf
});
buildAndCacheProperties(ModelClassCollection.prototype);
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"model-class-collection.js","sourceRoot":"ng://@pebula/metap/internal/","sources":["lib/model/model-class-collection.ts"],"names":[],"mappings":"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","sourcesContent":["import { Constructor, Mixin } from '@pebula/utils';\nimport { TargetStore } from '../metadata/target-store';\n\nconst ModelClassCollectionMark = Symbol('ModelClassCollection instance mark');\nconst NON_EXTENDABLE_PROPS = ['constructor'];\n\nconst pCopyMap = new Map<any, Array<string | symbol>>();\n\nfunction buildAndCacheProperties(proto: any) {\n  const propertiesToCopy = Object.getOwnPropertyNames(proto)\n    .concat(Object.getOwnPropertySymbols(proto) as any)\n    .filter(v => NON_EXTENDABLE_PROPS.indexOf(v) === -1);\n\n  pCopyMap.set(proto, propertiesToCopy);\n}\n\nfunction runtimeExtend(proto: any, thisVar: Array<any>): any {\n  const propertiesToCopy = pCopyMap.get(proto) || [];\n\n  thisVar[ModelClassCollectionMark] = true;\n\n  for (let i = 0, len = propertiesToCopy.length; i < len; i++) {\n    const name = propertiesToCopy[i];\n    const propDesc = Object.getOwnPropertyDescriptor(proto, name);\n    if (propDesc) {\n      Object.defineProperty(thisVar, name, propDesc);\n    } else {\n      thisVar[name] = proto[name];\n    }\n  }\n}\n\n// TODO: document the class and how to use it. explain about methods that return new instance (concat, reverse, etc)\n// that return Array instance and not ActiveRecordCollection instance.\n// TODO: override ref changing methods? throw on them? return ActiveRecordCollection on them?\nexport class ModelClassCollection<T /* extends ActiveRecord<any, any> */> extends Array<T> {\n  constructor() {\n    super();\n    runtimeExtend(ModelClassCollection.prototype, this);\n  }\n\n  static extend(type: any): void {\n    Mixin(ModelClassCollection as any, type);\n    buildAndCacheProperties(ModelClassCollection.prototype);\n  }\n\n  static instanceOf(instance: any): instance is ModelClassCollection<any> {\n    return instance[ModelClassCollectionMark] === true;\n  }\n\n  /**\n   * Creates a new instance of ModelClassCollection.\n   * If a type is specified, returns the ModelClassCollection class for that type.\n   * It is recommended to use this method along with a type to ensure plugins functionality.\n   * @param type\n   */\n  static create<T>(): ModelClassCollection<T>\n  static create<T>(targetStore: TargetStore, type: Constructor<T>): ModelClassCollection<T>;\n  static create<T>(targetStore?: TargetStore, type?: Constructor<T>): ModelClassCollection<T> {\n    if (!type) {\n      return new ModelClassCollection<any>();\n    } else {\n      return targetStore.getTargetMeta(type).createCollection();\n    }\n  }\n\n  /**\n   * Creates a new ModelClassCollection class mixed in with the proto object.\n   * @param proto An object literal used as a mixin to the ModelClassCollection prototype.\n   * @returns\n   */\n  static factory<T>(proto: any): typeof ModelClassCollection & Constructor<ModelClassCollection<T>> {\n    const clz = class RuntimeTDMCollection<T> extends ModelClassCollection<T> {\n      constructor() {\n        super();\n        runtimeExtend(clz.prototype, this);\n      }\n\n      static extend(type: any): void {\n        Mixin(ModelClassCollection as any, type);\n        buildAndCacheProperties(clz.prototype);\n      }\n    };\n\n    Object.defineProperty(clz, Symbol.hasInstance, {\n      value: clz.instanceOf\n    });\n\n    Object.assign(clz.prototype, proto);\n    buildAndCacheProperties(clz.prototype);\n\n    return clz;\n  }\n}\n\nObject.defineProperty(ModelClassCollection, Symbol.hasInstance, {\n  value: ModelClassCollection.instanceOf\n});\n\nbuildAndCacheProperties(ModelClassCollection.prototype);\n"]}