template.js 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. "use strict";
  2. /*!
  3. * devextreme-angular
  4. * Version: 19.1.16
  5. * Build date: Tue Oct 18 2022
  6. *
  7. * Copyright (c) 2012 - 2022 Developer Express Inc. ALL RIGHTS RESERVED
  8. *
  9. * This software may be modified and distributed under the terms
  10. * of the MIT license. See the LICENSE file in the root of the project for details.
  11. *
  12. * https://github.com/DevExpress/devextreme-angular
  13. */
  14. Object.defineProperty(exports, "__esModule", { value: true });
  15. var core_1 = require("@angular/core");
  16. var template_host_1 = require("./template-host");
  17. var utils_1 = require("./utils");
  18. var events = require("devextreme/events");
  19. exports.DX_TEMPLATE_WRAPPER_CLASS = 'dx-template-wrapper';
  20. var RenderData = (function () {
  21. function RenderData() {
  22. }
  23. return RenderData;
  24. }());
  25. exports.RenderData = RenderData;
  26. var DxTemplateDirective = (function () {
  27. function DxTemplateDirective(templateRef, viewContainerRef, templateHost, renderer, zone) {
  28. this.templateRef = templateRef;
  29. this.viewContainerRef = viewContainerRef;
  30. this.renderer = renderer;
  31. this.zone = zone;
  32. templateHost.setTemplate(this);
  33. }
  34. Object.defineProperty(DxTemplateDirective.prototype, "dxTemplateOf", {
  35. set: function (value) {
  36. this.name = value;
  37. },
  38. enumerable: true,
  39. configurable: true
  40. });
  41. ;
  42. DxTemplateDirective.prototype.renderTemplate = function (renderData) {
  43. var _this = this;
  44. var childView = this.viewContainerRef.createEmbeddedView(this.templateRef, {
  45. '$implicit': renderData.model,
  46. index: renderData.index
  47. });
  48. var container = utils_1.getElement(renderData.container);
  49. if (renderData.container) {
  50. childView.rootNodes.forEach(function (element) {
  51. _this.renderer.appendChild(container, element);
  52. });
  53. }
  54. return childView;
  55. };
  56. DxTemplateDirective.prototype.render = function (renderData) {
  57. var _this = this;
  58. var childView;
  59. if (this.zone.isStable) {
  60. childView = this.zone.run(function () {
  61. return _this.renderTemplate(renderData);
  62. });
  63. }
  64. else {
  65. childView = this.renderTemplate(renderData);
  66. // =========== WORKAROUND =============
  67. // https://github.com/angular/angular/issues/12243
  68. childView['detectChanges']();
  69. // =========== /WORKAROUND =============
  70. }
  71. childView.rootNodes.forEach(function (element) {
  72. if (element.nodeType === 1) {
  73. _this.renderer.addClass(element, exports.DX_TEMPLATE_WRAPPER_CLASS);
  74. }
  75. events.one(element, 'dxremove', function (_a, params) {
  76. if (!params || !params._angularIntegration) {
  77. childView.destroy();
  78. }
  79. });
  80. });
  81. return childView.rootNodes;
  82. };
  83. DxTemplateDirective.decorators = [
  84. { type: core_1.Directive, args: [{
  85. selector: '[dxTemplate]'
  86. },] },
  87. ];
  88. /** @nocollapse */
  89. DxTemplateDirective.ctorParameters = function () { return [
  90. { type: core_1.TemplateRef, },
  91. { type: core_1.ViewContainerRef, },
  92. { type: template_host_1.DxTemplateHost, },
  93. { type: core_1.Renderer2, },
  94. { type: core_1.NgZone, },
  95. ]; };
  96. DxTemplateDirective.propDecorators = {
  97. "dxTemplateOf": [{ type: core_1.Input },],
  98. };
  99. return DxTemplateDirective;
  100. }());
  101. exports.DxTemplateDirective = DxTemplateDirective;
  102. var DxTemplateModule = (function () {
  103. function DxTemplateModule() {
  104. }
  105. DxTemplateModule.decorators = [
  106. { type: core_1.NgModule, args: [{
  107. declarations: [DxTemplateDirective],
  108. exports: [DxTemplateDirective]
  109. },] },
  110. ];
  111. return DxTemplateModule;
  112. }());
  113. exports.DxTemplateModule = DxTemplateModule;
  114. //# sourceMappingURL=template.js.map