|
1 | | -import {Flow} from '../models/Flow'; |
2 | | -import {FlowElement} from '../models/FlowElement'; |
3 | | -import {FlowVariable} from '../models/FlowVariable'; |
4 | | -import {RuleResult} from '../models/RuleResult'; |
5 | | -import {ScanResult} from '../models/ScanResult'; |
6 | | -import {UnconnectedElements} from '../rules/UnconnectedElements'; |
7 | | -import {UnusedVariables} from '../rules/UnusedVariables'; |
8 | | -import {BuildFlow} from './BuildFlow'; |
| 1 | +import { Flow } from '../models/Flow'; |
| 2 | +import { FlowNode } from '../models/FlowNode'; |
| 3 | +import { FlowVariable } from '../models/FlowVariable'; |
| 4 | +import { ResultDetails } from '../models/ResultDetails'; |
| 5 | +import { RuleResult } from '../models/RuleResult'; |
| 6 | +import { ScanResult } from '../models/ScanResult'; |
| 7 | +import { UnconnectedElements } from '../rules/UnconnectedElements'; |
| 8 | +import { UnusedVariables } from '../rules/UnusedVariables'; |
| 9 | +import { BuildFlow } from './BuildFlow'; |
9 | 10 |
|
10 | | -export function FixFlows(flows: Flow[]) : ScanResult[] { |
| 11 | +export function FixFlows(flows: Flow[]): ScanResult[] { |
11 | 12 |
|
12 | | - const flowResults : ScanResult[] = []; |
| 13 | + const flowResults: ScanResult[] = []; |
13 | 14 | for (const flow of flows) { |
14 | | - const unconnectedElementsResult : RuleResult = new UnconnectedElements().execute(flow); |
15 | | - const unusedVariablesResult : RuleResult = new UnusedVariables().execute(flow); |
| 15 | + const unconnectedElementsResult: RuleResult = new UnconnectedElements().execute(flow); |
| 16 | + const unusedVariablesResult: RuleResult = new UnusedVariables().execute(flow); |
16 | 17 | const ruleResults: RuleResult[] = [unusedVariablesResult, unconnectedElementsResult]; |
17 | | - const unusedVariableReferences = unusedVariablesResult.details ? (unusedVariablesResult.details as FlowVariable[]).map(unusedVariable => unusedVariable.name) : []; |
18 | | - const unconnectedElementsReferences = unconnectedElementsResult.details ? (unconnectedElementsResult.details as FlowElement[]).map(unconnectedElement => unconnectedElement.name) : []; |
19 | | - const nodesToBuild = flow.nodes.filter(node => { |
20 | | - switch (node.nodeType) { |
21 | | - case 'variable': |
22 | | - const nodeVar = node as FlowVariable; |
23 | | - if (!unusedVariableReferences.includes(nodeVar.name)) { |
24 | | - return node; |
25 | | - } |
26 | | - break; |
27 | | - case 'element': |
28 | | - const nodeElement = node as FlowElement; |
29 | | - if (!unconnectedElementsReferences.includes(nodeElement.name)) { |
30 | | - return node; |
31 | | - } |
32 | | - break; |
33 | | - case 'metadata': |
| 18 | + const unusedVariableReferences = unusedVariablesResult.details ? (unusedVariablesResult.details as ResultDetails[]).map(unusedVariable => unusedVariable.name) : []; |
| 19 | + const unconnectedElementsReferences = unconnectedElementsResult.details ? (unconnectedElementsResult.details as ResultDetails[]).map(unconnectedElement => unconnectedElement.name) : []; |
| 20 | + const nodesToBuild = flow.elements.filter(node => { |
| 21 | + switch (node.metaType) { |
| 22 | + case 'variable': |
| 23 | + const nodeVar = node as FlowVariable; |
| 24 | + if (!unusedVariableReferences.includes(nodeVar.name)) { |
34 | 25 | return node; |
35 | | - } |
| 26 | + } |
| 27 | + break; |
| 28 | + case 'node': |
| 29 | + const nodeElement = node as FlowNode; |
| 30 | + if (!unconnectedElementsReferences.includes(nodeElement.name)) { |
| 31 | + return node; |
| 32 | + } |
| 33 | + break; |
| 34 | + case 'metadata': |
| 35 | + return node; |
36 | 36 | } |
| 37 | + } |
37 | 38 | ); |
38 | 39 | flow.xmldata = BuildFlow(nodesToBuild); |
39 | 40 | flow.preProcessNodes(); |
|
0 commit comments