@ngrx/entity 7.3.0 → 7.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (50) hide show
  1. package/bundles/entity.umd.js +4 -4
  2. package/bundles/entity.umd.min.js +2 -2
  3. package/bundles/entity.umd.min.js.map +1 -1
  4. package/esm2015/entity.js +0 -1
  5. package/esm2015/index.js +1 -2
  6. package/esm2015/public_api.js +1 -2
  7. package/esm2015/src/create_adapter.js +7 -4
  8. package/esm2015/src/entity_state.js +2 -3
  9. package/esm2015/src/index.js +1 -2
  10. package/esm2015/src/models.js +161 -94
  11. package/esm2015/src/sorted_state_adapter.js +38 -14
  12. package/esm2015/src/state_adapter.js +11 -6
  13. package/esm2015/src/state_selectors.js +27 -7
  14. package/esm2015/src/unsorted_state_adapter.js +49 -15
  15. package/esm2015/src/utils.js +2 -3
  16. package/esm5/entity.js +0 -1
  17. package/esm5/index.js +0 -1
  18. package/esm5/public_api.js +0 -1
  19. package/esm5/src/create_adapter.js +0 -1
  20. package/esm5/src/entity_state.js +0 -1
  21. package/esm5/src/index.js +0 -1
  22. package/esm5/src/models.js +0 -1
  23. package/esm5/src/sorted_state_adapter.js +0 -1
  24. package/esm5/src/state_adapter.js +0 -1
  25. package/esm5/src/state_selectors.js +0 -1
  26. package/esm5/src/unsorted_state_adapter.js +0 -1
  27. package/esm5/src/utils.js +0 -1
  28. package/fesm2015/entity.js +137 -42
  29. package/fesm2015/entity.js.map +1 -1
  30. package/fesm5/entity.js +1 -1
  31. package/migrations/6_0_0/index.js +2 -2
  32. package/package.json +2 -2
  33. package/schematics/ng-add/index.js +6 -6
  34. package/schematics-core/index.d.ts +1 -2
  35. package/schematics-core/index.js +4 -5
  36. package/schematics-core/utility/ast-utils.d.ts +10 -0
  37. package/schematics-core/utility/ast-utils.js +153 -154
  38. package/schematics-core/utility/change.js +39 -46
  39. package/schematics-core/utility/config.js +8 -8
  40. package/schematics-core/utility/find-module.js +22 -22
  41. package/schematics-core/utility/ngrx-utils.d.ts +2 -0
  42. package/schematics-core/utility/ngrx-utils.js +83 -142
  43. package/schematics-core/utility/package.js +3 -3
  44. package/schematics-core/utility/parse-name.js +4 -4
  45. package/schematics-core/utility/project.js +11 -8
  46. package/schematics-core/utility/strings.d.ts +12 -0
  47. package/schematics-core/utility/strings.js +27 -12
  48. package/schematics-core/utility/update.js +13 -13
  49. package/schematics-core/utility/route-utils.d.ts +0 -20
  50. package/schematics-core/utility/route-utils.js +0 -84
