ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
264 lines • 18.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
/**
* @license
* Copyright Alibaba.com All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE
*/
import { Directive, Input, TemplateRef, ViewContainerRef } from '@angular/core';
var NzStringTemplateOutletDirective = /** @class */ (function () {
function NzStringTemplateOutletDirective(viewContainer, defaultTemplate) {
this.viewContainer = viewContainer;
this.defaultTemplate = defaultTemplate;
// tslint:disable-next-line:no-any
this.inputTemplate = null;
this.inputViewRef = null;
this.defaultViewRef = null;
// tslint:disable-next-line:no-any
this.nzStringTemplateOutletContext = null;
}
Object.defineProperty(NzStringTemplateOutletDirective.prototype, "nzStringTemplateOutlet", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
if (value instanceof TemplateRef) {
this.isTemplate = true;
this.inputTemplate = value;
}
else {
this.isTemplate = false;
}
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
NzStringTemplateOutletDirective.prototype.recreateView = /**
* @return {?}
*/
function () {
if (!this.isTemplate) {
/** use default template when input is string **/
if (!this.defaultViewRef) {
if (this.defaultTemplate) {
this.defaultViewRef = this.viewContainer.createEmbeddedView(this.defaultTemplate, this.nzStringTemplateOutletContext);
}
}
}
else {
/** use input template when input is templateRef **/
if (!this.inputViewRef) {
if (this.inputTemplate) {
this.inputViewRef = this.viewContainer.createEmbeddedView(this.inputTemplate, this.nzStringTemplateOutletContext);
}
}
}
};
// tslint:disable-next-line:no-any
// tslint:disable-next-line:no-any
/**
* @private
* @param {?} value
* @return {?}
*/
NzStringTemplateOutletDirective.prototype.getType =
// tslint:disable-next-line:no-any
/**
* @private
* @param {?} value
* @return {?}
*/
function (value) {
if (value instanceof TemplateRef) {
return 'template';
}
else {
return 'string';
}
};
/**
* @private
* @param {?} changes
* @return {?}
*/
NzStringTemplateOutletDirective.prototype.shouldRecreateView = /**
* @private
* @param {?} changes
* @return {?}
*/
function (changes) {
var nzStringTemplateOutletContext = changes.nzStringTemplateOutletContext, nzStringTemplateOutlet = changes.nzStringTemplateOutlet;
/** @type {?} */
var shouldOutletRecreate = false;
if (nzStringTemplateOutlet) {
if (nzStringTemplateOutlet.firstChange) {
shouldOutletRecreate = true;
}
else {
/** @type {?} */
var previousOutletType = this.getType(nzStringTemplateOutlet.previousValue);
/** @type {?} */
var currentOutletType = this.getType(nzStringTemplateOutlet.currentValue);
shouldOutletRecreate = !(previousOutletType === 'string' && currentOutletType === 'string');
}
}
/** @type {?} */
var shouldContextRecreate = nzStringTemplateOutletContext && this.hasContextShapeChanged(nzStringTemplateOutletContext);
return shouldContextRecreate || shouldOutletRecreate;
};
/**
* @private
* @param {?} ctxChange
* @return {?}
*/
NzStringTemplateOutletDirective.prototype.hasContextShapeChanged = /**
* @private
* @param {?} ctxChange
* @return {?}
*/
function (ctxChange) {
var e_1, _a;
/** @type {?} */
var prevCtxKeys = Object.keys(ctxChange.previousValue || {});
/** @type {?} */
var currCtxKeys = Object.keys(ctxChange.currentValue || {});
if (prevCtxKeys.length === currCtxKeys.length) {
try {
for (var currCtxKeys_1 = tslib_1.__values(currCtxKeys), currCtxKeys_1_1 = currCtxKeys_1.next(); !currCtxKeys_1_1.done; currCtxKeys_1_1 = currCtxKeys_1.next()) {
var propName = currCtxKeys_1_1.value;
if (prevCtxKeys.indexOf(propName) === -1) {
return true;
}
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (currCtxKeys_1_1 && !currCtxKeys_1_1.done && (_a = currCtxKeys_1.return)) _a.call(currCtxKeys_1);
}
finally { if (e_1) throw e_1.error; }
}
return false;
}
else {
return true;
}
};
// tslint:disable-next-line:no-any
// tslint:disable-next-line:no-any
/**
* @private
* @param {?} ctx
* @return {?}
*/
NzStringTemplateOutletDirective.prototype.updateExistingContext =
// tslint:disable-next-line:no-any
/**
* @private
* @param {?} ctx
* @return {?}
*/
function (ctx) {
var e_2, _a;
try {
for (var _b = tslib_1.__values(Object.keys(ctx)), _c = _b.next(); !_c.done; _c = _b.next()) {
var propName = _c.value;
// tslint:disable-next-line:no-any
((/** @type {?} */ ((/** @type {?} */ (this.inputViewRef)).context)))[propName] = this.nzStringTemplateOutletContext[propName];
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_2) throw e_2.error; }
}
};
/**
* @param {?} changes
* @return {?}
*/
NzStringTemplateOutletDirective.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
/** @type {?} */
var recreateView = this.shouldRecreateView(changes);
if (recreateView) {
if (this.viewContainer) {
this.viewContainer.clear();
this.defaultViewRef = null;
this.inputViewRef = null;
}
this.recreateView();
}
else {
if (this.inputViewRef && this.nzStringTemplateOutletContext) {
this.updateExistingContext(this.nzStringTemplateOutletContext);
}
}
};
NzStringTemplateOutletDirective.decorators = [
{ type: Directive, args: [{
selector: '[nzStringTemplateOutlet]',
exportAs: 'nzStringTemplateOutlet'
},] }
];
/** @nocollapse */
NzStringTemplateOutletDirective.ctorParameters = function () { return [
{ type: ViewContainerRef },
{ type: TemplateRef }
]; };
NzStringTemplateOutletDirective.propDecorators = {
nzStringTemplateOutletContext: [{ type: Input }],
nzStringTemplateOutlet: [{ type: Input }]
};
return NzStringTemplateOutletDirective;
}());
export { NzStringTemplateOutletDirective };
if (false) {
/**
* @type {?}
* @private
*/
NzStringTemplateOutletDirective.prototype.isTemplate;
/**
* @type {?}
* @private
*/
NzStringTemplateOutletDirective.prototype.inputTemplate;
/**
* @type {?}
* @private
*/
NzStringTemplateOutletDirective.prototype.inputViewRef;
/**
* @type {?}
* @private
*/
NzStringTemplateOutletDirective.prototype.defaultViewRef;
/** @type {?} */
NzStringTemplateOutletDirective.prototype.nzStringTemplateOutletContext;
/**
* @type {?}
* @private
*/
NzStringTemplateOutletDirective.prototype.viewContainer;
/**
* @type {?}
* @private
*/
NzStringTemplateOutletDirective.prototype.defaultTemplate;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"string_template_outlet.js","sourceRoot":"ng://ng-zorro-antd/core/addon/","sources":["string_template_outlet.ts"],"names":[],"mappings":";;;;;;;;;;;;AAQA,OAAO,EACL,SAAS,EAET,KAAK,EAIL,WAAW,EACX,gBAAgB,EACjB,MAAM,eAAe,CAAC;AAEvB;IAmGE,yCAAoB,aAA+B,EAAU,eAAkC;QAA3E,kBAAa,GAAb,aAAa,CAAkB;QAAU,oBAAe,GAAf,eAAe,CAAmB;;QA5FvF,kBAAa,GAA4B,IAAI,CAAC;QAC9C,iBAAY,GAAiC,IAAI,CAAC;QAClD,mBAAc,GAAiC,IAAI,CAAC;;QAGnD,kCAA6B,GAAe,IAAI,CAAC;IAuFwC,CAAC;IArFnG,sBAEI,mEAAsB;;;;;QAF1B,UAE2B,KAAgC;YACzD,IAAI,KAAK,YAAY,WAAW,EAAE;gBAChC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBACvB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;aAC5B;iBAAM;gBACL,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;aACzB;QACH,CAAC;;;OAAA;;;;IAED,sDAAY;;;IAAZ;QACE,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACpB,iDAAiD;YACjD,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;gBACxB,IAAI,IAAI,CAAC,eAAe,EAAE;oBACxB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,aAAa,CAAC,kBAAkB,CACzD,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,6BAA6B,CACnC,CAAC;iBACH;aACF;SACF;aAAM;YACL,oDAAoD;YACpD,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;gBACtB,IAAI,IAAI,CAAC,aAAa,EAAE;oBACtB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,kBAAkB,CACvD,IAAI,CAAC,aAAa,EAClB,IAAI,CAAC,6BAA6B,CACnC,CAAC;iBACH;aACF;SACF;IACH,CAAC;IAED,kCAAkC;;;;;;;IAC1B,iDAAO;;;;;;;IAAf,UAAgB,KAAgC;QAC9C,IAAI,KAAK,YAAY,WAAW,EAAE;YAChC,OAAO,UAAU,CAAC;SACnB;aAAM;YACL,OAAO,QAAQ,CAAC;SACjB;IACH,CAAC;;;;;;IAEO,4DAAkB;;;;;IAA1B,UAA2B,OAAsB;QACvC,IAAA,qEAA6B,EAAE,uDAAsB;;YACzD,oBAAoB,GAAG,KAAK;QAChC,IAAI,sBAAsB,EAAE;YAC1B,IAAI,sBAAsB,CAAC,WAAW,EAAE;gBACtC,oBAAoB,GAAG,IAAI,CAAC;aAC7B;iBAAM;;oBACC,kBAAkB,GAAG,IAAI,CAAC,OAAO,CAAC,sBAAsB,CAAC,aAAa,CAAC;;oBACvE,iBAAiB,GAAG,IAAI,CAAC,OAAO,CAAC,sBAAsB,CAAC,YAAY,CAAC;gBAC3E,oBAAoB,GAAG,CAAC,CAAC,kBAAkB,KAAK,QAAQ,IAAI,iBAAiB,KAAK,QAAQ,CAAC,CAAC;aAC7F;SACF;;YACK,qBAAqB,GACzB,6BAA6B,IAAI,IAAI,CAAC,sBAAsB,CAAC,6BAA6B,CAAC;QAC7F,OAAO,qBAAqB,IAAI,oBAAoB,CAAC;IACvD,CAAC;;;;;;IAEO,gEAAsB;;;;;IAA9B,UAA+B,SAAuB;;;YAC9C,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,IAAI,EAAE,CAAC;;YACxD,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,IAAI,EAAE,CAAC;QAE7D,IAAI,WAAW,CAAC,MAAM,KAAK,WAAW,CAAC,MAAM,EAAE;;gBAC7C,KAAuB,IAAA,gBAAA,iBAAA,WAAW,CAAA,wCAAA,iEAAE;oBAA/B,IAAM,QAAQ,wBAAA;oBACjB,IAAI,WAAW,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE;wBACxC,OAAO,IAAI,CAAC;qBACb;iBACF;;;;;;;;;YACD,OAAO,KAAK,CAAC;SACd;aAAM;YACL,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IAED,kCAAkC;;;;;;;IAC1B,+DAAqB;;;;;;;IAA7B,UAA8B,GAAQ;;;YACpC,KAAuB,IAAA,KAAA,iBAAA,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA,gBAAA,4BAAE;gBAApC,IAAM,QAAQ,WAAA;gBACjB,kCAAkC;gBAClC,CAAC,mBAAA,mBAAA,IAAI,CAAC,YAAY,EAAC,CAAC,OAAO,EAAO,CAAC,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,6BAA6B,CAAC,QAAQ,CAAC,CAAC;aAC9F;;;;;;;;;IACH,CAAC;;;;;IAID,qDAAW;;;;IAAX,UAAY,OAAsB;;YAC1B,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC;QACrD,IAAI,YAAY,EAAE;YAChB,IAAI,IAAI,CAAC,aAAa,EAAE;gBACtB,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;gBAC3B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;gBAC3B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;aAC1B;YACD,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;aAAM;YACL,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,6BAA6B,EAAE;gBAC3D,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;aAChE;SACF;IACH,CAAC;;gBAnHF,SAAS,SAAC;oBACT,QAAQ,EAAE,0BAA0B;oBACpC,QAAQ,EAAE,wBAAwB;iBACnC;;;;gBANC,gBAAgB;gBADhB,WAAW;;;gDAgBV,KAAK;yCAEL,KAAK;;IAsGR,sCAAC;CAAA,AApHD,IAoHC;SAhHY,+BAA+B;;;;;;IAC1C,qDAA4B;;;;;IAE5B,wDAAsD;;;;;IACtD,uDAA0D;;;;;IAC1D,yDAA4D;;IAG5D,wEAA0D;;;;;IAuF9C,wDAAuC;;;;;IAAE,0DAA0C","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport {\n  Directive,\n  EmbeddedViewRef,\n  Input,\n  OnChanges,\n  SimpleChange,\n  SimpleChanges,\n  TemplateRef,\n  ViewContainerRef\n} from '@angular/core';\n\n@Directive({\n  selector: '[nzStringTemplateOutlet]',\n  exportAs: 'nzStringTemplateOutlet'\n})\nexport class NzStringTemplateOutletDirective implements OnChanges {\n  private isTemplate: boolean;\n  // tslint:disable-next-line:no-any\n  private inputTemplate: TemplateRef<any> | null = null;\n  private inputViewRef: EmbeddedViewRef<void> | null = null;\n  private defaultViewRef: EmbeddedViewRef<void> | null = null;\n\n  // tslint:disable-next-line:no-any\n  @Input() nzStringTemplateOutletContext: any | null = null;\n\n  @Input()\n  // tslint:disable-next-line:no-any\n  set nzStringTemplateOutlet(value: string | TemplateRef<any>) {\n    if (value instanceof TemplateRef) {\n      this.isTemplate = true;\n      this.inputTemplate = value;\n    } else {\n      this.isTemplate = false;\n    }\n  }\n\n  recreateView(): void {\n    if (!this.isTemplate) {\n      /** use default template when input is string **/\n      if (!this.defaultViewRef) {\n        if (this.defaultTemplate) {\n          this.defaultViewRef = this.viewContainer.createEmbeddedView(\n            this.defaultTemplate,\n            this.nzStringTemplateOutletContext\n          );\n        }\n      }\n    } else {\n      /** use input template when input is templateRef **/\n      if (!this.inputViewRef) {\n        if (this.inputTemplate) {\n          this.inputViewRef = this.viewContainer.createEmbeddedView(\n            this.inputTemplate,\n            this.nzStringTemplateOutletContext\n          );\n        }\n      }\n    }\n  }\n\n  // tslint:disable-next-line:no-any\n  private getType(value: string | TemplateRef<any>): 'template' | 'string' {\n    if (value instanceof TemplateRef) {\n      return 'template';\n    } else {\n      return 'string';\n    }\n  }\n\n  private shouldRecreateView(changes: SimpleChanges): boolean {\n    const { nzStringTemplateOutletContext, nzStringTemplateOutlet } = changes;\n    let shouldOutletRecreate = false;\n    if (nzStringTemplateOutlet) {\n      if (nzStringTemplateOutlet.firstChange) {\n        shouldOutletRecreate = true;\n      } else {\n        const previousOutletType = this.getType(nzStringTemplateOutlet.previousValue);\n        const currentOutletType = this.getType(nzStringTemplateOutlet.currentValue);\n        shouldOutletRecreate = !(previousOutletType === 'string' && currentOutletType === 'string');\n      }\n    }\n    const shouldContextRecreate =\n      nzStringTemplateOutletContext && this.hasContextShapeChanged(nzStringTemplateOutletContext);\n    return shouldContextRecreate || shouldOutletRecreate;\n  }\n\n  private hasContextShapeChanged(ctxChange: SimpleChange): boolean {\n    const prevCtxKeys = Object.keys(ctxChange.previousValue || {});\n    const currCtxKeys = Object.keys(ctxChange.currentValue || {});\n\n    if (prevCtxKeys.length === currCtxKeys.length) {\n      for (const propName of currCtxKeys) {\n        if (prevCtxKeys.indexOf(propName) === -1) {\n          return true;\n        }\n      }\n      return false;\n    } else {\n      return true;\n    }\n  }\n\n  // tslint:disable-next-line:no-any\n  private updateExistingContext(ctx: any): void {\n    for (const propName of Object.keys(ctx)) {\n      // tslint:disable-next-line:no-any\n      (this.inputViewRef!.context as any)[propName] = this.nzStringTemplateOutletContext[propName];\n    }\n  }\n\n  constructor(private viewContainer: ViewContainerRef, private defaultTemplate: TemplateRef<void>) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const recreateView = this.shouldRecreateView(changes);\n    if (recreateView) {\n      if (this.viewContainer) {\n        this.viewContainer.clear();\n        this.defaultViewRef = null;\n        this.inputViewRef = null;\n      }\n      this.recreateView();\n    } else {\n      if (this.inputViewRef && this.nzStringTemplateOutletContext) {\n        this.updateExistingContext(this.nzStringTemplateOutletContext);\n      }\n    }\n  }\n}\n"]}