@@ -1,40 +1,10 @@
1
- var __values = (this && this.__values) || function (o) {
2
- var m = typeof Symbol === "function" && o[Symbol.iterator], i = 0;
3
- if (m) return m.call(o);
4
- return {
5
- next: function () {
6
- if (o && i >= o.length) o = void 0;
7
- return { value: o && o[i++], done: !o };
8
- }
9
- };
10
- };
11
- var __read = (this && this.__read) || function (o, n) {
12
- var m = typeof Symbol === "function" && o[Symbol.iterator];
13
- if (!m) return o;
14
- var i = m.call(o), r, ar = [], e;
15
- try {
16
- while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
17
- }
18
- catch (error) { e = { error: error }; }
19
- finally {
20
- try {
21
- if (r && !r.done && (m = i["return"])) m.call(i);
22
- }
23
- finally { if (e) throw e.error; }
24
- }
25
- return ar;
26
- };
27
- var __spread = (this && this.__spread) || function () {
28
- for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));
29
- return ar;
30
- };
31
1
  (function (factory) {
32
2
  if (typeof module === "object" && typeof module.exports === "object") {
33
3
  var v = factory(require, exports);
34
4
  if (v !== undefined) module.exports = v;
35
5
  }
36
6
  else if (typeof define === "function" && define.amd) {
37
- define("@ngrx/entity/schematics-core/utility/ast-utils", ["require", "exports", "typescript", "@ngrx/entity/schematics-core/utility/change", "@ngrx/entity/schematics-core/utility/route-utils"], factory);
7
+ define("@ngrx/entity/schematics-core/utility/ast-utils", ["require", "exports", "typescript", "@ngrx/entity/schematics-core/utility/change"], factory);
38
8
  }
39
9
  })(function (require, exports) {
40
10
  "use strict";
@@ -47,9 +17,8 @@ var __spread = (this && this.__spread) || function () {
47
17
  * Use of this source code is governed by an MIT-style license that can be
48
18
  * found in the LICENSE file at https://angular.io/license
49
19
  */
50
- var ts = require("typescript");
51
- var change_1 = require("@ngrx/entity/schematics-core/utility/change");
52
- var route_utils_1 = require("@ngrx/entity/schematics-core/utility/route-utils");
20
+ const ts = require("typescript");
21
+ const change_1 = require("@ngrx/entity/schematics-core/utility/change");
53
22
  /**
54
23
  * Find all nodes from the AST in the subtree of node of SyntaxKind kind.
55
24
  * @param node
@@ -57,39 +26,27 @@ var __spread = (this && this.__spread) || function () {
57
26
  * @param max The maximum number of items to return.
58
27
  * @return all nodes of kind, or [] if none is found
59
28
  */
60
- function findNodes(node, kind, max) {
61
- if (max === void 0) { max = Infinity; }
62
- var e_1, _a;
29
+ function findNodes(node, kind, max = Infinity) {
63
30
  if (!node || max == 0) {
64
31
  return [];
65
32
  }
66
- var arr = [];
33
+ const arr = [];
67
34
  if (node.kind === kind) {
68
35
  arr.push(node);
69
36
  max--;
70
37
  }
71
38
  if (max > 0) {
72
- try {
73
- for (var _b = __values(node.getChildren()), _c = _b.next(); !_c.done; _c = _b.next()) {
74
- var child = _c.value;
75
- findNodes(child, kind, max).forEach(function (node) {
76
- if (max > 0) {
77
- arr.push(node);
78
- }
79
- max--;
80
- });
81
- if (max <= 0) {
82
- break;
39
+ for (const child of node.getChildren()) {
40
+ findNodes(child, kind, max).forEach(node => {
41
+ if (max > 0) {
42
+ arr.push(node);
83
43
  }
44
+ max--;
45
+ });
46
+ if (max <= 0) {
47
+ break;
84
48
  }
85
49
  }
86
- catch (e_1_1) { e_1 = { error: e_1_1 }; }
87
- finally {
88
- try {
89
- if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
90
- }
91
- finally { if (e_1) throw e_1.error; }
92
- }
93
50
  }
94
51
  return arr;
95
52
  }
@@ -100,14 +57,14 @@ var __spread = (this && this.__spread) || function () {
100
57
  * @returns {Observable<ts.Node>} An observable of all the nodes in the source.
101
58
  */
102
59
  function getSourceNodes(sourceFile) {
103
- var nodes = [sourceFile];
104
- var result = [];
60
+ const nodes = [sourceFile];
61
+ const result = [];
105
62
  while (nodes.length > 0) {
106
- var node = nodes.shift();
63
+ const node = nodes.shift();
107
64
  if (node) {
108
65
  result.push(node);
109
66
  if (node.getChildCount(sourceFile) >= 0) {
110
- nodes.unshift.apply(nodes, __spread(node.getChildren()));
67
+ nodes.unshift(...node.getChildren());
111
68
  }
112
69
  }
113
70
  }
@@ -135,7 +92,7 @@ var __spread = (this && this.__spread) || function () {
135
92
  * @throw Error if toInsert is first occurence but fall back is not set
136
93
  */
137
94
  function insertAfterLastOccurrence(nodes, toInsert, file, fallbackPos, syntaxKind) {
138
- var lastItem = nodes.sort(nodesByPosition).pop();
95
+ let lastItem = nodes.sort(nodesByPosition).pop();
139
96
  if (!lastItem) {
140
97
  throw new Error();
141
98
  }
@@ -145,9 +102,9 @@ var __spread = (this && this.__spread) || function () {
145
102
  .pop();
146
103
  }
147
104
  if (!lastItem && fallbackPos == undefined) {
148
- throw new Error("tried to insert " + toInsert + " as first occurence with no fallback position");
105
+ throw new Error(`tried to insert ${toInsert} as first occurence with no fallback position`);
149
106
  }
150
- var lastItemPosition = lastItem ? lastItem.end : fallbackPos;
107
+ const lastItemPosition = lastItem ? lastItem.end : fallbackPos;
151
108
  return new change_1.InsertChange(file, lastItemPosition, toInsert);
152
109
  }
153
110
  exports.insertAfterLastOccurrence = insertAfterLastOccurrence;
@@ -164,9 +121,8 @@ var __spread = (this && this.__spread) || function () {
164
121
  }
165
122
  exports.getContentOfKeyLiteral = getContentOfKeyLiteral;
166
123
  function _angularImportsFromNode(node, _sourceFile) {
167
- var _a;
168
- var ms = node.moduleSpecifier;
169
- var modulePath;
124
+ const ms = node.moduleSpecifier;
125
+ let modulePath;
170
126
  switch (ms.kind) {
171
127
  case ts.SyntaxKind.StringLiteral:
172
128
  modulePath = ms.text;
@@ -183,21 +139,19 @@ var __spread = (this && this.__spread) || function () {
183
139
  return {};
184
140
  }
185
141
  else if (node.importClause.namedBindings) {
186
- var nb = node.importClause.namedBindings;
142
+ const nb = node.importClause.namedBindings;
187
143
  if (nb.kind == ts.SyntaxKind.NamespaceImport) {
188
144
  // This is of the form `import * as name from 'path'`. Return `name.`.
189
- return _a = {},
190
- _a[nb.name.text + '.'] = modulePath,
191
- _a;
145
+ return {
146
+ [nb.name.text + '.']: modulePath,
147
+ };
192
148
  }
193
149
  else {
194
150
  // This is of the form `import {a,b,c} from 'path'`
195
- var namedImports = nb;
151
+ const namedImports = nb;
196
152
  return namedImports.elements
197
- .map(function (is) {
198
- return is.propertyName ? is.propertyName.text : is.name.text;
199
- })
200
- .reduce(function (acc, curr) {
153
+ .map((is) => is.propertyName ? is.propertyName.text : is.name.text)
154
+ .reduce((acc, curr) => {
201
155
  acc[curr] = modulePath;
202
156
  return acc;
203
157
  }, {});
@@ -211,71 +165,58 @@ var __spread = (this && this.__spread) || function () {
211
165
  }
212
166
  }
213
167
  function getDecoratorMetadata(source, identifier, module) {
214
- var angularImports = findNodes(source, ts.SyntaxKind.ImportDeclaration)
215
- .map(function (node) { return _angularImportsFromNode(node, source); })
216
- .reduce(function (acc, current) {
217
- var e_2, _a;
218
- try {
219
- for (var _b = __values(Object.keys(current)), _c = _b.next(); !_c.done; _c = _b.next()) {
220
- var key = _c.value;
221
- acc[key] = current[key];
222
- }
223
- }
224
- catch (e_2_1) { e_2 = { error: e_2_1 }; }
225
- finally {
226
- try {
227
- if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
228
- }
229
- finally { if (e_2) throw e_2.error; }
168
+ const angularImports = findNodes(source, ts.SyntaxKind.ImportDeclaration)
169
+ .map(node => _angularImportsFromNode(node, source))
170
+ .reduce((acc, current) => {
171
+ for (const key of Object.keys(current)) {
172
+ acc[key] = current[key];
230
173
  }
231
174
  return acc;
232
175
  }, {});
233
176
  return getSourceNodes(source)
234
- .filter(function (node) {
177
+ .filter(node => {
235
178
  return (node.kind == ts.SyntaxKind.Decorator &&
236
179
  node.expression.kind == ts.SyntaxKind.CallExpression);
237
180
  })
238
- .map(function (node) { return node.expression; })
239
- .filter(function (expr) {
181
+ .map(node => node.expression)
182
+ .filter(expr => {
240
183
  if (expr.expression.kind == ts.SyntaxKind.Identifier) {
241
- var id = expr.expression;
184
+ const id = expr.expression;
242
185
  return (id.getFullText(source) == identifier &&
243
186
  angularImports[id.getFullText(source)] === module);
244
187
  }
245
188
  else if (expr.expression.kind == ts.SyntaxKind.PropertyAccessExpression) {
246
189
  // This covers foo.NgModule when importing * as foo.
247
- var paExpr = expr.expression;
190
+ const paExpr = expr.expression;
248
191
  // If the left expression is not an identifier, just give up at that point.
249
192
  if (paExpr.expression.kind !== ts.SyntaxKind.Identifier) {
250
193
  return false;
251
194
  }
252
- var id = paExpr.name.text;
253
- var moduleId = paExpr.expression.getText(source);
195
+ const id = paExpr.name.text;
196
+ const moduleId = paExpr.expression.getText(source);
254
197
  return id === identifier && angularImports[moduleId + '.'] === module;
255
198
  }
256
199
  return false;
257
200
  })
258
- .filter(function (expr) {
259
- return expr.arguments[0] &&
260
- expr.arguments[0].kind == ts.SyntaxKind.ObjectLiteralExpression;
261
- })
262
- .map(function (expr) { return expr.arguments[0]; });
201
+ .filter(expr => expr.arguments[0] &&
202
+ expr.arguments[0].kind == ts.SyntaxKind.ObjectLiteralExpression)
203
+ .map(expr => expr.arguments[0]);
263
204
  }
264
205
  exports.getDecoratorMetadata = getDecoratorMetadata;
265
206
  function _addSymbolToNgModuleMetadata(source, ngModulePath, metadataField, symbolName, importPath) {
266
- var nodes = getDecoratorMetadata(source, 'NgModule', '@angular/core');
267
- var node = nodes[0]; // tslint:disable-line:no-any
207
+ const nodes = getDecoratorMetadata(source, 'NgModule', '@angular/core');
208
+ let node = nodes[0]; // tslint:disable-line:no-any
268
209
  // Find the decorator declaration.
269
210
  if (!node) {
270
211
  return [];
271
212
  }
272
213
  // Get all the children property assignment of object literals.
273
- var matchingProperties = node.properties
274
- .filter(function (prop) { return prop.kind == ts.SyntaxKind.PropertyAssignment; })
214
+ const matchingProperties = node.properties
215
+ .filter(prop => prop.kind == ts.SyntaxKind.PropertyAssignment)
275
216
  // Filter out every fields that's not "metadataField". Also handles string literals
276
217
  // (but not expressions).
277
- .filter(function (prop) {
278
- var name = prop.name;
218
+ .filter((prop) => {
219
+ const name = prop.name;
279
220
  switch (name.kind) {
280
221
  case ts.SyntaxKind.Identifier:
281
222
  return name.getText(source) == metadataField;
@@ -290,36 +231,36 @@ var __spread = (this && this.__spread) || function () {
290
231
  }
291
232
  if (matchingProperties.length == 0) {
292
233
  // We haven't found the field in the metadata declaration. Insert a new field.
293
- var expr = node;
294
- var position_1;
295
- var toInsert_1;
234
+ const expr = node;
235
+ let position;
236
+ let toInsert;
296
237
  if (expr.properties.length == 0) {
297
- position_1 = expr.getEnd() - 1;
298
- toInsert_1 = " " + metadataField + ": [" + symbolName + "]\n";
238
+ position = expr.getEnd() - 1;
239
+ toInsert = ` ${metadataField}: [${symbolName}]\n`;
299
240
  }
300
241
  else {
301
242
  node = expr.properties[expr.properties.length - 1];
302
- position_1 = node.getEnd();
243
+ position = node.getEnd();
303
244
  // Get the indentation of the last element, if any.
304
- var text = node.getFullText(source);
305
- var matches = text.match(/^\r?\n\s*/);
245
+ const text = node.getFullText(source);
246
+ const matches = text.match(/^\r?\n\s*/);
306
247
  if (matches.length > 0) {
307
- toInsert_1 = "," + matches[0] + metadataField + ": [" + symbolName + "]";
248
+ toInsert = `,${matches[0]}${metadataField}: [${symbolName}]`;
308
249
  }
309
250
  else {
310
- toInsert_1 = ", " + metadataField + ": [" + symbolName + "]";
251
+ toInsert = `, ${metadataField}: [${symbolName}]`;
311
252
  }
312
253
  }
313
- var newMetadataProperty = new change_1.InsertChange(ngModulePath, position_1, toInsert_1);
314
- var newMetadataImport = route_utils_1.insertImport(source, ngModulePath, symbolName.replace(/\..*$/, ''), importPath);
254
+ const newMetadataProperty = new change_1.InsertChange(ngModulePath, position, toInsert);
255
+ const newMetadataImport = insertImport(source, ngModulePath, symbolName.replace(/\..*$/, ''), importPath);
315
256
  return [newMetadataProperty, newMetadataImport];
316
257
  }
317
- var assignment = matchingProperties[0];
258
+ const assignment = matchingProperties[0];
318
259
  // If it's not an array, nothing we can do really.
319
260
  if (assignment.initializer.kind !== ts.SyntaxKind.ArrayLiteralExpression) {
320
261
  return [];
321
262
  }
322
- var arrLiteral = assignment.initializer;
263
+ const arrLiteral = assignment.initializer;
323
264
  if (arrLiteral.elements.length == 0) {
324
265
  // Forward the property.
325
266
  node = arrLiteral;
@@ -332,41 +273,39 @@ var __spread = (this && this.__spread) || function () {
332
273
  return [];
333
274
  }
334
275
  if (Array.isArray(node)) {
335
- var nodeArray = node;
336
- var symbolsArray = nodeArray.map(function (node) { return node.getText(); });
276
+ const nodeArray = node;
277
+ const symbolsArray = nodeArray.map(node => node.getText());
337
278
  if (symbolsArray.includes(symbolName)) {
338
279
  return [];
339
280
  }
340
281
  node = node[node.length - 1];
341
- var effectsModule = nodeArray.find(function (node) {
342
- return (node.getText().includes('EffectsModule.forRoot') &&
343
- symbolName.includes('EffectsModule.forRoot')) ||
344
- (node.getText().includes('EffectsModule.forFeature') &&
345
- symbolName.includes('EffectsModule.forFeature'));
346
- });
282
+ const effectsModule = nodeArray.find(node => (node.getText().includes('EffectsModule.forRoot') &&
283
+ symbolName.includes('EffectsModule.forRoot')) ||
284
+ (node.getText().includes('EffectsModule.forFeature') &&
285
+ symbolName.includes('EffectsModule.forFeature')));
347
286
  if (effectsModule && symbolName.includes('EffectsModule')) {
348
- var effectsArgs = effectsModule.arguments.shift();
287
+ const effectsArgs = effectsModule.arguments.shift();
349
288
  if (effectsArgs &&
350
289
  effectsArgs.kind === ts.SyntaxKind.ArrayLiteralExpression) {
351
- var effectsElements = effectsArgs
290
+ const effectsElements = effectsArgs
352
291
  .elements;
353
- var _a = __read(symbolName.match(/\[(.*)\]/), 2), effectsSymbol = _a[1];
354
- var epos = void 0;
292
+ const [, effectsSymbol] = symbolName.match(/\[(.*)\]/);
293
+ let epos;
355
294
  if (effectsElements.length === 0) {
356
295
  epos = effectsArgs.getStart() + 1;
357
296
  return [new change_1.InsertChange(ngModulePath, epos, effectsSymbol)];
358
297
  }
359
298
  else {
360
- var lastEffect = effectsElements[effectsElements.length - 1];
299
+ const lastEffect = effectsElements[effectsElements.length - 1];
361
300
  epos = lastEffect.getEnd();
362
301
  // Get the indentation of the last element, if any.
363
- var text = lastEffect.getFullText(source);
364
- var effectInsert = void 0;
302
+ const text = lastEffect.getFullText(source);
303
+ let effectInsert;
365
304
  if (text.match('^\r?\r?\n')) {
366
- effectInsert = "," + text.match(/^\r?\n\s+/)[0] + effectsSymbol;
305
+ effectInsert = `,${text.match(/^\r?\n\s+/)[0]}${effectsSymbol}`;
367
306
  }
368
307
  else {
369
- effectInsert = ", " + effectsSymbol;
308
+ effectInsert = `, ${effectsSymbol}`;
370
309
  }
371
310
  return [new change_1.InsertChange(ngModulePath, epos, effectInsert)];
372
311
  }
@@ -376,46 +315,46 @@ var __spread = (this && this.__spread) || function () {
376
315
  }
377
316
  }
378
317
  }
379
- var toInsert;
380
- var position = node.getEnd();
318
+ let toInsert;
319
+ let position = node.getEnd();
381
320
  if (node.kind == ts.SyntaxKind.ObjectLiteralExpression) {
382
321
  // We haven't found the field in the metadata declaration. Insert a new
383
322
  // field.
384
- var expr = node;
323
+ const expr = node;
385
324
  if (expr.properties.length == 0) {
386
325
  position = expr.getEnd() - 1;
387
- toInsert = " " + metadataField + ": [" + symbolName + "]\n";
326
+ toInsert = ` ${metadataField}: [${symbolName}]\n`;
388
327
  }
389
328
  else {
390
329
  node = expr.properties[expr.properties.length - 1];
391
330
  position = node.getEnd();
392
331
  // Get the indentation of the last element, if any.
393
- var text = node.getFullText(source);
332
+ const text = node.getFullText(source);
394
333
  if (text.match('^\r?\r?\n')) {
395
- toInsert = "," + text.match(/^\r?\n\s+/)[0] + metadataField + ": [" + symbolName + "]";
334
+ toInsert = `,${text.match(/^\r?\n\s+/)[0]}${metadataField}: [${symbolName}]`;
396
335
  }
397
336
  else {
398
- toInsert = ", " + metadataField + ": [" + symbolName + "]";
337
+ toInsert = `, ${metadataField}: [${symbolName}]`;
399
338
  }
400
339
  }
401
340
  }
402
341
  else if (node.kind == ts.SyntaxKind.ArrayLiteralExpression) {
403
342
  // We found the field but it's empty. Insert it just before the `]`.
404
343
  position--;
405
- toInsert = "" + symbolName;
344
+ toInsert = `${symbolName}`;
406
345
  }
407
346
  else {
408
347
  // Get the indentation of the last element, if any.
409
- var text = node.getFullText(source);
348
+ const text = node.getFullText(source);
410
349
  if (text.match(/^\r?\n/)) {
411
- toInsert = "," + text.match(/^\r?\n(\r?)\s+/)[0] + symbolName;
350
+ toInsert = `,${text.match(/^\r?\n(\r?)\s+/)[0]}${symbolName}`;
412
351
  }
413
352
  else {
414
- toInsert = ", " + symbolName;
353
+ toInsert = `, ${symbolName}`;
415
354
  }
416
355
  }
417
- var insert = new change_1.InsertChange(ngModulePath, position, toInsert);
418
- var importInsert = route_utils_1.insertImport(source, ngModulePath, symbolName.replace(/\..*$/, ''), importPath);
356
+ const insert = new change_1.InsertChange(ngModulePath, position, toInsert);
357
+ const importInsert = insertImport(source, ngModulePath, symbolName.replace(/\..*$/, ''), importPath);
419
358
  return [insert, importInsert];
420
359
  }
421
360
  /**
@@ -455,5 +394,65 @@ var __spread = (this && this.__spread) || function () {
455
394
  return _addSymbolToNgModuleMetadata(source, modulePath, 'bootstrap', classifiedName, importPath);
456
395
  }
457
396
  exports.addBootstrapToModule = addBootstrapToModule;
397
+ /**
398
+ * Add Import `import { symbolName } from fileName` if the import doesn't exit
399
+ * already. Assumes fileToEdit can be resolved and accessed.
400
+ * @param fileToEdit (file we want to add import to)
401
+ * @param symbolName (item to import)
402
+ * @param fileName (path to the file)
403
+ * @param isDefault (if true, import follows style for importing default exports)
404
+ * @return Change
405
+ */
406
+ function insertImport(source, fileToEdit, symbolName, fileName, isDefault = false) {
407
+ const rootNode = source;
408
+ const allImports = findNodes(rootNode, ts.SyntaxKind.ImportDeclaration);
409
+ // get nodes that map to import statements from the file fileName
410
+ const relevantImports = allImports.filter(node => {
411
+ // StringLiteral of the ImportDeclaration is the import file (fileName in this case).
412
+ const importFiles = node
413
+ .getChildren()
414
+ .filter(child => child.kind === ts.SyntaxKind.StringLiteral)
415
+ .map(n => n.text);
416
+ return importFiles.filter(file => file === fileName).length === 1;
417
+ });
418
+ if (relevantImports.length > 0) {
419
+ let importsAsterisk = false;
420
+ // imports from import file
421
+ const imports = [];
422
+ relevantImports.forEach(n => {
423
+ Array.prototype.push.apply(imports, findNodes(n, ts.SyntaxKind.Identifier));
424
+ if (findNodes(n, ts.SyntaxKind.AsteriskToken).length > 0) {
425
+ importsAsterisk = true;
426
+ }
427
+ });
428
+ // if imports * from fileName, don't add symbolName
429
+ if (importsAsterisk) {
430
+ return new change_1.NoopChange();
431
+ }
432
+ const importTextNodes = imports.filter(n => n.text === symbolName);
433
+ // insert import if it's not there
434
+ if (importTextNodes.length === 0) {
435
+ const fallbackPos = findNodes(relevantImports[0], ts.SyntaxKind.CloseBraceToken)[0].getStart() ||
436
+ findNodes(relevantImports[0], ts.SyntaxKind.FromKeyword)[0].getStart();
437
+ return insertAfterLastOccurrence(imports, `, ${symbolName}`, fileToEdit, fallbackPos);
438
+ }
439
+ return new change_1.NoopChange();
440
+ }
441
+ // no such import declaration exists
442
+ const useStrict = findNodes(rootNode, ts.SyntaxKind.StringLiteral).filter(n => n.getText() === 'use strict');
443
+ let fallbackPos = 0;
444
+ if (useStrict.length > 0) {
445
+ fallbackPos = useStrict[0].end;
446
+ }
447
+ const open = isDefault ? '' : '{ ';
448
+ const close = isDefault ? '' : ' }';
449
+ // if there are no imports or 'use strict' statement, insert import at beginning of file
450
+ const insertAtBeginning = allImports.length === 0 && useStrict.length === 0;
451
+ const separator = insertAtBeginning ? '' : ';\n';
452
+ const toInsert = `${separator}import ${open}${symbolName}${close}` +
453
+ ` from '${fileName}'${insertAtBeginning ? ';\n' : ''}`;
454
+ return insertAfterLastOccurrence(allImports, toInsert, fileToEdit, fallbackPos, ts.SyntaxKind.StringLiteral);
455
+ }
456
+ exports.insertImport = insertImport;
458
457
  });
459
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ast-utils.js","sourceRoot":"","sources":["../../../../../../../modules/entity/schematics-core/utility/ast-utils.ts"],"names":[],"mappings":"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","sourcesContent":["/* istanbul ignore file */\n/**\n * @license\n * Copyright Google Inc. 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://angular.io/license\n */\nimport * as ts from 'typescript';\nimport { Change, InsertChange } from './change';\nimport { insertImport } from './route-utils';\n\n/**\n * Find all nodes from the AST in the subtree of node of SyntaxKind kind.\n * @param node\n * @param kind\n * @param max The maximum number of items to return.\n * @return all nodes of kind, or [] if none is found\n */\nexport function findNodes(\n  node: ts.Node,\n  kind: ts.SyntaxKind,\n  max = Infinity\n): ts.Node[] {\n  if (!node || max == 0) {\n    return [];\n  }\n\n  const arr: ts.Node[] = [];\n  if (node.kind === kind) {\n    arr.push(node);\n    max--;\n  }\n  if (max > 0) {\n    for (const child of node.getChildren()) {\n      findNodes(child, kind, max).forEach(node => {\n        if (max > 0) {\n          arr.push(node);\n        }\n        max--;\n      });\n\n      if (max <= 0) {\n        break;\n      }\n    }\n  }\n\n  return arr;\n}\n\n/**\n * Get all the nodes from a source.\n * @param sourceFile The source file object.\n * @returns {Observable<ts.Node>} An observable of all the nodes in the source.\n */\nexport function getSourceNodes(sourceFile: ts.SourceFile): ts.Node[] {\n  const nodes: ts.Node[] = [sourceFile];\n  const result = [];\n\n  while (nodes.length > 0) {\n    const node = nodes.shift();\n\n    if (node) {\n      result.push(node);\n      if (node.getChildCount(sourceFile) >= 0) {\n        nodes.unshift(...node.getChildren());\n      }\n    }\n  }\n\n  return result;\n}\n\n/**\n * Helper for sorting nodes.\n * @return function to sort nodes in increasing order of position in sourceFile\n */\nfunction nodesByPosition(first: ts.Node, second: ts.Node): number {\n  return first.pos - second.pos;\n}\n\n/**\n * Insert `toInsert` after the last occurence of `ts.SyntaxKind[nodes[i].kind]`\n * or after the last of occurence of `syntaxKind` if the last occurence is a sub child\n * of ts.SyntaxKind[nodes[i].kind] and save the changes in file.\n *\n * @param nodes insert after the last occurence of nodes\n * @param toInsert string to insert\n * @param file file to insert changes into\n * @param fallbackPos position to insert if toInsert happens to be the first occurence\n * @param syntaxKind the ts.SyntaxKind of the subchildren to insert after\n * @return Change instance\n * @throw Error if toInsert is first occurence but fall back is not set\n */\nexport function insertAfterLastOccurrence(\n  nodes: ts.Node[],\n  toInsert: string,\n  file: string,\n  fallbackPos: number,\n  syntaxKind?: ts.SyntaxKind\n): Change {\n  let lastItem = nodes.sort(nodesByPosition).pop();\n  if (!lastItem) {\n    throw new Error();\n  }\n  if (syntaxKind) {\n    lastItem = findNodes(lastItem, syntaxKind)\n      .sort(nodesByPosition)\n      .pop();\n  }\n  if (!lastItem && fallbackPos == undefined) {\n    throw new Error(\n      `tried to insert ${toInsert} as first occurence with no fallback position`\n    );\n  }\n  const lastItemPosition: number = lastItem ? lastItem.end : fallbackPos;\n\n  return new InsertChange(file, lastItemPosition, toInsert);\n}\n\nexport function getContentOfKeyLiteral(\n  _source: ts.SourceFile,\n  node: ts.Node\n): string | null {\n  if (node.kind == ts.SyntaxKind.Identifier) {\n    return (node as ts.Identifier).text;\n  } else if (node.kind == ts.SyntaxKind.StringLiteral) {\n    return (node as ts.StringLiteral).text;\n  } else {\n    return null;\n  }\n}\n\nfunction _angularImportsFromNode(\n  node: ts.ImportDeclaration,\n  _sourceFile: ts.SourceFile\n): { [name: string]: string } {\n  const ms = node.moduleSpecifier;\n  let modulePath: string;\n  switch (ms.kind) {\n    case ts.SyntaxKind.StringLiteral:\n      modulePath = (ms as ts.StringLiteral).text;\n      break;\n    default:\n      return {};\n  }\n\n  if (!modulePath.startsWith('@angular/')) {\n    return {};\n  }\n\n  if (node.importClause) {\n    if (node.importClause.name) {\n      // This is of the form `import Name from 'path'`. Ignore.\n      return {};\n    } else if (node.importClause.namedBindings) {\n      const nb = node.importClause.namedBindings;\n      if (nb.kind == ts.SyntaxKind.NamespaceImport) {\n        // This is of the form `import * as name from 'path'`. Return `name.`.\n        return {\n          [(nb as ts.NamespaceImport).name.text + '.']: modulePath,\n        };\n      } else {\n        // This is of the form `import {a,b,c} from 'path'`\n        const namedImports = nb as ts.NamedImports;\n\n        return namedImports.elements\n          .map(\n            (is: ts.ImportSpecifier) =>\n              is.propertyName ? is.propertyName.text : is.name.text\n          )\n          .reduce((acc: { [name: string]: string }, curr: string) => {\n            acc[curr] = modulePath;\n\n            return acc;\n          }, {});\n      }\n    }\n\n    return {};\n  } else {\n    // This is of the form `import 'path';`. Nothing to do.\n    return {};\n  }\n}\n\nexport function getDecoratorMetadata(\n  source: ts.SourceFile,\n  identifier: string,\n  module: string\n): ts.Node[] {\n  const angularImports: { [name: string]: string } = findNodes(\n    source,\n    ts.SyntaxKind.ImportDeclaration\n  )\n    .map(node => _angularImportsFromNode(node as ts.ImportDeclaration, source))\n    .reduce(\n      (\n        acc: { [name: string]: string },\n        current: { [name: string]: string }\n      ) => {\n        for (const key of Object.keys(current)) {\n          acc[key] = current[key];\n        }\n\n        return acc;\n      },\n      {}\n    );\n\n  return getSourceNodes(source)\n    .filter(node => {\n      return (\n        node.kind == ts.SyntaxKind.Decorator &&\n        (node as ts.Decorator).expression.kind == ts.SyntaxKind.CallExpression\n      );\n    })\n    .map(node => (node as ts.Decorator).expression as ts.CallExpression)\n    .filter(expr => {\n      if (expr.expression.kind == ts.SyntaxKind.Identifier) {\n        const id = expr.expression as ts.Identifier;\n\n        return (\n          id.getFullText(source) == identifier &&\n          angularImports[id.getFullText(source)] === module\n        );\n      } else if (\n        expr.expression.kind == ts.SyntaxKind.PropertyAccessExpression\n      ) {\n        // This covers foo.NgModule when importing * as foo.\n        const paExpr = expr.expression as ts.PropertyAccessExpression;\n        // If the left expression is not an identifier, just give up at that point.\n        if (paExpr.expression.kind !== ts.SyntaxKind.Identifier) {\n          return false;\n        }\n\n        const id = paExpr.name.text;\n        const moduleId = (paExpr.expression as ts.Identifier).getText(source);\n\n        return id === identifier && angularImports[moduleId + '.'] === module;\n      }\n\n      return false;\n    })\n    .filter(\n      expr =>\n        expr.arguments[0] &&\n        expr.arguments[0].kind == ts.SyntaxKind.ObjectLiteralExpression\n    )\n    .map(expr => expr.arguments[0] as ts.ObjectLiteralExpression);\n}\n\nfunction _addSymbolToNgModuleMetadata(\n  source: ts.SourceFile,\n  ngModulePath: string,\n  metadataField: string,\n  symbolName: string,\n  importPath: string\n): Change[] {\n  const nodes = getDecoratorMetadata(source, 'NgModule', '@angular/core');\n  let node: any = nodes[0]; // tslint:disable-line:no-any\n\n  // Find the decorator declaration.\n  if (!node) {\n    return [];\n  }\n\n  // Get all the children property assignment of object literals.\n  const matchingProperties: ts.ObjectLiteralElement[] = (node as ts.ObjectLiteralExpression).properties\n    .filter(prop => prop.kind == ts.SyntaxKind.PropertyAssignment)\n    // Filter out every fields that's not \"metadataField\". Also handles string literals\n    // (but not expressions).\n    .filter((prop: any) => {\n      const name = prop.name;\n      switch (name.kind) {\n        case ts.SyntaxKind.Identifier:\n          return (name as ts.Identifier).getText(source) == metadataField;\n        case ts.SyntaxKind.StringLiteral:\n          return (name as ts.StringLiteral).text == metadataField;\n      }\n\n      return false;\n    });\n\n  // Get the last node of the array literal.\n  if (!matchingProperties) {\n    return [];\n  }\n  if (matchingProperties.length == 0) {\n    // We haven't found the field in the metadata declaration. Insert a new field.\n    const expr = node as ts.ObjectLiteralExpression;\n    let position: number;\n    let toInsert: string;\n    if (expr.properties.length == 0) {\n      position = expr.getEnd() - 1;\n      toInsert = `  ${metadataField}: [${symbolName}]\\n`;\n    } else {\n      node = expr.properties[expr.properties.length - 1];\n      position = node.getEnd();\n      // Get the indentation of the last element, if any.\n      const text = node.getFullText(source);\n      const matches = text.match(/^\\r?\\n\\s*/);\n      if (matches.length > 0) {\n        toInsert = `,${matches[0]}${metadataField}: [${symbolName}]`;\n      } else {\n        toInsert = `, ${metadataField}: [${symbolName}]`;\n      }\n    }\n    const newMetadataProperty = new InsertChange(\n      ngModulePath,\n      position,\n      toInsert\n    );\n    const newMetadataImport = insertImport(\n      source,\n      ngModulePath,\n      symbolName.replace(/\\..*$/, ''),\n      importPath\n    );\n\n    return [newMetadataProperty, newMetadataImport];\n  }\n\n  const assignment = matchingProperties[0] as ts.PropertyAssignment;\n\n  // If it's not an array, nothing we can do really.\n  if (assignment.initializer.kind !== ts.SyntaxKind.ArrayLiteralExpression) {\n    return [];\n  }\n\n  const arrLiteral = assignment.initializer as ts.ArrayLiteralExpression;\n  if (arrLiteral.elements.length == 0) {\n    // Forward the property.\n    node = arrLiteral;\n  } else {\n    node = arrLiteral.elements;\n  }\n\n  if (!node) {\n    console.log(\n      'No app module found. Please add your new class to your component.'\n    );\n\n    return [];\n  }\n\n  if (Array.isArray(node)) {\n    const nodeArray = (node as {}) as Array<ts.Node>;\n    const symbolsArray = nodeArray.map(node => node.getText());\n    if (symbolsArray.includes(symbolName)) {\n      return [];\n    }\n\n    node = node[node.length - 1];\n\n    const effectsModule = nodeArray.find(\n      node =>\n        (node.getText().includes('EffectsModule.forRoot') &&\n          symbolName.includes('EffectsModule.forRoot')) ||\n        (node.getText().includes('EffectsModule.forFeature') &&\n          symbolName.includes('EffectsModule.forFeature'))\n    );\n\n    if (effectsModule && symbolName.includes('EffectsModule')) {\n      const effectsArgs = (effectsModule as any).arguments.shift();\n\n      if (\n        effectsArgs &&\n        effectsArgs.kind === ts.SyntaxKind.ArrayLiteralExpression\n      ) {\n        const effectsElements = (effectsArgs as ts.ArrayLiteralExpression)\n          .elements;\n        const [, effectsSymbol] = (<any>symbolName).match(/\\[(.*)\\]/);\n\n        let epos;\n        if (effectsElements.length === 0) {\n          epos = effectsArgs.getStart() + 1;\n          return [new InsertChange(ngModulePath, epos, effectsSymbol)];\n        } else {\n          const lastEffect = effectsElements[\n            effectsElements.length - 1\n          ] as ts.Expression;\n          epos = lastEffect.getEnd();\n          // Get the indentation of the last element, if any.\n          const text: any = lastEffect.getFullText(source);\n\n          let effectInsert: string;\n          if (text.match('^\\r?\\r?\\n')) {\n            effectInsert = `,${text.match(/^\\r?\\n\\s+/)[0]}${effectsSymbol}`;\n          } else {\n            effectInsert = `, ${effectsSymbol}`;\n          }\n\n          return [new InsertChange(ngModulePath, epos, effectInsert)];\n        }\n      } else {\n        return [];\n      }\n    }\n  }\n\n  let toInsert: string;\n  let position = node.getEnd();\n  if (node.kind == ts.SyntaxKind.ObjectLiteralExpression) {\n    // We haven't found the field in the metadata declaration. Insert a new\n    // field.\n    const expr = node as ts.ObjectLiteralExpression;\n    if (expr.properties.length == 0) {\n      position = expr.getEnd() - 1;\n      toInsert = `  ${metadataField}: [${symbolName}]\\n`;\n    } else {\n      node = expr.properties[expr.properties.length - 1];\n      position = node.getEnd();\n      // Get the indentation of the last element, if any.\n      const text = node.getFullText(source);\n      if (text.match('^\\r?\\r?\\n')) {\n        toInsert = `,${\n          text.match(/^\\r?\\n\\s+/)[0]\n        }${metadataField}: [${symbolName}]`;\n      } else {\n        toInsert = `, ${metadataField}: [${symbolName}]`;\n      }\n    }\n  } else if (node.kind == ts.SyntaxKind.ArrayLiteralExpression) {\n    // We found the field but it's empty. Insert it just before the `]`.\n    position--;\n    toInsert = `${symbolName}`;\n  } else {\n    // Get the indentation of the last element, if any.\n    const text = node.getFullText(source);\n    if (text.match(/^\\r?\\n/)) {\n      toInsert = `,${text.match(/^\\r?\\n(\\r?)\\s+/)[0]}${symbolName}`;\n    } else {\n      toInsert = `, ${symbolName}`;\n    }\n  }\n  const insert = new InsertChange(ngModulePath, position, toInsert);\n  const importInsert: Change = insertImport(\n    source,\n    ngModulePath,\n    symbolName.replace(/\\..*$/, ''),\n    importPath\n  );\n\n  return [insert, importInsert];\n}\n\n/**\n * Custom function to insert a declaration (component, pipe, directive)\n * into NgModule declarations. It also imports the component.\n */\nexport function addDeclarationToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return _addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'declarations',\n    classifiedName,\n    importPath\n  );\n}\n\n/**\n * Custom function to insert a declaration (component, pipe, directive)\n * into NgModule declarations. It also imports the component.\n */\nexport function addImportToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return _addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'imports',\n    classifiedName,\n    importPath\n  );\n}\n\n/**\n * Custom function to insert a provider into NgModule. It also imports it.\n */\nexport function addProviderToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return _addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'providers',\n    classifiedName,\n    importPath\n  );\n}\n\n/**\n * Custom function to insert an export into NgModule. It also imports it.\n */\nexport function addExportToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return _addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'exports',\n    classifiedName,\n    importPath\n  );\n}\n\n/**\n * Custom function to insert an export into NgModule. It also imports it.\n */\nexport function addBootstrapToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return _addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'bootstrap',\n    classifiedName,\n    importPath\n  );\n}\n"]}
458
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ast-utils.js","sourceRoot":"","sources":["../../../../../../../modules/entity/schematics-core/utility/ast-utils.ts"],"names":[],"mappings":"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","sourcesContent":["/* istanbul ignore file */\n/**\n * @license\n * Copyright Google Inc. 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://angular.io/license\n */\nimport * as ts from 'typescript';\nimport { Change, InsertChange, NoopChange } from './change';\n\n/**\n * Find all nodes from the AST in the subtree of node of SyntaxKind kind.\n * @param node\n * @param kind\n * @param max The maximum number of items to return.\n * @return all nodes of kind, or [] if none is found\n */\nexport function findNodes(\n  node: ts.Node,\n  kind: ts.SyntaxKind,\n  max = Infinity\n): ts.Node[] {\n  if (!node || max == 0) {\n    return [];\n  }\n\n  const arr: ts.Node[] = [];\n  if (node.kind === kind) {\n    arr.push(node);\n    max--;\n  }\n  if (max > 0) {\n    for (const child of node.getChildren()) {\n      findNodes(child, kind, max).forEach(node => {\n        if (max > 0) {\n          arr.push(node);\n        }\n        max--;\n      });\n\n      if (max <= 0) {\n        break;\n      }\n    }\n  }\n\n  return arr;\n}\n\n/**\n * Get all the nodes from a source.\n * @param sourceFile The source file object.\n * @returns {Observable<ts.Node>} An observable of all the nodes in the source.\n */\nexport function getSourceNodes(sourceFile: ts.SourceFile): ts.Node[] {\n  const nodes: ts.Node[] = [sourceFile];\n  const result = [];\n\n  while (nodes.length > 0) {\n    const node = nodes.shift();\n\n    if (node) {\n      result.push(node);\n      if (node.getChildCount(sourceFile) >= 0) {\n        nodes.unshift(...node.getChildren());\n      }\n    }\n  }\n\n  return result;\n}\n\n/**\n * Helper for sorting nodes.\n * @return function to sort nodes in increasing order of position in sourceFile\n */\nfunction nodesByPosition(first: ts.Node, second: ts.Node): number {\n  return first.pos - second.pos;\n}\n\n/**\n * Insert `toInsert` after the last occurence of `ts.SyntaxKind[nodes[i].kind]`\n * or after the last of occurence of `syntaxKind` if the last occurence is a sub child\n * of ts.SyntaxKind[nodes[i].kind] and save the changes in file.\n *\n * @param nodes insert after the last occurence of nodes\n * @param toInsert string to insert\n * @param file file to insert changes into\n * @param fallbackPos position to insert if toInsert happens to be the first occurence\n * @param syntaxKind the ts.SyntaxKind of the subchildren to insert after\n * @return Change instance\n * @throw Error if toInsert is first occurence but fall back is not set\n */\nexport function insertAfterLastOccurrence(\n  nodes: ts.Node[],\n  toInsert: string,\n  file: string,\n  fallbackPos: number,\n  syntaxKind?: ts.SyntaxKind\n): Change {\n  let lastItem = nodes.sort(nodesByPosition).pop();\n  if (!lastItem) {\n    throw new Error();\n  }\n  if (syntaxKind) {\n    lastItem = findNodes(lastItem, syntaxKind)\n      .sort(nodesByPosition)\n      .pop();\n  }\n  if (!lastItem && fallbackPos == undefined) {\n    throw new Error(\n      `tried to insert ${toInsert} as first occurence with no fallback position`\n    );\n  }\n  const lastItemPosition: number = lastItem ? lastItem.end : fallbackPos;\n\n  return new InsertChange(file, lastItemPosition, toInsert);\n}\n\nexport function getContentOfKeyLiteral(\n  _source: ts.SourceFile,\n  node: ts.Node\n): string | null {\n  if (node.kind == ts.SyntaxKind.Identifier) {\n    return (node as ts.Identifier).text;\n  } else if (node.kind == ts.SyntaxKind.StringLiteral) {\n    return (node as ts.StringLiteral).text;\n  } else {\n    return null;\n  }\n}\n\nfunction _angularImportsFromNode(\n  node: ts.ImportDeclaration,\n  _sourceFile: ts.SourceFile\n): { [name: string]: string } {\n  const ms = node.moduleSpecifier;\n  let modulePath: string;\n  switch (ms.kind) {\n    case ts.SyntaxKind.StringLiteral:\n      modulePath = (ms as ts.StringLiteral).text;\n      break;\n    default:\n      return {};\n  }\n\n  if (!modulePath.startsWith('@angular/')) {\n    return {};\n  }\n\n  if (node.importClause) {\n    if (node.importClause.name) {\n      // This is of the form `import Name from 'path'`. Ignore.\n      return {};\n    } else if (node.importClause.namedBindings) {\n      const nb = node.importClause.namedBindings;\n      if (nb.kind == ts.SyntaxKind.NamespaceImport) {\n        // This is of the form `import * as name from 'path'`. Return `name.`.\n        return {\n          [(nb as ts.NamespaceImport).name.text + '.']: modulePath,\n        };\n      } else {\n        // This is of the form `import {a,b,c} from 'path'`\n        const namedImports = nb as ts.NamedImports;\n\n        return namedImports.elements\n          .map(\n            (is: ts.ImportSpecifier) =>\n              is.propertyName ? is.propertyName.text : is.name.text\n          )\n          .reduce((acc: { [name: string]: string }, curr: string) => {\n            acc[curr] = modulePath;\n\n            return acc;\n          }, {});\n      }\n    }\n\n    return {};\n  } else {\n    // This is of the form `import 'path';`. Nothing to do.\n    return {};\n  }\n}\n\nexport function getDecoratorMetadata(\n  source: ts.SourceFile,\n  identifier: string,\n  module: string\n): ts.Node[] {\n  const angularImports: { [name: string]: string } = findNodes(\n    source,\n    ts.SyntaxKind.ImportDeclaration\n  )\n    .map(node => _angularImportsFromNode(node as ts.ImportDeclaration, source))\n    .reduce(\n      (\n        acc: { [name: string]: string },\n        current: { [name: string]: string }\n      ) => {\n        for (const key of Object.keys(current)) {\n          acc[key] = current[key];\n        }\n\n        return acc;\n      },\n      {}\n    );\n\n  return getSourceNodes(source)\n    .filter(node => {\n      return (\n        node.kind == ts.SyntaxKind.Decorator &&\n        (node as ts.Decorator).expression.kind == ts.SyntaxKind.CallExpression\n      );\n    })\n    .map(node => (node as ts.Decorator).expression as ts.CallExpression)\n    .filter(expr => {\n      if (expr.expression.kind == ts.SyntaxKind.Identifier) {\n        const id = expr.expression as ts.Identifier;\n\n        return (\n          id.getFullText(source) == identifier &&\n          angularImports[id.getFullText(source)] === module\n        );\n      } else if (\n        expr.expression.kind == ts.SyntaxKind.PropertyAccessExpression\n      ) {\n        // This covers foo.NgModule when importing * as foo.\n        const paExpr = expr.expression as ts.PropertyAccessExpression;\n        // If the left expression is not an identifier, just give up at that point.\n        if (paExpr.expression.kind !== ts.SyntaxKind.Identifier) {\n          return false;\n        }\n\n        const id = paExpr.name.text;\n        const moduleId = (paExpr.expression as ts.Identifier).getText(source);\n\n        return id === identifier && angularImports[moduleId + '.'] === module;\n      }\n\n      return false;\n    })\n    .filter(\n      expr =>\n        expr.arguments[0] &&\n        expr.arguments[0].kind == ts.SyntaxKind.ObjectLiteralExpression\n    )\n    .map(expr => expr.arguments[0] as ts.ObjectLiteralExpression);\n}\n\nfunction _addSymbolToNgModuleMetadata(\n  source: ts.SourceFile,\n  ngModulePath: string,\n  metadataField: string,\n  symbolName: string,\n  importPath: string\n): Change[] {\n  const nodes = getDecoratorMetadata(source, 'NgModule', '@angular/core');\n  let node: any = nodes[0]; // tslint:disable-line:no-any\n\n  // Find the decorator declaration.\n  if (!node) {\n    return [];\n  }\n\n  // Get all the children property assignment of object literals.\n  const matchingProperties: ts.ObjectLiteralElement[] = (node as ts.ObjectLiteralExpression).properties\n    .filter(prop => prop.kind == ts.SyntaxKind.PropertyAssignment)\n    // Filter out every fields that's not \"metadataField\". Also handles string literals\n    // (but not expressions).\n    .filter((prop: any) => {\n      const name = prop.name;\n      switch (name.kind) {\n        case ts.SyntaxKind.Identifier:\n          return (name as ts.Identifier).getText(source) == metadataField;\n        case ts.SyntaxKind.StringLiteral:\n          return (name as ts.StringLiteral).text == metadataField;\n      }\n\n      return false;\n    });\n\n  // Get the last node of the array literal.\n  if (!matchingProperties) {\n    return [];\n  }\n  if (matchingProperties.length == 0) {\n    // We haven't found the field in the metadata declaration. Insert a new field.\n    const expr = node as ts.ObjectLiteralExpression;\n    let position: number;\n    let toInsert: string;\n    if (expr.properties.length == 0) {\n      position = expr.getEnd() - 1;\n      toInsert = `  ${metadataField}: [${symbolName}]\\n`;\n    } else {\n      node = expr.properties[expr.properties.length - 1];\n      position = node.getEnd();\n      // Get the indentation of the last element, if any.\n      const text = node.getFullText(source);\n      const matches = text.match(/^\\r?\\n\\s*/);\n      if (matches.length > 0) {\n        toInsert = `,${matches[0]}${metadataField}: [${symbolName}]`;\n      } else {\n        toInsert = `, ${metadataField}: [${symbolName}]`;\n      }\n    }\n    const newMetadataProperty = new InsertChange(\n      ngModulePath,\n      position,\n      toInsert\n    );\n    const newMetadataImport = insertImport(\n      source,\n      ngModulePath,\n      symbolName.replace(/\\..*$/, ''),\n      importPath\n    );\n\n    return [newMetadataProperty, newMetadataImport];\n  }\n\n  const assignment = matchingProperties[0] as ts.PropertyAssignment;\n\n  // If it's not an array, nothing we can do really.\n  if (assignment.initializer.kind !== ts.SyntaxKind.ArrayLiteralExpression) {\n    return [];\n  }\n\n  const arrLiteral = assignment.initializer as ts.ArrayLiteralExpression;\n  if (arrLiteral.elements.length == 0) {\n    // Forward the property.\n    node = arrLiteral;\n  } else {\n    node = arrLiteral.elements;\n  }\n\n  if (!node) {\n    console.log(\n      'No app module found. Please add your new class to your component.'\n    );\n\n    return [];\n  }\n\n  if (Array.isArray(node)) {\n    const nodeArray = (node as {}) as Array<ts.Node>;\n    const symbolsArray = nodeArray.map(node => node.getText());\n    if (symbolsArray.includes(symbolName)) {\n      return [];\n    }\n\n    node = node[node.length - 1];\n\n    const effectsModule = nodeArray.find(\n      node =>\n        (node.getText().includes('EffectsModule.forRoot') &&\n          symbolName.includes('EffectsModule.forRoot')) ||\n        (node.getText().includes('EffectsModule.forFeature') &&\n          symbolName.includes('EffectsModule.forFeature'))\n    );\n\n    if (effectsModule && symbolName.includes('EffectsModule')) {\n      const effectsArgs = (effectsModule as any).arguments.shift();\n\n      if (\n        effectsArgs &&\n        effectsArgs.kind === ts.SyntaxKind.ArrayLiteralExpression\n      ) {\n        const effectsElements = (effectsArgs as ts.ArrayLiteralExpression)\n          .elements;\n        const [, effectsSymbol] = (<any>symbolName).match(/\\[(.*)\\]/);\n\n        let epos;\n        if (effectsElements.length === 0) {\n          epos = effectsArgs.getStart() + 1;\n          return [new InsertChange(ngModulePath, epos, effectsSymbol)];\n        } else {\n          const lastEffect = effectsElements[\n            effectsElements.length - 1\n          ] as ts.Expression;\n          epos = lastEffect.getEnd();\n          // Get the indentation of the last element, if any.\n          const text: any = lastEffect.getFullText(source);\n\n          let effectInsert: string;\n          if (text.match('^\\r?\\r?\\n')) {\n            effectInsert = `,${text.match(/^\\r?\\n\\s+/)[0]}${effectsSymbol}`;\n          } else {\n            effectInsert = `, ${effectsSymbol}`;\n          }\n\n          return [new InsertChange(ngModulePath, epos, effectInsert)];\n        }\n      } else {\n        return [];\n      }\n    }\n  }\n\n  let toInsert: string;\n  let position = node.getEnd();\n  if (node.kind == ts.SyntaxKind.ObjectLiteralExpression) {\n    // We haven't found the field in the metadata declaration. Insert a new\n    // field.\n    const expr = node as ts.ObjectLiteralExpression;\n    if (expr.properties.length == 0) {\n      position = expr.getEnd() - 1;\n      toInsert = `  ${metadataField}: [${symbolName}]\\n`;\n    } else {\n      node = expr.properties[expr.properties.length - 1];\n      position = node.getEnd();\n      // Get the indentation of the last element, if any.\n      const text = node.getFullText(source);\n      if (text.match('^\\r?\\r?\\n')) {\n        toInsert = `,${\n          text.match(/^\\r?\\n\\s+/)[0]\n        }${metadataField}: [${symbolName}]`;\n      } else {\n        toInsert = `, ${metadataField}: [${symbolName}]`;\n      }\n    }\n  } else if (node.kind == ts.SyntaxKind.ArrayLiteralExpression) {\n    // We found the field but it's empty. Insert it just before the `]`.\n    position--;\n    toInsert = `${symbolName}`;\n  } else {\n    // Get the indentation of the last element, if any.\n    const text = node.getFullText(source);\n    if (text.match(/^\\r?\\n/)) {\n      toInsert = `,${text.match(/^\\r?\\n(\\r?)\\s+/)[0]}${symbolName}`;\n    } else {\n      toInsert = `, ${symbolName}`;\n    }\n  }\n  const insert = new InsertChange(ngModulePath, position, toInsert);\n  const importInsert: Change = insertImport(\n    source,\n    ngModulePath,\n    symbolName.replace(/\\..*$/, ''),\n    importPath\n  );\n\n  return [insert, importInsert];\n}\n\n/**\n * Custom function to insert a declaration (component, pipe, directive)\n * into NgModule declarations. It also imports the component.\n */\nexport function addDeclarationToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return _addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'declarations',\n    classifiedName,\n    importPath\n  );\n}\n\n/**\n * Custom function to insert a declaration (component, pipe, directive)\n * into NgModule declarations. It also imports the component.\n */\nexport function addImportToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return _addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'imports',\n    classifiedName,\n    importPath\n  );\n}\n\n/**\n * Custom function to insert a provider into NgModule. It also imports it.\n */\nexport function addProviderToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return _addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'providers',\n    classifiedName,\n    importPath\n  );\n}\n\n/**\n * Custom function to insert an export into NgModule. It also imports it.\n */\nexport function addExportToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return _addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'exports',\n    classifiedName,\n    importPath\n  );\n}\n\n/**\n * Custom function to insert an export into NgModule. It also imports it.\n */\nexport function addBootstrapToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return _addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'bootstrap',\n    classifiedName,\n    importPath\n  );\n}\n\n/**\n * Add Import `import { symbolName } from fileName` if the import doesn't exit\n * already. Assumes fileToEdit can be resolved and accessed.\n * @param fileToEdit (file we want to add import to)\n * @param symbolName (item to import)\n * @param fileName (path to the file)\n * @param isDefault (if true, import follows style for importing default exports)\n * @return Change\n */\n\nexport function insertImport(\n  source: ts.SourceFile,\n  fileToEdit: string,\n  symbolName: string,\n  fileName: string,\n  isDefault = false\n): Change {\n  const rootNode = source;\n  const allImports = findNodes(rootNode, ts.SyntaxKind.ImportDeclaration);\n\n  // get nodes that map to import statements from the file fileName\n  const relevantImports = allImports.filter(node => {\n    // StringLiteral of the ImportDeclaration is the import file (fileName in this case).\n    const importFiles = node\n      .getChildren()\n      .filter(child => child.kind === ts.SyntaxKind.StringLiteral)\n      .map(n => (n as ts.StringLiteral).text);\n\n    return importFiles.filter(file => file === fileName).length === 1;\n  });\n\n  if (relevantImports.length > 0) {\n    let importsAsterisk = false;\n    // imports from import file\n    const imports: ts.Node[] = [];\n    relevantImports.forEach(n => {\n      Array.prototype.push.apply(\n        imports,\n        findNodes(n, ts.SyntaxKind.Identifier)\n      );\n      if (findNodes(n, ts.SyntaxKind.AsteriskToken).length > 0) {\n        importsAsterisk = true;\n      }\n    });\n\n    // if imports * from fileName, don't add symbolName\n    if (importsAsterisk) {\n      return new NoopChange();\n    }\n\n    const importTextNodes = imports.filter(\n      n => (n as ts.Identifier).text === symbolName\n    );\n\n    // insert import if it's not there\n    if (importTextNodes.length === 0) {\n      const fallbackPos =\n        findNodes(\n          relevantImports[0],\n          ts.SyntaxKind.CloseBraceToken\n        )[0].getStart() ||\n        findNodes(relevantImports[0], ts.SyntaxKind.FromKeyword)[0].getStart();\n\n      return insertAfterLastOccurrence(\n        imports,\n        `, ${symbolName}`,\n        fileToEdit,\n        fallbackPos\n      );\n    }\n\n    return new NoopChange();\n  }\n\n  // no such import declaration exists\n  const useStrict = findNodes(rootNode, ts.SyntaxKind.StringLiteral).filter(\n    n => n.getText() === 'use strict'\n  );\n  let fallbackPos = 0;\n  if (useStrict.length > 0) {\n    fallbackPos = useStrict[0].end;\n  }\n  const open = isDefault ? '' : '{ ';\n  const close = isDefault ? '' : ' }';\n  // if there are no imports or 'use strict' statement, insert import at beginning of file\n  const insertAtBeginning = allImports.length === 0 && useStrict.length === 0;\n  const separator = insertAtBeginning ? '' : ';\\n';\n  const toInsert =\n    `${separator}import ${open}${symbolName}${close}` +\n    ` from '${fileName}'${insertAtBeginning ? ';\\n' : ''}`;\n\n  return insertAfterLastOccurrence(\n    allImports,\n    toInsert,\n    fileToEdit,\n    fallbackPos,\n    ts.SyntaxKind.StringLiteral\n  );\n}\n"]}